mirror of
git://git.code.sf.net/p/zsh/code
synced 2025-09-02 22:11:54 +02:00
zsh-workers/8272
This commit is contained in:
parent
df3478da4e
commit
854c9fdafa
10 changed files with 68 additions and 15 deletions
|
@ -50,7 +50,7 @@ shift
|
|||
if [[ -n "$showd" ]]; then
|
||||
compdescribe -I ' -- ' "$@"
|
||||
else
|
||||
compdescribe -i ' -- ' "$@"
|
||||
compdescribe -i "$@"
|
||||
fi
|
||||
|
||||
[[ -n "$isopt" && "$compconfig[option_prefix]" = hide* ]] && hide=yes
|
||||
|
|
|
@ -82,13 +82,8 @@ if compvalues -i "$@"; then
|
|||
|
||||
eval ws\=\( "${action[3,-3]}" \)
|
||||
|
||||
if [[ -n "$compconfig[describe_values]" &&
|
||||
"$compconfig[describe_values]" != *\!${cmd}* ]] &&
|
||||
compdisplay tmp ' -- ' "$ws[@]"; then
|
||||
compadd "$expl[@]" -M 'r:|[_-]=* r:|=*' -ld tmp - "${(@)ws%%:*}"
|
||||
else
|
||||
compadd "$expl[@]" - "${(@)ws%%:*}"
|
||||
fi
|
||||
_describe "$descr" ws -M 'r:|[_-]=* r:|=*'
|
||||
|
||||
elif [[ "$action" = \(*\) ]]; then
|
||||
|
||||
# Anything inside `(...)' is added directly.
|
||||
|
|
|
@ -78,10 +78,6 @@ while [[ $# -gt 0 && $1 = -[dDf] ]]; do
|
|||
fi
|
||||
done
|
||||
|
||||
# Load the helper module.
|
||||
|
||||
zmodload computil
|
||||
|
||||
# The associative array containing the definitions for the commands.
|
||||
# Definitions for patterns will be stored in the normal arrays `_patcomps'
|
||||
# and `_postpatcomps'.
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
texinode(The complist Module)(The deltochar Module)(The compctl Module)(Zsh Modules)
|
||||
texinode(The complist Module)(The computil Module)(The compctl Module)(Zsh Modules)
|
||||
sect(The complist Module)
|
||||
cindex(completion, listing)
|
||||
cindex(completion, coloured listings)
|
||||
|
|
51
Doc/Zsh/mod_computil.yo
Normal file
51
Doc/Zsh/mod_computil.yo
Normal file
|
@ -0,0 +1,51 @@
|
|||
texinode(The computil Module)(The deltochar Module)(The complist Module)(Zsh Modules)
|
||||
sect(The computil Module)
|
||||
cindex(completion, utility)
|
||||
The tt(computil) module adds four builtin commands that are used by
|
||||
some of the completion functions in the shell function based
|
||||
completions system (see
|
||||
ifzman(zmanref(zshcompsys))\
|
||||
ifnzman(noderef(Completion System))
|
||||
). Except for tt(compdisplay) these builtin commands are very
|
||||
specialised and thus not very interesting when writing your own
|
||||
completion functions. In short, these builtin commands are:
|
||||
|
||||
startitem()
|
||||
item(tt(compdisplay) var(name) var(string) var(defs) ...)(
|
||||
The var(defs) are strings should be of the form
|
||||
`var(str)tt(:)var(descr)' (the intended use is that the var(descr)
|
||||
describes the var(str)) and tt(compdisplay) will convert them to
|
||||
strings in which the colon is replaced by the var(string) given as the
|
||||
second argument and spaces are inserted before that so that they are
|
||||
aligned over all strings. These resultings strings are then assigned
|
||||
to an array with the var(name) given as the first argument.
|
||||
)
|
||||
item(tt(compdescribe))(
|
||||
This is used by the tt(_describe) function to build the displays for
|
||||
the matches and to get the strings to add as matches with their
|
||||
options. The first call has to give the tt(-i) or tt(-I) option as the
|
||||
first argument. In the first case, display strings without the
|
||||
descriptions will be generated, inthe second case, the string used to
|
||||
separate the matches from their descriptions has to be given as the
|
||||
second argument and the descriptions (if any) will be shown. All other
|
||||
arguments are like the definition arguments to tt(_describe) itself.
|
||||
|
||||
Once tt(compdescribe) has been called with either the tt(-i) or the
|
||||
tt(-I) option, it can be repeatedly called with the tt(-g) option and
|
||||
the names of five arrays as its arguments. This will step through the
|
||||
different sets of matches and store the options in the first array,
|
||||
the strings with descriptions in the second, the matches for these in
|
||||
the third, the strings without descriptions in the fourth, and the
|
||||
matches for them in the fifth array. These are then directly given to
|
||||
tt(compadd) to register the matches with the completion code.
|
||||
)
|
||||
item(tt(comparguments))(
|
||||
This is used by the tt(_arguments) function to do the argument and
|
||||
command line parsing. Like tt(compdescribe) it has an option tt(-i) to
|
||||
do the parsing and initialize some internal state and various options
|
||||
to access the state information to decide what should be completed.
|
||||
)
|
||||
item(tt(compvalues))(
|
||||
Like tt(comparguments), but for the tt(_values) function.
|
||||
)
|
||||
enditem()
|
|
@ -1,4 +1,4 @@
|
|||
texinode(The deltochar Module)(The example Module)(The complist Module)(Zsh Modules)
|
||||
texinode(The deltochar Module)(The example Module)(The computil Module)(Zsh Modules)
|
||||
sect(The deltochar Module)
|
||||
The tt(deltochar) module makes available two ZLE functions:
|
||||
|
||||
|
|
|
@ -25,6 +25,10 @@ completion widgets.
|
|||
item(tt(complist))(
|
||||
Completion listing extensions.
|
||||
)
|
||||
item(tt(computil))(
|
||||
A module with utility builtins needed for the shell function based
|
||||
completion system.
|
||||
)
|
||||
item(tt(deltochar))(
|
||||
A ZLE function duplicating EMACS' tt(zap-to-char).
|
||||
)
|
||||
|
@ -62,6 +66,7 @@ menu(The clone Module)
|
|||
menu(The comp1 Module)
|
||||
menu(The compctl Module)
|
||||
menu(The complist Module)
|
||||
menu(The computil Module)
|
||||
menu(The deltochar Module)
|
||||
menu(The example Module)
|
||||
menu(The files Module)
|
||||
|
@ -78,6 +83,7 @@ includefile(Zsh/mod_clone.yo)
|
|||
includefile(Zsh/mod_comp1.yo)
|
||||
includefile(Zsh/mod_compctl.yo)
|
||||
includefile(Zsh/mod_complist.yo)
|
||||
includefile(Zsh/mod_computil.yo)
|
||||
includefile(Zsh/mod_deltochar.yo)
|
||||
includefile(Zsh/mod_example.yo)
|
||||
includefile(Zsh/mod_files.yo)
|
||||
|
|
|
@ -291,9 +291,11 @@ bin_compdescribe(char *nam, char **args, char *ops, int func)
|
|||
}
|
||||
switch (args[0][1]) {
|
||||
case 'i':
|
||||
cd_parsed = 1;
|
||||
return cd_init(nam, "", args + 1, 0);
|
||||
case 'I':
|
||||
cd_parsed = 1;
|
||||
return cd_init(nam, args[1], args + 2, (args[0][1] == 'I'));
|
||||
return cd_init(nam, args[1], args + 2, 1);
|
||||
case 'g':
|
||||
if (cd_parsed) {
|
||||
int n = arrlen(args);
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
moddeps="compctl zle"
|
||||
|
||||
objects="computil.o"
|
||||
|
||||
autobins="compdisplay compdescribe comparguments compvalues"
|
||||
|
|
|
@ -4,3 +4,4 @@ zle
|
|||
compctl
|
||||
sched
|
||||
complist
|
||||
computil
|
||||
|
|
Loading…
Reference in a new issue