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

#[pest_ast(rule(Rule::type)] fails since type is a reserved rust keyword. #31

Open
oxcrow opened this issue Jul 18, 2024 · 1 comment
Open
Labels
good first issue Good for newcomers help wanted Extra attention is needed

Comments

@oxcrow
Copy link

oxcrow commented Jul 18, 2024

Hi everyone,

pest and pest-derived seem to accept grammar that has rust's reserved keywords, such as type, struct, mod etc.

However, pest-ast fails.

#[derive(Debug, Clone, FromPest)]
#[pest_ast(rule(Rule::type))] // <<< Causes issue, and fails to compile, since type is a reserved keyword
pub enum Type {
    Int(Int),
    Id(Id),
}

Can this be fixed?

Thanks!

@tomtau tomtau added help wanted Extra attention is needed good first issue Good for newcomers labels Jul 19, 2024
@oxcrow
Copy link
Author

oxcrow commented Jul 19, 2024

I might have fixed it.

This is a rust specific issue, and it can be resolved using r#type. i.e

#[derive(Debug, Clone, FromPest)]
#[pest_ast(rule(Rule::r#type))] // <<< using r#type tells rust to not treat this as a keyword
pub enum Type {
    Int(Int),
    Id(Id),
}

This compiles correctly, although I need to do more tests to verify if everything is working correctly.

I don't think pest, or pest-ast created this issue, but documenting this issue maybe helpful for future users.

And it might be possible for pest maintainers to pattern match on the procedural macro attributes, and handle these cases internally by using r#ident.

It is little bit more extra work for pest maintainers, but might provide a more comfortable experience for future users.

I need to do more tests, to see if this works correctly.

Thanks.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
good first issue Good for newcomers help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

2 participants