Я определил перечисление, чтобы представить выбор "станции"; станции определяются уникальным положительным целым числом, поэтому я создал следующее перечисление, чтобы отрицательные значения отображали специальные варианты:
enum StationSelector : Printable {
case Nearest
case LastShown
case List
case Specific(Int)
func toInt() -> Int {
switch self {
case .Nearest:
return -1
case .LastShown:
return -2
case .List:
return -3
case .Specific(let stationNum):
return stationNum
}
}
static func fromInt(value:Int) -> StationSelector? {
if value > 0 {
return StationSelector.Specific(value)
}
switch value {
case -1:
return StationSelector.Nearest
case -2:
return StationSelector.LastShown
case -3:
return StationSelector.List
default:
return nil
}
}
var description: String {
get {
switch self {
case .Nearest:
return "Nearest Station"
case .LastShown:
return "Last Displayed Station"
case .List:
return "Station List"
case .Specific(let stationNumber):
return "Station #\(stationNumber)"
}
}
}
}
Я хотел бы использовать эти значения в качестве ключей в словаре. Объявление словаря дает ожидаемую ошибку, которую StationSelector не соответствует Hashable. В соответствии с Hashable легко с простой хэш-функцией:
var hashValue: Int {
get {
return self.toInt()
}
}
Однако Hashable
требует соответствия Equatable
, и я не могу определить, что оператор equals на моем перечислении удовлетворяет компилятору.
func == (lhs: StationSelector, rhs: StationSelector) -> Bool {
return lhs.toInt() == rhs.toInt()
}
Компилятор жалуется, что это две декларации в одной строке и хочет поставить ;
после func
, что тоже не имеет смысла.
Любые мысли?