diff options
author | neil <neil@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-09-13 20:05:17 +0000 |
---|---|---|
committer | neil <neil@138bc75d-0d04-0410-961f-82ee72b054a4> | 2001-09-13 20:05:17 +0000 |
commit | fb5ab82cb71f664b698bdae5cb881bd2cdbb8f04 (patch) | |
tree | f67a034f6447649165fb6297431354b49c7620fc /gcc/c-parse.in | |
parent | 0d95286fa914943fefb3e1a64ad2b8e7c8df1acb (diff) | |
download | gcc-fb5ab82cb71f664b698bdae5cb881bd2cdbb8f04.tar.gz |
* c-parse.in (_yylex): Use _cpp_backup_tokens.
* cpphash.h (struct tokenrun): Add prev.
(struct lexer_state): Remove bol.
(struct cpp_reader): Remove old lookahead stuff, add lookaheads.
(_cpp_free_lookaheads, _cpp_release_lookahead, _cpp_push_token)
: Remove.
* cppinit.c (cpp_create_reader): Don't set bol.
(cpp_destroy): Don't free lookaheads.
* cpplex.c (lex_directive): Remove.
(next_tokenrun): Update.
(_cpp_lex_token): Clean up logic.
(lex_token): Update to return a pointer to lexed token, since it
can move to the start of the buffer. Simpify newline handling.
* cpplib.c (SEEN_EOL): Update.
(skip_rest_of_line): Remove lookahead stuff.
(end_directive): Line numbers are already incremented. Revert
to start of lexed token buffer if we can.
(_cpp_handle_directive, do_pragma, do_pragma_dependency,
parse_answer): Use _cpp_backup_tokens.
(run_directive, cpp_pop_buffer): Don't set bol, set saved_flags
instead. Don't check for EOL.
(do_include_common, do_line, do_pragma_system_header): Use
skip_rest_of_line.
* cpplib.h (BOL, _cpp_backup_tokens): New.
* cppmacro.c (save_lookahead_token, take_lookahead_token,
alloc_lookahead, free_lookahead, _cpp_free_lookaheads,
cpp_start_lookahead, cpp_stop_lookahead, _cpp_push_token): Remove.
(builtin_macro): Don't use cpp_get_line.
(cpp_get_line): Short term kludge.
(parse_arg): Handle directives in arguments here. Back up when
appropriate. Store EOF at end of argument list.
(funlike_invocation_p): Use _cpp_backup_tokens.
(push_arg_context): Account for EOF at end of list.
(cpp_get_token): Remove lookahead stuff. Update.
* gcc.dg/cpp/directiv.c: Update.
* gcc.dg/cpp/undef1.c: Update.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@45582 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/c-parse.in')
-rw-r--r-- | gcc/c-parse.in | 4 |
1 files changed, 1 insertions, 3 deletions
diff --git a/gcc/c-parse.in b/gcc/c-parse.in index b8871c5952e..0d76c3e5966 100644 --- a/gcc/c-parse.in +++ b/gcc/c-parse.in @@ -3788,19 +3788,17 @@ ifobjc tree after_at; enum cpp_ttype after_at_type; - cpp_start_lookahead (parse_in); after_at_type = c_lex (&after_at); if (after_at_type == CPP_NAME && C_IS_RESERVED_WORD (after_at) && OBJC_IS_AT_KEYWORD (C_RID_CODE (after_at))) { - cpp_stop_lookahead (parse_in, 1); /* accept this token */ yylval.ttype = after_at; last_token = after_at_type; return rid_to_yy [(int) C_RID_CODE (after_at)]; } - cpp_stop_lookahead (parse_in, 0); /* put back this token */ + _cpp_backup_tokens (parse_in, 1); return '@'; } end ifobjc |