mirror of
https://github.com/Instagram/IGListKit
synced 2026-05-06 15:08:50 +00:00
Summary: Used migration tool with Swift 4, fixed build errors, and killed all warnings. Only non-trivial change was in the macOS example. Will flag that one. No changelog needed for this, right? - [x] All tests pass. Demo project builds and runs. Closes https://github.com/Instagram/IGListKit/pull/941 Differential Revision: D5890505 Pulled By: rnystrom fbshipit-source-id: 7e0d3510ff0e5856a0ffd59f1a97548a72266c20
46 lines
1.4 KiB
Swift
46 lines
1.4 KiB
Swift
/**
|
|
Copyright (c) 2016-present, Facebook, Inc. All rights reserved.
|
|
|
|
The examples provided by Facebook are for non-commercial testing and evaluation
|
|
purposes only. Facebook reserves all rights not expressly granted.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
FACEBOOK BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*/
|
|
|
|
import Foundation
|
|
|
|
extension MutableCollection {
|
|
|
|
/// Shuffles the contents of this collection.
|
|
mutating func shuffle() {
|
|
let c = count
|
|
guard c > 1 else { return }
|
|
|
|
for (firstUnshuffled, unshuffledCount) in zip(indices, stride(from: c, to: 1, by: -1)) {
|
|
let d: IndexDistance = numericCast(arc4random_uniform(numericCast(unshuffledCount)))
|
|
guard d != 0 else { continue }
|
|
|
|
let i = index(firstUnshuffled, offsetBy: d)
|
|
|
|
self.swapAt(firstUnshuffled, i)
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
extension Sequence {
|
|
|
|
/// Returns an array with the contents of this sequence, shuffled.
|
|
var shuffled: [Iterator.Element] {
|
|
var result = Array(self)
|
|
result.shuffle()
|
|
|
|
return result
|
|
}
|
|
|
|
}
|