/* * Copyright (c) 2004 Carsten Burghardt * * 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; version 2 of the License * * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * * In addition, as a special exception, the copyright holders give * permission to link the code of this program with any edition of * the TQt library by Trolltech AS, Norway (or with modified versions * of TQt that use the same license as TQt), and distribute linked * combinations including the two. You must obey the GNU General * Public License in all respects for all of the code used other than * TQt. If you modify this file, you may extend this exception to * your version of the file, but you are not obligated to do so. If * you do not wish to do so, delete this exception statement from * your version. */ #ifndef RENAMEJOB_H #define RENAMEJOB_H #include "folderjob.h" class FolderStorage; class KMFolderDir; class KMFolder; class KMCommand; namespace TDEIO { class Job; } namespace KMail { class CopyFolderJob; /** * Rename and move (d)imap folders * They can be moved everywhere (except search folders) as a new folder is * created, all messages are moved there and the original folder is deleted */ class RenameJob : public FolderJob { Q_OBJECT public: /** * Create a new job * @param storage the folder that should be renames * @param newName the new name of the folder * @param newParent the new parent if the folder should be moved, else 0 */ RenameJob( FolderStorage* storage, const TQString& newName, KMFolderDir* newParent = 0 ); virtual ~RenameJob(); virtual void execute(); protected slots: /** Rename the folder */ void slotRenameResult( TDEIO::Job* job ); /** All messages are copied so remove the original folder */ void folderCopyComplete( bool success ); signals: /** Emitted when the job is done, check the success bool */ void renameDone( TQString newName, bool success ); protected: FolderStorage* mStorage; FolderStorage* mStorageTempOpened; KMFolderDir* mNewParent; TQString mNewName; TQString mNewImapPath; TQString mOldName; TQString mOldImapPath; TQStringList mOldImapPaths; KMFolder* mNewFolder; CopyFolderJob *mCopyFolderJob; }; } // namespace KMail #endif /* RENAMEJOB_H */