Click here to Skip to main content
15,880,608 members
Articles / Programming Languages / XML

Yet Another XML Serialization Library for the .NET Framework

Rate me:
Please Sign up or sign in to vote.
4.92/5 (91 votes)
2 Oct 2012MIT24 min read 507.9K   207  
A flexible XML serialization library that lets developers design the XML file structure, and select the exception handling policy. YAXLib supports polymorphic serialization and serializing generic and non-generic collection classes and arrays.
// Copyright 2009 - 2010 Sina Iravanian - <sina@sinairv.com>
//
// This source file(s) may be redistributed, altered and customized
// by any means PROVIDING the authors name and all copyright
// notices remain intact.
// THIS SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED. USE IT AT YOUR OWN RISK. THE AUTHOR ACCEPTS NO
// LIABILITY FOR ANY DATA DAMAGE/LOSS THAT THIS PRODUCT MAY CAUSE.
//-----------------------------------------------------------------------

namespace YAXLib
{
    /// <summary>
    /// Enumerates different kinds of exception handling policies as used by YAX Library.
    /// </summary>
    public enum YAXExceptionHandlingPolicies
    {
        /// <summary>
        /// Throws Both Warnings And Errors
        /// </summary>
        ThrowWarningsAndErrors,

        /// <summary>
        /// Throws Errors only (default)
        /// </summary>
        ThrowErrorsOnly,

        /// <summary>
        /// Does not throw exceptions, the errors can be accessed via the YAXParsingErrors instance
        /// </summary>
        DoNotThrow
    }

    /// <summary>
    /// Enumerates different possible behaviours of the library toward exceptions
    /// </summary>
    public enum YAXExceptionTypes
    {
        /// <summary>
        /// Ignore non-fatal exceptions; neither throw them, nor log them.
        /// </summary>
        Ignore,

        /// <summary>
        /// Treat exception as a warning
        /// </summary>
        Warning,

        /// <summary>
        /// Treat exception as an error
        /// </summary>
        Error
    }

    /// <summary>
    /// Enumerates different serialization options which could be set at construction time.
    /// </summary>
    public enum YAXSerializationOptions
    {
        /// <summary>
        /// Prevents serialization of null objects.
        /// </summary>
        DontSerializeNullObjects,

        /// <summary>
        /// Serializes null objects also (the default)
        /// </summary>
        SerializeNullObjects
    }

    /// <summary>
    /// Enumerates the possible ways of serializing collection classes
    /// </summary>
    public enum YAXCollectionSerializationTypes
    {
        /// <summary>
        /// Serializes each member of the collection, as a separate element, all enclosed in an element regarding the collection itself
        /// </summary>
        Recursive,

        /// <summary>
        /// Serializes each member of the collection, as a separate element, with no enclosing element for the collection
        /// </summary>
        RecursiveWithNoContainingElement,

        /// <summary>
        /// Serializes all members of the collection in one element separated by some delimiter, if possible.
        /// </summary>
        Serially
    }

    /// <summary>
    /// Enumerates possible XML node types upon which a property can be serialized.
    /// </summary>
    public enum YAXNodeTypes
    {
        /// <summary>
        /// Serialize data as an attribute for the base element
        /// </summary>
        Attribute,

        /// <summary>
        /// Serialize data as an element
        /// </summary>
        Element
    }

    /// <summary>
    /// Enumerates possible options for a serializable type
    /// </summary>
    public enum YAXSerializationFields
    {
        /// <summary>
        /// Serializes only the public properties (the default behaviour)
        /// </summary>
        PublicPropertiesOnly,

        /// <summary>
        /// Serializes all fields (properties or member variables) which are public, or non-public.
        /// </summary>
        AllFields,

        /// <summary>
        /// Serializes all fields (properties or member variables) which are public, or non-public, if attributed as <c>YAXSerializableField</c>
        /// </summary>
        AttributedFieldsOnly
    }
}

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article, along with any associated source code and files, is licensed under The MIT License


Written By
Software Developer
Australia Australia
A software designer and developer

Comments and Discussions