summaryrefslogtreecommitdiffstats
path: root/parser.y
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2014-10-14 08:13:31 -0700
committerKaz Kylheku <kaz@kylheku.com>2014-10-14 08:13:31 -0700
commit68e4d78cf9f153871d9a3c07c8ce3e43eb517c3b (patch)
tree69b3947cb8bd09b49cb3015af70fc9034efadd6d /parser.y
parent851ffd5c85901f1609742c162e2f992099e4b848 (diff)
downloadtxr-68e4d78cf9f153871d9a3c07c8ce3e43eb517c3b.tar.gz
txr-68e4d78cf9f153871d9a3c07c8ce3e43eb517c3b.tar.bz2
txr-68e4d78cf9f153871d9a3c07c8ce3e43eb517c3b.zip
C++ upkeep.
TXR's support for compiling as C++ pays off: C++ compiler finds serious bugs introduced in August 2 ("Big switch to reentrant lexing and parsing"). The yyerror function was being misused; some of the calls reversed the scanner and parser arguments. Since one of the two parameters is void *, this reversal wasn't caught. * parser.l (yyerror): Fix first two arguments being reversed. (num_esc): Change previously correct call to yyerror to follow reversed arguments, so that it stays correct. * parser.y (%parse-param): Change order of these directives so that the scnr parameter is before the parser parameter. This causes the yacc-generated calls to yyerror to have the arguments in the correct order. It also has the effect of changing the signature of yyparse, reversing its parameters. (parse): Update call to yyparse to new argument order. * parser.h (yyparse): Declaration removed. (yyerror): Declaration updated. * regex.c (regex_kind_t): New enum typedef. (struct regex): Use regex_kind_t rather than an enum inside the struct, which has different scoping rules under C++. * txr.c (get_self_path): Fix signed/unsigned warning.
Diffstat (limited to 'parser.y')
-rw-r--r--parser.y4
1 files changed, 2 insertions, 2 deletions
diff --git a/parser.y b/parser.y
index d9b4f241..00bb15cf 100644
--- a/parser.y
+++ b/parser.y
@@ -72,8 +72,8 @@ int yylex(union YYSTYPE *, void *scanner);
%}
%pure-parser
-%parse-param{parser_t *parser}
%parse-param{void *scnr}
+%parse-param{parser_t *parser}
%lex-param{void *scnr}
%union {
@@ -1365,7 +1365,7 @@ int parse(val stream, val name, parser_t *parser)
yyset_extra(parser, parser->scanner);
- res = yyparse(parser, parser->scanner);
+ res = yyparse(parser->scanner, parser);
yylex_destroy(parser->scanner);