aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llui/llundo.h
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--linden/indra/llui/llundo.h71
1 files changed, 71 insertions, 0 deletions
diff --git a/linden/indra/llui/llundo.h b/linden/indra/llui/llundo.h
new file mode 100644
index 0000000..10d556f
--- /dev/null
+++ b/linden/indra/llui/llundo.h
@@ -0,0 +1,71 @@
1/**
2 * @file llundo.h
3 * @brief LLUndo class header file
4 *
5 * Copyright (c) 2000-2007, Linden Research, Inc.
6 *
7 * The source code in this file ("Source Code") is provided by Linden Lab
8 * to you under the terms of the GNU General Public License, version 2.0
9 * ("GPL"), unless you have obtained a separate licensing agreement
10 * ("Other License"), formally executed by you and Linden Lab. Terms of
11 * the GPL can be found in doc/GPL-license.txt in this distribution, or
12 * online at http://secondlife.com/developers/opensource/gplv2
13 *
14 * There are special exceptions to the terms and conditions of the GPL as
15 * it is applied to this Source Code. View the full text of the exception
16 * in the file doc/FLOSS-exception.txt in this software distribution, or
17 * online at http://secondlife.com/developers/opensource/flossexception
18 *
19 * By copying, modifying or distributing this software, you acknowledge
20 * that you have read and understood your obligations described above,
21 * and agree to abide by those obligations.
22 *
23 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
24 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
25 * COMPLETENESS OR PERFORMANCE.
26 */
27
28#ifndef LL_LLUNDO_H
29#define LL_LLUNDO_H
30
31class LLUndoAction
32{
33 friend class LLUndoBuffer;
34protected:
35 S32 mClusterID;
36protected:
37 LLUndoAction(): mClusterID(0) {};
38 virtual ~LLUndoAction(){};
39
40public:
41 static LLUndoAction *create() { return NULL; }
42
43 virtual void undo() = 0;
44 virtual void redo() = 0;
45 virtual void cleanup() {};
46};
47
48class LLUndoBuffer
49{
50protected:
51 LLUndoAction **mActions; // array of pointers to undoactions
52 S32 mNumActions; // total number of actions in ring buffer
53 S32 mNextAction; // next action to perform undo/redo on
54 S32 mLastAction; // last action actually added to undo buffer
55 S32 mFirstAction; // beginning of ring buffer (don't undo any further)
56 S32 mOperationID; // current operation id, for undoing and redoing in clusters
57
58public:
59 LLUndoBuffer( LLUndoAction (*create_func()), S32 initial_count );
60 virtual ~LLUndoBuffer();
61
62 LLUndoAction *getNextAction(BOOL setClusterBegin = TRUE);
63 BOOL undoAction();
64 BOOL redoAction();
65 BOOL canUndo() { return (mNextAction != mFirstAction); }
66 BOOL canRedo() { return (mNextAction != mLastAction); }
67
68 void flushActions();
69};
70
71#endif //LL_LLUNDO_H