X-Git-Url: https://git.nmode.ca/Fey/blobdiff_plain/a36e9479b2f84cc9b4e5b92e304ca2fac8ac8608..4e138f7a2baf0a4565bd82a3757ed5da97f56549:/lib/App/Fey.pm diff --git a/lib/App/Fey.pm b/lib/App/Fey.pm index 5b9206c..8b802a0 100644 --- a/lib/App/Fey.pm +++ b/lib/App/Fey.pm @@ -27,6 +27,13 @@ sub launch { my $self = shift; my $options = ref $_[0] ? shift : {}; + if (!(-t STDIN)) { + _read_stdin(\@_); + } + if (!@_ || $options->{interactive}) { + open STDIN, '<', '/dev/tty'; + _read_stdin(\@_); + } die "No files or URIs specified.\n" unless @_; if ($options->{group}) { @@ -47,13 +54,13 @@ sub _launch { 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; } } @@ -65,7 +72,7 @@ sub _launch_group { my ($groups, $handlers) = ({}, {}); for my $file_or_uri (@_) { - my $handler = $self->_get_handler($file_or_uri); + my $handler = $self->_get_handler($options, $file_or_uri); if ($handler) { $groups->{"$handler"} //= []; push @{ $groups->{"$handler"} }, $file_or_uri; @@ -99,12 +106,13 @@ sub _launch_single { 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; @@ -113,6 +121,11 @@ sub _get_handler { 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}; @@ -123,6 +136,13 @@ sub _get_handler { } } +sub _read_stdin { + for my $file_or_uri () { + chomp $file_or_uri; + push @{ $_[0] }, $file_or_uri; + } +} + sub fey { App::Fey->new(ref $_[0] ? $_[0] : {})->launch(@_); }