Commit e8408f25 by Neil Booth Committed by Neil Booth

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
parent 20f9202d
2001-03-03 Neil Booth <neil@daikokuya.demon.co.uk> 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. * longlong.h (umul_ppmm): Don't use a multiline string.
2001-03-03 John David Anglin <dave@hiauly1.hia.nrc.ca> 2001-03-03 John David Anglin <dave@hiauly1.hia.nrc.ca>
......
...@@ -1171,38 +1171,36 @@ _cpp_lex_token (pfile, result) ...@@ -1171,38 +1171,36 @@ _cpp_lex_token (pfile, result)
result->type = CPP_HASH; result->type = CPP_HASH;
do_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) if (pfile->state.parsing_args == 2)
{ cpp_error (pfile,
/* 6.10.3 paragraph 11: If there are sequences of "directives may not be used inside a macro argument");
preprocessing tokens within the list of arguments that
would otherwise act as preprocessing directives, the /* Put a '#' in lookahead, return CPP_EOF for parse_arg. */
behavior is undefined. buffer->extra_char = buffer->read_ahead;
buffer->read_ahead = '#';
This implementation will report a hard error, terminate pfile->state.next_bol = 1;
the macro invocation, and proceed to process the result->type = CPP_EOF;
directive. */
cpp_error (pfile, /* Get whitespace right - newline_in_args sets it. */
"directives may not be used inside a macro argument"); if (pfile->lexer_pos.col == 1)
result->flags &= ~(PREV_WHITE | AVOID_LPASTE);
/* Put a '#' in lookahead, return CPP_EOF for parse_arg. */ }
buffer->extra_char = buffer->read_ahead; else
buffer->read_ahead = '#'; {
pfile->state.next_bol = 1; /* This is the hash introducing a directive. */
result->type = CPP_EOF; if (_cpp_handle_directive (pfile, result->flags & PREV_WHITE))
goto done_directive; /* bol still 1. */
/* Get whitespace right - newline_in_args sets it. */ /* This is in fact an assembler #. */
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; break;
......
...@@ -602,6 +602,7 @@ funlike_invocation_p (pfile, node, list) ...@@ -602,6 +602,7 @@ funlike_invocation_p (pfile, node, list)
cpp_start_lookahead (pfile); cpp_start_lookahead (pfile);
cpp_get_token (pfile, &maybe_paren); cpp_get_token (pfile, &maybe_paren);
cpp_stop_lookahead (pfile, maybe_paren.type == CPP_OPEN_PAREN); cpp_stop_lookahead (pfile, maybe_paren.type == CPP_OPEN_PAREN);
pfile->state.parsing_args = 2;
if (maybe_paren.type == CPP_OPEN_PAREN) if (maybe_paren.type == CPP_OPEN_PAREN)
args = parse_args (pfile, node); args = parse_args (pfile, node);
...@@ -615,11 +616,12 @@ funlike_invocation_p (pfile, node, list) ...@@ -615,11 +616,12 @@ funlike_invocation_p (pfile, node, list)
pfile->state.prevent_expansion--; pfile->state.prevent_expansion--;
pfile->state.parsing_args = 0; 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) if (args)
{ {
/* The macro's expansion appears where the name would have. */
pfile->lexer_pos = macro_pos;
if (node->value.macro->paramc > 0) if (node->value.macro->paramc > 0)
{ {
/* Don't save tokens during pre-expansion. */ /* Don't save tokens during pre-expansion. */
......
2001-03-03 Neil Booth <neil@daikokuya.demon.co.uk> 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. * gcc.dg/cpp/multiline.c: Update.
2001-03-02 Nathan Sidwell <nathan@codesourcery.com> 2001-03-02 Nathan Sidwell <nathan@codesourcery.com>
......
/* { 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
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment