nsh/nsh_parse.c: Fix variable expansion inside double quotes
This also prevents expanding anything when inside single quotes, for full POSIX compliance.
This commit is contained in:
parent
f9dfb51001
commit
ad18a50282
@ -1638,6 +1638,7 @@ static FAR char *nsh_argument(FAR struct nsh_vtbl_s *vtbl,
|
||||
FAR char *prev;
|
||||
bool escaped;
|
||||
#endif
|
||||
bool squote;
|
||||
bool quoted;
|
||||
|
||||
/* Find the beginning of the next token */
|
||||
@ -1694,6 +1695,7 @@ static FAR char *nsh_argument(FAR struct nsh_vtbl_s *vtbl,
|
||||
* make sure that we do not break up any quoted substrings.
|
||||
*/
|
||||
|
||||
squote = false;
|
||||
quoted = false;
|
||||
#ifdef CONFIG_NSH_QUOTE
|
||||
escaped = false;
|
||||
@ -1747,6 +1749,24 @@ static FAR char *nsh_argument(FAR struct nsh_vtbl_s *vtbl,
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Is it a single-quote ? No expansion allowed */
|
||||
|
||||
if (*pend == '\'')
|
||||
{
|
||||
/* Yes, do not allow any expansions whatsoever */
|
||||
|
||||
squote = true;
|
||||
}
|
||||
|
||||
/* Is it a double-quote ? Variable expansion is allowed */
|
||||
|
||||
if (*pend == '"')
|
||||
{
|
||||
/* Don't split env variable if inside double quotes */
|
||||
|
||||
isenvvar = NULL;
|
||||
}
|
||||
|
||||
/* Is it a back-quote ? These are not removed here */
|
||||
|
||||
if (*pend != '`')
|
||||
@ -1797,8 +1817,15 @@ static FAR char *nsh_argument(FAR struct nsh_vtbl_s *vtbl,
|
||||
|
||||
/* Perform expansions as necessary for the argument */
|
||||
|
||||
if (squote)
|
||||
{
|
||||
argument = pbegin;
|
||||
}
|
||||
else
|
||||
{
|
||||
argument = nsh_argexpand(vtbl, pbegin, &allocation, isenvvar);
|
||||
}
|
||||
}
|
||||
|
||||
/* If any memory was allocated for this argument, make sure that it is
|
||||
* added to the list of memory to be freed at the end of command
|
||||
|
Loading…
Reference in New Issue
Block a user