Add @discardableResult to mutating partition methods#274
Open
adityasingh2400 wants to merge 1 commit into
Open
Add @discardableResult to mutating partition methods#274adityasingh2400 wants to merge 1 commit into
adityasingh2400 wants to merge 1 commit into
Conversation
The mutating partition/stablePartition methods return the index of the first element of the second partition. That index is often not needed at the call site (e.g. bringForward(elementsSatisfying:) from Embracing Algorithms, WWDC 2018), which produced a spurious 'result of call is unused' warning. Mark these methods @discardableResult so callers may ignore the returned index without a warning. Fixes apple#67
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.
Problem
The mutating
partition(by:)/stablePartition(by:)family returns the index of the first element in the second partition, but the methods are not marked@discardableResult. Callers who only want the in-place partitioning side effect and don't need the pivot index get an unavoidable "result of call is unused" warning, as requested in #67.Change
Add
@discardableResultto the four mutating partition methods onMutableCollection(and theBidirectionalCollectionoverload).@discardableResultis purely additive and source-compatible: it only suppresses the unused-result warning for callers that ignore the return value, and changes no runtime behavior. Callers who use the returned index are unaffected.Verification
swift buildandswift testpass. No behavioral change; the attribute only affects unused-result diagnostics.Fixes #67.