-
Notifications
You must be signed in to change notification settings - Fork 13k
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
macro pattern ($($arg:expr)*) should be illegal #48220
Comments
Can you show more precisely what language in the link makes you say this? I don't see anything on limitations of lists. The argument I find much more compelling is what you mentioned in the user's thread, that the following
is forbidden.
I fear much worse; that the way such invocations are parsed may even change as the grammar of expressions is extended. This would seem to defeat the whole purpose of the follow-set rules! (but of course! They've been entirely circumvented...) |
I think this may be the same as #44975. |
In response to ExpHP: It's in the last part of the "Syntactic Requirements" section, copied below.
Clearly allowing ($($arg:expr)*) breaks this rule. Durka: yes, same problem, thank you for linking this. Sorry if I am stating the obvious, but there's no good way of allowing space-separated expressions in this context. In addition to the "-" operator, there are function calls (is f (x) one or two expressions?), vectors (a [3]) and I don't know what else (my experience with Rust is about 4 days). |
I think calling this "space-separated" is a misnomer, because the same problem occurs without any spaces in the input at all, just depending on how the tokens are combined. |
Thanks, agree, "space-separated" is not good. It's more like "without a separator" or more precisely "without a separating token" since whitespace can separate tokens. In any case I don't think there's any confusion here. |
Triage: this text is no longer in the book; it seems like a warning was added. I'm gonna call this fixed. Please let me know if this is not the case! |
On rustc 1.21.0 it is legal to write a rule like
($($arg:expr)*) => { println!($($arg),*) }
but the manual does not allow space as a separator in an expr list:
https://doc.rust-lang.org/book/first-edition/macros.html#syntactic-requirements
which is reasonable because it leads to ambiguities (e.g. "a b -c" could be three expressions "a", "b", and "-c", or two, "a" and "b-c"). (If you're curious, the implementation picks the second choice in this case).
The text was updated successfully, but these errors were encountered: