From 4c97482494e6170733f4b2143199cff3abec5419 Mon Sep 17 00:00:00 2001 From: Kaz Kylheku Date: Tue, 14 Apr 2015 20:47:59 -0700 Subject: Diagnose trailing junk in numeric literals. * parser.l: Combining the handling of hex, octal and binary numeric literals into a single rule. Implementing an additional rule which diagnoses such tokens that have trailing junk. Thus, something like #x1F2AZ is now invalid syntax. --- parser.l | 33 +++++++++++++++++++-------------- 1 file changed, 19 insertions(+), 14 deletions(-) (limited to 'parser.l') diff --git a/parser.l b/parser.l index dc163ac0..9121de12 100644 --- a/parser.l +++ b/parser.l @@ -225,39 +225,44 @@ UONLY {U2}{U}|{U3}{U}{U}|{U4}{U}{U}{U} return NUMBER; } -{XNUM} { +({XNUM}|{ONUM}|{BNUM}) { val str = string_own(utf8_dup_from(yytext + 2)); + int base; + + switch (yytext[1]) { + case 'x': base = 16; break; + case 'o': base = 8; break; + case 'b': default: base = 2; break; + } if (yy_top_state(yyscanner) == INITIAL || yy_top_state(yyscanner) == QSILIT || yy_top_state(yyscanner) == QWLIT) yy_pop_state(yyscanner); - yylval->val = int_str(str, num(16)); + yylval->val = int_str(str, num_fast(base)); return NUMBER; } -{ONUM} { +({BNUM}|{ONUM}|{XNUM}){TOK} { + int base = 0; val str = string_own(utf8_dup_from(yytext + 2)); - if (yy_top_state(yyscanner) == INITIAL - || yy_top_state(yyscanner) == QSILIT - || yy_top_state(yyscanner) == QWLIT) - yy_pop_state(yyscanner); - - yylval->val = int_str(str, num(8)); - return NUMBER; -} + switch (yytext[1]) { + case 'x': base = 16; break; + case 'o': base = 8; break; + case 'b': default: base = 2; break; + } -{BNUM} { - val str = string_own(utf8_dup_from(yytext + 2)); + yyerrorf(yyg, lit("trailing junk in numeric literal: ~a~a~a"), + chr(yytext[0]), chr(yytext[1]), str, nao); if (yy_top_state(yyscanner) == INITIAL || yy_top_state(yyscanner) == QSILIT || yy_top_state(yyscanner) == QWLIT) yy_pop_state(yyscanner); - yylval->val = int_str(str, num(2)); + yylval->val = int_str(str, num_fast(base)); return NUMBER; } -- cgit v1.2.3