File: FrameworkFork\Microsoft.Xml\Xml\Dom\XmlEntity.cs
Web Access
Project: src\src\dotnet-svcutil\lib\src\dotnet-svcutil-lib.csproj (dotnet-svcutil-lib)
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
// See the LICENSE file in the project root for more information.
 
namespace Microsoft.Xml
{
    using System;
 
    using System.Diagnostics;
 
    // Represents a parsed or unparsed entity in the XML document.
    public class XmlEntity : XmlNode
    {
        private string _publicId;
        private string _systemId;
        private String _notationName;
        private String _name;
        private String _unparsedReplacementStr;
        private String _baseURI;
        private XmlLinkedNode _lastChild;
        private bool _childrenFoliating;
 
        internal XmlEntity(String name, String strdata, string publicId, string systemId, String notationName, XmlDocument doc) : base(doc)
        {
            _name = doc.NameTable.Add(name);
            _publicId = publicId;
            _systemId = systemId;
            _notationName = notationName;
            _unparsedReplacementStr = strdata;
            _childrenFoliating = false;
        }
 
        // Throws an excption since an entity can not be cloned.
        public override XmlNode CloneNode(bool deep)
        {
            throw new InvalidOperationException(ResXml.Xdom_Node_Cloning);
        }
 
        //
        // Microsoft extensions
        //
 
        // Gets a value indicating whether the node is read-only.
        public override bool IsReadOnly
        {
            get
            {
                return true;        // Make entities readonly
            }
        }
 
 
        // Gets the name of the node.
        public override string Name
        {
            get { return _name; }
        }
 
        // Gets the name of the node without the namespace prefix.
        public override string LocalName
        {
            get { return _name; }
        }
 
        // Gets the concatenated values of the entity node and all its children.
        // The property is read-only and when tried to be set, exception will be thrown.
        public override string InnerText
        {
            get { return base.InnerText; }
            set
            {
                throw new InvalidOperationException(ResXml.Xdom_Ent_Innertext);
            }
        }
 
        internal override bool IsContainer
        {
            get { return true; }
        }
 
        internal override XmlLinkedNode LastNode
        {
            get
            {
                if (_lastChild == null && !_childrenFoliating)
                { //expand the unparsedreplacementstring
                    _childrenFoliating = true;
                    //wrap the replacement string with an element
                    XmlLoader loader = new XmlLoader();
                    loader.ExpandEntity(this);
                }
                return _lastChild;
            }
            set { _lastChild = value; }
        }
 
        internal override bool IsValidChildType(XmlNodeType type)
        {
            return (type == XmlNodeType.Text ||
                   type == XmlNodeType.Element ||
                   type == XmlNodeType.ProcessingInstruction ||
                   type == XmlNodeType.Comment ||
                   type == XmlNodeType.CDATA ||
                   type == XmlNodeType.Whitespace ||
                   type == XmlNodeType.SignificantWhitespace ||
                   type == XmlNodeType.EntityReference);
        }
 
        // Gets the type of the node.
        public override XmlNodeType NodeType
        {
            get { return XmlNodeType.Entity; }
        }
 
        // Gets the value of the public identifier on the entity declaration.
        public String PublicId
        {
            get { return _publicId; }
        }
 
        // Gets the value of the system identifier on the entity declaration.
        public String SystemId
        {
            get { return _systemId; }
        }
 
        // Gets the name of the optional NDATA attribute on the
        // entity declaration.
        public String NotationName
        {
            get { return _notationName; }
        }
 
        //Without override these two functions, we can't guarantee that WriteTo()/WriteContent() functions will never be called
        public override String OuterXml
        {
            get { return String.Empty; }
        }
 
        public override String InnerXml
        {
            get { return String.Empty; }
            set { throw new InvalidOperationException(ResXml.Xdom_Set_InnerXml); }
        }
 
        // Saves the node to the specified XmlWriter.
        public override void WriteTo(XmlWriter w)
        {
        }
 
        // Saves all the children of the node to the specified XmlWriter.
        public override void WriteContentTo(XmlWriter w)
        {
        }
 
        public override String BaseURI
        {
            get { return _baseURI; }
        }
 
        internal void SetBaseURI(String inBaseURI)
        {
            _baseURI = inBaseURI;
        }
    }
}