summaryrefslogtreecommitdiffstats
path: root/src/undomanager.h
diff options
context:
space:
mode:
authortpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2010-01-17 23:39:35 +0000
committertpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2010-01-17 23:39:35 +0000
commitf48aef5ed7f2e333984766d9ceb02e01ecbd47a7 (patch)
tree6ed79de882f3051cf7999a9cee2b633d8daabeab /src/undomanager.h
downloaddolphin-f48aef5ed7f2e333984766d9ceb02e01ecbd47a7.tar.gz
dolphin-f48aef5ed7f2e333984766d9ceb02e01ecbd47a7.zip
Added old KDE3 version of dolphin
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/dolphin@1076309 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'src/undomanager.h')
-rw-r--r--src/undomanager.h196
1 files changed, 196 insertions, 0 deletions
diff --git a/src/undomanager.h b/src/undomanager.h
new file mode 100644
index 0000000..fb6f14e
--- /dev/null
+++ b/src/undomanager.h
@@ -0,0 +1,196 @@
+/***************************************************************************
+ * Copyright (C) 2006 by Peter Penz *
+ * *
+ * 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., *
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
+ ***************************************************************************/
+
+#ifndef UNDOMANAGER_H
+#define UNDOMANAGER_H
+
+#include <qobject.h>
+#include <qvaluelist.h>
+#include <kurl.h>
+#include <kio/jobclasses.h>
+
+class ProgressIndicator;
+
+/**
+ * @short Represents a file manager command which can be undone and redone.
+ *
+ * A command is specified by a type, a list of source URLs and a
+ * destination URL.
+ *
+ * Due to the fixed set of commands a file manager offers this class is
+ * a very simplified version of the classic command pattern.
+ *
+ * @see UndoManager
+ * @author Peter Penz <[email protected]>
+ */
+class DolphinCommand
+{
+public:
+ enum Type {
+ Copy,
+ Move,
+ Link,
+ Rename,
+ Trash,
+ CreateFolder,
+ CreateFile
+ };
+
+ DolphinCommand();
+ DolphinCommand(Type type, const KURL::List& source, const KURL& dest);
+ ~DolphinCommand(); // non-virtual
+
+ DolphinCommand& operator = (const DolphinCommand& command);
+ Type type() const { return m_type; }
+ void setSource(const KURL::List source) { m_source = source; }
+ const KURL::List& source() const { return m_source; }
+ const KURL& destination() const { return m_dest; }
+
+private:
+ Type m_type;
+ int m_macroIndex;
+ KURL::List m_source;
+ KURL m_dest;
+
+ friend class UndoManager; // allow to modify m_macroIndex
+};
+
+/**
+ * @short Stores all file manager commands which can be undone and redone.
+ *
+ * During the undo and redo operations a progress information is
+ * shown in the status bar.
+ *
+ * @author Peter Penz <[email protected]>
+ */
+class UndoManager : public QObject
+{
+ Q_OBJECT
+
+public:
+ static UndoManager& instance();
+
+ /**
+ * Adds the command \a command to the undo list. The command
+ * can be undone by invoking UndoManager::undo().
+ */
+ void addCommand(const DolphinCommand& command);
+
+ /**
+ * Allows to summarize several commands into one macro, which
+ * can be undo in one stop by UndoManager::undo(). Example
+ * \code
+ * UndoManager& undoMan = UndoManager.instance();
+ * undoMan.beginMacro();
+ * undoMan.addCommand(...);
+ * undoMan.addCommand(...);
+ * undoMan.addCommand(...);
+ * undoMan.endMacro();
+ * \endcode
+ * It is not allowed to do nested macro recordings.
+ */
+ void beginMacro();
+
+ /**
+ * Marks the end of a macro command. See UndoManager::beginMacro()
+ * for sample code.
+ */
+ void endMacro();
+
+public slots:
+ /**
+ * Performs an undo operation on the last command which has
+ * been added by UndoManager::addCommand().
+ */
+ void undo();
+
+ /**
+ * Performs a redo operation on the last command where an undo
+ * operation has been applied.
+ */
+ void redo();
+
+signals:
+ /**
+ * Is emitted if whenever the availability state
+ * of the current undo operation changes.
+ */
+ void undoAvailable(bool available);
+
+ /**
+ * Is emitted whenever the text of the current
+ * undo operation changes
+ * (e. g. from 'Undo: Delete' to 'Undo: Copy')
+ */
+ void undoTextChanged(const QString& text);
+
+ /**
+ * Is emitted if whenever the availability state
+ * of the current redo operation changes.
+ */
+ void redoAvailable(bool available);
+
+ /**
+ * Is emitted whenever the text of the current
+ * redo operation changes
+ * (e. g. from 'Redo: Delete' to 'Redo: Copy')
+ */
+ void redoTextChanged(const QString& text);
+
+protected:
+ UndoManager();
+ virtual ~UndoManager();
+ QString commandText(const DolphinCommand& command) const;
+
+private slots:
+ /**
+ * Slot for the percent information of the I/O slaves.
+ * Delegates the updating of the progress information
+ * to UndoManager::updateProgress().
+ */
+ void slotPercent(KIO::Job* job, unsigned long percent);
+
+ /**
+ * Updates the progress information of the statusbar
+ * by accessing the progress indicator information.
+ */
+ void updateProgress();
+
+private:
+ bool m_recordMacro;
+ int m_historyIndex;
+ int m_macroCounter;
+ QValueList<DolphinCommand> m_history;
+ ProgressIndicator* m_progressIndicator;
+
+ /**
+ * Dependent from the current history index \a m_historyIndex
+ * the number of macro commands is written to the output
+ * parameter \a macroCount. The number of steps for all macro
+ * commands is written to the output parameter \a progressCount.
+ *
+ * Per default \a macroCount is 1 and \a progressCount represents
+ * the number of operations for one command.
+ */
+ void calcStepsCount(int& macroCount,
+ int& progressCount);
+};
+
+#endif