//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// [....]
//------------------------------------------------------------------------------
namespace System.Xml {
using System.Diagnostics;
// Represents a parsed or unparsed entity in the XML document.
public class XmlEntity : XmlNode {
string publicId;
string systemId;
String notationName;
String name;
String unparsedReplacementStr;
String baseURI;
XmlLinkedNode lastChild;
private bool childrenFoliating;
internal XmlEntity( String name, String strdata, string publicId, string systemId, String notationName, XmlDocument doc ) : base( doc ) {
this.name = doc.NameTable.Add(name);
this.publicId = publicId;
this.systemId = systemId;
this.notationName = notationName;
this.unparsedReplacementStr = strdata;
this.childrenFoliating = false;
}
// Throws an excption since an entity can not be cloned.
public override XmlNode CloneNode(bool deep) {
throw new InvalidOperationException(Res.GetString(Res.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(Res.GetString(Res.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( Res.GetString(Res.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;
}
}
}