Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rejected valid signal name #2076

Open
matlupi opened this issue Jan 19, 2024 · 4 comments · May be fixed by #2102
Open

Rejected valid signal name #2076

matlupi opened this issue Jan 19, 2024 · 4 comments · May be fixed by #2102
Labels
rejects-valid syntax If the parser wrongly rejects syntactically valid code (according to SV-2017).

Comments

@matlupi
Copy link

matlupi commented Jan 19, 2024

Describe the bug

Short summary.

To Reproduce

verible-verilog-lint test.sv

with test.sv

module test;
  logic analog;
endmodule

Actual behavior:

Rejects valid syntax

test.sv:2 9-14 syntax error at token "analog"

Expected behavior

No syntax error.
analog is not a reserved keyword according to LRM Annex B Table B.1

@matlupi matlupi added the rejects-valid syntax If the parser wrongly rejects syntactically valid code (according to SV-2017). label Jan 19, 2024
@hzeller
Copy link
Collaborator

hzeller commented Jan 31, 2024

Yeah, this is because we accept a few more potential keywords from Verilog-AMS

We should probably add that to the 'keyword or identifier' classification like here

KeywordIdentifier
/* The following are keywords in certain dialects of Verilog.
* These are used in some contexts, but in others we just regard them as
* regular identifiers.
* TODO(hzeller): Often, SymbolIdentifier is used in direct token
* comparisons in the code. They should match GenericIdentifier instead.
*/
/* Verilog-AMS: */
: TK_access
{ $$ = std::move($1); }
| TK_exclude
{ $$ = std::move($1); }
| TK_flow
{ $$ = std::move($1); }
| TK_from
{ $$ = std::move($1); }
| TK_discrete
{ $$ = std::move($1); }
/* TK_sample is in SystemVerilog coverage_event */
| TK_sample
{ $$ = std::move($1); }
| TK_infinite
{ $$ = std::move($1); }
| TK_continuous
{ $$ = std::move($1); }
;

@matlupi
Copy link
Author

matlupi commented Feb 1, 2024

Is there a switch to avoid this syntax error?
Since the file is not a VAMS file, I should be able to get around that, right?

@hzeller
Copy link
Collaborator

hzeller commented Feb 1, 2024

Unfortunately not currently. We do have an issu #141 to allow switching Verilog dialects, but it is yet to be picked up by someone.

But if you make a pull request that adds the keyword to the section I mentioned, it should fix your issue.

@matlupi
Copy link
Author

matlupi commented Feb 2, 2024

Will do, thanks!

matlupi pushed a commit to matlupi/verible that referenced this issue Feb 6, 2024
@matlupi matlupi linked a pull request Feb 6, 2024 that will close this issue
matlupi pushed a commit to matlupi/verible that referenced this issue Feb 6, 2024
matlupi pushed a commit to matlupi/verible that referenced this issue Sep 25, 2024
matlupi pushed a commit to matlupi/verible that referenced this issue Sep 25, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
rejects-valid syntax If the parser wrongly rejects syntactically valid code (according to SV-2017).
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants