Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
Re: [PATCH] Completion: Add _lua
- X-seq: zsh-workers 43203
- From: dana <dana@xxxxxxx>
- To: Zsh hackers list <zsh-workers@xxxxxxx>
- Subject: Re: [PATCH] Completion: Add _lua
- Date: Mon, 23 Jul 2018 06:40:04 -0500
- Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=dana-is.20150623.gappssmtp.com; s=20150623; h=from:content-transfer-encoding:mime-version:subject:date:references :to:in-reply-to:message-id; bh=gbLkf+po0XFa6WAVeoNEOhIICzgqHcw88Mf6kO/1P80=; b=v2Ofnz2IZN7JlzFLH44vZncieVPwYNOesSPAa7ha4pgNOQP0IYs3nOeBnTCkbWl+IM TYWFFR5Opa2xFeeOf7CQ9guJ6ItroEmg5ubHTECO8JJbmO45VfO477kX3NzH1DBKbiIf 35Yc3uNuLsTHcB/ulA9ENmSAZn3+edgJiEk+m2w46ZihW85KixeSIZ0gQyemIUO30Uvr BYxG8J9+Gd9Gq0ab6XVlUGeqPYP1L5lEeDMAG8CSLBbzjPhBtWMZFbt1fxSRPVxc9Kpw G6xMCSwtYAR21JmPI5pIIRTMJrTNy8mrYWHypT7gxP5Z25lbZvand3YIARfGM+WBBy4e uSeA==
- In-reply-to: <84B28497-6E79-439D-BFB5-CDD32D6BECB5@dana.is>
- List-help: <mailto:zsh-workers-help@zsh.org>
- List-id: Zsh Workers List <zsh-workers.zsh.org>
- List-post: <mailto:zsh-workers@zsh.org>
- List-unsubscribe: <mailto:zsh-workers-unsubscribe@zsh.org>
- Mailing-list: contact zsh-workers-help@xxxxxxx; run by ezmlm
- References: <84B28497-6E79-439D-BFB5-CDD32D6BECB5@dana.is>
On 23 Jul 2018, at 01:50, dana <dana@xxxxxxx> wrote:
>_lua_libraries is maybe a little excessive, tbh, but i found it useful — i don't
>think there's any 'official' way to do what it does.
Eric showed me his own _lua function, which uses an embarrassingly less silly
method of building the library matches for this. His also handles script
arguments more like other interpreters' functions do. I've incorporated those
enhancements here.
dana
diff --git a/Completion/Unix/Command/_lua b/Completion/Unix/Command/_lua
new file mode 100644
index 000000000..7254d3819
--- /dev/null
+++ b/Completion/Unix/Command/_lua
@@ -0,0 +1,63 @@
+#compdef lua -P lua[0-9.-]##
+
+# Complete lua library names. We go out of our way here to support sub-modules
+# (of the format foo.bar.baz), even though the way `lua -l` handles those isn't
+# very nice, because it might be useful for informational purposes
+(( $+functions[_lua_libraries] )) ||
+_lua_libraries() {
+ local p pre
+ local -a tmp tmp2
+
+ # Get Lua's library search path
+ tmp=( ${(s<;>)${(@f)"$(
+ _call_program library-path $words[1] -e '"print(package.path)"'
+ )"}} )
+ # Support C modules, which aren't explicitly included in the above
+ tmp+=( ${(@)${(@M)tmp:#*'?.lua'}/%.lua/.so} )
+
+ for p in ${(@u)tmp}; do
+ # Don't recurse infinitely into the current directory; we'll just trust
+ # that all other paths are sensible
+ if [[ $p == './?'* ]]; then
+ tmp=( ${~${${(b)p}/'\?'/'*'}}(#qN) )
+ else
+ tmp=( ${~${${(b)p}/'\?'/'**/*'}}(#qN) )
+ fi
+ tmp2+=( ${(@)tmp##${p%%'?'*}} )
+ done
+
+ tmp=( ${(@)tmp2%%(/init.lua|.lua|.so)} )
+ tmp=( ${(@u)${(@)tmp//\//.}} )
+
+ _wanted -x libraries expl 'Lua library' compadd -a "$@" - tmp
+}
+
+_lua() {
+ local ret=1
+ local -a context expl line state state_descr
+ local -A opt_args
+
+ # Stacking not supported, no arguments are exclusive except `-`
+ _arguments -S -A '-*' : \
+ '*-e+[execute specified command string]:command string' \
+ '-E[ignore environment variables]' \
+ '-i[enter interactive mode]' \
+ '*-l+[specify library or module to require]: :_lua_libraries' \
+ '-v[display version information]' \
+ '(1 -)-[stop argument parsing and execute script on stdin]' \
+ '1:Lua script:_files' \
+ '*:: :->arg' \
+ && ret=0
+
+ [[ $state == arg ]] &&
+ if [[ $line[1] == - ]]; then
+ _description files expl 'script argument'
+ _files "${(@)expl}" && ret=0
+ else
+ _normal && ret=0
+ fi
+
+ return ret
+}
+
+_lua "$@"
Messages sorted by:
Reverse Date,
Date,
Thread,
Author