1
0
Fork 0
mirror of git://git.code.sf.net/p/zsh/code synced 2024-05-07 08:06:22 +02:00

52373: fix _numbers for suffixes containing % and update affected functions

This commit is contained in:
Oliver Kiddle 2023-12-05 18:46:25 +01:00
parent 57d70d1b70
commit 0394b7cf17
4 changed files with 17 additions and 10 deletions

View File

@ -1,3 +1,9 @@
2023-12-05 Oliver Kiddle <opk@zsh.org>
* 52373: Completion/Base/Utility/_numbers,
Completion/Solaris/Command/_dumpadm, Completion/Unix/Command/_xz:
fix _numbers for suffixes containing % and update affected functions
2023-12-04 Jun-ichi Takimoto <takimoto-j@kba.biglobe.ne.jp>
* 52356: (cf. 52327 Dennis Eriksen): Doc/Zsh/builtins.yo: add

View File

@ -73,7 +73,7 @@ elif [[ -prefix $~pat || $PREFIX = $~partial ]]; then
zformat -f suffix "$suffixfmt" "x:${${argv[i+1]#:}%%:*}" \
"X:${${argv[i+1]#:}#*:}" "d:${#${argv[i+1]}[1]#:}" \
i:i r:$(( $# - i - 1))
suffixes+="$suffix"
suffixes+="${suffix//\%/%%}"
done
[[ -n $suffixes ]] && formats+=( x:$suffixes )

View File

@ -16,7 +16,7 @@ _arguments -s \
'-y[run savecore on reboot]' \
'-c[set dump content]:dump content:(($content))' \
'-d[set dump device]: : _alternative "tokens\:token\:(swap none)" "files\:block device\:_files -g \*\(-%b\)"' \
'-m[set minfree size]:size' \
'-m[set minfree size]: :_numbers size k m %' \
'-s[set the savecore directory]:directory:_files -/' \
'-r[alternate root directory]:directory:_files -/' \
'-z[enable saving core files in a compressed format]:compression:(on off)'

View File

@ -22,20 +22,20 @@ case "$service" in
'(I)*'{-v,--verbose}'[verbose mode]' \
'(I * --files --files0)--files=-[read list of files to process from file]::file:_files' \
'(I * --files --files0)--files0=-[read null terminated list of files to process from file]::file:_files' \
'(I -F --format)'{-F,--format}'=[specify file format]:format:(auto xz lzma raw)' \
'(I -F --format)'{-F+,--format=}'[specify file format]:format:(auto xz lzma lzip raw)' \
'(I -T --threads)'{-T+,--threads=}'[use specified number of threads]:threads [1]' \
'(I -M --memlimit --memory)'{-M+,--memlimit=,--memory=}'[set memory usage limit]:memory usage' \
'(I -M --memlimit --memory)'{-M+,--memlimit=,--memory=}'[set memory usage limit]: :_numbers -u bytes "memory limit" KiB MiB GiB %\:percentage\ of\ available\ RAM' \
'(I)--no-adjust[give error if settings exceed memory limit]' \
'(I -Q --no-warn)'{-Q,--no-warn}'[make warnings not affect exit status]' \
+ 'comp' \
"(I decomp)"{-z,--compress}'[compress]' \
'(I decomp -e --extreme)'{-e,--extreme}'[try to improve compression ratio by using more CPU time]' \
'(I decomp -S --suffix)'{-S+,--suffix=}'[use specified suffix for compressed files]:suffix [.xz]' \
'(I decomp -C --check)'{-C,--check}'=[integrity check type]:check type:(none crc32 crc64 sha256)' \
'(I decomp -C --check)'{-C+,--check=}'[integrity check type]:check type:(none crc32 crc64 sha256)' \
'(I decomp)--block-size=[start a new .xz block after specified bytes of input]:size' \
'(I decomp)--block-list=[start a new .xz block after specified intervals of uncompressed data]:size' \
'(I decomp)--flush-timeout=[specify maximum time between flushing of output]:time (ms) [0]' \
'(I decomp)--memlimit-compress=[set memory usage limit for compression]:memory usage' \
'(I decomp)--memlimit-compress=[set memory usage limit for compression]: :_numbers -u bytes "memory limit" KiB MiB GiB %\:percentage\ of\ available\ RAM' \
+ 'decomp' \
'(I comp level filters)'{-d,--decompress}'[decompress]' \
'(I comp level filters)'{-t,--test}'[test compressed file integrity]' \
@ -43,7 +43,8 @@ case "$service" in
"(I comp level filters)--ignore-check[don't verify integrity when decompressing]" \
'(I comp level filters)--single-stream[decompress only the first stream]' \
"(I comp level filters)--no-sparse[don't create sparse files when decompressing]" \
'(I comp level filters)--memlimit-decompress=[set memory usage limit for decompression]:memory usage' \
'(I comp level filters)--memlimit-decompress=[set memory usage limit for decompression]: :_numbers -u bytes "memory limit" KiB MiB GiB %\:percentage\ of\ available\ RAM' \
'(I comp level filters)--memlimit-mt-decompress=[set memory usage limit for multithreaded decompression]: :_numbers -u bytes "memory limit" KiB MiB GiB %\:percentage\ of\ available\ RAM' \
+ '(I)' \
'(* comp decomp level filters common)--info-memory[display amount of RAM and memory usage limits]' \
'(- *)'{-h,--help}'[display help message]' \
@ -52,7 +53,7 @@ case "$service" in
+ '(level)' \
'(I filters decomp)-'{-best,-fast,1,2,3,4,5,6,7,8,9} \
+ filters \
'(I level decomp --extreme)'--{x86,powerpc,ia64,arm,armthumb,sparc}=-'[add a branch/call/jump filter]::option:->bcj-options' \
'(I level decomp --extreme)'--{x86,powerpc,ia64,arm,armthumb,arm64,sparc}=-'[add a branch/call/jump filter]::option:->bcj-options' \
'(I level decomp --extreme)'--lzma{1,2}=-'[add lzma filter]::option:->lzma-options' \
'(I level decomp --extreme)--delta=-[add delta filter]::option:->delta-options' && ret=0
;;
@ -64,10 +65,10 @@ case $state in
[[ -n ${(k)opt_args[(i)decomp*]} ]] && unset decompress
if [[ -z "$decompress" ]]; then
_description files expl 'compressed file'
_files "$expl[@]" -g '*.(xz|txz|lzma|tlz)(-.)' && return
_files "$expl[@]" -g '*.(xz|txz||lz|lzma|tlz)(-.)' && return
else
_description files expl 'file to compress'
_files "$expl[@]" -g '^*.(xz|txz|lzma|tlz)(-.)' && return
_files "$expl[@]" -g '^*.(xz|txz|lz|lzma|tlz)(-.)' && return
fi
;;
lzma-options)