summaryrefslogtreecommitdiffstats
path: root/Test
diff options
context:
space:
mode:
authordana <dana@dana.is>2026-04-19 12:35:02 -0500
committerdana <dana@dana.is>2026-04-19 12:36:10 -0500
commit90fa3d2816ee3c770966dd42f548d770d266d2bd (patch)
tree043524d84eaa407ebd31bf51dfa4819b6c978bc3 /Test
parent54181, 54331: remove support for restricted shell (diff)
downloadzsh-90fa3d2816ee3c770966dd42f548d770d266d2bd.tar
zsh-90fa3d2816ee3c770966dd42f548d770d266d2bd.tar.gz
zsh-90fa3d2816ee3c770966dd42f548d770d266d2bd.tar.bz2
zsh-90fa3d2816ee3c770966dd42f548d770d266d2bd.tar.lz
zsh-90fa3d2816ee3c770966dd42f548d770d266d2bd.tar.xz
zsh-90fa3d2816ee3c770966dd42f548d770d266d2bd.tar.zst
zsh-90fa3d2816ee3c770966dd42f548d770d266d2bd.zip
54361 (tweaked): zparseopts: print friendlier usage errors, add -n option
tweaked to adjust order of options in documentation
Diffstat (limited to 'Test')
-rw-r--r--Test/V12zparseopts.ztst59
1 files changed, 46 insertions, 13 deletions
diff --git a/Test/V12zparseopts.ztst b/Test/V12zparseopts.ztst
index 5736dd3a1..907134230 100644
--- a/Test/V12zparseopts.ztst
+++ b/Test/V12zparseopts.ztst
@@ -17,6 +17,18 @@
%test
+ () { zparseopts -F } -x
+ () { zparseopts -F - } -x
+ () { zparseopts -F -- } -x
+ () { zparseopts -F - a } -x
+ () { zparseopts -F a } -x
+1:zparseopts without option specs, without array
+?(anon):zparseopts: missing option descriptions
+?(anon): bad option: -x
+?(anon): bad option: -x
+?(anon):zparseopts: no default array defined: a
+?(anon):zparseopts: no default array defined: a
+
() {
local -a optv
zparseopts -a optv - a b: c:- z
@@ -65,15 +77,15 @@
} $=1
done
0:zparseopts -F
-?(anon):zparseopts:2: bad option: -x
+?(anon): bad option: -x
>ret: 1, optv: , argv: -a -x -z
-?(anon):zparseopts:2: bad option: -x
+?(anon): bad option: -x
>ret: 1, optv: , argv: -ax -z
-?(anon):zparseopts:2: bad option: --x
+?(anon): bad option: --x
>ret: 1, optv: , argv: -a --x -z
-?(anon):zparseopts:2: bad option: -x
+?(anon): bad option: -x
>ret: 1, optv: , argv: -axy
-?(anon):zparseopts:2: bad option: --
+?(anon): bad option: --
>ret: 1, optv: , argv: -a-xy
for 1 in '-a 1 2 3' '1 2 3'; do
@@ -218,7 +230,7 @@
print -r - ret: $?, optv: $optv, argv: $argv
} -ab1 -c
0:missing optarg
-?(anon):zparseopts:2: missing argument for option: -c
+?(anon): missing argument for option: -c
>ret: 1, optv: , argv: -ab1 -c
for spec in -foo: -foo:- -foo::; do
@@ -253,11 +265,11 @@
} --foobar 1 2 3
done
0:zparseopts -G, single parameter, without =
-?(anon):zparseopts:2: bad option: --foobar
+?(anon): bad option: --foobar
>ret: 1, optv: , argv: --foobar 1 2 3
-?(anon):zparseopts:2: bad option: --foobar
+?(anon): bad option: --foobar
>ret: 1, optv: , argv: --foobar 1 2 3
-?(anon):zparseopts:2: bad option: --foobar
+?(anon): bad option: --foobar
>ret: 1, optv: , argv: --foobar 1 2 3
for spec in -foo: -foo:- -foo::; do
@@ -352,15 +364,15 @@
>ret: 0, gopt: , optv: -foobar, argv: 1 2 3
>ret: 0, gopt: , optv: -foo=bar, argv: 1 2 3
>ret: 0, gopt: , optv: -foobar, argv: 1 2 3
-?(anon):zparseopts:2: bad option: -f
+?(anon): bad option: -f
>ret: 1, gopt: -G, optv: , argv: -foobar 1 2 3
>ret: 0, gopt: -G, optv: -foo bar, argv: 1 2 3
>ret: 0, gopt: -G, optv: -foo bar, argv: 1 2 3
-?(anon):zparseopts:2: bad option: -f
+?(anon): bad option: -f
>ret: 1, gopt: -G, optv: , argv: -foobar 1 2 3
>ret: 0, gopt: -G, optv: -foo=bar, argv: 1 2 3
>ret: 0, gopt: -G, optv: -foo=bar, argv: 1 2 3
-?(anon):zparseopts:2: bad option: -f
+?(anon): bad option: -f
>ret: 1, gopt: -G, optv: , argv: -foobar 1 2 3
>ret: 0, gopt: -G, optv: -foo=bar, argv: 1 2 3
>ret: 0, gopt: -G, optv: -foo=, argv: bar 1 2 3
@@ -382,10 +394,31 @@
done
done
0:only -- acts as explicit parsing terminator with -G
-?(anon):zparseopts:2: bad option: --baz
+?(anon): bad option: --baz
>ret: 1, term: -, optv: , argv: --foo x --bar - --baz
>ret: 0, term: -, gopt: , optv: --foo, argv: --bar
>ret: 0, term: -, gopt: -G, optv: --foo, argv: - --bar
>ret: 0, term: --, optv: --foo --bar, argv: x -- --baz
>ret: 0, term: --, gopt: , optv: --foo, argv: --bar
>ret: 0, term: --, gopt: -G, optv: --foo, argv: --bar
+
+ fn1() {
+ zparseopts -F - a
+ }
+ fn2() {
+ local -a optv
+ zparseopts -a optv -F - a
+ }
+ fn3() {
+ local -a optv
+ zparseopts -a optv -nprog -F - a
+ zparseopts -a optv -n prog -F - a
+ }
+ fn1 -x
+ fn2 -x
+ fn3 -x
+1:zparseopts -n, internal vs external usage errors
+?fn1:zparseopts:1: no default array defined: a
+?fn2: bad option: -x
+?prog: bad option: -x
+?prog: bad option: -x