diff options
author | Akim Demaille <akim@epita.fr> | 2002-06-14 17:35:45 +0000 |
---|---|---|
committer | Akim Demaille <akim@epita.fr> | 2002-06-14 17:35:45 +0000 |
commit | 0c15323de7250aea9aaef638dd7390cf24ad9ce8 (patch) | |
tree | 26d682cd521f8d25d0c73d2fcc08010d10dad587 /src/reader.h | |
parent | e96c9728dacee1d130874c7f521ee8cbea921eea (diff) | |
download | bison-0c15323de7250aea9aaef638dd7390cf24ad9ce8.tar.gz |
* src/location.h: New, extracted from...
* src/reader.h: here.
* src/Makefile.am (noinst_HEADERS): Merge into
(bison_SOURCES): this.
Add location.h.
* src/parse-gram.y: Use location_t instead of Bison's.
* src/reader.h, src/reader.c (prologue_augment, epilogue_set):
Use location_t instead of ints.
Diffstat (limited to 'src/reader.h')
-rw-r--r-- | src/reader.h | 40 |
1 files changed, 4 insertions, 36 deletions
diff --git a/src/reader.h b/src/reader.h index 0115f8a5..d35dd051 100644 --- a/src/reader.h +++ b/src/reader.h @@ -21,6 +21,8 @@ #ifndef READER_H_ # define READER_H_ +# include "location.h" + typedef struct symbol_list { struct symbol_list *next; @@ -36,40 +38,6 @@ typedef struct symbol_list # include "parse-gram.h" -typedef int location_t; - -/* Initialize LOC. */ -# define LOCATION_RESET(Loc) \ - (Loc).first_column = (Loc).first_line = 1; \ - (Loc).last_column = (Loc).last_line = 1; - -/* Advance of NUM columns. */ -# define LOCATION_COLUMNS(Loc, Num) \ - (Loc).last_column += Num; - -/* Advance of NUM lines. */ -# define LOCATION_LINES(Loc, Num) \ - (Loc).last_column = 1; \ - (Loc).last_line += Num; - -/* Restart: move the first cursor to the last position. */ -# define LOCATION_STEP(Loc) \ - (Loc).first_column = (Loc).last_column; \ - (Loc).first_line = (Loc).last_line; - -/* Output LOC on the stream OUT. */ -# define LOCATION_PRINT(Out, Loc) \ - fprintf (stderr, "%s:", infile); \ - if ((Loc).first_line != (Loc).last_line) \ - fprintf (Out, "%d.%d-%d.%d", \ - (Loc).first_line, (Loc).first_column, \ - (Loc).last_line, (Loc).last_column - 1); \ - else if ((Loc).first_column < (Loc).last_column - 1) \ - fprintf (Out, "%d.%d-%d", (Loc).first_line, \ - (Loc).first_column, (Loc).last_column - 1); \ - else \ - fprintf (Out, "%d.%d", (Loc).first_line, (Loc).first_column) - typedef struct gram_control_s { int errcode; @@ -83,7 +51,7 @@ void scanner_initialize PARAMS ((void)); void scanner_free PARAMS ((void)); # define YY_DECL \ - int gram_lex (yystype *yylval, yyltype *yylloc, \ + int gram_lex (yystype *yylval, location_t *yylloc, \ gram_control_t *yycontrol) YY_DECL; @@ -91,7 +59,7 @@ YY_DECL; /* From the parser. */ extern int gram_debug; void gram_error (gram_control_t *control, - yyltype *loc, const char *msg); + location_t *loc, const char *msg); int gram_parse (void *control); char *get_type_name PARAMS ((int n, symbol_list *rule)); |