Jump to content
Xtreme .Net Talk

Recommended Posts

Posted

I have a class that I'm using for configuration of part of my app. The serializtion and deserialization work fine. The problem I'm having is if I want to add a new property to the class that is serialized then the old xml config file will not load because now the class has more members than the serialized xml file.

 

I've found some information on the binder memeber of IFormatter class, but this seems like overkill. I would just like it to load the values that it can and then rewrite the file when I save it after the new member is added. Easier said than done?

Posted

Ok I figured something out. I had been using the SoapFormatter for my serialization. I found this code on the net it works as I hoped it doesn't mind if I have changed my class and added properties when it loads the data.

 

/// <summary>

/// Serializes an object instance to a file.

/// </summary>

/// <param name="Instance">the object instance to serialize</param>

/// <param name="Filename"></param>

/// <param name="BinarySerialization">determines whether XML serialization or binary serialization is used</param>

/// <returns></returns>

 

public static bool SerializeObject(object Instance, string Filename,

bool BinarySerialization)

{

bool retVal = true;

if (!BinarySerialization)

{

XmlTextWriter writer = null;

try

{

XmlSerializer serializer =

new XmlSerializer(Instance.GetType());

// Create an XmlTextWriter using a FileStream.

Stream fs = new FileStream(Filename, FileMode.Create);

writer = new XmlTextWriter(fs, new UTF8Encoding());

writer.Formatting = Formatting.Indented;

writer.IndentChar = ' ';

writer.Indentation = 3;

// Serialize using the XmlTextWriter.

serializer.Serialize(writer,Instance);

}

catch(Exception e)

{

MessageBox.Show(e.Message);

retVal = false;

}

finally

{

if (writer != null)

writer.Close();

}

}

else

{

Stream fs = null;

try

{

BinaryFormatter serializer = new BinaryFormatter();

fs = new FileStream(Filename, FileMode.Create);

serializer.Serialize(fs,Instance);

}

catch

{

retVal = false;

}

finally

{

if (fs != null)

fs.Close();

}

}

return retVal;

}

 

 

 

/// <summary>

/// Deserializes an object from file and returns a reference.

/// </summary>

/// <param name="Filename">name of the file to serialize to</param>

/// <param name="ObjectType">The Type of the object. Use typeof(yourobject class)</param>

/// <param name="BinarySerialization">determines whether we use Xml or Binary serialization</param>

/// <returns>Instance of the deserialized object or null. Must be cast to your object type</returns>

 

public static object DeSerializeObject(string Filename,Type ObjectType,

bool BinarySerialization)

{

object Instance = null;

 

if (!BinarySerialization)

{

XmlReader reader = null;

XmlSerializer serializer = null;

FileStream fs = null;

try

{

// Create an instance of the XmlSerializer specifying type and namespace.

serializer = new XmlSerializer(ObjectType);

// A FileStream is needed to read the XML document.

fs = new FileStream(Filename, FileMode.Open);

reader = new XmlTextReader(fs);

Instance = serializer.Deserialize(reader);

}

catch

{

return null;

}

finally

{

if (fs != null)

fs.Close();

if (reader != null)

reader.Close();

}

}

else

{

BinaryFormatter serializer = null;

FileStream fs = null;

try

{

serializer = new BinaryFormatter();

fs = new FileStream(Filename, FileMode.Open);

Instance = serializer.Deserialize(fs);

}

catch

{

return null;

}

finally

{

if (fs != null)

fs.Close();

}

}

return Instance;

}

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...