#region License Information /* HeuristicLab * Copyright (C) 2002-2015 Heuristic and Evolutionary Algorithms Laboratory (HEAL) * * This file is part of HeuristicLab. * * HeuristicLab is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * HeuristicLab 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with HeuristicLab. If not, see . */ #endregion using System; using System.Text; using System.Text.RegularExpressions; using HeuristicLab.Persistence.Core; using HeuristicLab.Persistence.Interfaces; namespace HeuristicLab.Persistence.Default.Xml.Primitive { internal sealed class Char2XmlSerializer : PrimitiveSerializerBase { private static readonly Regex base64Regex = new Regex("(.+)"); private static bool IsSpecial(char c) { return c <= 0x1F && c != 0x9 && c != 0xA && c != 0xD; } private static string ToBase64String(char c) { return string.Format("{0}", Convert.ToBase64String(Encoding.ASCII.GetBytes(new[] {c}))); } public override XmlString Format(char c) { return new XmlString(IsSpecial(c) ? ToBase64String(c) : new string(c, 1)); } public override char Parse(XmlString x) { if (x.Data.Length <= 1) return x.Data[0]; var m = base64Regex.Match(x.Data); if (m.Success) return Encoding.ASCII.GetString(Convert.FromBase64String(m.Groups[1].Value))[0]; throw new PersistenceException("Invalid character format, XML string length != 1"); } } }