CSHARP-5654: String.IndexOf comparisons to -1 return incorrect results #1855
+117
−0
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 problem is that our code to translate
IndexOfcomparisons assumes that the comparand is greater than or equal to zero but did not enforce that.The behavior is undefined when the comparand is negative.
The short term fix is to throw an
ExpressionNotSupportedExceptionwhen the comparand is negative, which has the effect of causing the queries to be translated using$expr.Queries using
$exprare not very efficient. But with this PR at least they are correct so the bug is fixed.See CSHARP-5844 for possible future work to translate these queries using regular expressions.