about summary refs log tree commit homepage
path: root/lib/PublicInbox/LeiExternal.pm
diff options
context:
space:
mode:
authorEric Wong <e@80x24.org>2021-04-29 09:46:20 +0000
committerEric Wong <e@80x24.org>2021-04-30 06:41:37 +0000
commitdc82a4a2af4c8c2e34cdbd56e07f097dff5c9a78 (patch)
tree1b42e1b7b616a1ec1890dbe0d70cc45bd69599b9 /lib/PublicInbox/LeiExternal.pm
parent90155b72ccd38d51415f12547e39c4d65c469fe1 (diff)
downloadpublic-inbox-dc82a4a2af4c8c2e34cdbd56e07f097dff5c9a78.tar.gz
This also fixes completion of "lei up" for IMAP folders.
Diffstat (limited to 'lib/PublicInbox/LeiExternal.pm')
-rw-r--r--lib/PublicInbox/LeiExternal.pm22
1 files changed, 12 insertions, 10 deletions
diff --git a/lib/PublicInbox/LeiExternal.pm b/lib/PublicInbox/LeiExternal.pm
index 3858085e..6fd3efef 100644
--- a/lib/PublicInbox/LeiExternal.pm
+++ b/lib/PublicInbox/LeiExternal.pm
@@ -215,7 +215,8 @@ sub lei_forget_external {
         }
 }
 
-sub complete_url_common {
+# returns an anonymous sub which returns an array of potential results
+sub complete_url_prepare {
         my $argv = $_[-1];
         # Workaround bash word-splitting URLs to ['https', ':', '//' ...]
         # Maybe there's a better way to go about this in
@@ -239,37 +240,38 @@ sub complete_url_common {
                 }
                 $re = quotemeta($re);
         }
-        ($cur, $re);
+        my $match_cb = sub {
+                # only return the part specified on the CLI
+                # don't duplicate if already 100% completed
+                $_[0] =~ /\A$re(\Q$cur\E.*)/ ? ($cur eq $1 ? () : $1) : ()
+        };
+        wantarray ? ($re, $cur, $match_cb) : $match_cb;
 }
 
 # shell completion helper called by lei__complete
 sub _complete_forget_external {
         my ($self, @argv) = @_;
         my $cfg = $self->_lei_cfg;
-        my ($cur, $re) = complete_url_common(\@argv);
+        my ($cur, $re, $match_cb) = complete_url_prepare(\@argv);
         # FIXME: bash completion off "http:" or "https:" when the last
         # character is a colon doesn't work properly even if we're
         # returning "//$HTTP_HOST/$PATH_INFO/", not sure why, could
         # be a bash issue.
         map {
-                my $x = substr($_, length('external.'));
-                # only return the part specified on the CLI
-                # don't duplicate if already 100% completed
-                $x =~ /\A$re(\Q$cur\E.*)/ ? ($cur eq $1 ? () : $1) : ();
+                $match_cb->(substr($_, length('external.')));
         } grep(/\Aexternal\.$re\Q$cur/, @{$cfg->{-section_order}});
 }
 
 sub _complete_add_external { # for bash, this relies on "compopt -o nospace"
         my ($self, @argv) = @_;
         my $cfg = $self->_lei_cfg;
-        my ($cur, $re) = complete_url_common(\@argv);
+        my $match_cb = complete_url_prepare(\@argv);
         require URI;
         map {
                 my $u = URI->new(substr($_, length('external.')));
                 my ($base) = ($u->path =~ m!((?:/?.*)?/)[^/]+/?\z!);
                 $u->path($base);
-                $u = $u->as_string;
-                $u =~ /\A$re(\Q$cur\E.*)/ ? ($cur eq $1 ? () : $1) : ();
+                $match_cb->($u->as_string);
         } grep(m!\Aexternal\.https?://!, @{$cfg->{-section_order}});
 }