mirror of
https://github.com/verilator/verilator.git
synced 2025-01-01 04:07:34 +00:00
Internals: Minor parser reorgs in prep for future pull. No functional change intended.
This commit is contained in:
parent
650da7beb2
commit
a3bbf13506
@ -447,6 +447,20 @@ size_t V3ParseImp::tokenPipeScanTypeEq(size_t depth) {
|
||||
return depth;
|
||||
}
|
||||
|
||||
int V3ParseImp::tokenPipelineId(int token) {
|
||||
const V3ParseBisonYYSType* nexttokp = tokenPeekp(0); // First char after yaID
|
||||
const int nexttok = nexttokp->token;
|
||||
UASSERT(yylval.token == yaID__LEX, "Start with ID");
|
||||
if (nexttok == yP_COLONCOLON) { return yaID__CC; }
|
||||
VL_RESTORER(yylval); // Remember value, as about to read ahead
|
||||
if (nexttok == '#') {
|
||||
VL_RESTORER(yylval); // Remember value, as about to read ahead
|
||||
const size_t depth = tokenPipeScanParam(0);
|
||||
if (tokenPeekp(depth)->token == yP_COLONCOLON) return yaID__CC;
|
||||
}
|
||||
return token;
|
||||
}
|
||||
|
||||
void V3ParseImp::tokenPipeline() {
|
||||
// called from bison's "yylex", has a "this"
|
||||
if (m_tokensAhead.empty()) tokenPull(); // corrupts yylval
|
||||
@ -552,13 +566,7 @@ void V3ParseImp::tokenPipeline() {
|
||||
token = yWITH__ETC;
|
||||
}
|
||||
} else if (token == yaID__LEX) {
|
||||
if (nexttok == yP_COLONCOLON) {
|
||||
token = yaID__CC;
|
||||
} else if (nexttok == '#') {
|
||||
VL_RESTORER(yylval); // Remember value, as about to read ahead
|
||||
const size_t depth = tokenPipeScanParam(0);
|
||||
if (tokenPeekp(depth)->token == yP_COLONCOLON) token = yaID__CC;
|
||||
}
|
||||
token = tokenPipelineId(token);
|
||||
}
|
||||
// If add to above "else if", also add to "if (token" further above
|
||||
}
|
||||
|
@ -302,6 +302,7 @@ private:
|
||||
void yylexReadTok() VL_MT_DISABLED;
|
||||
void tokenPull() VL_MT_DISABLED;
|
||||
void tokenPipeline() VL_MT_DISABLED; // Internal; called from tokenToBison
|
||||
int tokenPipelineId(int token) VL_MT_DISABLED;
|
||||
void tokenPipelineSym() VL_MT_DISABLED;
|
||||
size_t tokenPipeScanParam(size_t depth) VL_MT_DISABLED;
|
||||
size_t tokenPipeScanTypeEq(size_t depth) VL_MT_DISABLED;
|
||||
|
@ -1412,12 +1412,17 @@ udpFront<nodeModulep>:
|
||||
SYMP->pushNew($$); }
|
||||
;
|
||||
|
||||
parameter_value_assignmentE<pinp>: // IEEE: [ parameter_value_assignment ]
|
||||
parameter_value_assignmentInstE<pinp>: // IEEE: [ parameter_value_assignment ] for instance
|
||||
/* empty */ { $$ = nullptr; }
|
||||
| parameter_value_assignment { $$ = $1; }
|
||||
| parameter_value_assignmentInst { $$ = $1; }
|
||||
;
|
||||
|
||||
parameter_value_assignment<pinp>: // IEEE: parameter_value_assignment
|
||||
parameter_value_assignmentClassE<pinp>: // IEEE: [ parameter_value_assignment ] for classes
|
||||
/* empty */ { $$ = nullptr; }
|
||||
| parameter_value_assignmentClass { $$ = $1; }
|
||||
;
|
||||
|
||||
parameter_value_assignmentInst<pinp>: // IEEE: parameter_value_assignment for instance
|
||||
'#' '(' cellparamListE ')' { $$ = $3; }
|
||||
// // Parentheses are optional around a single parameter
|
||||
| '#' yaINTNUM { $$ = new AstPin{$<fl>2, 1, "", new AstConst{$<fl>2, *$2}}; }
|
||||
@ -3242,7 +3247,7 @@ instDecl<nodep>:
|
||||
// // Currently disambiguated from data_declaration based on
|
||||
// // VARs being type, and cells non-type.
|
||||
// // IEEE requires a '(' to disambiguate, we need TODO force this
|
||||
id parameter_value_assignmentE
|
||||
id parameter_value_assignmentInstE
|
||||
/*mid*/ { INSTPREP($<fl>1, *$1, $2); }
|
||||
/*cont*/ instnameList ';'
|
||||
{ $$ = $4;
|
||||
@ -4506,7 +4511,14 @@ property_actual_arg<nodeExprp>: // ==IEEE: property_actual_arg
|
||||
exprOrDataType<nodep>: // expr | data_type: combined to prevent conflicts
|
||||
expr { $$ = $1; }
|
||||
// // data_type includes id that overlaps expr, so special flavor
|
||||
| data_type { $$ = $1; }
|
||||
// // data_type expanded:
|
||||
| data_typeNoRef { $$ = $1; }
|
||||
| packageClassScopeE idType packed_dimensionListE
|
||||
{ AstRefDType* const refp = new AstRefDType{$<fl>2, *$2, $1, nullptr};
|
||||
$$ = GRAMMARP->createArray(refp, $3, true); }
|
||||
| packageClassScopeE idType parameter_value_assignmentClass packed_dimensionListE
|
||||
{ AstRefDType* const refp = new AstRefDType{$<fl>2, *$2, $1, $3};
|
||||
$$ = GRAMMARP->createArray(refp, $4, true); }
|
||||
// // not in spec, but needed for $past(sig,1,,@(posedge clk))
|
||||
//UNSUP event_control { }
|
||||
;
|
||||
@ -4634,10 +4646,20 @@ funcId<nodeFTaskp>: // IEEE: function_data_type_or_implicit + part o
|
||||
{ $$ = $2;
|
||||
$$->fvarp(new AstBasicDType{$<fl>2, LOGIC_IMPLICIT, $1});
|
||||
SYMP->pushNewUnderNodeOrCurrent($$, $<scp>2); }
|
||||
| data_type fIdScoped
|
||||
| data_typeNoRef fIdScoped
|
||||
{ $$ = $2;
|
||||
$$->fvarp($1);
|
||||
SYMP->pushNewUnderNodeOrCurrent($$, $<scp>2); }
|
||||
| packageClassScopeE idType packed_dimensionListE fIdScoped
|
||||
{ AstRefDType* const refp = new AstRefDType{$<fl>2, *$2, $1, nullptr};
|
||||
$$ = $4;
|
||||
$$->fvarp(GRAMMARP->createArray(refp, $3, true));
|
||||
SYMP->pushNewUnderNodeOrCurrent($$, $<scp>4); }
|
||||
| packageClassScopeE idType parameter_value_assignmentClass packed_dimensionListE fIdScoped
|
||||
{ AstRefDType* const refp = new AstRefDType{$<fl>2, *$2, $1, $3};
|
||||
$$ = $5;
|
||||
$$->fvarp(GRAMMARP->createArray(refp, $4, true));
|
||||
SYMP->pushNewUnderNodeOrCurrent($$, $<scp>5); }
|
||||
// // To verilator tasks are the same as void functions (we separately detect time passing)
|
||||
| yVOID taskId
|
||||
{ $$ = $2; }
|
||||
@ -7151,12 +7173,12 @@ class_typeExtImpOne<nodeExprp>: // part of IEEE: class_type, where we either ge
|
||||
// // If idAny below is otherwise, not legal
|
||||
idAny
|
||||
/*mid*/ { /* no nextId as not refing it above this*/ }
|
||||
/*cont*/ parameter_value_assignmentE
|
||||
/*cont*/ parameter_value_assignmentClassE
|
||||
{ $$ = new AstClassOrPackageRef{$<fl>1, *$1, $<scp>1, $3};
|
||||
$<scp>$ = $<scp>1; }
|
||||
| idCC
|
||||
/*mid*/ { /* no nextId as not refing it above this*/ }
|
||||
/*cont*/ parameter_value_assignmentE
|
||||
/*cont*/ parameter_value_assignmentClassE
|
||||
{ $$ = new AstClassOrPackageRef{$<fl>1, *$1, $<scp>1, $3};
|
||||
$<scp>$ = $<scp>1; }
|
||||
//
|
||||
@ -7227,7 +7249,7 @@ packageClassScopeItem<nodeExprp>: // IEEE: package_scope or [package_scope]::[
|
||||
/*cont*/ yP_COLONCOLON
|
||||
{ $$ = new AstClassOrPackageRef{$<fl>1, *$1, $<scp>1, nullptr}; $<scp>$ = $<scp>1; }
|
||||
//
|
||||
| idCC parameter_value_assignment
|
||||
| idCC parameter_value_assignmentClass
|
||||
/*mid*/ { SYMP->nextId($<scp>1); } // Change next *after* we handle parameters, not before
|
||||
/*cont*/ yP_COLONCOLON
|
||||
{ $$ = new AstClassOrPackageRef{$<fl>1, *$1, $<scp>1, $2}; $<scp>$ = $<scp>1; }
|
||||
|
4
test_regress/t/t_typedef_id_bad.out
Normal file
4
test_regress/t/t_typedef_id_bad.out
Normal file
@ -0,0 +1,4 @@
|
||||
%Error: t/t_typedef_id_bad.v:9:34: Expecting a data type: 'i'
|
||||
9 | class Cls #(parameter type P_T = i);
|
||||
| ^
|
||||
%Error: Exiting due to
|
16
test_regress/t/t_typedef_id_bad.py
Executable file
16
test_regress/t/t_typedef_id_bad.py
Executable file
@ -0,0 +1,16 @@
|
||||
#!/usr/bin/env python3
|
||||
# DESCRIPTION: Verilator: Verilog Test driver/expect definition
|
||||
#
|
||||
# Copyright 2024 by Wilson Snyder. This program is free software; you
|
||||
# can redistribute it and/or modify it under the terms of either the GNU
|
||||
# Lesser General Public License Version 3 or the Perl Artistic License
|
||||
# Version 2.0.
|
||||
# SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
||||
|
||||
import vltest_bootstrap
|
||||
|
||||
test.scenarios('linter')
|
||||
|
||||
test.lint(fails=test.vlt_all, expect_filename=test.golden_filename)
|
||||
|
||||
test.passes()
|
10
test_regress/t/t_typedef_id_bad.v
Normal file
10
test_regress/t/t_typedef_id_bad.v
Normal file
@ -0,0 +1,10 @@
|
||||
// DESCRIPTION: Verilator: Verilog Test module
|
||||
//
|
||||
// This file ONLY is placed under the Creative Commons Public Domain, for
|
||||
// any use, without warranty, 2019 by Wilson Snyder.
|
||||
// SPDX-License-Identifier: CC0-1.0
|
||||
|
||||
int i;
|
||||
|
||||
class Cls #(parameter type P_T = i);
|
||||
endclass
|
Loading…
Reference in New Issue
Block a user