Click here to Skip to main content
Click here to Skip to main content
Articles » Languages » XML » Serializing » Downloads
 
Add your own
alternative version

Yet Another XML Serialization Library for the .NET Framework

, 2 Oct 2012
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.
YAXLib-src-1.1.zip
YAXLib
DemoApplication
Properties
Settings.settings
SampleClasses
YAXLib
Properties
YAXLib-src-1.zip
Settings.settings
YAXLib-src-1_1.zip
Settings.settings
YAXLib-src-2.0.zip
Settings.settings
LocalTestRun.testrunconfig
YAXLib.vsmdi
YAXLibTests
Properties
Test References
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using YAXLib;

namespace DemoApplication.SampleClasses
{
    [YAXComment(@"This example shows serialization of multi-dimensional, 
        and jagged arrays")]
    public class MultiDimArraySample
    {
        public int[,] IntArray { get; set; }

        public double[, ,] DoubleArray { get; set; }

        public int[][] JaggedArray { get; set; }

        [YAXComment("The containing element should not disappear because of the dims attribute")]
        [YAXCollection(YAXCollectionSerializationTypes.RecursiveWithNoContainingElement)]
        public int[,] IntArrayNoContainingElems { get; set; }

        [YAXComment("This element should not be serialized serially because each element is not of basic type")]
        [YAXCollection(YAXCollectionSerializationTypes.Serially)]
        public int[][] JaggedNotSerially { get; set; }

        public override string ToString()
        {
            return GeneralToStringProvider.GeneralToString(this);
        }

        public static MultiDimArraySample GetSampleInstance()
        {
            int[,] intArray = new int[2,3];

            for (int i = 0; i < 2; i++)
                for (int j = 0; j < 3; j++)
                    intArray[i, j] = i + j + 1;


            double[, ,] doubleArray = new double[2, 3, 3];

            for (int i = 0; i < 2; i++)
                for (int j = 0; j < 3; j++)
                    for (int k = 0; k < 3; k++)
                        doubleArray[i, j, k] = (double)(i * j + 1) / (k + 0.5);

            int[][] jaggedArray = new int[3][];
            for (int i = 0; i < 3; i++)
            {
                jaggedArray[i] = new int[(i + 1) * 2];
                for (int j = 1; j <= (i + 1) * 2; j++)
                    jaggedArray[i][j - 1] = j;
            }

            return new MultiDimArraySample()
            {
                IntArray = intArray,
                DoubleArray = doubleArray,
                JaggedArray = jaggedArray,
                IntArrayNoContainingElems = intArray,
                JaggedNotSerially = jaggedArray
            };
        }
    }
}

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

About the Author

Sina Iravanian
Software Developer
Australia Australia
A software designer and developer
Follow on   Twitter   Google+

| Advertise | Privacy | Mobile
Web01 | 2.8.140721.1 | Last Updated 2 Oct 2012
Article Copyright 2009 by Sina Iravanian
Everything else Copyright © CodeProject, 1999-2014
Terms of Service
Layout: fixed | fluid