KEMBAR78
FIX: Use lazy encoding in UTF-8 encoded string comparison by milaGGL · Pull Request #2021 · googleapis/java-firestore · GitHub
Skip to content

Conversation

milaGGL
Copy link
Contributor

@milaGGL milaGGL commented Feb 18, 2025

The previous fix created a performance issue due to expensive UTF-8 encoding. Update compareUtf8Strings to use lazy encoding instead.

@product-auto-label product-auto-label bot added size: l Pull request size is large. api: firestore Issues related to the googleapis/java-firestore API. labels Feb 18, 2025
@product-auto-label product-auto-label bot added size: m Pull request size is medium. and removed size: l Pull request size is large. labels Feb 18, 2025
@milaGGL milaGGL marked this pull request as ready for review February 19, 2025 15:14
@milaGGL milaGGL requested review from a team as code owners February 19, 2025 15:14
@milaGGL milaGGL requested a review from ehsannas February 19, 2025 15:14
@milaGGL milaGGL assigned milaGGL and ehsannas and unassigned milaGGL Feb 19, 2025
@milaGGL milaGGL changed the title Use lazy encoding in utf-8 encoded string comparison FIX: Use lazy encoding in UTF-8 encoded string comparison Feb 19, 2025
@product-auto-label product-auto-label bot added size: l Pull request size is large. and removed size: m Pull request size is medium. labels Feb 20, 2025
@milaGGL milaGGL requested a review from dconeybe February 20, 2025 21:27
@milaGGL milaGGL requested a review from ehsannas February 26, 2025 15:50
private static int validateLength(String name, int length) {
if (length < 0) {
throw new IllegalArgumentException(
"invalid " + name + " length: " + length + " (must be greater than or equal to zero)");
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit: I'm not sure what's the point of passing maximum string as an argument to validateLength instead of having "invalid string length: " + length + ...

this.maxLength = validateLength("maximum string", maxLength);
}

private static float validateProbability(String name, float probability) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit: I'm not sure what's the point of passing "surrogate pair" as an argument to this function.

StringPairGenerator.StringPair stringPair = stringPairGenerator.next();
s1 = stringPair.s1;
s2 = stringPair.s2;
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why create a new scope here?

could just use the following?

StringPairGenerator.StringPair stringPair = stringPairGenerator.next();
String s1 = stringPair.s1;
String s2 = stringPair.s2;

@dconeybe dconeybe dismissed their stale review February 26, 2025 19:11

Ehsan has taken over code review

@milaGGL milaGGL added the kokoro:force-run Add this label to force Kokoro to re-run the tests. label Mar 3, 2025
@yoshi-kokoro yoshi-kokoro removed the kokoro:force-run Add this label to force Kokoro to re-run the tests. label Mar 3, 2025
@milaGGL milaGGL merged commit 11a4c74 into main Mar 3, 2025
23 checks passed
@milaGGL milaGGL deleted the mila/string-uses-byte-comparison branch March 3, 2025 17:13
dconeybe added a commit that referenced this pull request Jul 7, 2025
The semantics of this logic were originally fixed by #1967, but this fix
caused a material performance degradation, which was then improved by #2021.
The performance was, however, still suboptimal, and this PR further improves the
speed back to close to its original speed and, serendipitously, simplifies the
algorithm too.

This commit effectively ports the following two PRs from the
firebase-android-sdk repository:

- firebase/firebase-android-sdk#7098
- firebase/firebase-android-sdk#7109
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

api: firestore Issues related to the googleapis/java-firestore API. size: l Pull request size is large.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants