mirror of
https://github.com/samsonjs/SwiftBatteries.git
synced 2026-03-25 09:25:51 +00:00
56 lines
1.7 KiB
Swift
56 lines
1.7 KiB
Swift
import Foundation
|
|
|
|
public extension CollectionType {
|
|
|
|
typealias T = Generator.Element
|
|
|
|
/// Returns elements of the collection that match the given regular expression.
|
|
/// If elements are String or NSString instances they will be matched directly.
|
|
/// if they are NSObject instances their -description is matched. Otherwise
|
|
/// they are not matched.
|
|
func grep(regex: String) throws -> [T] {
|
|
let re = try NSRegularExpression(pattern: regex, options: NSRegularExpressionOptions(rawValue: 0))
|
|
return filter({ item -> Bool in
|
|
if let string = item as? String {
|
|
return re.matches(string)
|
|
}
|
|
if let string = item as? NSString {
|
|
return re.matches(String(string))
|
|
}
|
|
if let object = item as? NSObject {
|
|
return re.matches(object.description)
|
|
}
|
|
return false
|
|
})
|
|
}
|
|
|
|
}
|
|
|
|
public extension CollectionType where Index: RandomAccessIndexType {
|
|
|
|
/// Returns a random element, or nil if the collection is empty
|
|
func sample() -> T? {
|
|
guard !isEmpty else {
|
|
return nil
|
|
}
|
|
let n = Int(count.toIntMax())
|
|
let i = startIndex.advancedBy(Index.Distance(IntMax(randomInt(n) - 1)))
|
|
return self[i]
|
|
}
|
|
|
|
}
|
|
|
|
public extension CollectionType where Self.Generator.Element: Equatable {
|
|
|
|
/// Returns the unique elements of a sorted collection by collapsing runs of
|
|
/// identical elements.
|
|
func unique() -> [T] {
|
|
var last: T?
|
|
return filter({ item -> Bool in
|
|
let isUnique: Bool = last == nil || last != item
|
|
last = item
|
|
return isUnique
|
|
})
|
|
}
|
|
|
|
}
|