]> Sergey Matveev's repositories - public-inbox.git/commitdiff
lei import: support shell completion of known folders
authorEric Wong <e@80x24.org>
Thu, 29 Apr 2021 09:46:20 +0000 (09:46 +0000)
committerEric Wong <e@80x24.org>
Fri, 30 Apr 2021 06:41:37 +0000 (06:41 +0000)
This also fixes completion of "lei up" for IMAP folders.

contrib/completion/lei-completion.bash
lib/PublicInbox/LeiExternal.pm
lib/PublicInbox/LeiImport.pm
lib/PublicInbox/LeiUp.pm

index 2c28d44a56463ab4e56f71fe02d51ae041e19502..5c137e68ac2ea5aec7237d7461b153a97d72a577 100644 (file)
@@ -9,6 +9,7 @@ _lei() {
        *':'* | *'='* | '//'*) compopt -o nospace ;;
        *) compopt +o nospace ;; # the default
        esac
+       wordlist="${wordlist//;/\\\\;}" # escape ';' for ';UIDVALIDITY' and such
        COMPREPLY=($(compgen -W "$wordlist" -- "${COMP_WORDS[COMP_CWORD]}"))
        return 0
 }
index 3858085ece8cc0c04e49164a0edcaf4b26161837..6fd3efef6cbd8f9259098f0a43faf2613cda9998 100644 (file)
@@ -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}});
 }
 
index 277f4f95de7fde637fda66f0db8187f1390b3000..def121abbe5b8fd53cdd0fa342ae4a23915d7c21 100644 (file)
@@ -89,6 +89,14 @@ sub lei_import { # the main "lei import" method
        $op_c->op_wait_event($ops);
 }
 
+sub _complete_import {
+       my ($lei, @argv) = @_;
+       my $sto = $lei->_lei_store or return;
+       my $lms = $sto->search->lms or return;
+       my $match_cb = $lei->complete_url_prepare(\@argv);
+       map { $match_cb->($_) } $lms->folders;
+}
+
 no warnings 'once';
 *ipc_atfork_child = \&PublicInbox::LeiInput::input_only_atfork_child;
 
index f4ff070be8bb925c0902035de32077223c55403e..4399c4fba7641a0e4df7933415e207bda203376d 100644 (file)
@@ -99,8 +99,8 @@ sub lei_up {
 
 sub _complete_up {
        my ($lei, @argv) = @_;
-       my ($cur, $re) = $lei->complete_url_common(\@argv);
-       grep(/\A$re\Q$cur/, PublicInbox::LeiSavedSearch::list($lei));
+       my $match_cb = $lei->complete_url_prepare(\@argv);
+       map { $match_cb->($_) } PublicInbox::LeiSavedSearch::list($lei);
 }
 
 1;