diff options
author | Neil Booth <neil@daikokuya.demon.co.uk> | 2001-03-03 22:14:08 +0000 |
---|---|---|
committer | Neil Booth <neil@gcc.gnu.org> | 2001-03-03 22:14:08 +0000 |
commit | e8408f251a70640dcc208877ef3122efd5b7e824 (patch) | |
tree | 7dc28de2225965477d01df8a6de99ec5755e2829 /gcc | |
parent | 20f9202d81c1a89a0cb65a6ef260101a8ee8822b (diff) | |
download | gcc-e8408f251a70640dcc208877ef3122efd5b7e824.zip gcc-e8408f251a70640dcc208877ef3122efd5b7e824.tar.gz gcc-e8408f251a70640dcc208877ef3122efd5b7e824.tar.bz2 |
cpplex.c (_cpp_lex_token): Don't warn about directives in macro arguments when looking for the '('.
* cpplex.c (_cpp_lex_token): Don't warn about directives in
macro arguments when looking for the '('.
* cppmacro.c (funlike_invocation_p): Set parsing_args to
2 when really parsing arguments; 1 when looking for '('.
Always restore the lexer position.
* gcc.dg/cpp/cppmacro7.c: New test.
From-SVN: r40223
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 8 | ||||
-rw-r--r-- | gcc/cpplex.c | 60 | ||||
-rw-r--r-- | gcc/cppmacro.c | 8 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/cpp/macro7.c | 10 |
5 files changed, 56 insertions, 34 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index a4f7d64..322d241 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,13 @@ 2001-03-03 Neil Booth <neil@daikokuya.demon.co.uk> + * cpplex.c (_cpp_lex_token): Don't warn about directives in + macro arguments when looking for the '('. + * cppmacro.c (funlike_invocation_p): Set parsing_args to + 2 when really parsing arguments; 1 when looking for '('. + Always restore the lexer position. + +2001-03-03 Neil Booth <neil@daikokuya.demon.co.uk> + * longlong.h (umul_ppmm): Don't use a multiline string. 2001-03-03 John David Anglin <dave@hiauly1.hia.nrc.ca> diff --git a/gcc/cpplex.c b/gcc/cpplex.c index 939951a..bd96303 100644 --- a/gcc/cpplex.c +++ b/gcc/cpplex.c @@ -1171,38 +1171,36 @@ _cpp_lex_token (pfile, result) result->type = CPP_HASH; do_hash: - if (bol) + if (!bol) + break; + /* 6.10.3 paragraph 11: If there are sequences of preprocessing + tokens within the list of arguments that would otherwise act + as preprocessing directives, the behavior is undefined. + + This implementation will report a hard error, terminate the + macro invocation, and proceed to process the directive. */ + if (pfile->state.parsing_args) { - if (pfile->state.parsing_args) - { - /* 6.10.3 paragraph 11: If there are sequences of - preprocessing tokens within the list of arguments that - would otherwise act as preprocessing directives, the - behavior is undefined. - - This implementation will report a hard error, terminate - the macro invocation, and proceed to process the - directive. */ - cpp_error (pfile, - "directives may not be used inside a macro argument"); - - /* Put a '#' in lookahead, return CPP_EOF for parse_arg. */ - buffer->extra_char = buffer->read_ahead; - buffer->read_ahead = '#'; - pfile->state.next_bol = 1; - result->type = CPP_EOF; - - /* Get whitespace right - newline_in_args sets it. */ - if (pfile->lexer_pos.col == 1) - result->flags &= ~(PREV_WHITE | AVOID_LPASTE); - } - else - { - /* This is the hash introducing a directive. */ - if (_cpp_handle_directive (pfile, result->flags & PREV_WHITE)) - goto done_directive; /* bol still 1. */ - /* This is in fact an assembler #. */ - } + if (pfile->state.parsing_args == 2) + cpp_error (pfile, + "directives may not be used inside a macro argument"); + + /* Put a '#' in lookahead, return CPP_EOF for parse_arg. */ + buffer->extra_char = buffer->read_ahead; + buffer->read_ahead = '#'; + pfile->state.next_bol = 1; + result->type = CPP_EOF; + + /* Get whitespace right - newline_in_args sets it. */ + if (pfile->lexer_pos.col == 1) + result->flags &= ~(PREV_WHITE | AVOID_LPASTE); + } + else + { + /* This is the hash introducing a directive. */ + if (_cpp_handle_directive (pfile, result->flags & PREV_WHITE)) + goto done_directive; /* bol still 1. */ + /* This is in fact an assembler #. */ } break; diff --git a/gcc/cppmacro.c b/gcc/cppmacro.c index d424a41..2390ee4 100644 --- a/gcc/cppmacro.c +++ b/gcc/cppmacro.c @@ -602,6 +602,7 @@ funlike_invocation_p (pfile, node, list) cpp_start_lookahead (pfile); cpp_get_token (pfile, &maybe_paren); cpp_stop_lookahead (pfile, maybe_paren.type == CPP_OPEN_PAREN); + pfile->state.parsing_args = 2; if (maybe_paren.type == CPP_OPEN_PAREN) args = parse_args (pfile, node); @@ -615,11 +616,12 @@ funlike_invocation_p (pfile, node, list) pfile->state.prevent_expansion--; pfile->state.parsing_args = 0; + /* Reset the position in case of failure. If success, the macro's + expansion appears where the name would have. */ + pfile->lexer_pos = macro_pos; + if (args) { - /* The macro's expansion appears where the name would have. */ - pfile->lexer_pos = macro_pos; - if (node->value.macro->paramc > 0) { /* Don't save tokens during pre-expansion. */ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5718cf4..8e2e7b0 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,9 @@ 2001-03-03 Neil Booth <neil@daikokuya.demon.co.uk> + * gcc.dg/cpp/macro7.c: New test. + +2001-03-03 Neil Booth <neil@daikokuya.demon.co.uk> + * gcc.dg/cpp/multiline.c: Update. 2001-03-02 Nathan Sidwell <nathan@codesourcery.com> diff --git a/gcc/testsuite/gcc.dg/cpp/macro7.c b/gcc/testsuite/gcc.dg/cpp/macro7.c new file mode 100644 index 0000000..6f2c67c --- /dev/null +++ b/gcc/testsuite/gcc.dg/cpp/macro7.c @@ -0,0 +1,10 @@ +/* { dg-do preprocess } */ + +/* Test we don't complain about directives in macro expansions when + looking for the '(' of a function-like macro. + + Submitter: Neil Booth. 3 Mar 2000. */ + +#define f(x) x +f +#define g |