From 080f1697e97e13461ec6df4d31c8924d01257a1b Mon Sep 17 00:00:00 2001 From: Roy Ben Shabat Date: Tue, 9 Apr 2019 01:47:48 +0300 Subject: MERGE --- .../Document/UndoOperationGroup.cs | 61 ++++++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100644 Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/UndoOperationGroup.cs (limited to 'Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/UndoOperationGroup.cs') diff --git a/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/UndoOperationGroup.cs b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/UndoOperationGroup.cs new file mode 100644 index 000000000..12afe3838 --- /dev/null +++ b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/UndoOperationGroup.cs @@ -0,0 +1,61 @@ +// Copyright (c) AlphaSierraPapa for the SharpDevelop Team (for details please see \doc\copyright.txt) +// This code is distributed under the GNU LGPL (for details please see \doc\license.txt) + +using System; +using System.Diagnostics; +using Tango.Scripting.Editors.Utils; + +namespace Tango.Scripting.Editors.Document +{ + /// + /// This class stacks the last x operations from the undostack and makes + /// one undo/redo operation from it. + /// + sealed class UndoOperationGroup : IUndoableOperationWithContext + { + IUndoableOperation[] undolist; + + public UndoOperationGroup(Deque stack, int numops) + { + if (stack == null) { + throw new ArgumentNullException("stack"); + } + + Debug.Assert(numops > 0 , "UndoOperationGroup : numops should be > 0"); + Debug.Assert(numops <= stack.Count); + + undolist = new IUndoableOperation[numops]; + for (int i = 0; i < numops; ++i) { + undolist[i] = stack.PopBack(); + } + } + + public void Undo() + { + for (int i = 0; i < undolist.Length; ++i) { + undolist[i].Undo(); + } + } + + public void Undo(UndoStack stack) + { + for (int i = 0; i < undolist.Length; ++i) { + stack.RunUndo(undolist[i]); + } + } + + public void Redo() + { + for (int i = undolist.Length - 1; i >= 0; --i) { + undolist[i].Redo(); + } + } + + public void Redo(UndoStack stack) + { + for (int i = undolist.Length - 1; i >= 0; --i) { + stack.RunRedo(undolist[i]); + } + } + } +} -- cgit v1.3.1