line-map.h (linenum_type): New typedef.

2008-07-21  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>

	* include/line-map.h (linenum_type): New typedef.
	(struct line_map): Use it.
	(SOURCE_LINE): Second arguments is a LOCATION not a LINE.
	(SOURCE_COLUMN): Likewise.
	* macro.c (_cpp_builtin_macro_text): Use linenum_type. Don't store
	source_location values in a variable of type linenum_type.
	* directives.c (struct if_stack): Use linenum_type.
	(strtoul_for_line): Rename as strtolinenum.
	(do_line): Use linenum_type.
	(do_linemarker): Use linenum_type and strtolinenum.
	(_cpp_do_file_change): Use linenum_t.
	* line-map.c (linemap_add): Likewise.
	(linemap_line_start): Likewise.
	* traditional.c (struct fun_macro): 'line' is a source_location.
	* errors.c (print_location): Use linenum_type.
	* directives-only.c (_cpp_preprocess_dir_only): Likewise.
	* internal.h (CPP_INCREMENT_LINE): Likewise.
	* lex.c (_cpp_skip_block_comment): Use source_location.

From-SVN: r138026
This commit is contained in:
Manuel López-Ibáñez 2008-07-21 09:33:38 +00:00
parent e24313f349
commit 1bb64668d0
10 changed files with 58 additions and 34 deletions

View File

@ -1,3 +1,24 @@
2008-07-21 Manuel Lopez-Ibanez <manu@gcc.gnu.org>
* include/line-map.h (linenum_type): New typedef.
(struct line_map): Use it.
(SOURCE_LINE): Second arguments is a LOCATION not a LINE.
(SOURCE_COLUMN): Likewise.
* macro.c (_cpp_builtin_macro_text): Use linenum_type. Don't store
source_location values in a variable of type linenum_type.
* directives.c (struct if_stack): Use linenum_type.
(strtoul_for_line): Rename as strtolinenum.
(do_line): Use linenum_type.
(do_linemarker): Use linenum_type and strtolinenum.
(_cpp_do_file_change): Use linenum_t.
* line-map.c (linemap_add): Likewise.
(linemap_line_start): Likewise.
* traditional.c (struct fun_macro): 'line' is a source_location.
* errors.c (print_location): Use linenum_type.
* directives-only.c (_cpp_preprocess_dir_only): Likewise.
* internal.h (CPP_INCREMENT_LINE): Likewise.
* lex.c (_cpp_skip_block_comment): Use source_location.
2008-07-14 Ben Elliston <bje@au.ibm.com> 2008-07-14 Ben Elliston <bje@au.ibm.com>
* include/cpplib.h (NODE_CONDITIONAL): New. * include/cpplib.h (NODE_CONDITIONAL): New.

View File

@ -42,7 +42,8 @@ _cpp_preprocess_dir_only (cpp_reader *pfile,
const unsigned char *cur, *base, *next_line, *rlimit; const unsigned char *cur, *base, *next_line, *rlimit;
cppchar_t c, last_c; cppchar_t c, last_c;
unsigned flags; unsigned flags;
int lines, col; linenum_type lines;
int col;
source_location loc; source_location loc;
restart: restart:

View File

@ -32,7 +32,7 @@ Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */
struct if_stack struct if_stack
{ {
struct if_stack *next; struct if_stack *next;
unsigned int line; /* Line where condition started. */ linenum_type line; /* Line where condition started. */
const cpp_hashnode *mi_cmacro;/* macro name for #ifndef around entire file */ const cpp_hashnode *mi_cmacro;/* macro name for #ifndef around entire file */
bool skip_elses; /* Can future #else / #elif be skipped? */ bool skip_elses; /* Can future #else / #elif be skipped? */
bool was_skipping; /* If were skipping on entry. */ bool was_skipping; /* If were skipping on entry. */
@ -102,7 +102,7 @@ static char *glue_header_name (cpp_reader *);
static const char *parse_include (cpp_reader *, int *, const cpp_token ***); static const char *parse_include (cpp_reader *, int *, const cpp_token ***);
static void push_conditional (cpp_reader *, int, int, const cpp_hashnode *); static void push_conditional (cpp_reader *, int, int, const cpp_hashnode *);
static unsigned int read_flag (cpp_reader *, unsigned int); static unsigned int read_flag (cpp_reader *, unsigned int);
static int strtoul_for_line (const uchar *, unsigned int, unsigned long *); static int strtolinenum (const uchar *, unsigned int, linenum_type *);
static void do_diagnostic (cpp_reader *, int, int); static void do_diagnostic (cpp_reader *, int, int);
static cpp_hashnode *lex_macro_node (cpp_reader *, bool); static cpp_hashnode *lex_macro_node (cpp_reader *, bool);
static int undefine_macros (cpp_reader *, cpp_hashnode *, void *); static int undefine_macros (cpp_reader *, cpp_hashnode *, void *);
@ -840,9 +840,9 @@ read_flag (cpp_reader *pfile, unsigned int last)
of length LEN, to binary; store it in NUMP, and return 0 if the of length LEN, to binary; store it in NUMP, and return 0 if the
number was well-formed, 1 if not. Temporary, hopefully. */ number was well-formed, 1 if not. Temporary, hopefully. */
static int static int
strtoul_for_line (const uchar *str, unsigned int len, long unsigned int *nump) strtolinenum (const uchar *str, unsigned int len, linenum_type *nump)
{ {
unsigned long reg = 0; linenum_type reg = 0;
uchar c; uchar c;
while (len--) while (len--)
{ {
@ -871,16 +871,16 @@ do_line (cpp_reader *pfile)
unsigned char map_sysp = map->sysp; unsigned char map_sysp = map->sysp;
const cpp_token *token; const cpp_token *token;
const char *new_file = map->to_file; const char *new_file = map->to_file;
unsigned long new_lineno; linenum_type new_lineno;
/* C99 raised the minimum limit on #line numbers. */ /* C99 raised the minimum limit on #line numbers. */
unsigned int cap = CPP_OPTION (pfile, c99) ? 2147483647 : 32767; linenum_type cap = CPP_OPTION (pfile, c99) ? 2147483647 : 32767;
/* #line commands expand macros. */ /* #line commands expand macros. */
token = cpp_get_token (pfile); token = cpp_get_token (pfile);
if (token->type != CPP_NUMBER if (token->type != CPP_NUMBER
|| strtoul_for_line (token->val.str.text, token->val.str.len, || strtolinenum (token->val.str.text, token->val.str.len,
&new_lineno)) &new_lineno))
{ {
if (token->type == CPP_EOF) if (token->type == CPP_EOF)
cpp_error (pfile, CPP_DL_ERROR, "unexpected end of file after #line"); cpp_error (pfile, CPP_DL_ERROR, "unexpected end of file after #line");
@ -925,7 +925,7 @@ do_linemarker (cpp_reader *pfile)
const struct line_map *map = &line_table->maps[line_table->used - 1]; const struct line_map *map = &line_table->maps[line_table->used - 1];
const cpp_token *token; const cpp_token *token;
const char *new_file = map->to_file; const char *new_file = map->to_file;
unsigned long new_lineno; linenum_type new_lineno;
unsigned int new_sysp = map->sysp; unsigned int new_sysp = map->sysp;
enum lc_reason reason = LC_RENAME; enum lc_reason reason = LC_RENAME;
int flag; int flag;
@ -938,8 +938,8 @@ do_linemarker (cpp_reader *pfile)
/* #line commands expand macros. */ /* #line commands expand macros. */
token = cpp_get_token (pfile); token = cpp_get_token (pfile);
if (token->type != CPP_NUMBER if (token->type != CPP_NUMBER
|| strtoul_for_line (token->val.str.text, token->val.str.len, || strtolinenum (token->val.str.text, token->val.str.len,
&new_lineno)) &new_lineno))
{ {
/* Unlike #line, there does not seem to be a way to get an EOF /* Unlike #line, there does not seem to be a way to get an EOF
here. So, it should be safe to always spell the token. */ here. So, it should be safe to always spell the token. */
@ -999,7 +999,7 @@ do_linemarker (cpp_reader *pfile)
and zero otherwise. */ and zero otherwise. */
void void
_cpp_do_file_change (cpp_reader *pfile, enum lc_reason reason, _cpp_do_file_change (cpp_reader *pfile, enum lc_reason reason,
const char *to_file, unsigned int file_line, const char *to_file, linenum_type file_line,
unsigned int sysp) unsigned int sysp)
{ {
const struct line_map *map = linemap_add (pfile->line_table, reason, sysp, const struct line_map *map = linemap_add (pfile->line_table, reason, sysp,

View File

@ -42,7 +42,7 @@ print_location (cpp_reader *pfile, source_location line, unsigned int col)
else else
{ {
const struct line_map *map; const struct line_map *map;
unsigned int lin; linenum_type lin;
map = linemap_lookup (pfile->line_table, line); map = linemap_lookup (pfile->line_table, line);
linemap_print_containing_files (pfile->line_table, map); linemap_print_containing_files (pfile->line_table, map);

View File

@ -34,6 +34,9 @@ Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
(e.g. a #line directive in C). */ (e.g. a #line directive in C). */
enum lc_reason {LC_ENTER = 0, LC_LEAVE, LC_RENAME}; enum lc_reason {LC_ENTER = 0, LC_LEAVE, LC_RENAME};
/* The type of line numbers. */
typedef unsigned int linenum_type;
/* A logical line/column number, i.e. an "index" into a line_map. */ /* A logical line/column number, i.e. an "index" into a line_map. */
/* Long-term, we want to use this to replace struct location_s (in input.h), /* Long-term, we want to use this to replace struct location_s (in input.h),
and effectively typedef source_location location_t. */ and effectively typedef source_location location_t. */
@ -57,7 +60,7 @@ typedef void *(*line_map_realloc) (void *, size_t);
struct line_map GTY(()) struct line_map GTY(())
{ {
const char *to_file; const char *to_file;
unsigned int to_line; linenum_type to_line;
source_location start_location; source_location start_location;
int included_from; int included_from;
ENUM_BITFIELD (lc_reason) reason : CHAR_BIT; ENUM_BITFIELD (lc_reason) reason : CHAR_BIT;
@ -119,7 +122,7 @@ extern void linemap_check_files_exited (struct line_maps *);
the highest_location). */ the highest_location). */
extern source_location linemap_line_start extern source_location linemap_line_start
(struct line_maps *set, unsigned int to_line, unsigned int max_column_hint); (struct line_maps *set, linenum_type to_line, unsigned int max_column_hint);
/* Add a mapping of logical source line to physical source file and /* Add a mapping of logical source line to physical source file and
line number. line number.
@ -134,7 +137,7 @@ extern source_location linemap_line_start
maps, so any stored line_map pointers should not be used. */ maps, so any stored line_map pointers should not be used. */
extern const struct line_map *linemap_add extern const struct line_map *linemap_add
(struct line_maps *, enum lc_reason, unsigned int sysp, (struct line_maps *, enum lc_reason, unsigned int sysp,
const char *to_file, unsigned int to_line); const char *to_file, linenum_type to_line);
/* Given a logical line, returns the map from which the corresponding /* Given a logical line, returns the map from which the corresponding
(source file, line) pair can be deduced. */ (source file, line) pair can be deduced. */
@ -148,11 +151,11 @@ extern void linemap_print_containing_files (struct line_maps *,
const struct line_map *); const struct line_map *);
/* Converts a map and a source_location to source line. */ /* Converts a map and a source_location to source line. */
#define SOURCE_LINE(MAP, LINE) \ #define SOURCE_LINE(MAP, LOC) \
((((LINE) - (MAP)->start_location) >> (MAP)->column_bits) + (MAP)->to_line) ((((LOC) - (MAP)->start_location) >> (MAP)->column_bits) + (MAP)->to_line)
#define SOURCE_COLUMN(MAP, LINE) \ #define SOURCE_COLUMN(MAP, LOC) \
(((LINE) - (MAP)->start_location) & ((1 << (MAP)->column_bits) - 1)) (((LOC) - (MAP)->start_location) & ((1 << (MAP)->column_bits) - 1))
/* Returns the last source line within a map. This is the (last) line /* Returns the last source line within a map. This is the (last) line
of the #include, or other directive, that caused a map change. */ of the #include, or other directive, that caused a map change. */

View File

@ -68,7 +68,7 @@ struct cset_converter
#define CPP_INCREMENT_LINE(PFILE, COLS_HINT) do { \ #define CPP_INCREMENT_LINE(PFILE, COLS_HINT) do { \
const struct line_maps *line_table = PFILE->line_table; \ const struct line_maps *line_table = PFILE->line_table; \
const struct line_map *map = &line_table->maps[line_table->used-1]; \ const struct line_map *map = &line_table->maps[line_table->used-1]; \
unsigned int line = SOURCE_LINE (map, line_table->highest_line); \ linenum_type line = SOURCE_LINE (map, line_table->highest_line); \
linemap_line_start (PFILE->line_table, line + 1, COLS_HINT); \ linemap_line_start (PFILE->line_table, line + 1, COLS_HINT); \
} while (0) } while (0)
@ -585,7 +585,7 @@ extern int _cpp_do__Pragma (cpp_reader *);
extern void _cpp_init_directives (cpp_reader *); extern void _cpp_init_directives (cpp_reader *);
extern void _cpp_init_internal_pragmas (cpp_reader *); extern void _cpp_init_internal_pragmas (cpp_reader *);
extern void _cpp_do_file_change (cpp_reader *, enum lc_reason, const char *, extern void _cpp_do_file_change (cpp_reader *, enum lc_reason, const char *,
unsigned int, unsigned int); linenum_type, unsigned int);
extern void _cpp_pop_buffer (cpp_reader *); extern void _cpp_pop_buffer (cpp_reader *);
/* In directives.c */ /* In directives.c */

View File

@ -384,7 +384,7 @@ static int
skip_line_comment (cpp_reader *pfile) skip_line_comment (cpp_reader *pfile)
{ {
cpp_buffer *buffer = pfile->buffer; cpp_buffer *buffer = pfile->buffer;
unsigned int orig_line = pfile->line_table->highest_line; source_location orig_line = pfile->line_table->highest_line;
while (*buffer->cur != '\n') while (*buffer->cur != '\n')
buffer->cur++; buffer->cur++;

View File

@ -85,7 +85,7 @@ linemap_free (struct line_maps *set)
const struct line_map * const struct line_map *
linemap_add (struct line_maps *set, enum lc_reason reason, linemap_add (struct line_maps *set, enum lc_reason reason,
unsigned int sysp, const char *to_file, unsigned int to_line) unsigned int sysp, const char *to_file, linenum_type to_line)
{ {
struct line_map *map; struct line_map *map;
source_location start_location = set->highest_location + 1; source_location start_location = set->highest_location + 1;
@ -182,13 +182,13 @@ linemap_add (struct line_maps *set, enum lc_reason reason,
} }
source_location source_location
linemap_line_start (struct line_maps *set, unsigned int to_line, linemap_line_start (struct line_maps *set, linenum_type to_line,
unsigned int max_column_hint) unsigned int max_column_hint)
{ {
struct line_map *map = &set->maps[set->used - 1]; struct line_map *map = &set->maps[set->used - 1];
source_location highest = set->highest_location; source_location highest = set->highest_location;
source_location r; source_location r;
unsigned int last_line = SOURCE_LINE (map, set->highest_line); linenum_type last_line = SOURCE_LINE (map, set->highest_line);
int line_delta = to_line - last_line; int line_delta = to_line - last_line;
bool add_map = false; bool add_map = false;
if (line_delta < 0 if (line_delta < 0

View File

@ -118,7 +118,7 @@ _cpp_builtin_macro_text (cpp_reader *pfile, cpp_hashnode *node)
{ {
const struct line_map *map; const struct line_map *map;
const uchar *result = NULL; const uchar *result = NULL;
unsigned int number = 1; linenum_type number = 1;
switch (node->value.builtin) switch (node->value.builtin)
{ {
@ -200,11 +200,10 @@ _cpp_builtin_macro_text (cpp_reader *pfile, cpp_hashnode *node)
/* If __LINE__ is embedded in a macro, it must expand to the /* If __LINE__ is embedded in a macro, it must expand to the
line of the macro's invocation, not its definition. line of the macro's invocation, not its definition.
Otherwise things like assert() will not work properly. */ Otherwise things like assert() will not work properly. */
if (CPP_OPTION (pfile, traditional)) number = SOURCE_LINE (map,
number = pfile->line_table->highest_line; CPP_OPTION (pfile, traditional)
else ? pfile->line_table->highest_line
number = pfile->cur_token[-1].src_loc; : pfile->cur_token[-1].src_loc);
number = SOURCE_LINE (map, number);
break; break;
/* __STDC__ has the value 1 under normal circumstances. /* __STDC__ has the value 1 under normal circumstances.

View File

@ -60,7 +60,7 @@ struct fun_macro
size_t offset; size_t offset;
/* The line the macro name appeared on. */ /* The line the macro name appeared on. */
unsigned int line; source_location line;
/* Zero-based index of argument being currently lexed. */ /* Zero-based index of argument being currently lexed. */
unsigned int argc; unsigned int argc;