Pretty Print XML

image_pdfimage_print
   
 
#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
{
  
  ///  
  /// <summary>
  /// 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.
  ///
  /// </summary>
  /// 
    
  public abstract class XmlUtils
  {
    /// -----------------------------------------------------------
    /// <summary>
    /// Pretty Print XML
    /// </summary>
    /// <param name="xml"></param>
    /// <returns>Pretty print xml string</returns>
    /// <remarks> Thanks to http://dotnet.editme.com/codePrettyPrintXML</remarks>
    /// -----------------------------------------------------------
    public static string PrettyPrint(string xml)
    {
      XmlDocument xmlDom   = new XmlDocument();

      // Load the XmlDocument with the XML.
      xmlDom.LoadXml(xml);

      return PrettyPrint(xmlDom);
    }


    /// -----------------------------------------------------------
    /// <summary>
        /// Print Print an <see cref="XmlDocument"/>
    /// </summary>
    /// <param name="xmlDom"></param>
    /// <returns></returns>
    /// -----------------------------------------------------------
    public static string PrettyPrint(XmlDocument xmlDom)
    {
            return PrettyPrint(xmlDom, true);
    }


        /// <summary>
        /// Print Print an <see cref="XmlNode"/>
        /// </summary>
        /// <param name="xmlNode"></param>
        /// <returns></returns>
        public static string PrettyPrint(XmlNode xmlNode)
        {
            return PrettyPrint(xmlNode, false);
        }


        /// <summary>
        /// Pretty Print an <see cref="XmlDocument"/> or an <see cref="XmlNode"/>
        /// </summary>
        /// <param name="xmlObj"></param>
        /// <param name="isXmlDoc"></param>
        /// <returns></returns>
        public static string PrettyPrint(object xmlObj, bool isXmlDoc)
        {

            if (!(xmlObj is XmlDocument || xmlObj is XmlDataDocument ||
                xmlObj is XmlNode || xmlObj is XmlElement))
                throw new ArgumentException("xmlObj must be either an XmlDocument, XmlDataDocument, XmlNode or an XmlElement object");

            String prettyXml = "";

            MemoryStream memStream = new MemoryStream();
            XmlTextWriter xmlTextWriter = new XmlTextWriter(memStream, Encoding.Unicode);

            try
            {
                xmlTextWriter.Formatting = Formatting.Indented;
                xmlTextWriter.Indentation = 4;
                xmlTextWriter.QuoteChar = &#039;&#039;&#039;;


                // Write the XML into a formatting XmlTextWriter
                if (xmlObj is XmlDocument)
                    ((XmlDocument)xmlObj).WriteContentTo(xmlTextWriter);
                else if (xmlObj is XmlDataDocument)
                    ((XmlDataDocument)xmlObj).WriteContentTo(xmlTextWriter);
                else
                    ((XmlNode)xmlObj).ParentNode.WriteContentTo(xmlTextWriter);

                
                xmlTextWriter.Flush();
                memStream.Flush();

                // Have to rewind the MemoryStream in order to read
                // its contents.
                memStream.Position = 0;

                // Read MemoryStream contents into a StreamReader.
                StreamReader streamReader = new StreamReader(memStream);

                // Extract the text from the StreamReader.
                String sFormattedXML = streamReader.ReadToEnd();

                prettyXml = sFormattedXML;
            }
            catch
            {
            }

            memStream.Close();
            xmlTextWriter.Close();

            return prettyXml;
        }
    }
}

   
     


This entry was posted in XML-RPC. Bookmark the permalink.