/****************************************************************************** * Copyright (C) 2005-2015 by * * Bjoern Erik Nilsen (bjoern.nilsen@bjoernen.com), * * Fredrik Berg Kjoelstad (fredrikbk@hotmail.com), * * Ralf Lange (ralf.lange@longsoft.de) * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * * the Free Software Foundation; either version 2 of the License, or * * (at your option) any later version. * * * * This program is distributed in the hope that it will be useful, * * but WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * * GNU General Public License for more details. * * * * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ******************************************************************************/ #ifndef UNDOTAKEREMOVE_H #define UNDOTAKEREMOVE_H #include /** * The UndoTakeRemove class for undoing removeTake(...) calls to the project. */ class UndoTakeRemove : public UndoBase { Q_OBJECT public: /** * Sets up the UndoTakeRemove command object with the information needed to undo and * redo the add command. * @param df Domain facade for commands. * @param si the index of the scene the removed take had. * @param ti the index the removed take had. * command */ UndoTakeRemove(DomainFacade *df, int si, int ti); /** * Cleans up after the undo object. */ ~UndoTakeRemove(); /** * Abstract function for undoing the command represented by this undo object. */ virtual void undo(); /** * Abstract function for redoing (performing) the command represented by this * undo object. */ virtual void redo(); private: /** * The model to perform the redo command on. */ int sceneIndex; int takeIndex; Take *removedTake; bool undoFlag; }; #endif