2 Copyright (C) 2002 Brett Viren & Paul Davis
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 #ifndef __lib_pbd_undo_h__
21 #define __lib_pbd_undo_h__
26 #include <sigc++/slot.h>
27 #include <sigc++/bind.h>
31 #include <ardourext/misc.h>
34 #include "pbd/command.h"
36 typedef sigc::slot<void> UndoAction;
38 class UndoTransaction : public Command
42 UndoTransaction (const UndoTransaction&);
43 UndoTransaction& operator= (const UndoTransaction&);
48 bool clearing () const { return _clearing; }
50 void add_command (Command* const);
51 void remove_command (Command* const);
59 void set_timestamp (struct timeval &t) {
63 const struct timeval& timestamp() const {
68 std::list<Command*> actions;
69 struct timeval _timestamp;
72 friend void command_death (UndoTransaction*, Command *);
74 void about_to_explicitly_delete ();
77 class UndoHistory : public PBD::ScopedConnectionList
83 void add (UndoTransaction* ut);
84 void undo (unsigned int n);
85 void redo (unsigned int n);
87 unsigned long undo_depth() const { return UndoList.size(); }
88 unsigned long redo_depth() const { return RedoList.size(); }
90 std::string next_undo() const { return (UndoList.empty() ? std::string() : UndoList.back()->name()); }
91 std::string next_redo() const { return (RedoList.empty() ? std::string() : RedoList.back()->name()); }
97 /* returns all or part of the history.
98 If depth==0 it returns just the top
99 node. If depth<0, it returns everything.
100 If depth>0, it returns state for that
101 many elements of the history, or
102 the full history, whichever is smaller.
105 XMLNode &get_state(int32_t depth = 0);
108 void set_depth (uint32_t);
110 PBD::Signal0<void> Changed;
111 PBD::Signal0<void> BeginUndoRedo;
112 PBD::Signal0<void> EndUndoRedo;
117 std::list<UndoTransaction*> UndoList;
118 std::list<UndoTransaction*> RedoList;
120 void remove (UndoTransaction*);
124 #endif /* __lib_pbd_undo_h__ */