aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/LineNode.cs
diff options
context:
space:
mode:
authorVictoria Plitt <Victoria.Plitt@twine-s.com>2019-04-08 13:49:55 +0300
committerVictoria Plitt <Victoria.Plitt@twine-s.com>2019-04-08 13:49:55 +0300
commitfc8a05358a92cc3c77c5f1e30d536807ef0614fd (patch)
treec65f696ebd60f3790145721307c255e5a339923f /Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/LineNode.cs
parentb4a71931ea52636c6b36376aa9d71697ccf73524 (diff)
downloadTango-fc8a05358a92cc3c77c5f1e30d536807ef0614fd.tar.gz
Tango-fc8a05358a92cc3c77c5f1e30d536807ef0614fd.zip
were added scripting projects
Diffstat (limited to 'Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/LineNode.cs')
-rw-r--r--Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/LineNode.cs83
1 files changed, 83 insertions, 0 deletions
diff --git a/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/LineNode.cs b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/LineNode.cs
new file mode 100644
index 000000000..317202721
--- /dev/null
+++ b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Document/LineNode.cs
@@ -0,0 +1,83 @@
+// 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;
+
+namespace Tango.Scripting.Editors.Document
+{
+ using LineNode = DocumentLine;
+
+ // A tree node in the document line tree.
+ // For the purpose of the invariants, "children", "descendents", "siblings" etc. include the DocumentLine object,
+ // it is treated as a third child node between left and right.
+
+ // Originally, this was a separate class, with a reference to the documentLine. The documentLine had a reference
+ // back to the node. To save memory, the same object is used for both the documentLine and the line node.
+ // This saves 16 bytes per line (8 byte object overhead + two pointers).
+// sealed class LineNode
+// {
+// internal readonly DocumentLine documentLine;
+ partial class DocumentLine
+ {
+ internal DocumentLine left, right, parent;
+ internal bool color;
+ // optimization note: I tried packing color and isDeleted into a single byte field, but that
+ // actually increased the memory requirements. The JIT packs two bools and a byte (delimiterSize)
+ // into a single DWORD, but two bytes get each their own DWORD. Three bytes end up in the same DWORD, so
+ // apparently the JIT only optimizes for memory when there are at least three small fields.
+ // Currently, DocumentLine takes 36 bytes on x86 (8 byte object overhead, 3 pointers, 3 ints, and another DWORD
+ // for the small fields).
+ // TODO: a possible optimization would be to combine 'totalLength' and the small fields into a single uint.
+ // delimiterSize takes only two bits, the two bools take another two bits; so there's still
+ // 28 bits left for totalLength. 268435455 characters per line should be enough for everyone :)
+
+ /// <summary>
+ /// Resets the line to enable its reuse after a document rebuild.
+ /// </summary>
+ internal void ResetLine()
+ {
+ totalLength = delimiterLength = 0;
+ isDeleted = color = false;
+ left = right = parent = null;
+ }
+
+ internal LineNode InitLineNode()
+ {
+ this.nodeTotalCount = 1;
+ this.nodeTotalLength = this.TotalLength;
+ return this;
+ }
+
+ internal LineNode LeftMost {
+ get {
+ LineNode node = this;
+ while (node.left != null)
+ node = node.left;
+ return node;
+ }
+ }
+
+ internal LineNode RightMost {
+ get {
+ LineNode node = this;
+ while (node.right != null)
+ node = node.right;
+ return node;
+ }
+ }
+
+ /// <summary>
+ /// The number of lines in this node and its child nodes.
+ /// Invariant:
+ /// nodeTotalCount = 1 + left.nodeTotalCount + right.nodeTotalCount
+ /// </summary>
+ internal int nodeTotalCount;
+
+ /// <summary>
+ /// The total text length of this node and its child nodes.
+ /// Invariant:
+ /// nodeTotalLength = left.nodeTotalLength + documentLine.TotalLength + right.nodeTotalLength
+ /// </summary>
+ internal int nodeTotalLength;
+ }
+}