aboutsummaryrefslogtreecommitdiff
path: root/gcc/c-lex.c
diff options
context:
space:
mode:
authorNeil Booth <neil@gcc.gnu.org>2001-08-02 23:03:31 +0000
committerNeil Booth <neil@gcc.gnu.org>2001-08-02 23:03:31 +0000
commitd82fc1085fad2fd7a776bcc88dbac88f081dd10f (patch)
treeaedb0e3e4381261de71d4d7cee777f2ccde7880d /gcc/c-lex.c
parent6ff02a9579cfb21fd184f3e634c4c837732d7cb5 (diff)
downloadgcc-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.c26
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 ();