Conforme descrito nas notas de versão do Xcode 8 beta 6,
Os tipos de erro definidos por Swift podem fornecer descrições de erro localizadas adotando o novo protocolo LocalizedError.
No seu caso:
public enum MyError: Error {
case customError
}
extension MyError: LocalizedError {
public var errorDescription: String? {
switch self {
case .customError:
return NSLocalizedString("A user-friendly description of the error.", comment: "My error")
}
}
}
let error: Error = MyError.customError
print(error.localizedDescription) // A user-friendly description of the error.
Você pode fornecer ainda mais informações se o erro for convertido para NSError
(o que é sempre possível):
extension MyError : LocalizedError {
public var errorDescription: String? {
switch self {
case .customError:
return NSLocalizedString("I failed.", comment: "")
}
}
public var failureReason: String? {
switch self {
case .customError:
return NSLocalizedString("I don't know why.", comment: "")
}
}
public var recoverySuggestion: String? {
switch self {
case .customError:
return NSLocalizedString("Switch it off and on again.", comment: "")
}
}
}
let error = MyError.customError as NSError
print(error.localizedDescription) // I failed.
print(error.localizedFailureReason) // Optional("I don\'t know why.")
print(error.localizedRecoverySuggestion) // Optional("Switch it off and on again.")
Ao adotar o CustomNSError
protocolo, o erro pode fornecer um userInfo
dicionário (e também um domain
e code
). Exemplo:
extension MyError: CustomNSError {
public static var errorDomain: String {
return "myDomain"
}
public var errorCode: Int {
switch self {
case .customError:
return 999
}
}
public var errorUserInfo: [String : Any] {
switch self {
case .customError:
return [ "line": 13]
}
}
}
let error = MyError.customError as NSError
if let line = error.userInfo["line"] as? Int {
print("Error in line", line) // Error in line 13
}
print(error.code) // 999
print(error.domain) // myDomain
MyError
umError
primeiro e estendê-loLocalizedError
depois? Existe alguma diferença se você fez issoLocalizedError
em primeiro lugar?var errorDescription: String?
vez deString
. Há um erro na implementação do LocalizedError. Veja SR-5858 .Eu também acrescentaria, se o seu erro tiver parâmetros como este
você pode chamar esses parâmetros em sua descrição localizada assim:
Você pode até tornar isso mais curto assim:
fonte
Agora, existem dois protocolos de adoção de erros que seu tipo de erro pode adotar para fornecer informações adicionais ao Objective-C - LocalizedError e CustomNSError. Aqui está um exemplo de erro que adota os dois:
fonte
Usar uma estrutura pode ser uma alternativa. Um pouco de elegância com localização estática:
fonte
Aqui está a solução mais elegante:
fonte
"Bad entry in file – Argument is not a literal string"
erro ao executarexportLocalizations
ougenstrings
criar sua lista de texto traduzível.switch + case
seja apenas uma opção ...