Tune usage of resultConforms
to prefer the chosen alternative
#22730
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.
resultConforms
should only make us change our mind when we're sure that the chosen alternative does not fit the result type but another alternative would. The problem is that due to approximations and adaptation, we can guess wrong on both counts.In i22713 in particular, we guessed that the chosen alternative does not work (but it does because of Unit insertion) and that another alternative would, but it doesn't because
resultConforms
prefers false positives to false negatives (the result type is under-approximated toNothing
which is indeed a subtype ofUnit
).We only really need to prefer false positives to false negatives when considering whether to discard the currently chosen alternative (because there's probably a good reason we chose it in the first place), so this commit introduces a parameter to
resultConforms
to control this.Fixes #22713.