diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 11:50:49 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 11:50:49 +0000 |
commit | c853ffb5b2f75f5a889ed2e3ef89b818a736e87a (patch) | |
tree | 7d13a0883bb7936b84d6ecdd7bc332b41ed04bee /src/undo-stack-observer.h | |
parent | Initial commit. (diff) | |
download | inkscape-c853ffb5b2f75f5a889ed2e3ef89b818a736e87a.tar.xz inkscape-c853ffb5b2f75f5a889ed2e3ef89b818a736e87a.zip |
Adding upstream version 1.3+ds.upstream/1.3+dsupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/undo-stack-observer.h')
-rw-r--r-- | src/undo-stack-observer.h | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/src/undo-stack-observer.h b/src/undo-stack-observer.h new file mode 100644 index 0000000..89e7198 --- /dev/null +++ b/src/undo-stack-observer.h @@ -0,0 +1,72 @@ +// SPDX-License-Identifier: GPL-2.0-or-later +/* + * Authors: + * David Yip <yipdw@rose-hulman.edu> + * + * Copyright (c) 2005 Authors + * + * Released under GNU GPL v2+, read the file 'COPYING' for more information. + */ + +#ifndef SEEN_UNDO_COMMIT_OBSERVER_H +#define SEEN_UNDO_COMMIT_OBSERVER_H + +namespace Inkscape { + +struct Event; + +/** + * Observes changes made to the undo and redo stacks. + * + * More specifically, an UndoStackObserver is a class that receives notifications when + * any of the following events occur: + * <ul> + * <li>A change is committed to the undo stack.</li> + * <li>An undo action is made.</li> + * <li>A redo action is made.</li> + * </ul> + * + * UndoStackObservers should not be used on their own. Instead, they should be registered + * with a CompositeUndoStackObserver. + */ +class UndoStackObserver { +public: + UndoStackObserver() = default; + virtual ~UndoStackObserver() = default; + + /** + * Triggered when the user issues an undo command. + * + * \param log Pointer to an Event describing the undone event. + */ + virtual void notifyUndoEvent(Event* log) = 0; + + /** + * Triggered when the user issues a redo command. + * + * \param log Pointer to an Event describing the redone event. + */ + virtual void notifyRedoEvent(Event* log) = 0; + + /** + * Triggered when a set of transactions is committed to the undo log. + * + * \param log Pointer to an Event describing the committed events. + */ + virtual void notifyUndoCommitEvent(Event* log) = 0; + + /** + * Triggered when the undo log is cleared. + */ + virtual void notifyClearUndoEvent() = 0; + + /** + * Triggered when the redo log is cleared. + */ + virtual void notifyClearRedoEvent() = 0; + +}; + +} + +#endif // SEEN_UNDO_COMMIT_OBSERVER_H |