Direct cast is possible between equivalent types #3935
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
The issue was that the following code ended with a
CompilerBug
:The problem is with the double cast to
bool
(more specifically castingbool
intobool
). The problem was that the source and destination types were two different objects of the same class:Therefore the original check for
canCastBetween
did not match those as the same type (since the pointers are not equal):p4c/frontends/p4/typeChecking/typeChecker.cpp
Lines 690 to 692 in 1b47d14
Which lead to a new cast being introduced (so essentially there were 3 casts to
bool
instead of 2), while one of the original ones was not added into the type map:p4c/frontends/p4/typeChecking/typeChecker.cpp
Lines 2810 to 2828 in 1b47d14