forked from github/verilator
Fix parsing #1_2 delays
This commit is contained in:
parent
45690faea7
commit
36da6a3563
@ -913,7 +913,10 @@ vnum {vnum1}|{vnum2}|{vnum3}|{vnum4}|{vnum5}
|
||||
/* "# 1'b0" is a delay value so must lex as "#" "1" "'b0" */
|
||||
if (PARSEP->lexPrevToken()=='#') {
|
||||
int shortlen = 0;
|
||||
while (std::isdigit(yytext[shortlen])) ++shortlen;
|
||||
if (std::isdigit(yytext[shortlen])) {
|
||||
while (std::isdigit(yytext[shortlen])
|
||||
|| yytext[shortlen]=='_') ++shortlen;
|
||||
}
|
||||
if (shortlen) {
|
||||
// Push rest past numbers for later parse
|
||||
PARSEP->lexUnputString(yytext + shortlen, yyleng - shortlen);
|
||||
|
@ -28,6 +28,13 @@ module t;
|
||||
$finish;
|
||||
end
|
||||
|
||||
int x;
|
||||
initial begin
|
||||
x = # 1_1 'd 12_34; // Checks we parse _ correctly
|
||||
if (x != 1234) $stop;
|
||||
if ($time != 11) $stop;
|
||||
end
|
||||
|
||||
initial #21 $stop; // timeout
|
||||
endmodule
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user