XML C#

#region License and Copyright
/*
 * Dotnet Commons Xml
 *
 *
 * This library is free software; you can redistribute it and/or modify it 
 * under the terms of the GNU Lesser General Public License as published by 
 * the Free Software Foundation; either version 2.1 of the License, or 
 * (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful, but 
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 
 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License 
 * for more details. 
 *
 * You should have received a copy of the GNU Lesser General Public License 
 * along with this library; if not, write to the 
 * Free Software Foundation, Inc., 
 * 59 Temple Place, 
 * Suite 330, 
 * Boston, 
 * MA 02111-1307 
 * USA 
 * 
 */
#endregion
using System;
using System.Collections;
using System.Collections.Specialized;
using System.Diagnostics;
using System.IO;
using System.Reflection;
using System.Text;
using System.Text.RegularExpressions;
using System.Xml;
using System.Xml.Xsl;
using System.Xml.Serialization;
//using Dotnet.Commons.Reflection;
namespace Dotnet.Commons.Xml
{
  
  ///  
  /// 
  /// This utility class contains wrapper functions that help to ease the handling and 
    /// manipulation of Xml documents, such as adding an element, adding an attribute
    /// to an element, copying and cloning of nodes, etc.
  ///
  /// 

  /// 
    
  public abstract class XmlUtils
  {
    /// -----------------------------------------------------------
    /// 
    /// Set the value to the Element
    /// 

    /// the node to set the value 
    /// Value to set
    /// 
    ///    Thrown if XmlNode is not an element or node is 
    ///    not a text node (no child nodes)
    ///  
    /// -----------------------------------------------------------
    public static void SetNodeValue( XmlNode node, object nodeValue )
    {  
      if (node == null)
        throw new ArgumentNullException("node");
      if (node.NodeType != XmlNodeType.Element)
        throw new XmlException("Node is not an element.");
      if (node.ChildNodes.Count > 0)
        throw new XmlException("Node is not a text node as it has child nodes.");
      node.AppendChild(node.OwnerDocument.CreateTextNode(nodeValue.ToString()));
    }
    /// ------------------------------------------------------------------
    /// 
    /// Set the value to a node
    /// 

    /// parentNode to start search from
    /// XPath to the child node
    /// the new value to set to
    /// Thrown if parentNode is null
    /// Thrown if no text node is found at the xpath provided.
    /// Thrown if node to set the value is not a text node (ie. no child nodes)
    /// ------------------------------------------------------------------
    public static void SetNodeValue(XmlNode parentNode, 
                    string xpath, 
                    object nodeValue)
    {
      if (parentNode == null)
        throw new ArgumentNullException("parentNode");
      XmlNode childNode = parentNode.SelectSingleNode(xpath);
      
      if(childNode == null)
        throw new ArgumentException(String.Format("No node is not found at the path specified '{0}'", xpath), "xpath");
      
      if (childNode.ChildNodes.Count > 0)
        throw new XmlException("Child node is not a text node as it has child nodes.");
      childNode.InnerText = nodeValue.ToString();
      
    }
    /// -----------------------------------------------------------
    /// 
    /// Set a blog of binary data encoded with Base64 to an XML element.
    /// 

    /// the node to set the blog of data
    /// an array of bytes containing the actual data
    /// Thrown if XmlNode is not an element or 
    ///    node is not a text node (no child nodes)
    /// -----------------------------------------------------------
    public static void SetNodeBase64BinaryValue( XmlNode node, byte[] byteArray )
    {
      if (node.NodeType != XmlNodeType.Element)
        throw new XmlException("Node is not an element.");
      if (node.ChildNodes.Count > 0)
        throw new XmlException("Node is not a text node as it has child nodes.");
      // Convet byte array into Base64 string
      string encodedData = Convert.ToBase64String(byteArray);
      
      node.AppendChild(node.OwnerDocument.CreateTextNode(encodedData));
    }
    /// -----------------------------------------------------------
    /// 
    /// Encode a value to Base64 and set it to the node.
    /// 

    /// the node to set the value
    /// value to set to the node
    /// Thrown if XmlNode is not an element 
    /// or node is not a text node (no child nodes)
    /// -----------------------------------------------------------
    public static void SetNodeBase64EncodedValue( XmlNode node, object value)
    {
      if (value is byte[])
        SetNodeBase64BinaryValue(node, (byte[])value);
      if (node.NodeType != XmlNodeType.Element)
        throw new XmlException("Node is not an element.");
      if (node.ChildNodes.Count > 0)
        throw new XmlException("Node is not a text node as it has child nodes.");
      // Convet byte array into Base64 string
      ASCIIEncoding encoding = new ASCIIEncoding();
      byte[] bytes = encoding.GetBytes(value.ToString());
      SetNodeBase64BinaryValue(node, bytes);      
    }
    }
}