Прочитав Как проверить равенство перечислений Swift со связанными значениями , я реализовал следующее перечисление:
enum CardRank {
case Number(Int)
case Jack
case Queen
case King
case Ace
}
func ==(a: CardRank, b: CardRank) -> Bool {
switch (a, b) {
case (.Number(let a), .Number(let b)) where a == b: return true
case (.Jack, .Jack): return true
case (.Queen, .Queen): return true
case (.King, .King): return true
case (.Ace, .Ace): return true
default: return false
}
}
Следующий код работает:
let card: CardRank = CardRank.Jack
if card == CardRank.Jack {
print("You played a jack!")
} else if card == CardRank.Number(2) {
print("A two cannot be played at this time.")
}
Однако это не компилируется:
let number = CardRank.Number(5)
if number == CardRank.Number {
print("You must play a face card!")
}
... и выдает следующее сообщение об ошибке:
Бинарный оператор '==' не может применяться к операндам типа 'CardRank' и '(Int) -> CardRank'
Я предполагаю, что это связано с тем, что он ожидает полный тип и CardRank.Number
не указывает весь тип, тогда как CardRank.Number(2)
это было. Однако в этом случае я хочу, чтобы он совпадал с любым числом; не только конкретный.
Очевидно, я могу использовать оператор switch, но весь смысл реализации ==
оператора заключался в том, чтобы избежать этого подробного решения:
switch number {
case .Number:
print("You must play a face card!")
default:
break
}
Is there any way to compare an enum with associated values while ignoring its associated value?
Note: I realize that I could change the case in the ==
method to case (.Number, .Number): return true
, but, although it would return true correctly, my comparison would still look like its being compared to a specific number (number == CardRank.Number(2)
; where 2 is a dummy value) rather than any number (number == CardRank.Number
).
Jack
,Queen
,King
,Ace
cases in the==
operator implementation to just:case (let x, let y) where x == y: return true