die "No files or URIs specified.\n" unless @_;
- if ($options->{single}) {
+ if ($options->{group}) {
+ $self->_launch_group($options, @_);
+ } elsif ($options->{single}) {
$self->_launch_single($options, @_);
} else {
$self->_launch($options, @_);
my $pid = fork;
next if $pid;
- my $handler = $self->_get_handler($file_or_uri);
+ my $handler = $self->_get_handler($options, $file_or_uri);
$handler->($file_or_uri) if $handler;
return;
}
} else {
for my $file_or_uri (@_) {
- my $handler = $self->_get_handler($file_or_uri);
+ my $handler = $self->_get_handler($options, $file_or_uri);
$handler->($file_or_uri) if $handler;
}
}
}
+sub _launch_group {
+ my $self = shift;
+ my $options = shift;
+
+ my ($groups, $handlers) = ({}, {});
+ for my $file_or_uri (@_) {
+ my $handler = $self->_get_handler($options, $file_or_uri);
+ if ($handler) {
+ $groups->{"$handler"} //= [];
+ push @{ $groups->{"$handler"} }, $file_or_uri;
+ $handlers->{"$handler"} = $handler;
+ }
+ }
+
+ if ($options->{fork}) {
+ for my $group (keys %{ $groups }) {
+ if ($options->{fork}) {
+ my $pid = fork;
+ next if $pid;
+ }
+
+ $handlers->{$group}->(@{ $groups->{$group} });
+ return;
+ }
+ } else {
+ for my $group (keys %{ $groups }) {
+ $handlers->{$group}->(@{ $groups->{$group} });
+ }
+ }
+}
+
sub _launch_single {
my $self = shift;
my $options = shift;
return if $pid;
}
- my $handler = $self->_get_handler($_[0]);
+ my $handler = $self->_get_handler($options, $_[0]);
$handler->(@_) if $handler;
}
sub _get_handler {
my $self = shift;
+ my $options = shift;
my $file_or_uri = $_[0] =~ m|^file://(.+)| ? $1 : $_[0];
my $mime_or_uri = -e $file_or_uri ? $self->{mime_query}->($file_or_uri) : $file_or_uri;
for my $pattern (@{ $target->{patterns} }) {
if ($mime_or_uri =~ /$pattern/) {
my $associations = $target->{associations};
+
+ my $context = $options->{context};
+ my $handler = $associations->{$context} if $context;
+ return $handler if defined $handler;
+
for my $context (keys %{ $associations }) {
if ($self->{contexts}->{$context}->()) {
return $associations->{$context};