diff options
author | Petteri Räty <petsku@petteriraty.eu> | 2012-08-19 17:49:11 +0300 |
---|---|---|
committer | Petteri Räty <petsku@petteriraty.eu> | 2012-08-19 17:49:11 +0300 |
commit | a6de545c440ed82f16ccf12cf229efc99ecd7ec7 (patch) | |
tree | 76d19ae4b68035b7427d33e2e22a0623d06f584a /bashast | |
parent | Parser: Support line break after pipe (diff) | |
parent | Parser: Accept semicolons inside builtin variable definitions (diff) | |
download | libbash-a6de545c440ed82f16ccf12cf229efc99ecd7ec7.tar.gz libbash-a6de545c440ed82f16ccf12cf229efc99ecd7ec7.tar.bz2 libbash-a6de545c440ed82f16ccf12cf229efc99ecd7ec7.zip |
Merge remote-tracking branch 'aparicio/multiline_string_declaration'
Diffstat (limited to 'bashast')
-rw-r--r-- | bashast/bashast.g | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/bashast/bashast.g b/bashast/bashast.g index 8943209..799b1cf 100644 --- a/bashast/bashast.g +++ b/bashast/bashast.g @@ -466,15 +466,23 @@ array_atom builtin_variable_definition_item scope { int parens; +#ifdef OUTPUT_C + bool dquotes; +#else + boolean dquotes; +#endif } @init { $builtin_variable_definition_item::parens = 0; + $builtin_variable_definition_item::dquotes = false; } : ( (LPAREN) => LPAREN { ++$builtin_variable_definition_item::parens; } |(RPAREN) => RPAREN { --$builtin_variable_definition_item::parens; } + |(DQUOTE) => DQUOTE { $builtin_variable_definition_item::dquotes = ! $builtin_variable_definition_item::dquotes; } |(~(EOL|SEMIC)) => expansion_base - | {LA(1) == EOL && $builtin_variable_definition_item::parens > 0}? => EOL + | {LA(1) == SEMIC && $builtin_variable_definition_item::dquotes}? => SEMIC + | {LA(1) == EOL && $builtin_variable_definition_item::parens > 0 || $builtin_variable_definition_item::dquotes}? => EOL )+; #ifdef OUTPUT_C |