Я определил перечисление для представления выбора «станции»; станции определяются уникальным положительным целым числом, поэтому я создал следующее перечисление, чтобы отрицательные значения представляли специальные выборки:
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)"
}
}
}
}
Я хотел бы использовать эти значения в качестве ключей в словаре. Объявление Dictionary приводит к ожидаемой ошибке, что StationSelector не соответствует Hashable. Соответствовать Hashable легко с помощью простой хеш-функции:
var hashValue: Int {
get {
return self.toInt()
}
}
Однако Hashable
требует соответствия Equatable
, и я не могу определить оператор равенства в своем перечислении, чтобы удовлетворить компилятор.
func == (lhs: StationSelector, rhs: StationSelector) -> Bool {
return lhs.toInt() == rhs.toInt()
}
Компилятор жалуется, что это два объявления в одной строке, и хочет поставить ;
после func
, что тоже не имеет смысла.
Какие-нибудь мысли?
@infix func ==
? - person Kreiri   schedule 04.07.2014