1
0
Fork 0
mirror of git://git.code.sf.net/p/cdesktopenv/code synced 2025-02-13 03:32:24 +00:00

Fix syntax error detection in associative array assignments

Reproducer:

$ fn=([foo_key]=foo_val [bar_key])
-ksh: [bar_key]: not found

Expected output:
-ksh: syntax error: `[bar_key]' unexpected

As soon as one correct associative array assignment element has
been processed, a subsequent one, starting with '[' but not
containing ']=', is incorrectly seen as a command to execute.
If a command '[bar_key]' existed on $PATH, it would have been run.

src/cmd/ksh93/sh/parse.c: simple():
- In the syntax check for associative array assignments, don't just
  check for an initial '[' but also verify the presence of ']='.

Thanks to @JohnoKing for finding this bug.

Resolves: https://github.com/ksh93/ksh/issues/427
This commit is contained in:
Martijn Dekker 2022-07-05 22:09:29 +02:00
parent 06e56251b9
commit fbfd4d3ab8
3 changed files with 15 additions and 1 deletions

3
NEWS
View file

@ -9,6 +9,9 @@ Any uppercase BUG_* names are modernish shell bug IDs.
following a redirection without being an argument to a redirection.
For example, this now writes 'OK' to standard error: cat >&2 <(echo OK)
- Fixed the detection of a syntax error in compound assignments to
associative arays.
2022-07-02:
- Fixed a bug where, if the last command in a subshell was an external

View file

@ -1507,7 +1507,7 @@ static Shnode_t *simple(Lex_t *lexp,int flag, struct ionod *io)
lexp->token = LBRACE;
break;
}
if(associative && argp->argval[0]!='[')
if(associative && (argp->argval[0]!='[' || !strstr(argp->argval,"]=")))
sh_syntax(lexp);
/* check for assignment argument */
if((argp->argflag&ARG_ASSIGN) && assignment!=2)

View file

@ -830,5 +830,16 @@ exp=$'typeset -A a=([0]=1 [1]=2 [2]=3)\ntypeset -a a=(1 2 3)'
[[ $got == "$exp" ]] || err_exit 'conversion of indexed array to associative fails in subshell' \
"(expected $(printf %q "$exp"), got $(printf %q "$got"))"
# ======
# spurious command execution of a word starting with '[' but not containing ']=' in associative array assignments
# https://github.com/ksh93/ksh/issues/427
exp='*: syntax error at line *: `\[badword]'\'' unexpected'
got=$(set +x; PATH=/dev/null; eval 'typeset -A badword=([x]=1 \[badword])' 2>&1)
case $((e=$?)),$got in
3,$exp) ;;
*) err_exit 'spurious command execution in invalid associative array assignment' \
"(expected status 3 and $(printf %q "$exp"), got status $e and $(printf %q "$got"))" ;;
esac
# ======
exit $((Errors<125?Errors:125))