2019-12-19 17:32:49 +00:00
|
|
|
/*
|
2023-04-06 09:44:16 +00:00
|
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
2019-12-19 17:32:49 +00:00
|
|
|
*
|
|
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2016-12-19 17:13:21 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
import Foundation
|
|
|
|
|
|
2017-09-22 13:34:52 +00:00
|
|
|
extension MutableCollection {
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2016-12-19 17:13:21 +00:00
|
|
|
/// Shuffles the contents of this collection.
|
|
|
|
|
mutating func shuffle() {
|
2018-05-31 00:59:51 +00:00
|
|
|
guard count > 1 else { return }
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2018-05-31 00:59:51 +00:00
|
|
|
for (firstUnshuffled, unshuffledCount) in zip(indices, stride(from: count, to: 1, by: -1)) {
|
|
|
|
|
let distance: Int = numericCast(arc4random_uniform(numericCast(unshuffledCount)))
|
|
|
|
|
guard distance != 0 else { continue }
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2018-05-31 00:59:51 +00:00
|
|
|
let shuffleIndex = index(firstUnshuffled, offsetBy: distance)
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2018-05-31 00:59:51 +00:00
|
|
|
self.swapAt(firstUnshuffled, shuffleIndex)
|
2016-12-19 17:13:21 +00:00
|
|
|
}
|
|
|
|
|
}
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2016-12-19 17:13:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
extension Sequence {
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2016-12-19 17:13:21 +00:00
|
|
|
/// Returns an array with the contents of this sequence, shuffled.
|
|
|
|
|
var shuffled: [Iterator.Element] {
|
|
|
|
|
var result = Array(self)
|
|
|
|
|
result.shuffle()
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2016-12-19 17:13:21 +00:00
|
|
|
return result
|
|
|
|
|
}
|
2017-05-16 14:30:08 +00:00
|
|
|
|
2016-12-19 17:13:21 +00:00
|
|
|
}
|