c++: display locations as C does

See commit 3804aa260b.

* data/location.cc (operator<<): Display location exactly as is
done in C skeletons.
* tests/local.at (AT_LOC_PUSHDEF, AT_LOC_POPDEF): Also define
AT_FIRST_LINE, AT_LAST_LINE, AT_FIRST_COLUMN, AT_LAST_COLUMN.
* tests/actions.at (Location Print): Also check C++ skeletons.
This commit is contained in:
Akim Demaille
2013-01-25 14:14:01 +01:00
parent c7442984e3
commit aedcb6c095
3 changed files with 36 additions and 23 deletions

View File

@@ -253,16 +253,17 @@ m4_define([b4_location_define],
inline std::basic_ostream<YYChar>& inline std::basic_ostream<YYChar>&
operator<< (std::basic_ostream<YYChar>& ostr, const location& loc) operator<< (std::basic_ostream<YYChar>& ostr, const location& loc)
{ {
position last = loc.end - 1; unsigned int end_col = 0 < loc.end.column ? loc.end.column - 1 : 0;
ostr << loc.begin; ostr << loc.begin// << "(" << loc.end << ") "
if (last.filename ;
if (loc.end.filename
&& (!loc.begin.filename && (!loc.begin.filename
|| *loc.begin.filename != *last.filename)) || *loc.begin.filename != *loc.end.filename))
ostr << '-' << last; ostr << '-' << loc.end.filename << ':' << loc.end.line << '.' << end_col;
else if (loc.begin.line != last.line) else if (loc.begin.line < loc.end.line)
ostr << '-' << last.line << '.' << last.column; ostr << '-' << loc.end.line << '.' << end_col;
else if (loc.begin.column != last.column) else if (loc.begin.column < end_col)
ostr << '-' << last.column; ostr << '-' << end_col;
return ostr; return ostr;
} }
]]) ]])

View File

@@ -204,12 +204,15 @@ exp: /* empty */;
int int
main (void) main (void)
{ {
]AT_YYLTYPE[ loc;
]AT_GLR_CC_IF([loc.initialize();])[
#define TEST(L1, C1, L2, C2) \ #define TEST(L1, C1, L2, C2) \
]AT_LOC_FIRST_LINE[ = L1; \ loc.]AT_FIRST_LINE[ = L1; \
]AT_LOC_FIRST_COLUMN[ = C1; \ loc.]AT_FIRST_COLUMN[ = C1; \
]AT_LOC_LAST_LINE[ = L2; \ loc.]AT_LAST_LINE[ = L2; \
]AT_LOC_LAST_COLUMN[ = C2; \ loc.]AT_LAST_COLUMN[ = C2; \
]YY_LOCATION_PRINT(stdout, AT_LOC)[;\ ]AT_SKEL_CC_IF([std::cout << loc],
[YY_LOCATION_PRINT(stdout, loc)])[;\
putchar ('\n'); putchar ('\n');
TEST(1, 1, 1, 1); TEST(1, 1, 1, 1);
@@ -239,8 +242,8 @@ AT_CLEANUP
## FIXME: test Java, and iterate over skeletons. ## FIXME: test Java, and iterate over skeletons.
AT_TEST([yacc.c]) AT_TEST([yacc.c])
AT_TEST([glr.c]) AT_TEST([glr.c])
#AT_TEST([lalr1.cc]) AT_TEST([lalr1.cc])
#AT_TEST([glr.cc]) AT_TEST([glr.cc])
m4_popdef([AT_TEST]) m4_popdef([AT_TEST])

View File

@@ -94,21 +94,30 @@ m4_define([AT_RESTORE_SPECIAL_FILES], [at_restore_special_files])
# AT_LOC_PUSHDEF(FIRST-LINE, FIRST-COLUMN, LAST-LINE, LAST-COLUMN) # AT_LOC_PUSHDEF(FIRST-LINE, FIRST-COLUMN, LAST-LINE, LAST-COLUMN)
# ---------------------------------------------------------------- # ----------------------------------------------------------------
# Pushdef AT_LOC_(FIRST|LAST)_(LINE|COLUMN). # Pushdef AT(_LOC)?_(FIRST|LAST)_(LINE|COLUMN).
m4_define([AT_LOC_PUSHDEF], m4_define([AT_LOC_PUSHDEF],
[m4_pushdef([AT_LOC_FIRST_LINE], [AT_LOC.$1]) [m4_pushdef([AT_FIRST_LINE], [$1])
m4_pushdef([AT_LOC_FIRST_COLUMN], [AT_LOC.$2]) m4_pushdef([AT_FIRST_COLUMN], [$2])
m4_pushdef([AT_LOC_LAST_LINE], [AT_LOC.$3]) m4_pushdef([AT_LAST_LINE], [$3])
m4_pushdef([AT_LOC_LAST_COLUMN], [AT_LOC.$4])]) m4_pushdef([AT_LAST_COLUMN], [$4])
m4_pushdef([AT_LOC_FIRST_LINE], [AT_LOC.AT_FIRST_LINE])
m4_pushdef([AT_LOC_FIRST_COLUMN], [AT_LOC.AT_FIRST_COLUMN])
m4_pushdef([AT_LOC_LAST_LINE], [AT_LOC.AT_LAST_LINE])
m4_pushdef([AT_LOC_LAST_COLUMN], [AT_LOC.AT_LAST_COLUMN])])
# AT_LOC_POPDEF # AT_LOC_POPDEF
# ------------- # -------------
# Popdef AT_LOC_(FIRST|LAST)_(LINE|COL). # Popdef AT(_LOC)?_(FIRST|LAST)_(LINE|COLUMN).
m4_define([AT_LOC_POPDEF], m4_define([AT_LOC_POPDEF],
[m4_popdef([AT_LOC_FIRST_LINE]) [m4_popdef([AT_LOC_FIRST_LINE])
m4_popdef([AT_LOC_FIRST_COLUMN]) m4_popdef([AT_LOC_FIRST_COLUMN])
m4_popdef([AT_LOC_LAST_LINE]) m4_popdef([AT_LOC_LAST_LINE])
m4_popdef([AT_LOC_LAST_COLUMN])]) m4_popdef([AT_LOC_LAST_COLUMN])
m4_popdef([AT_FIRST_LINE])
m4_popdef([AT_FIRST_COLUMN])
m4_popdef([AT_LAST_LINE])
m4_popdef([AT_LAST_COLUMN])
])