You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
This happens regardless whether priority is higher or lower between each other - e.g. commentstart would have 2 instead of 20 and MaybeValue has 20 instead of 2 - effectively ignoring the priority e.g.:
If I add ( to the [^..] exclusive Tokens::MaybeValue then it works but it would be nice if priority can be used to compose regular expression/s over tokens that may match each other.
Looking at the codegen both seem to be treated as regexes but it doesn't explain different priorities not working.
That said the documentation perhaps could be filled out re: limitations if not supported - happy to help doc or send PR/s.
What is curious that if the priority is same you get the warning at least about it matching the same input but given priority is different it probably could be composable grouping.
I think this is part of related to all the bugs with priorities, see also #265, and other related issues.
Sadly, I currently have not time to invest into this problem, but I hope someone smarter than me (and with more free time) can address this in the near future! That would greatly help the project!
Here the regex for Identifier could also match the input int. However Logos uses a heuristic to decide which regex has a higher priority (other lexer generators such as flex use the definition order instead). In this case the regex int gets priority 6 and [a-z][a-z]* gets priority 2. So the priority is only relevant when multiple regexes can match input of the same length.
Assigning an explicit priority is just an escape hatch for when the priority heuristic fails. In your example both regexes have the same priority and can match (, so by assigning a higher priority to the first regex you get a CommentStart if ( is the longest match.
I guess it would be possible to extend Logos, such that one could specify a lazy match for certain regexes. However I don't think this would be a good idea, as it would implicitly change the possible matches for other regexes in a non-obvious way. For example, if such a flag was used for the int regex in the above example, it would prevent integer from being lexed as an identifier.
I know the regex support is limited but being able to do exclusive regexes would be nice without repeating ?
e.g. in the below I would like to match the token
'('
and stop there not even try the regex below it.Results regex with priority = 2 overriding the priority = 20 token
This happens regardless whether priority is higher or lower between each other - e.g. commentstart would have 2 instead of 20 and MaybeValue has 20 instead of 2 - effectively ignoring the priority e.g.:
If I add
(
to the[^..]
exclusiveTokens::MaybeValue
then it works but it would be nice ifpriority
can be used to compose regular expression/s over tokens that may match each other.Looking at the codegen both seem to be treated as regexes but it doesn't explain different priorities not working.
That said the documentation perhaps could be filled out re: limitations if not supported - happy to help doc or send PR/s.
What is curious that if the priority is same you get the warning at least about it matching the same input but given priority is different it probably could be composable grouping.
Related:
Sidenote
If I write it all regexes then it also works but it would be nice to compose tokens with regexes w/ diff priorites
e.g. this works:
But my preference would be to use tokens where I can and leave regexes where I can't use tokens.
I could always split to different lexer but having to construct & morph diff lexer is time consuming.
The text was updated successfully, but these errors were encountered: