Обновленный подход:
Я думаю, что нет никакой встроенной поддержки для этого.Но вы можете достичь этого, определив пользовательский оператор (предпочтительно с помощью протокола, но вы можете сделать это и напрямую).Примерно так:
protocol EnumTypeEquatable {
static func ~=(lhs: Self, rhs: Self) -> Bool
}
extension DataType: EnumTypeEquatable {
static func ~=(lhs: DataType, rhs: DataType) -> Bool {
switch (lhs, rhs) {
case (.one, .one),
(.two, .two):
return true
default:
return false
}
}
}
А затем использовать его как:
let isTypeEqual = DataType.One(value: 1) ~= DataType.One(value: 2)
print (isTypeEqual) // true
Старый подход:
protocol EnumTypeEquatable {
var enumCaseIdentifier: String { get }
}
extension DataType: EnumTypeEquatable {
var enumCaseIdentifier: String {
switch self {
case .one: return "ONE"
case .two: return "TWO"
}
}
}
func ~=<T>(lhs: T, rhs: T) -> Bool where T: EnumTypeEquatable {
return lhs.enumCaseIdentifier == rhs.enumCaseIdentifier
}
Старая версия зависит от времени выполнения и может быть снабжена реализацией enumCaseIdentifier
по умолчанию в зависимости от String(describing: self)
, что не рекомендуется.(поскольку String(describing: self)
работает с протоколом CustromStringConvertible
и может быть изменен)