diff options
author | Sven Wischnowsky <wischnow@users.sourceforge.net> | 2001-04-02 11:01:42 +0000 |
---|---|---|
committer | Sven Wischnowsky <wischnow@users.sourceforge.net> | 2001-04-02 11:01:42 +0000 |
commit | ea5ec115fb107d9ddeef253d73018984fe555f36 (patch) | |
tree | a5ff45ee273b76561cd533c7357dc993880f2094 /Completion | |
parent | 992b23ab059ed6bf199eb5f879dab1a7892046aa (diff) | |
download | zsh-ea5ec115fb107d9ddeef253d73018984fe555f36.tar.gz zsh-ea5ec115fb107d9ddeef253d73018984fe555f36.tar.xz zsh-ea5ec115fb107d9ddeef253d73018984fe555f36.zip |
moved to Completion/compdump
Diffstat (limited to 'Completion')
-rw-r--r-- | Completion/Core/compdump | 135 |
1 files changed, 0 insertions, 135 deletions
diff --git a/Completion/Core/compdump b/Completion/Core/compdump deleted file mode 100644 index a94a41df6..000000000 --- a/Completion/Core/compdump +++ /dev/null @@ -1,135 +0,0 @@ -# This is a function to dump the definitions for new-style -# completion defined by 'compinit' in the same directory. The output -# should be directed into the "compinit.dump" in the same directory as -# compinit. If you rename init, just stick .dump onto the end of whatever -# you have called it and put it in the same directory. This is handled -# automatically if you invoke compinit with the option -d. -# -# You will need to update the dump every time you add a new completion. -# To do this, simply remove the .dump file, start a new shell, and -# create the .dump file as before. Again, compinit -d handles this -# automatically. - -# Print the number of files used for completion. This is used in compinit -# to see if auto-dump should re-dump the dump-file. - -emulate -L zsh -setopt extendedglob noshglob - -typeset _d_file _d_f _d_bks _d_line _d_als _d_files - -_d_file=${_comp_dumpfile-${0:h}/compinit.dump}.$HOST.$$ -[[ $_d_file = //* ]] && _d_file=${_d_file[2,-1]} - -[[ -w ${_d_file:h} ]] || return 1 - -_d_files=( ${^~fpath:/.}/^([^_]*|*~|*.zwc)(N) ) - -if [[ -n "$_comp_secure" ]]; then - _d_wdirs=( ${^fpath}(Nf:g+w:,f:o+w:,^u0u${EUID}) ) - _d_wfiles=( ${^~fpath:/.}/^([^_]*|*~|*.zwc)(N^u0u${EUID}) ) - - (( $#_d_wfiles )) && _d_files=( "${(@)_d_files:#(${(j:|:)_d_wfiles})}" ) - (( $#_d_wdirs )) && _d_files=( "${(@)_d_files:#(${(j:|:)_d_wdirs})/*}" ) -fi - -print "#files: $#_d_files" > $_d_file - -# First dump the arrays _comps, _services and _patcomps. The quoting -# hieroglyphyics ensure that a single quote inside a variable is itself -# correctly quoted. - -print "_comps=(" >> $_d_file -for _d_f in ${(ok)_comps}; do - print -r - "${(q)_d_f}" "${(q)_comps[$_d_f]}" -done >> $_d_file -print ")" >> $_d_file - -print "_services=(" >> $_d_file -for _d_f in ${(ok)_services}; do - print -r - "${(q)_d_f}" "${(q)_services[$_d_f]}" -done >> $_d_file -print ")" >> $_d_file - -print "\n_patcomps=(" >> $_d_file -for _d_f in "${(ok@)_patcomps}"; do - print -r - "${(q)_d_f}" "${(q)_patcomps[$_d_f]}" -done >> $_d_file -print ")" >> $_d_file - -print "\n_postpatcomps=(" >> $_d_file -for _d_f in "${(ok@)_postpatcomps}"; do - print -r - "${(q)_d_f}" "${(q)_postpatcomps[$_d_f]}" -done >> $_d_file -print ")" >> $_d_file - -print "\n_compautos=(" >> $_d_file -for _d_f in "${(ok@)_compautos}"; do - print -r - "${(q)_d_f}" "${(q)_compautos[$_d_f]}" -done >> $_d_file -print ")" >> $_d_file - -print >> $_d_file - -# Now dump the key bindings. We dump all bindings for zle widgets -# whose names start with a underscore. -# We need both the zle -C's and the bindkey's to recreate. -# We can ignore any zle -C which rebinds a standard widget (second -# argument to zle does not begin with a `_'). - -_d_bks=() -_d_complist= -zle -lL | - while read -rA _d_line; do - if [[ ${_d_line[3]} = _* && ${_d_line[5]} = _* ]]; then - if [[ -z "$_d_complist" && ${_d_line[4]} = .menu-select ]]; then - print 'zmodload -i zsh/complist' - d_complist=yes - fi - print -r - ${_d_line} - _d_bks=($_d_bks ${_d_line[3]}) - fi - done >> $_d_file -bindkey | - while read -rA _d_line; do - if [[ ${_d_line[2]} = (${(j.|.)~_d_bks}) ]]; then - print -r "bindkey '${_d_line[1][2,-2]}' ${_d_line[2]}" - fi - done >> $_d_file - -print >> $_d_file - - -# Autoloads: whence -w produces "_d_foo: function", so look for -# all functions beginning with `_'. - -_d_als=($(whence -wm '_*' | sort | -while read -rA _d_line; do - [[ ${_d_line[2]} = function ]] && print -r - ${_d_line[1]%:} -done)) - -# print them out: about five to a line looks neat - -_i=5 -print -n autoload -U >> $_d_file -while (( $#_d_als )); do - if (( ! $+_compautos[$_d_als[1]] )); then - print -n " $_d_als[1]" - if (( ! _i-- && $#_d_als > 1 )); then - _i=5 - print -n ' \\\n ' - fi - fi - shift _d_als -done >> $_d_file - -print >> $_d_file - -for _i in "${(ok@)_compautos}"; do - print "autoload -U $_compautos[$_i] $_i" >> $_d_file -done - -mv $_d_file ${_d_file%.$HOST.$$} - -unfunction compdump -autoload -U compdump |