Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
PATCH: completion for gcc (first draft proposal)
- X-seq: zsh-workers 7862
- From: Sven Wischnowsky <wischnow@xxxxxxxxxxxxxxxxxxxxxxx>
- To: zsh-workers@xxxxxxxxxxxxxx
- Subject: PATCH: completion for gcc (first draft proposal)
- Date: Thu, 16 Sep 1999 14:06:59 +0200 (MET DST)
- Mailing-list: contact zsh-workers-help@xxxxxxxxxxxxxx; run by ezmlm
It would be nice if we could find out for as many different machine
types as possible, if the selection of machine-specific options works
(I could only try sparc/Solaris, alpha/DU, and i586/Linux).
And of course there is much more that could be done, I mainly took the
option names from the info for `gcc' (and it's not the latest version).
This also adds the `-M' option to `_arguments' which can be used to
override the default match spec.
Then I found an ugliness when displaying `compadd -d' matches --
duplicates weren't eliminated.
Bye
Sven
diff -u -r oldcompletion/Base/_arguments Completion/Base/_arguments
--- oldcompletion/Base/_arguments Wed Sep 15 16:48:58 1999
+++ Completion/Base/_arguments Thu Sep 16 13:57:56 1999
@@ -8,7 +8,7 @@
local args rest ws cur nth def nm expl descr action opt arg tmp xor
local single uns ret=1 aret soptseq soptseq1 sopts prefix _line odescr
local beg optbeg argbeg nargbeg inopt inrest fromrest cmd="$words[1]"
-local matched curopt noargs i tmp1 tmp2 tmp3 suffix
+local matched curopt noargs i tmp1 tmp2 tmp3 suffix match
# Associative arrays used to collect information about the options.
@@ -22,14 +22,26 @@
unset _args_cache_{opts,dopts,odopts,odescr,xors}
typeset -gA _args_cache_{opts,dopts,odopts,xors}
- unset _args_cache_{long,longcmd,single,rest,args,sopts,soptseq,soptseq1}
+ unset _args_cache_{long,longcmd,single,match,rest,args,sopts,soptseq,soptseq1}
- # See if we are using single-letter options.
+ # Default match spec.
- if [[ "$1" = -s ]]; then
- shift
- _args_cache_single=yes
- fi
+ _args_cache_match='r:|[_-]=* r:|=*'
+
+ # See if we are using single-letter options or have a match spec.
+
+ while [[ "$1" = -(s|M*) ]]; do
+ if [[ "$1" = -s ]]; then
+ shift
+ _args_cache_single=yes
+ elif [[ "$1" = -M?* ]]; then
+ _args_cache_match="${1[3,-1]}"
+ shift
+ else
+ _args_cache_match="$2"
+ shift 2
+ fi
+ done
# See if we support long options, too.
@@ -336,6 +348,7 @@
odescr=( "$_args_cache_odescr[@]" )
xors=( "${(@kv)_args_cache_xors}" )
single="$_args_cache_single"
+match="$_args_cache_match"
# Parse the command line...
@@ -793,7 +806,7 @@
eval ws\=\( "${action[3,-3]}" \)
- _describe -c "$cmd" "$descr" ws -M 'r:|[_-]=* r:|=*'
+ _describe -c "$cmd" "$descr" ws -M "$match"
elif [[ "$action" = \(*\) ]]; then
@@ -841,11 +854,11 @@
tmp2=( "${(@o)tmp2}" )
_describe -o -c "$cmd" option \
- tmp1 tmp2 -Q -M 'r:|[_-]=* r:|=*'
+ tmp1 tmp2 -Q -M 'r:|[_-]=* r:|=*'
else
# The last option takes an argument in the next word.
- compadd "$expl[@]" -Q -M 'r:|[_-]=* r:|=*' - "${PREFIX}" && ret=0
+ compadd "$expl[@]" -Q -M "$match" - "${PREFIX}" && ret=0
fi
else
tmp1=( "${(@k)opts}" "${(@k)odopts[(I)*[^=]]}" )
@@ -853,9 +866,9 @@
tmp2=( "${(@M)odescr:#(${(kj:|:)~dopts}):*}" )
tmp3=( "${(@M)odescr:#(${(kj:|:)~odopts[(I)*=]%=}):*}" )
_describe -o -c "$cmd" option \
- tmp1 -Q -M 'r:|[_-]=* r:|=*' -- \
- tmp2 -QS '' -M 'r:|[_-]=* r:|=*' -- \
- tmp3 -QqS= -M 'r:|[_-]=* r:|=*'
+ tmp1 -Q -M "$match" -- \
+ tmp2 -QS '' -M "$match" -- \
+ tmp3 -QqS= -M "$match"
fi
fi
@@ -867,7 +880,7 @@
suffix="$SUFFIX"
PREFIX="${PREFIX%%\=*}"
SUFFIX=''
- compadd -M 'r:|[_-]=* r:|=*' -D tmp - "${(@)tmp%\=}"
+ compadd -M "$match" -D tmp - "${(@)tmp%\=}"
if [[ $#tmp -eq 1 ]]; then
def="$odopts[$tmp[1]]"
@@ -882,9 +895,9 @@
break
done
-[[ -n "$noargs" ]] && _message "$noargs"
-
[[ -n "$aret" ]] && return 300
+
+[[ -n "$noargs" ]] && _message "$noargs"
# Set the return value.
diff -u -r oldcompletion/User/_gcc Completion/User/_gcc
--- oldcompletion/User/_gcc Thu Sep 16 13:58:22 1999
+++ Completion/User/_gcc Thu Sep 16 13:55:56 1999
@@ -0,0 +1,282 @@
+#compdef gcc
+
+local state line ret=1 expl args
+typeset -A options
+
+args=()
+case $MACHTYPE in
+m68*)
+ args=(
+ -m68000 -m68020 -m68020-40 -m68030 -m68040 -m68881
+ -mbitfield -mc68000 -mc68020 -mfpa -mnobitfield
+ -mrtd -mshort -msoft-float
+ )
+ ;;
+vax)
+ args=(
+ -mg -mgnu -munix
+ )
+ ;;
+c[1234]*)
+ args=(
+ -mc1 -mc2 -mc32 -mc34 -mc38
+ -margcount -mnoargcount
+ -mlong32 -mlong64
+ -mvolatile-cache -mvolatile-nocache
+ )
+ ;;
+amd290?0)
+ args=(
+ -m29000 -m29050 -mbw -mnbw -mdw -mndw
+ -mlarge -mnormal -msmall
+ -mkernel-registers -mno-reuse-arg-regs
+ -mno-stack-check -mno-storem-bug
+ -mreuse-arg-regs -msoft-float -mstack-check
+ -mstorem-bug -muser-registers
+ )
+ ;;
+arm)
+ args=(
+ -mapcs -m2 -m3 -m6 -mbsd -mxopen -mno-symrename
+ )
+ ;;
+m88k)
+ args=(
+ -m88000 -m88100 -m88110 -mbig-pic
+ -mcheck-zero-division -mhandle-large-shift
+ -midentify-revision -mno-check-zero-division
+ -mno-ocs-debug-info -mno-ocs-frame-position
+ -mno-optimize-arg-area -mno-serialize-volatile
+ -mno-underscores -mocs-debug-info
+ -mocs-frame-position -moptimize-arg-area
+ -mserialize-volatile -msvr3
+ -msvr4 -mtrap-large-shift -muse-div-instruction
+ -mversion-03.00 -mwarn-passed-structs
+ '-mshort-data--:maximum displacement:'
+ )
+ ;;
+rs6000|powerpc*)
+ args=(
+ '-mcpu=:CPU type:(rios1 rios2 rsc 501 603 604 power powerpc 403 common)'
+ -mpower -mno-power -mpower2 -mno-power2
+ -mpowerpc -mno-powerpc
+ -mpowerpc-gpopt -mno-powerpc-gpopt
+ -mpowerpc-gfxopt -mno-powerpc-gfxopt
+ -mnew-mnemonics -mno-new-mnemonics
+ -mfull-toc -mminimal-toc -mno-fop-in-toc -mno-sum-in-toc
+ -msoft-float -mhard-float -mmultiple -mno-multiple
+ -mstring -mno-string -mbit-align -mno-bit-align
+ -mstrict-align -mno-strict-align -mrelocatable -mno-relocatable
+ -mtoc -mno-toc -mtraceback -mno-traceback
+ -mlittle -mlittle-endian -mbig -mbig-endian
+ -mcall-aix -mcall-sysv -mprototype
+ )
+ ;;
+romp)
+ args=(
+ -mcall-lib-mul -mfp-arg-in-fpregs -mfp-arg-in-gregs
+ -mfull-fp-blocks -mhc-struct-return -min-line-mul
+ -mminimum-fp-blocks -mnohc-struct-return
+ )
+ ;;
+mips*)
+ args=(
+ '-mcpu=:CPU type:(r2000 r3000 r4000 r4400 r4600 r6000_'
+ -mabicalls -membedded-data
+ -membedded-pic -mfp32 -mfp64 -mgas -mgp32 -mgp64
+ -mgpopt -mhalf-pic -mhard-float -mint64 -mips1
+ -mips2 -mips3 -mlong64 -mlong-calls -mmemcpy
+ -mmips-as -mmips-tfile -mno-abicalls
+ -mno-embedded-data -mno-embedded-pic
+ -mno-gpopt -mno-long-calls
+ -mno-memcpy -mno-mips-tfile -mno-rnames -mno-stats
+ -mrnames -msoft-float
+ -m4650 -msingle-float -mmad
+ -mstats -EL -EB -nocpp
+ '-G:maximum size for small section objects:'
+ )
+ ;;
+i[345]86)
+ args=(
+ -m486 -m386 -mieee-fp -mno-fancy-math-387
+ -mno-fp-ret-in-387 -msoft-float -msvr3-shlib
+ -mno-wide-multiply -mrtd -malign-double
+ '-mreg-alloc=:default register allocation order:'
+ '-mregparm=:number of integer argument registers:'
+ '-malign-jumps=: **2 base for jump goal alignment:'
+ '-malign-loops=: **2 base for loop alignment:'
+ '-malign-functions=: **2 base for function alignment:'
+ )
+ ;;
+hppa*)
+ args=(
+ -mdisable-fpregs -mdisable-indexing -mfast-indirect-calls
+ -mgas -mjump-in-delay -mlong-millicode-calls -mno-disable-fpregs
+ -mno-disable-indexing -mno-fast-indirect-calls -mno-gas
+ -mno-jump-in-delay -mno-millicode-long-calls
+ -mno-portable-runtime -mno-soft-float -msoft-float
+ -mpa-risc-1-0 -mpa-risc-1-1 -mportable-runtime
+ '-mschedule=:code scheduling constraints:(700 7100 7100LC)'
+ )
+ ;;
+i960)
+ args=(
+ -m{ka,kb,mc,ca,cf,sa,sb}
+ -masm-compat -mclean-linkage
+ -mcode-align -mcomplex-addr -mleaf-procedures
+ -mic-compat -mic2.0-compat -mic3.0-compat
+ -mintel-asm -mno-clean-linkage -mno-code-align
+ -mno-complex-addr -mno-leaf-procedures
+ -mno-old-align -mno-strict-align -mno-tail-call
+ -mnumerics -mold-align -msoft-float -mstrict-align
+ -mtail-call
+ )
+ ;;
+sparc)
+ args=(
+ -mapp-regs -mcypress -mepilogue -mflat -mfpu -mhard-float
+ -mhard-quad-float -mno-app-regs -mno-flat -mno-fpu
+ -mno-epilogue -mno-unaligned-doubles
+ -msoft-float -msoft-quad-float
+ -msparclite -msupersparc -munaligned-doubles -mv8
+ -mmedlow -mmedany
+ -mint32 -mint64 -mlong32 -mlong64
+ -mno-stack-bias -mstack-bias
+ )
+ ;;
+alpha*)
+ args=(
+ -mfp-regs -mno-fp-regs -mno-soft-float
+ -msoft-float
+ )
+ ;;
+clipper)
+ args=(
+ -mc300 -mc400
+ )
+ ;;
+h8/300)
+ args=(
+ -mrelax -mh
+ )
+ ;;
+esac
+
+
+_arguments -M 'L:|-{fW}no-=-{fW} r:|[_-]=* r:|=*' \
+ "$args[@]" \
+ -c -S -E -v -a -w -C -H -P -s '(-pg)-p' '(-p)-pg' \
+ '-o:output file:_files' \
+ '-x:input file language:(c objective-c c++ c-header cpp-output c++-cpp-output assembler assembler-with-cpp none)' \
+ '+e-:virtual function definitions in classes:((0\:only\ interface 1\:generate\ code))' \
+ '-d-:dump:->dump' \
+ '-g-::debugging information type:(gdb coff stabs stabs+ dwarf dwarf+ xcoff xcoff+)' \
+ '-O-::optimization level:(0 1 2 3)' \
+ '*-M-::output dependencies:((M\:only\ user\ header\ files MD\:output\ to\ file G\:treat\ missing\ header\ files\ as\ generated))' \
+ '*-A-:define assertion:' \
+ '*-D-:define macro:' \
+ '*-U-:undefine macro:' \
+ '*-Wp,-:preprocessor option:' \
+ '*-Wl,-:linker option:' \
+ '*-Xlinker:linker option:' \
+ '*-u:pretend symbol to be undefined:' \
+ '*-Wa,-:assembler option:' \
+ '*-l:library:->library' \
+ '*-L-:library search path:_files -/' \
+ '*-I-:header file search path:_files -/' \
+ '-B-:executable prefix:_files -/' \
+ '-b:target machine:' \
+ '-V:gcc version:' \
+ '-print-file-name=:library:->library' \
+ '-print-prog-name=:program:' \
+ '*-include:include file:_files -g \*.h' \
+ '*-imacros:macro input file:_files -g \*.h' \
+ '*-idirafter:second include path directory:_files -/' \
+ '*-iprefix:prefix:_files' \
+ '*-iwithprefix:second include path directory:_files -/' \
+ '*-iwithprefixbefore:main include path directory:_files -/' \
+ '*-isystem:second include path directory (system):_files -/' \
+ -nostdinc -trigraphs -undef -pipe -ansi \
+ -fallow-single-precision -fcond-mismatch -fasm \
+ -fbuiltin -fsigned-bitfields -fsigned-char \
+ -funsigned-bitfields -funsigned-char -fwritable-strings \
+ -traditional -traditional-cpp -trigraphs \
+ -fall-virtual -fdollars-in-identifiers -felide-constructors \
+ -fenum-int-equiv -fexternal-templates -ffor-scope \
+ -fhandle-signatures -fmemoize-lookups -fdefault-inline -fgnu-keywords \
+ -fnonnull-objects -foperator-names -fstrict-prototype \
+ -fthis-is-variable -nostdinc++ -traditional \
+ -fsyntax-only -pedantic -pedantic-errors \
+ -Wall -Waggregate-return -Wbad-function-cast \
+ -Wcast-align -Wcast-qual -Wchar-subscript -Wcomment \
+ -Wconversion -Wenum-clash -Werror -Wformat \
+ '-Wid-clash--:minimum identifier difference length:' \
+ -Wimplicit -Wimport -Winline \
+ '-Wlarger-than--:maximum object length:' \
+ -Wmissing-declarations \
+ -Wmissing-prototypes -Wnested-externs \
+ -Wimport -Woverloaded-virtual -Wparentheses \
+ -Wpointer-arith -Wredundant-decls -Wreorder -Wreturn-type -Wshadow \
+ -Wstrict-prototypes -Wswitch -Wsynth -Wtemplate-debugging \
+ -Wtraditional -Wtrigraphs -Wuninitialized -Wunused \
+ -Wwrite-strings \
+ -fpretend-float \
+ -print-libgcc-file-name \
+ -print-search-dirs -save-temps \
+ -fcaller-saves -fcse-follow-jumps -fcse-skip-blocks \
+ -fdelayed-branch -fexpensive-optimizations \
+ -ffast-math -ffloat-store -fforce-addr -fforce-mem \
+ -finline-functions -fkeep-inline-functions \
+ -fdefault-inline -fdefer-pop -ffunction-cse \
+ -finline -fpeephole -fomit-frame-pointer \
+ -frerun-cse-after-loop -fschedule-insns \
+ -fschedule-insns2 -fstrength-reduce -fthread-jumps \
+ -funroll-all-loops -funroll-loops \
+ -nostartfiles -nodefaultlibs -nostdlib \
+ -static -shared -symbolic \
+ '*-fcall-saved--:register saved by function call:' \
+ '*-fcall-used--:register clobbered by function call:' \
+ '*-ffixed--:fixed register:' \
+ -finhibit-size-directive \
+ -fno-common -fno-ident -fno-gnu-linker \
+ -fpcc-struct-return -fpic -fPIC \
+ -freg-struct-return -fshared-data -fshort-enums \
+ -fshort-double -fvolatile -fvolatile-global \
+ -fverbose-asm -fpack-struct \
+ '*:input file:_files -g \*.\(\[cCmisSoak\]\|cc\|cxx\|ii\|k\[ih\]\)' && ret=0
+
+
+case "$state" in
+dump)
+ _values -s '' 'dump information' \
+ 'M[only macro definitions]' \
+ 'N[macro names]' \
+ 'D[macro definitions and normal output]' \
+ 'y[debugging information during parsing]' \
+ 'r[after RTL generation]' \
+ 'x[only generate RTL]' \
+ 'j[after jump optimization]' \
+ 's[after CSE]' \
+ 'L[after loop optimization]' \
+ 't[after second CSE pass]' \
+ 'f[after flow analysis]' \
+ 'c[after instruction combination]' \
+ 'S[after first instruction scheduling pass]' \
+ 'l[after local register allocation]' \
+ 'g[after global register allocation]' \
+ 'R[after second instruction scheduling pass]' \
+ 'J[after last jump optimization]' \
+ 'd[after delayed branch scheduling]' \
+ 'k[after conversion from registers to stack]' \
+ 'a[all dumps]' \
+ 'm[print memory usage statistics]' \
+ 'p[annotate assembler output]' && ret=0
+ ;;
+library)
+ _description expl library
+ compadd "$expl[@]" - ${^=LD_LIBRARY_PATH:-/usr/lib /usr/local/lib}/lib*.(a|so*)(:t:fr:s/lib//) && ret=0
+ ;;
+esac
+
+return ret
+
diff -u od/Zsh/compsys.yo Doc/Zsh/compsys.yo
--- od/Zsh/compsys.yo Wed Sep 15 14:39:16 1999
+++ Doc/Zsh/compsys.yo Thu Sep 16 13:55:55 1999
@@ -855,13 +855,18 @@
Normally the option names are taken as multi-character names and a
word from the line is considered to contain only one option (or
-none). By giving the tt(-s) option to this function (as the first
-argument), options are considered to be one-character options and the
+none). By giving the tt(-s) option to this function (before the first
+description), options are considered to be one-character options and the
strings from the line may contain more than one such option
letter. However, strings beginning with two hyphens (like
`tt(-)tt(-prefix)') are still considered to contain only one option
name. This allows the use of the `tt(-s)' option to describe
single-letter options together with such long option names.
+
+Also, the tt(-M) option followed by a string may be given before the
+first description. The string will be used as the match specification
+when completing option names and values instead of the default
+`tt(r:|[_-]=* r:|=*)'.
The function can also be made to automatically complete long options
for commands that support the `tt(-)tt(-help)' option as, for example,
diff -u os/Zle/zle_tricky.c Src/Zle/zle_tricky.c
--- os/Zle/zle_tricky.c Wed Sep 15 15:39:21 1999
+++ Src/Zle/zle_tricky.c Thu Sep 16 13:55:55 1999
@@ -7035,7 +7035,9 @@
matchstreq(a->ppre, b->ppre) &&
matchstreq(a->psuf, b->psuf) &&
matchstreq(a->suf, b->suf) &&
- !a->disp && !b->disp && matchstreq(a->str, b->str);
+ ((!a->disp && !b->disp && matchstreq(a->str, b->str)) ||
+ (a->disp && b->disp && !strcmp(a->disp, b->disp) &&
+ matchstreq(a->str, b->str)));
}
/* Make an array from a linked list. The second argument says whether *
--
Sven Wischnowsky wischnow@xxxxxxxxxxxxxxxxxxxxxxx
Messages sorted by:
Reverse Date,
Date,
Thread,
Author