2016-12-19 17:13:21 +00:00
|
|
|
/**
|
|
|
|
|
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
|
|
|
|
|
|
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
|
|
|
}
|