//
// System.Xml.XmlAttribute
//
-// Author:
+// Authors:
// Jason Diamond (jason@injektilo.org)
+// Atsushi Enomoto (ginga@kit.hi-ho.ne.jp)
//
// (C) 2002 Jason Diamond http://injektilo.org/
+// (C) 2003 Atsushi Enomoto
//
using System;
#region Constructor
- [MonoTODO("need to set namespaceURI if prefix is recognized built-in ones like xmlns")]
protected internal XmlAttribute (
string prefix,
string localName,
- string namespaceURI,
+ string namespaceURI,
XmlDocument doc) : base (doc)
{
+ if (prefix == null)
+ prefix = String.Empty;
+ if (namespaceURI == null)
+ namespaceURI = String.Empty;
+
+ // Prefix "xml" should be also checked (http://www.w3.org/XML/xml-names-19990114-errata#NE05)
+ // but MS.NET ignores such case.
+ if (prefix == "xmlns" || (prefix == "" && localName == "xmlns"))
+ if (namespaceURI != XmlNamespaceManager.XmlnsXmlns)
+ throw new ArgumentException ("Invalid attribute namespace for namespace declaration.");
+ else if (prefix == "xml" && namespaceURI != XmlNamespaceManager.XmlnsXml)
+ throw new ArgumentException ("Invalid attribute namespace for namespace declaration.");
+
+ // There are no means to identify the DOM is namespace-
+ // aware or not, so we can only check Name validity.
+ if (prefix != "" && !XmlChar.IsName (prefix))
+ throw new ArgumentException ("Invalid attribute prefix.");
+ else if (!XmlChar.IsName (localName))
+ throw new ArgumentException ("Invalid attribute local name.");
+
this.prefix = prefix;
this.localName = localName;
this.namespaceURI = namespaceURI;
}
}
- [MonoTODO ("Setter")]
public override string InnerText {
get {
- StringBuilder builder = new StringBuilder ();
- AppendChildValues (this, builder);
- return builder.ToString ();
- }
+ return base.InnerText;
+ }
set {
- throw new NotImplementedException ();
+ Value = value;
}
}
- private void AppendChildValues (XmlNode parent, StringBuilder builder)
- {
- XmlNode node = parent.FirstChild;
-
- while (node != null) {
- builder.Append (node.Value);
- AppendChildValues (node, builder);
- node = node.NextSibling;
- }
- }
-
- [MonoTODO ("Setter.")]
public override string InnerXml {
get {
// Not sure why this is an override. Passing through for now.
}
set {
- throw new NotImplementedException ();
+ RemoveAll ();
+ XmlNamespaceManager nsmgr = ConstructNamespaceManager ();
+ XmlParserContext ctx = new XmlParserContext (OwnerDocument.NameTable, nsmgr,
+ OwnerDocument.DocumentType != null ? OwnerDocument.DocumentType.DTD : null,
+ BaseURI, XmlLang, XmlSpace, null);
+ XmlTextReader xtr = new XmlTextReader (value, XmlNodeType.Attribute, ctx);
+ xtr.XmlResolver = OwnerDocument.Resolver;
+ xtr.Read ();
+ OwnerDocument.ReadAttributeNodeValue (xtr, this);
}
}
}
}
- [MonoTODO]
public override XmlNode ParentNode {
get {
+ // It always returns null (by specification).
return null;
}
}
- [MonoTODO]
// We gotta do more in the set block here
// We need to do the proper tests and throw
// the correct Exceptions
+ //
+ // Wrong cases are: (1)check readonly, (2)check character validity,
+ // (3)check format validity, (4)this is attribute and qualifiedName != "xmlns"
public override string Prefix {
set {
+ if (IsReadOnly)
+ throw new XmlException ("This node is readonly.");
+ if (!XmlChar.IsNCName (value))
+ throw new ArgumentException ("Specified name is not a valid NCName: " + value);
+
prefix = value;
}
}
}
- [MonoTODO("There are no code which sets 'specified = true', so this logic is without checking.")]
public virtual bool Specified {
get {
return !isDefault;
XmlNode firstChild = FirstChild;
if (firstChild == null)
AppendChild (OwnerDocument.CreateTextNode (value));
+ else if (FirstChild.NextSibling != null) {
+ this.RemoveAll ();
+ AppendChild (OwnerDocument.CreateTextNode (value));
+ }
else
firstChild.Value = value;
}
}
+ internal override string XmlLang {
+ get { return OwnerElement.XmlLang; }
+ }
+
+ internal override XmlSpace XmlSpace {
+ get { return OwnerElement.XmlSpace; }
+ }
+
#endregion
#region Methods
XmlNode node = new XmlAttribute (prefix, localName, namespaceURI,
OwnerDocument);
if (deep) {
- while ((node != null) && (node.HasChildNodes)) {
- AppendChild (node.NextSibling.CloneNode (true));
- node = node.NextSibling;
- }
+ foreach (XmlNode child in this.ChildNodes)
+ node.AppendChild (child.CloneNode (deep));
}
return node;
}
+ internal void SetDefault ()
+ {
+ isDefault = true;
+ }
+
// Parent of XmlAttribute must be null
- internal void SetOwnerElement(XmlElement el) {
+ internal void SetOwnerElement (XmlElement el) {
ownerElement = el;
}
public override void WriteContentTo (XmlWriter w)
{
- w.WriteString (Value);
+ foreach (XmlNode n in ChildNodes)
+ n.WriteTo (w);
}
public override void WriteTo (XmlWriter w)
{
- w.WriteAttributeString (prefix, localName, namespaceURI, Value);
+ w.WriteStartAttribute (prefix, localName, namespaceURI);
+ WriteContentTo (w);
+ w.WriteEndAttribute ();
}
#endregion