+ next if $pid;
+
+ 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($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} });