mirror of
https://github.com/Instagram/IGListKit
synced 2026-05-15 21:38:18 +00:00
47 lines
1.5 KiB
Swift
47 lines
1.5 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 where Indices.Iterator.Element == Index {
|
||
|
|
|
||
|
|
/// 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)
|
||
|
|
|
||
|
|
swap(&self[firstUnshuffled], &self[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
|
||
|
|
}
|
||
|
|
|
||
|
|
}
|