summaryrefslogtreecommitdiff
path: root/src/reader.h
diff options
context:
space:
mode:
authorAkim Demaille <akim@epita.fr>2002-06-14 17:35:45 +0000
committerAkim Demaille <akim@epita.fr>2002-06-14 17:35:45 +0000
commit0c15323de7250aea9aaef638dd7390cf24ad9ce8 (patch)
tree26d682cd521f8d25d0c73d2fcc08010d10dad587 /src/reader.h
parente96c9728dacee1d130874c7f521ee8cbea921eea (diff)
downloadbison-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.h40
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));