Quality: Negative startIndex causes IndexOutOfBoundsException in indexOfFrom#1894
Open
Nam0101 wants to merge 1 commit into
Conversation
…exoffrom `indexOfFrom` only checks `startIndex >= size`. When `startIndex < 0`, `subList(startIndex, size)` throws `IndexOutOfBoundsException`, causing a runtime crash. As a general-purpose utility extension, this should not crash on invalid indices. Affected files: CollectionUtils.kt Signed-off-by: Nguyen Van Nam <nam.nv205106@gmail.com>
|
These seem to be LLM generated. Please do not overwhelm the development team with AI generated PRs. There is a growing problem with LLM generated slop PRs overwhelming open source development teams. |
Owner
|
@Nam0101 Would you mind adding unit tests to CollectionUtilsTest that validate the difference the change in your PR makes? |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
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.
Hi there! 👋
While going through the codebase, I noticed a minor opportunity for improvement regarding
myExpenses/src/main/java/org/totschnig/myexpenses/util/CollectionUtils.kt.Context:
indexOfFromonly checksstartIndex >= size. WhenstartIndex < 0,subList(startIndex, size)throwsIndexOutOfBoundsException, causing a runtime crash. As a general-purpose utility extension, this should not crash on invalid indices.Proposed fix:
Normalize or guard
startIndexbefore callingsubList:fun List.indexOfFrom(element: T, startIndex: Int): Int {
val from = startIndex.coerceAtLeast(0)
if (from >= this.size) return -1
val subIndex = this.subList(from, this.size).indexOf(element)
return if (subIndex == -1) -1 else from + subIndex
}
Files touched:
myExpenses/src/main/java/org/totschnig/myexpenses/util/CollectionUtils.kt(modified)(Note: Tested the changes locally to ensure everything works as expected. Let me know if you need any adjustments, happy to help!)
—
NamNV
📍 Hanoi, Vietnam
📧 nam.nv205106@gmail.com