diff options
author | Nick Clifton <nickc@redhat.com> | 2005-08-09 15:47:46 +0000 |
---|---|---|
committer | Nick Clifton <nickc@redhat.com> | 2005-08-09 15:47:46 +0000 |
commit | 2f6178c175ba113600c532b8fc84e8d54beddb78 (patch) | |
tree | 9c5b0ff31ada6dc28f8297427792ee3de4470f5a /gas/macro.c | |
parent | 3260c64dd284ac6dc82371c33c505b94ca22dea6 (diff) | |
download | gdb-2f6178c175ba113600c532b8fc84e8d54beddb78.zip gdb-2f6178c175ba113600c532b8fc84e8d54beddb78.tar.gz gdb-2f6178c175ba113600c532b8fc84e8d54beddb78.tar.bz2 |
PR 1070
* macro.c (getstring): Do not treat round parentheses exactly the same as angle
brackets - the parentheses need to be preserved and passed on to the macro processing code.
Diffstat (limited to 'gas/macro.c')
-rw-r--r-- | gas/macro.c | 31 |
1 files changed, 26 insertions, 5 deletions
diff --git a/gas/macro.c b/gas/macro.c index fbe2666..eab3e66 100644 --- a/gas/macro.c +++ b/gas/macro.c @@ -310,12 +310,11 @@ getstring (int idx, sb *in, sb *acc) || (in->ptr[idx] == '<' && (macro_alternate || macro_mri)) || (in->ptr[idx] == '\'' && macro_alternate))) { - if (in->ptr[idx] == '<' - || in->ptr[idx] == '(') + if (in->ptr[idx] == '<') { int nest = 0; - char start_char = in->ptr[idx]; - char end_char = in->ptr[idx] == '<' ? '>' : ')'; + char start_char = '>'; + char end_char = '>'; idx++; while ((in->ptr[idx] != end_char || nest) @@ -337,6 +336,28 @@ getstring (int idx, sb *in, sb *acc) } idx++; } + else if (in->ptr[idx] == '(') + { + int nest = 0; + char c; + + do + { + c = in->ptr[idx]; + + if (c == '!') + c = in->ptr[++idx]; + else if (c == ')') + nest--; + else if (c == '(') + nest++; + + sb_add_char (acc, c); + idx++; + } + while ((c != ')' || nest) + && idx < in->len); + } else if (in->ptr[idx] == '"' || in->ptr[idx] == '\'') { char tchar = in->ptr[idx]; @@ -389,7 +410,7 @@ getstring (int idx, sb *in, sb *acc) 'Bxyx<whitespace> -> return 'Bxyza %<expr> -> return string of decimal value of <expr> "string" -> return string - (string) -> return string + (string) -> return (string-including-whitespaces) xyx<whitespace> -> return xyz. */ static int |