Swift 3.0
Майже ідентичний Swift 2.0. OptionSetType було перейменовано на OptionSet, а перерахунки записуються в нижній регістр за умовою.
struct MyOptions : OptionSet {
let rawValue: Int
static let firstOption = MyOptions(rawValue: 1 << 0)
static let secondOption = MyOptions(rawValue: 1 << 1)
static let thirdOption = MyOptions(rawValue: 1 << 2)
}
Замість того, щоб надавати none
параметр, рекомендація Swift 3 полягає в тому, щоб просто використовувати порожній літеральний масив:
let noOptions: MyOptions = []
Інше використання:
let singleOption = MyOptions.firstOption
let multipleOptions: MyOptions = [.firstOption, .secondOption]
if multipleOptions.contains(.secondOption) {
print("multipleOptions has SecondOption")
}
let allOptions = MyOptions(rawValue: 7)
if allOptions.contains(.thirdOption) {
print("allOptions has ThirdOption")
}
Швидкий 2.0
У Swift 2.0 розширення протоколу опікуються більшою частиною цих котлів, які зараз імпортуються як відповідна структура OptionSetType
. ( RawOptionSetType
зник, як у Swift 2 beta 2.) Декларація набагато простіша:
struct MyOptions : OptionSetType {
let rawValue: Int
static let None = MyOptions(rawValue: 0)
static let FirstOption = MyOptions(rawValue: 1 << 0)
static let SecondOption = MyOptions(rawValue: 1 << 1)
static let ThirdOption = MyOptions(rawValue: 1 << 2)
}
Тепер ми можемо використовувати семантику на основі набору з MyOptions
:
let singleOption = MyOptions.FirstOption
let multipleOptions: MyOptions = [.FirstOption, .SecondOption]
if multipleOptions.contains(.SecondOption) {
print("multipleOptions has SecondOption")
}
let allOptions = MyOptions(rawValue: 7)
if allOptions.contains(.ThirdOption) {
print("allOptions has ThirdOption")
}
Швидкий 1.2
Дивлячись на варіанти Objective-C , які були імпортовані Свіфт ( UIViewAutoresizing
наприклад), ми можемо бачити , що варіанти оголошені в якості , struct
яке відповідає протоколу RawOptionSetType
, який , в свою чергу , відповідає вимогам _RawOptionSetType
, Equatable
, RawRepresentable
, BitwiseOperationsType
, і NilLiteralConvertible
. Ми можемо створити власне так:
struct MyOptions : RawOptionSetType {
typealias RawValue = UInt
private var value: UInt = 0
init(_ value: UInt) { self.value = value }
init(rawValue value: UInt) { self.value = value }
init(nilLiteral: ()) { self.value = 0 }
static var allZeros: MyOptions { return self(0) }
static func fromMask(raw: UInt) -> MyOptions { return self(raw) }
var rawValue: UInt { return self.value }
static var None: MyOptions { return self(0) }
static var FirstOption: MyOptions { return self(1 << 0) }
static var SecondOption: MyOptions { return self(1 << 1) }
static var ThirdOption: MyOptions { return self(1 << 2) }
}
Тепер ми можемо розглядати цей новий набір параметрів, MyOptions
як описано в документації Apple: ви можете використовувати enum
синтаксис-подібний:
let opt1 = MyOptions.FirstOption
let opt2: MyOptions = .SecondOption
let opt3 = MyOptions(4)
І він також поводиться так, як ми очікуємо, що варіанти поводитись так:
let singleOption = MyOptions.FirstOption
let multipleOptions: MyOptions = singleOption | .SecondOption
if multipleOptions & .SecondOption != nil { // see note
println("multipleOptions has SecondOption")
}
let allOptions = MyOptions.fromMask(7) // aka .fromMask(0b111)
if allOptions & .ThirdOption != nil {
println("allOptions has ThirdOption")
}
Я створив генератор для створення набору параметрів Swift без усієї знахідки / заміни.
Останні: Модифікації для Swift 1.1 beta 3.
RawOptionsSetType
: nshipster.com/rawoptionsettype