diff options
author | Wayne Davison <wayned@users.sourceforge.net> | 2006-02-15 10:13:43 +0000 |
---|---|---|
committer | Wayne Davison <wayned@users.sourceforge.net> | 2006-02-15 10:13:43 +0000 |
commit | e22cb5192286b6eab13fe7d1ac5f0e8a28e5252e (patch) | |
tree | c6d5adfb7f9920491adbacea162ced5db5dedfc4 | |
parent | d0ea78e557358e5f20268e4114f813697091f8c2 (diff) | |
download | zsh-e22cb5192286b6eab13fe7d1ac5f0e8a28e5252e.tar.gz zsh-e22cb5192286b6eab13fe7d1ac5f0e8a28e5252e.tar.xz zsh-e22cb5192286b6eab13fe7d1ac5f0e8a28e5252e.zip |
- Some changes to handle ${1+"$@"} being fixed.
- Added quite a few new tests.
-rw-r--r-- | Test/D04parameter.ztst | 162 |
1 files changed, 149 insertions, 13 deletions
diff --git a/Test/D04parameter.ztst b/Test/D04parameter.ztst index 6abba0ab3..284042d90 100644 --- a/Test/D04parameter.ztst +++ b/Test/D04parameter.ztst @@ -37,6 +37,7 @@ setopt shwordsplit print -l $foo ${bar} + print -l ${==bar} unsetopt shwordsplit 0:Basic shwordsplit option handling >the @@ -45,6 +46,7 @@ >the >second >parameter +>the second parameter print $+foo ${+foo} $+notappearinginthistest ${+notappearinginthistest} 0:$+... @@ -547,20 +549,154 @@ >shell >again - set If "this test fails" maybe "we have finally fixed" the shell + local sure_that='sure that' varieties_of='varieties of' one=1 two=2 + set Make $sure_that "this test keeps" on 'preserving all' "$varieties_of" quoted whitespace print -l ${=1+"$@"} -0:Regression test of unfixed ${=1+"$@"} bug ->If ->this ->test ->fails ->maybe ->we ->have ->finally ->fixed ->the ->shell + print -l ${=1+Make $sure_that "this test keeps" on 'preserving all' "$varieties_of" quoted whitespace} + print -l ${=1+$one $two} +0:Regression test of ${=1+"$@"} bug and some related expansions +>Make +>sure that +>this test keeps +>on +>preserving all +>varieties of +>quoted +>whitespace +>Make +>sure +>that +>this test keeps +>on +>preserving all +>varieties of +>quoted +>whitespace +>1 +>2 + + splitfn() { + emulate -L sh + local HOME="/differs from/bash" foo='1 2' bar='3 4' + print -l ${1:-~} + touch has\ space + print -l ${1:-*[ ]*} + print -l ${1:-*[\ ]*} + print -l ${1:-*} + print -l ${1:-"$foo" $bar} + print -l ${==1:-$foo $bar} + rm has\ space + } + splitfn +0:More bourne-shell-compatible nested word-splitting with wildcards and ~ +>/differs from/bash +>*[ +>]* +>has space +>boringfile +>evenmoreboringfile +>has space +>1 2 +>3 +>4 +>1 2 3 4 + + splitfn() { + local IFS=.- + local foo=1-2.3-4 + # + print "Called with argument '$1'" + print "No quotes" + print -l ${=1:-1-2.3-4} ${=1:-$foo} + print "With quotes on default argument only" + print -l ${=1:-"1-2.3-4"} ${=1:-"$foo"} + } + print 'Using "="' + splitfn + splitfn 5.6-7.8 + # + splitfn() { + emulate -L zsh + setopt shwordsplit + local IFS=.- + local foo=1-2.3-4 + # + print "Called with argument '$1'" + print "No quotes" + print -l ${1:-1-2.3-4} ${1:-$foo} + print "With quotes on default argument only" + print -l ${1:-"1-2.3-4"} ${1:-"$foo"} + } + print Using shwordsplit + splitfn + splitfn 5.6-7.8 +0:Test of nested word splitting with and without quotes +>Using "=" +>Called with argument '' +>No quotes +>1 +>2 +>3 +>4 +>1 +>2 +>3 +>4 +>With quotes on default argument only +>1-2.3-4 +>1-2.3-4 +>Called with argument '5.6-7.8' +>No quotes +>5 +>6 +>7 +>8 +>5 +>6 +>7 +>8 +>With quotes on default argument only +>5 +>6 +>7 +>8 +>5 +>6 +>7 +>8 +>Using shwordsplit +>Called with argument '' +>No quotes +>1 +>2 +>3 +>4 +>1 +>2 +>3 +>4 +>With quotes on default argument only +>1-2.3-4 +>1-2.3-4 +>Called with argument '5.6-7.8' +>No quotes +>5 +>6 +>7 +>8 +>5 +>6 +>7 +>8 +>With quotes on default argument only +>5 +>6 +>7 +>8 +>5 +>6 +>7 +>8 unset SHLVL (( SHLVL++ )) |