aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/AXmlDocument.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/Xml/AXmlDocument.cs
parentb4a71931ea52636c6b36376aa9d71697ccf73524 (diff)
downloadTango-fc8a05358a92cc3c77c5f1e30d536807ef0614fd.tar.gz
Tango-fc8a05358a92cc3c77c5f1e30d536807ef0614fd.zip
were added scripting projects
Diffstat (limited to 'Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/AXmlDocument.cs')
-rw-r--r--Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/AXmlDocument.cs69
1 files changed, 69 insertions, 0 deletions
diff --git a/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/AXmlDocument.cs b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/AXmlDocument.cs
new file mode 100644
index 000000000..f96c50ca4
--- /dev/null
+++ b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Xml/AXmlDocument.cs
@@ -0,0 +1,69 @@
+// 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.Collections.Generic;
+using System.Collections.ObjectModel;
+using System.Collections.Specialized;
+using System.Diagnostics;
+using System.Globalization;
+using System.Linq;
+
+using Tango.Scripting.Editors.Document;
+
+namespace Tango.Scripting.Editors.Xml
+{
+ /// <summary>
+ /// The root object of the XML document
+ /// </summary>
+ public class AXmlDocument: AXmlContainer
+ {
+ /// <summary> Parser that produced this document </summary>
+ internal AXmlParser Parser { get; set; }
+
+ /// <summary> Occurs when object is added to any part of the document </summary>
+ public event EventHandler<NotifyCollectionChangedEventArgs> ObjectInserted;
+ /// <summary> Occurs when object is removed from any part of the document </summary>
+ public event EventHandler<NotifyCollectionChangedEventArgs> ObjectRemoved;
+ /// <summary> Occurs before local data of any object in the document changes </summary>
+ public event EventHandler<AXmlObjectEventArgs> ObjectChanging;
+ /// <summary> Occurs after local data of any object in the document changed </summary>
+ public event EventHandler<AXmlObjectEventArgs> ObjectChanged;
+
+ internal void OnObjectInserted(int index, AXmlObject obj)
+ {
+ if (ObjectInserted != null)
+ ObjectInserted(this, new NotifyCollectionChangedEventArgs(NotifyCollectionChangedAction.Add, new AXmlObject[] { obj }.ToList(), index));
+ }
+
+ internal void OnObjectRemoved(int index, AXmlObject obj)
+ {
+ if (ObjectRemoved != null)
+ ObjectRemoved(this, new NotifyCollectionChangedEventArgs(NotifyCollectionChangedAction.Remove, new AXmlObject[] { obj }.ToList(), index));
+ }
+
+ internal void OnObjectChanging(AXmlObject obj)
+ {
+ if (ObjectChanging != null)
+ ObjectChanging(this, new AXmlObjectEventArgs() { Object = obj } );
+ }
+
+ internal void OnObjectChanged(AXmlObject obj)
+ {
+ if (ObjectChanged != null)
+ ObjectChanged(this, new AXmlObjectEventArgs() { Object = obj } );
+ }
+
+ /// <inheritdoc/>
+ public override void AcceptVisitor(IAXmlVisitor visitor)
+ {
+ visitor.VisitDocument(this);
+ }
+
+ /// <inheritdoc/>
+ public override string ToString()
+ {
+ return string.Format(CultureInfo.InvariantCulture, "[{0} Chld:{1}]", base.ToString(), this.Children.Count);
+ }
+ }
+}