After this method returns, subsequent calls to {@link #isDone} will * always return true. Subsequent calls to {@link #isCancelled} * will always return true if this method returned true. * * @param mayInterruptIfRunning true if the thread executing this * task should be interrupted; otherwise, in-progress tasks are allowed * to complete * @return false if the task could not be cancelled, * typically because it has already completed normally; * true otherwise */ boolean cancel(boolean mayInterruptIfRunning); /** * Returns true if this task was cancelled before it completed * normally. * * @return true if this task was cancelled before it completed */ boolean isCancelled(); /** * Returns true if this task completed. * * Completion may be due to normal termination, an exception, or * cancellation -- in all of these cases, this method will return * true. * * @return true if this task completed */ boolean isDone(); /** * Accessor for the future result the {@link AccountManagerFuture} represents. This * call will block until the result is available. In order to check if the result is * available without blocking, one may call {@link #isDone()} and {@link #isCancelled()}. * If the request that generated this result fails or is canceled then an exception * will be thrown rather than the call returning normally. * @return the actual result * @throws android.accounts.OperationCanceledException if the request was canceled for any * reason (including if it is forbidden * by policy to modify an account (of that type)) * @throws android.accounts.AuthenticatorException if there was an error communicating with * the authenticator or if the authenticator returned an invalid response * @throws java.io.IOException if the authenticator returned an error response that indicates * that it encountered an IOException while communicating with the authentication server */ V getResult() throws OperationCanceledException, IOException, AuthenticatorException; /** * Accessor for the future result the {@link AccountManagerFuture} represents. This * call will block until the result is available. In order to check if the result is * available without blocking, one may call {@link #isDone()} and {@link #isCancelled()}. * If the request that generated this result fails or is canceled then an exception * will be thrown rather than the call returning normally. If a timeout is specified then * the request will automatically be canceled if it does not complete in that amount of time. * @param timeout the maximum time to wait * @param unit the time unit of the timeout argument. This must not be null. * @return the actual result * @throws android.accounts.OperationCanceledException if the request was canceled for any * reason * @throws android.accounts.AuthenticatorException if there was an error communicating with * the authenticator or if the authenticator returned an invalid response * @throws java.io.IOException if the authenticator returned an error response that indicates * that it encountered an IOException while communicating with the authentication server */ V getResult(long timeout, TimeUnit unit) throws OperationCanceledException, IOException, AuthenticatorException; }