Oto ogólne rozwiązanie, które można zastosować do dowolnej funkcji asynchronicznej, że nie posiada żadnych parametrów, z wyjątkiem tych wywołań zwrotnych. Uprościłem logikę, mając tylko wywołania zwrotne o numerach od success
i failure
, co nie powinno być trudne.
Zakładając więc, że funkcja jest tak:
func startUploading(success: Void -> Void, failure: NSError -> Void) {
DDLogDebug("JogUploader: Creating jog: \(self.jog)")
API.sharedInstance.createJog(self.jog,
failure: { error in
failure(error)
}, success: {_ in
success()
})
}
retry
funkcja dopasowania to będzie wyglądać następująco:
func retry(numberOfTimes: Int, task: (success: Void -> Void, failure: NSError -> Void) -> Void, success: Void -> Void, failure: NSError -> Void) {
task(success: success,
failure: { error in
// do we have retries left? if yes, call retry again
// if not, report error
if numberOfTimes > 1 {
retry(numberOfTimes - 1, task: task, success: success, failure: failure)
} else {
failure(error)
}
})
}
i można nazwać tak:
retry(3, task: startUploading,
success: {
print("Succeeded")
},
failure: { err in
print("Failed: \(err)")
})
Powyższa próba będzie się powtórzyć trzy razy, jeśli zostanie wykonana próba połączenia z numerem startUploading
. ciągle się nie udaje, inaczej zakończy się z pierwszym sukcesem.
Edytuj. Funkcje, które mają inne params może być po prostu osadzone w zamknięciu:
func updateUsername(username: String, success: Void -> Void, failure: NSError -> Void) {
...
}
retry(3, { success, failure in updateUsername(newUsername, success, failure) },
success: {
print("Updated username")
},
failure: {
print("Failed with error: \($0)")
}
)
Sprawdź moje odpowiedzi na podobne pytanie: http://stackoverflow.com/a/38720898/319805 – MNassar