From 96b881094b114685413c63774117e5186627263a Mon Sep 17 00:00:00 2001 From: Akim Demaille Date: Sun, 31 Jan 2021 21:28:58 +0100 Subject: examples: do not rely on YY_LOCATION_PRINT * examples/c/bistromathic/parse.y (location_print): New. Use it. --- examples/c/bistromathic/parse.y | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) (limited to 'examples') diff --git a/examples/c/bistromathic/parse.y b/examples/c/bistromathic/parse.y index b772f1ba..ad025e66 100644 --- a/examples/c/bistromathic/parse.y +++ b/examples/c/bistromathic/parse.y @@ -94,6 +94,10 @@ // Emitted in the implementation file. %code { + // Print *LOC on OUT. + static void location_print (FILE *out, YYLTYPE const * const loc); + #define YY_LOCATION_PRINT(Out, Loc) location_print(Out, &(Loc)) + #if defined ENABLE_NLS && ENABLE_NLS # define _(Msgid) gettext (Msgid) #else @@ -269,6 +273,26 @@ symbol_count (void) } + +/*------------. +| Locations. | +`------------*/ + +// Print *LOC on OUT. Do it in a compact way, that avoids redundancy. + +static void +location_print (FILE *out, YYLTYPE const * const loc) +{ + fprintf (out, "%d.%d", loc->first_line, loc->first_column); + + int end_col = 0 != loc->last_column ? loc->last_column - 1 : 0; + if (loc->first_line < loc->last_line) + fprintf (out, "-%d.%d", loc->last_line, end_col); + else if (loc->first_column < end_col) + fprintf (out, "-%d", end_col); +} + + /*----------. | Scanner. | `----------*/ -- cgit v1.2.1