diff options
author | Neil Booth <neil@gcc.gnu.org> | 2001-08-02 23:03:31 +0000 |
---|---|---|
committer | Neil Booth <neil@gcc.gnu.org> | 2001-08-02 23:03:31 +0000 |
commit | d82fc1085fad2fd7a776bcc88dbac88f081dd10f (patch) | |
tree | aedb0e3e4381261de71d4d7cee777f2ccde7880d /gcc/c-lex.c | |
parent | 6ff02a9579cfb21fd184f3e634c4c837732d7cb5 (diff) | |
download | gcc-d82fc1085fad2fd7a776bcc88dbac88f081dd10f.zip gcc-d82fc1085fad2fd7a776bcc88dbac88f081dd10f.tar.gz gcc-d82fc1085fad2fd7a776bcc88dbac88f081dd10f.tar.bz2 |
line-map.c: New.
* line-map.c: New.
* line-map.h: New.
* Makefile.in (line-map.o): New.
(LIBCPP_OBJS, LIBCPP_DEPS): Update.
* c-lex.c (cb_file_change): Update for new cpp_file_change structure.
* cpperror.c (print_containing_files): Similarly.
(print_location): Update. Don't output a space before _Pragma.
* cppfiles.c (stack_include_file): Set to line 1 immediately.
(stack_include_filee, cpp_make_system_header): Update.
(_cpp_execute_include): Get logical line number right for calling
as-yet-unterminated #include.
* cpphash.h (struct cpp_reader): Add line_maps.
(_cpp_do_file_change): Update.
* cppinit.c (cpp_create_reader): Initialize line maps.
(cpp_destroy): Destroy line maps.
(cpp_start_read): Get logical line number right.
* cpplex.c (parse_string): Only warn once for multi-line strings.
Use boolean variable for null warning.
* cpplib.c (_cpp_handle_directive): End the directive if it isn't
already.
(do_include_common): End the directive early.
(do_line): Don't warn about out-of-range lines in preprocessed
source. Update. Remove unused variables.
(_cpp_do_file_change): Update for new line mapping.
(pragma_cb): New typedef.
(cpp_register_pragma): Stop looking ahead before calling the
handler. Clean up.
(do_pragma_system_header): End directive early.
(cpp_get_line_maps): New.
(cpp_pop_buffer): Fudge logical line. Update.
* cpplib.h: Include line-map.h
(enum cpp_fc_reason): Remove.
(struct cpp_file_change): Update.
(cpp_get_line_maps): New.
* cppmain.c (struct_printer): New member map.
(cb_file_change): Update for new mappings.
* fix-header.c (cb_file_change): Similarly.
testsuite:
* gcc.dg/cpp/19951025-1.c: Update.
From-SVN: r44584
Diffstat (limited to 'gcc/c-lex.c')
-rw-r--r-- | gcc/c-lex.c | 26 |
1 files changed, 14 insertions, 12 deletions
diff --git a/gcc/c-lex.c b/gcc/c-lex.c index cf958f5..ffd3b74 100644 --- a/gcc/c-lex.c +++ b/gcc/c-lex.c @@ -241,16 +241,20 @@ cb_file_change (pfile, fc) cpp_reader *pfile ATTRIBUTE_UNUSED; const cpp_file_change *fc; { - if (fc->reason == FC_ENTER) + unsigned int from_line = SOURCE_LINE (fc->map - 1, fc->line - 1); + + if (fc->reason == LC_ENTER) { /* Don't stack the main buffer on the input stack; we already did in compile_file. */ - if (fc->from.filename) + if (MAIN_FILE_P (fc->map)) + main_input_filename = fc->map->to_file; + else { - lineno = fc->from.lineno; - push_srcloc (fc->to.filename, 1); + lineno = from_line; + push_srcloc (fc->map->to_file, 1); input_file_stack->indent_level = indent_level; - (*debug_hooks->start_source_file) (fc->from.lineno, fc->to.filename); + (*debug_hooks->start_source_file) (lineno, fc->map->to_file); #ifndef NO_IMPLICIT_EXTERN_C if (c_header_level) ++c_header_level; @@ -261,10 +265,8 @@ cb_file_change (pfile, fc) } #endif } - else - main_input_filename = fc->to.filename; } - else if (fc->reason == FC_LEAVE) + else if (fc->reason == LC_LEAVE) { /* Popping out of a file. */ if (input_file_stack->next) @@ -288,16 +290,16 @@ cb_file_change (pfile, fc) } #endif pop_srcloc (); - (*debug_hooks->end_source_file) (input_file_stack->line); + (*debug_hooks->end_source_file) (from_line); } else error ("leaving more files than we entered"); } - update_header_times (fc->to.filename); + update_header_times (fc->map->to_file); in_system_header = fc->sysp != 0; - input_filename = fc->to.filename; - lineno = fc->to.lineno; /* Do we need this? */ + input_filename = fc->map->to_file; + lineno = SOURCE_LINE (fc->map, fc->line); /* Do we need this? */ /* Hook for C++. */ extract_interface_info (); |