Кстати, это круто.
Я реализовал этот код, чтобы упростить работу с фрагментами XML в виде классов, а затем вы можете просто заменить узел, когда закончите. Это делает переход между кодом и XML очень простым.
Сначала создайте несколько методов расширения.
public static class SerializableFragmentExtensions
{
public static XElement ToElement(this ISerializableFragment iSerializableFragment)
{
var serializer = new XmlSerializer(iSerializableFragment.GetType());
var emptyNamespace = new XmlSerializerNamespaces();
emptyNamespace.Add(String.Empty, String.Empty);
var output = new StringBuilder();
var writer = XmlWriter.Create(output,
new XmlWriterSettings { OmitXmlDeclaration = true });
serializer.Serialize(writer, iSerializableFragment, emptyNamespace);
return XElement.Parse(output.ToString(), LoadOptions.None);
}
public static T ToObject<T>(this XElement xElement)
{
var serializer = new XmlSerializer(typeof (T));
var reader = xElement.CreateReader();
var obj = (T) serializer.Deserialize(reader);
return obj;
}
}
Далее Реализация необходимого интерфейса (маркерный интерфейс - я знаю, что вы не должны, но я думаю, что это идеальная причина для этого.)
public interface ISerializableFragment
{
}
Теперь все, что вам нужно сделать, это украсить любой класс Serializable, который вы хотите преобразовать во фрагмент XElement, с помощью интерфейса.
[Serializable]
public class SomeSerializableClass : ISerializableFragment
{
[XmlAttribute]
public string SomeData { get; set; }
}
Наконец, проверьте код.
static void Main(string[] args)
{
var someSerializableClassObj = new SomeSerializableClass() {SomeData = "Testing"};
var element = someSerializableClass.ToElement();
var backToSomeSerializableClassObj = element.ToObject<SomeSerializableClass>();
}
Еще раз спасибо за этот удивительно полезный код.