aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/DocumentChangeEventArgs.cs
diff options
context:
space:
mode:
authorRoy Ben Shabat <Roy.mail.net@gmail.com>2019-04-09 01:47:48 +0300
committerRoy Ben Shabat <Roy.mail.net@gmail.com>2019-04-09 01:47:48 +0300
commit080f1697e97e13461ec6df4d31c8924d01257a1b (patch)
treeb1fe0285de7bc9bc52e9e2195e66fe022bf8f5b3 /Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/DocumentChangeEventArgs.cs
parent1608e69a417bc5e40a607c3958c4a60f19f66f1a (diff)
downloadTango-080f1697e97e13461ec6df4d31c8924d01257a1b.tar.gz
Tango-080f1697e97e13461ec6df4d31c8924d01257a1b.zip
MERGE
Diffstat (limited to 'Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/DocumentChangeEventArgs.cs')
-rw-r--r--Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/DocumentChangeEventArgs.cs131
1 files changed, 131 insertions, 0 deletions
diff --git a/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/DocumentChangeEventArgs.cs b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/DocumentChangeEventArgs.cs
new file mode 100644
index 000000000..17307680a
--- /dev/null
+++ b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/DocumentChangeEventArgs.cs
@@ -0,0 +1,131 @@
+// 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 Tango.Scripting.Editors.Utils;
+using System;
+
+namespace Tango.Scripting.Editors.Document
+{
+ /// <summary>
+ /// Describes a change of the document text.
+ /// This class is thread-safe.
+ /// </summary>
+ [Serializable]
+ public class DocumentChangeEventArgs : EventArgs
+ {
+ /// <summary>
+ /// The offset at which the change occurs.
+ /// </summary>
+ public int Offset { get; private set; }
+
+ /// <summary>
+ /// The text that was removed.
+ /// </summary>
+ public string RemovedText { get; private set; }
+
+ /// <summary>
+ /// The number of characters removed.
+ /// </summary>
+ public int RemovalLength {
+ get { return RemovedText.Length; }
+ }
+
+ /// <summary>
+ /// The text that was inserted.
+ /// </summary>
+ public string InsertedText { get; private set; }
+
+ /// <summary>
+ /// The number of characters inserted.
+ /// </summary>
+ public int InsertionLength {
+ get { return InsertedText.Length; }
+ }
+
+ volatile OffsetChangeMap offsetChangeMap;
+
+ /// <summary>
+ /// Gets the OffsetChangeMap associated with this document change.
+ /// </summary>
+ /// <remarks>The OffsetChangeMap instance is guaranteed to be frozen and thus thread-safe.</remarks>
+ public OffsetChangeMap OffsetChangeMap {
+ get {
+ OffsetChangeMap map = offsetChangeMap;
+ if (map == null) {
+ // create OffsetChangeMap on demand
+ map = OffsetChangeMap.FromSingleElement(CreateSingleChangeMapEntry());
+ offsetChangeMap = map;
+ }
+ return map;
+ }
+ }
+
+ internal OffsetChangeMapEntry CreateSingleChangeMapEntry()
+ {
+ return new OffsetChangeMapEntry(this.Offset, this.RemovalLength, this.InsertionLength);
+ }
+
+ /// <summary>
+ /// Gets the OffsetChangeMap, or null if the default offset map (=single replacement) is being used.
+ /// </summary>
+ internal OffsetChangeMap OffsetChangeMapOrNull {
+ get {
+ return offsetChangeMap;
+ }
+ }
+
+ /// <summary>
+ /// Gets the new offset where the specified offset moves after this document change.
+ /// </summary>
+ public int GetNewOffset(int offset, AnchorMovementType movementType)
+ {
+ if (offsetChangeMap != null)
+ return offsetChangeMap.GetNewOffset(offset, movementType);
+ else
+ return CreateSingleChangeMapEntry().GetNewOffset(offset, movementType);
+ }
+
+ /// <summary>
+ /// Creates a new DocumentChangeEventArgs object.
+ /// </summary>
+ public DocumentChangeEventArgs(int offset, string removedText, string insertedText)
+ : this(offset, removedText, insertedText, null)
+ {
+ }
+
+ /// <summary>
+ /// Creates a new DocumentChangeEventArgs object.
+ /// </summary>
+ public DocumentChangeEventArgs(int offset, string removedText, string insertedText, OffsetChangeMap offsetChangeMap)
+ {
+ ThrowUtil.CheckNotNegative(offset, "offset");
+ ThrowUtil.CheckNotNull(removedText, "removedText");
+ ThrowUtil.CheckNotNull(insertedText, "insertedText");
+
+ this.Offset = offset;
+ this.RemovedText = removedText;
+ this.InsertedText = insertedText;
+
+ if (offsetChangeMap != null) {
+ if (!offsetChangeMap.IsFrozen)
+ throw new ArgumentException("The OffsetChangeMap must be frozen before it can be used in DocumentChangeEventArgs");
+ if (!offsetChangeMap.IsValidForDocumentChange(offset, removedText.Length, insertedText.Length))
+ throw new ArgumentException("OffsetChangeMap is not valid for this document change", "offsetChangeMap");
+ this.offsetChangeMap = offsetChangeMap;
+ }
+ }
+
+ /// <summary>
+ /// Creates DocumentChangeEventArgs for the reverse change.
+ /// </summary>
+ public DocumentChangeEventArgs Invert()
+ {
+ OffsetChangeMap map = this.OffsetChangeMapOrNull;
+ if (map != null) {
+ map = map.Invert();
+ map.Freeze();
+ }
+ return new DocumentChangeEventArgs(this.Offset, this.InsertedText, this.RemovedText, map);
+ }
+ }
+}