/* * Copyright (C) 2012 The CyanogenMod Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.cyanogenmod.filemanager.console; import android.os.AsyncTask; import com.cyanogenmod.filemanager.commands.SyncResultExecutable; import java.util.ArrayList; import java.util.List; /** * An exception that determines that an operation should be re-executed. */ public abstract class RelaunchableException extends Exception { private static final long serialVersionUID = -3897597978154453512L; private final List<SyncResultExecutable> mExecutables; private AsyncTask<Object, Integer, Boolean> mTask; /** * Constructor of <code>RelaunchableException</code>. * * @param executable The executable that should be re-executed */ public RelaunchableException(SyncResultExecutable executable) { super(); this.mExecutables = new ArrayList<SyncResultExecutable>(); addExecutable(executable); } /** * Constructor of <code>RelaunchableException</code>. * * @param detailMessage Message associated to the exception * @param executable The executable that should be re-executed */ public RelaunchableException(String detailMessage, SyncResultExecutable executable) { super(detailMessage); this.mExecutables = new ArrayList<SyncResultExecutable>(); addExecutable(executable); } /** * Constructor of <code>RelaunchableException</code>. * * @param detailMessage Message associated to the exception * @param throwable The cause of the exception * @param executable The executable that should be re-executed */ public RelaunchableException( String detailMessage, Throwable throwable, SyncResultExecutable executable) { super(detailMessage, throwable); this.mExecutables = new ArrayList<SyncResultExecutable>(); addExecutable(executable); } /** * Method that returns the executable that should be re-executed. * * @return SyncResultExecutable The list of executable that should be re-executed */ public List<SyncResultExecutable> getExecutables() { return this.mExecutables; } /** * Method that add a new executable to the queue of command to be re-executed. * * @param executable The executable to add */ public void addExecutable(SyncResultExecutable executable) { this.mExecutables.add(executable); } /** * Method that returns the task to execute when the re-execution ends. * * @return AsyncTask<Object, Integer, Boolean> The task to execute when the re-execution ends */ public AsyncTask<Object, Integer, Boolean> getTask() { return this.mTask; } /** * Method that set the task to execute when the re-execution ends. * * @param task The task to execute when the re-execution ends */ public void setTask(AsyncTask<Object, Integer, Boolean> task) { this.mTask = task; } /** * Method that returns he resource identifier of the question to translate to the user. * * @return int The resource identifier of the question to translate to the user. */ public abstract int getQuestionResourceId(); }