/* ************************************************************************** description -------------------- copyright : (C) 2000-2001 by Andreas Zehender email : zehender@kde.org ************************************************************************** ************************************************************************** * * * 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. * * * **************************************************************************/ #ifndef PMADDCOMMAND_H #define PMADDCOMMAND_H #ifdef HAVE_CONFIG_H #include <config.h> #endif #include "pmcommand.h" #include "pmobject.h" class PMMemento; /** * Command class for adding a new PMObject */ class PMAddCommand : public PMCommand { public: /** * Command that adds a new PMObject. * * The object obj will be inserted as child of parent after * the object after. * * If after is 0, the object becomes the first child. */ PMAddCommand( PMObject* obj, PMObject* parent, PMObject* after ); /** * Command that adds a list of new PMObjects. * * The object in the list will be inserted as children of parent after * the object after. * * If after is 0, the objects will be inserted as first children. */ PMAddCommand( const PMObjectList& list, PMObject* parent, PMObject* after ); /** * Deletes the command. The inserted object will be deleted, if the command was not executed (or undo-ed) */ virtual ~PMAddCommand( ); /** */ virtual int errorFlags( PMPart* ); protected: /** * Executes the command and stores undo information */ virtual void execute( PMCommandManager* theManager ); /** * Undo the command */ virtual void undo( PMCommandManager* theManager ); private: PMObject* m_pParent; PMObjectList m_objects; PMObject* m_pAfter; bool m_executed, m_firstExecution; PMObjectList m_insertErrors; PMObjectList m_links; PMObjectList m_linkedDeclares; bool m_linksCreated; PMMemento* m_pParentChangeMemento; }; #endif