- Timestamp:
- 05/04/17 17:19:35 (7 years ago)
- Location:
- branches/PersistenceReintegration/HeuristicLab.Persistence
- Files:
-
- 2 deleted
- 56 edited
- 2 copied
Legend:
- Unmodified
- Added
- Removed
-
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Auxiliary/TypeLoader.cs
r14185 r14927 59 59 try { 60 60 typeName = TypeNameParser.Parse(typeNameString); 61 } 62 catch (Exception) { 61 } catch (Exception) { 63 62 throw new PersistenceException(String.Format( 64 63 "Could not parse type string \"{0}\"", … … 69 68 // try to load type normally 70 69 return LoadInternal(typeName); 71 } 72 catch (PersistenceException) { 70 } catch (PersistenceException) { 73 71 #region Mono Compatibility 74 72 // if that fails, try to convert to the corresponding Mono or .NET type … … 92 90 try { 93 91 type = Type.GetType(typeName.ToString(true, true), true); 94 } 95 catch (Exception) { 92 } catch (Exception) { 96 93 Logger.Warn(String.Format( 97 94 "Cannot load type \"{0}\", falling back to partial name", typeName.ToString(true, true))); … … 109 106 #pragma warning restore 0618 110 107 return a.GetType(typeName.ToString(false, false), true); 111 } 112 catch (Exception) { 108 } catch (Exception) { 113 109 throw new PersistenceException(String.Format( 114 110 "Could not load type \"{0}\"", … … 130 126 typeName.ToString(true, true), 131 127 type.AssemblyQualifiedName)); 132 } 133 catch (PersistenceException) { 128 } catch (PersistenceException) { 134 129 throw; 135 } 136 catch (Exception e) { 130 } catch (Exception e) { 137 131 Logger.Warn(String.Format( 138 132 "Could not perform version check requested type was {0} while loaded type is {1}:", -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Auxiliary/TypeName.cs
r14185 r14927 24 24 using System.Linq; 25 25 using System.Text; 26 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;26 using HeuristicLab.Persistence; 27 27 28 28 namespace HeuristicLab.Persistence.Auxiliary { … … 33 33 /// attributes. 34 34 /// </summary> 35 [Storable Class]35 [StorableType("a83d8580-07c2-4805-a31f-23b702689e0c")] 36 36 public class TypeName { 37 37 … … 57 57 public List<int> GenericArgCounts { get; private set; } 58 58 59 59 /// <summary> 60 60 /// Gets or sets the generic args. 61 61 /// </summary> … … 110 110 /// <param name="nameSpace">The namespace.</param> 111 111 /// <param name="className">Name of the class.</param> 112 internal TypeName(string nameSpace, string className, List<int> genericArgCounts =null) {112 internal TypeName(string nameSpace, string className, List<int> genericArgCounts = null) { 113 113 Namespace = nameSpace; 114 114 ClassName = className; … … 187 187 private IEnumerable<string> GetNestedClassesInCode(HashSet<string> omitNamespaces, bool includeAllNamespaces) { 188 188 var i = 0; 189 foreach (var pair in ClassName.Split('+').Zip(GenericArgCounts, (n, c) => new { n, c})) {189 foreach (var pair in ClassName.Split('+').Zip(GenericArgCounts, (n, c) => new { n, c })) { 190 190 if (pair.c == 0) { 191 191 yield return pair.n; 192 } 193 else { 192 } else { 194 193 yield return string.Format("{0}<{1}>", 195 194 pair.n, … … 208 207 (omitNamespaces == null && includeNamespaces) || 209 208 omitNamespaces != null && !omitNamespaces.Contains(Namespace)) 210 209 sb.Append(Namespace).Append('.'); 211 210 if (GenericArgCounts != null) { 212 211 sb.Append(string.Join(".", GetNestedClassesInCode(omitNamespaces, includeNamespaces))); … … 273 272 } 274 273 return false; 275 } 276 catch (KeyNotFoundException) { 274 } catch (KeyNotFoundException) { 277 275 throw new Exception("Could not extract version information from type string"); 278 276 } … … 311 309 } 312 310 return true; 313 } 314 catch (KeyNotFoundException) { 311 } catch (KeyNotFoundException) { 315 312 throw new Exception("Could not extract version infomration from type string"); 316 313 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Auxiliary/TypeNameParser.cs
r14185 r14927 166 166 try { 167 167 return p.TransformTypeSpec(); 168 } 169 catch (ParseError x) { 168 } catch (ParseError x) { 170 169 if (p.Position > 0) 171 170 throw new ParseError(String.Format( -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Core/Configuration.cs
r14185 r14927 22 22 using System; 23 23 using System.Collections.Generic; 24 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;24 using HeuristicLab.Persistence; 25 25 using HeuristicLab.Persistence.Interfaces; 26 26 … … 32 32 /// <c>ConfigurationService</c>. 33 33 /// </summary> 34 [Storable Class]34 [StorableType("181b0384-ee37-4a51-93ab-624977ee6613")] 35 35 public class Configuration { 36 36 -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Core/FormatBase.cs
r14185 r14927 21 21 22 22 using System; 23 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;23 using HeuristicLab.Persistence; 24 24 25 25 namespace HeuristicLab.Persistence.Interfaces { … … 29 29 /// </summary> 30 30 /// <typeparam name="SerialDataFormat">The type of the serial data format.</typeparam> 31 [Storable Class]31 [StorableType("654b6142-b4c5-4b82-94e9-13b4ff8cbe53")] 32 32 public abstract class FormatBase<SerialDataFormat> : IFormat<SerialDataFormat> where SerialDataFormat : ISerialData { 33 33 -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Core/PrimitiveSerializerBase.cs
r14185 r14927 22 22 using System; 23 23 using System.Text; 24 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;24 using HeuristicLab.Persistence; 25 25 26 26 namespace HeuristicLab.Persistence.Interfaces { … … 32 32 /// <typeparam name="Source">The source type.</typeparam> 33 33 /// <typeparam name="SerialData">The serialized type.</typeparam> 34 [Storable Class]34 [StorableType("0e1d11cc-9ff0-46b6-b661-c1a408ae0917")] 35 35 public abstract class PrimitiveSerializerBase<Source, SerialData> : 36 36 IPrimitiveSerializer<Source, SerialData> -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Core/Serializer.cs
r14185 r14927 247 247 emitTypeInfo); 248 248 throw CreatePersistenceException(type, "Could not determine how to serialize a value.", true); 249 } 250 catch (Exception x) { 249 } catch (Exception x) { 251 250 if (isTestRun) { 252 251 exceptions.Add(x); … … 260 259 false); 261 260 } 262 } 263 finally { 261 } finally { 264 262 objectGraphTrace.Pop(); 265 263 } 266 } 264 } 267 265 268 266 private PersistenceException CreatePersistenceException(Type type, string message, bool appendConfig) { -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/ArraySerializer.cs
r14185 r14927 23 23 using System.Collections.Generic; 24 24 using HeuristicLab.Persistence.Core; 25 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;25 using HeuristicLab.Persistence; 26 26 using HeuristicLab.Persistence.Interfaces; 27 27 28 28 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 29 29 30 [Storable Class]30 [StorableType("17987df2-38f0-4158-b4c7-783ffa2737d1")] 31 31 internal sealed class ArraySerializer : ICompositeSerializer { 32 32 … … 99 99 } 100 100 return Array.CreateInstance(t.GetElementType(), lengths, lowerBounds); 101 } 102 catch (InvalidOperationException x) { 101 } catch (InvalidOperationException x) { 103 102 throw new PersistenceException("Insufficient meta information to construct array instance.", x); 104 } 105 catch (InvalidCastException x) { 103 } catch (InvalidCastException x) { 106 104 throw new PersistenceException("Invalid format of array metainfo.", x); 107 105 } … … 134 132 } 135 133 } 136 } 137 catch (InvalidOperationException x) { 134 } catch (InvalidOperationException x) { 138 135 throw new PersistenceException("Insufficient data to fill array instance", x); 139 } 140 catch (InvalidCastException x) { 136 } catch (InvalidCastException x) { 141 137 throw new PersistenceException("Invalid element data. Cannot fill array", x); 142 } 143 catch (IndexOutOfRangeException x) { 138 } catch (IndexOutOfRangeException x) { 144 139 throw new PersistenceException("Too many elements during array deserialization", x); 145 140 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/CompactNumberArray2StringSerializer.cs
r14185 r14927 26 26 using HeuristicLab.Persistence.Auxiliary; 27 27 using HeuristicLab.Persistence.Core; 28 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;28 using HeuristicLab.Persistence; 29 29 using HeuristicLab.Persistence.Interfaces; 30 30 31 31 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 32 32 33 [Storable Class]33 [StorableType("a5c269da-4122-4ea0-9eb7-c3441be404b8")] 34 34 public sealed class CompactNumberArray2StringSerializer : ICompositeSerializer { 35 35 … … 187 187 } 188 188 return a; 189 } 190 catch (InvalidOperationException e) { 189 } catch (InvalidOperationException e) { 191 190 throw new PersistenceException("Insuffictient data to deserialize compact array", e); 192 } 193 catch (InvalidCastException e) { 191 } catch (InvalidCastException e) { 194 192 throw new PersistenceException("Invalid element data during compact array deserialization", e); 195 193 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/ConcreteDictionarySerializer.cs
r14185 r14927 25 25 using System.Linq; 26 26 using HeuristicLab.Persistence.Core; 27 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;27 using HeuristicLab.Persistence; 28 28 using HeuristicLab.Persistence.Interfaces; 29 29 30 30 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 31 31 32 [Storable Class]32 [StorableType("0ce2011a-5666-40df-9874-f5eeccea5a72")] 33 33 internal sealed class ConcreteDictionarySerializer : ICompositeSerializer { 34 34 -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/DictionarySerializer.cs
r14185 r14927 25 25 using HeuristicLab.Persistence.Auxiliary; 26 26 using HeuristicLab.Persistence.Core; 27 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;27 using HeuristicLab.Persistence; 28 28 using HeuristicLab.Persistence.Interfaces; 29 29 30 30 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 31 31 32 [Storable Class]32 [StorableType("813d9a0f-a611-478e-8149-e5d338c9a273")] 33 33 internal sealed class DictionarySerializer : ICompositeSerializer { 34 34 … … 79 79 dict.Add(key.Value, value.Value); 80 80 } 81 } 82 catch (InvalidOperationException e) { 81 } catch (InvalidOperationException e) { 83 82 throw new PersistenceException("Dictionaries must contain an even number of elements (key+value).", e); 84 } 85 catch (NotSupportedException e) { 83 } catch (NotSupportedException e) { 86 84 throw new PersistenceException("The serialized dictionary type was read-only or had a fixed size and cannot be deserialized.", e); 87 } 88 catch (ArgumentNullException e) { 85 } catch (ArgumentNullException e) { 89 86 throw new PersistenceException("Dictionary key was null.", e); 90 } 91 catch (ArgumentException e) { 87 } catch (ArgumentException e) { 92 88 throw new PersistenceException("Duplicate dictionary key.", e); 93 89 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/EnumSerializer.cs
r14185 r14927 23 23 using System.Collections.Generic; 24 24 using HeuristicLab.Persistence.Core; 25 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;25 using HeuristicLab.Persistence; 26 26 using HeuristicLab.Persistence.Interfaces; 27 27 28 28 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 29 29 30 [Storable Class]30 [StorableType("7ff55c07-1c83-4d0f-924a-37c28d936d74")] 31 31 internal sealed class EnumSerializer : ICompositeSerializer { 32 32 … … 60 60 it.MoveNext(); 61 61 return Enum.Parse(t, (string)it.Current.Value); 62 } 63 catch (InvalidOperationException e) { 62 } catch (InvalidOperationException e) { 64 63 throw new PersistenceException("not enough meta information to recstruct enum", e); 65 } 66 catch (InvalidCastException e) { 64 } catch (InvalidCastException e) { 67 65 throw new PersistenceException("invalid meta information found while trying to reconstruct enum", e); 68 66 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/EnumerableSerializer.cs
r14185 r14927 26 26 using HeuristicLab.Persistence.Auxiliary; 27 27 using HeuristicLab.Persistence.Core; 28 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;28 using HeuristicLab.Persistence; 29 29 using HeuristicLab.Persistence.Interfaces; 30 30 31 31 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 32 32 33 [Storable Class]33 [StorableType("4421c2a4-9ee1-4cfc-b98e-755a81dc5241")] 34 34 internal sealed class EnumerableSerializer : ICompositeSerializer { 35 35 … … 80 80 foreach (var tag in tags) 81 81 addMethod.Invoke(instance, new[] { tag.Value }); 82 } 83 catch (Exception e) { 82 } catch (Exception e) { 84 83 throw new PersistenceException("Exception caught while trying to populate enumerable.", e); 85 84 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/HashSetSerializer.cs
r14185 r14927 26 26 using System.Reflection; 27 27 using HeuristicLab.Persistence.Core; 28 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;28 using HeuristicLab.Persistence; 29 29 using HeuristicLab.Persistence.Interfaces; 30 30 31 31 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 32 32 33 [Storable Class]33 [StorableType("51099049-20f2-4a71-8eae-b4ea9d677115")] 34 34 internal sealed class HashSetSerializer : ICompositeSerializer { 35 35 -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/KeyValuePairSerializer.cs
r14185 r14927 25 25 using System.Reflection; 26 26 using HeuristicLab.Persistence.Core; 27 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;27 using HeuristicLab.Persistence; 28 28 using HeuristicLab.Persistence.Interfaces; 29 29 30 30 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 31 31 32 [Storable Class]32 [StorableType("97d00efc-4eb0-4dc7-a58c-977c45c2904c")] 33 33 internal sealed class KeyValuePairSerializer : ICompositeSerializer { 34 34 … … 64 64 try { 65 65 key = new Tag("key", t.GetProperty("Key").GetValue(o, null)); 66 } 67 catch (Exception e) { 66 } catch (Exception e) { 68 67 throw new PersistenceException("Exception caught during KeyValuePair decomposition", e); 69 68 } … … 71 70 try { 72 71 value = new Tag("value", t.GetProperty("Value").GetValue(o, null)); 73 } 74 catch (Exception e) { 72 } catch (Exception e) { 75 73 throw new PersistenceException("Exception caught during KeyValuePair decomposition", e); 76 74 } … … 91 89 t.GetFields(BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic) 92 90 .Single(fi => fi.Name == "value").SetValue(instance, iter.Current.Value); 93 } 94 catch (InvalidOperationException e) { 91 } catch (InvalidOperationException e) { 95 92 throw new PersistenceException("Not enough components to populate KeyValuePair instance", e); 96 } 97 catch (Exception e) { 93 } catch (Exception e) { 98 94 throw new PersistenceException("Exception caught during KeyValuePair reconstruction", e); 99 95 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/Number2StringSerializer.cs
r14185 r14927 25 25 using HeuristicLab.Persistence.Auxiliary; 26 26 using HeuristicLab.Persistence.Core; 27 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;27 using HeuristicLab.Persistence; 28 28 using HeuristicLab.Persistence.Default.Xml; 29 29 using HeuristicLab.Persistence.Default.Xml.Primitive; … … 40 40 /// but can be useful in generating custom serializers. 41 41 /// </summary> 42 [Storable Class]42 [StorableType("23af67f5-2af6-4aca-b841-21345eacfb2f")] 43 43 public sealed class Number2StringSerializer : ICompositeSerializer { 44 44 … … 115 115 try { 116 116 return numberSerializerMap[Nullable.GetUnderlyingType(type) ?? type].Parse(new XmlString(stringValue)); 117 } 118 catch (FormatException e) { 117 } catch (FormatException e) { 119 118 throw new PersistenceException("Invalid element data during number parsing.", e); 120 } 121 catch (OverflowException e) { 119 } catch (OverflowException e) { 122 120 throw new PersistenceException("Overflow during number parsing.", e); 123 121 } … … 172 170 it.MoveNext(); 173 171 return Parse((string)it.Current.Value, type); 174 } 175 catch (InvalidOperationException e) { 172 } catch (InvalidOperationException e) { 176 173 throw new PersistenceException( 177 174 String.Format("Insufficient meta information to reconstruct number of type {0}.", 178 175 type.VersionInvariantName()), e); 179 } 180 catch (InvalidCastException e) { 176 } catch (InvalidCastException e) { 181 177 throw new PersistenceException("Invalid meta information element type", e); 182 178 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/NumberEnumerable2StringSerializer.cs
r14185 r14927 26 26 using HeuristicLab.Persistence.Auxiliary; 27 27 using HeuristicLab.Persistence.Core; 28 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;28 using HeuristicLab.Persistence; 29 29 using HeuristicLab.Persistence.Interfaces; 30 30 31 31 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 32 32 33 [Storable Class]33 [StorableType("8bb7c8b8-89e5-41d4-a37e-c43e5beee451")] 34 34 internal sealed class NumberEnumerable2StringSerializer : ICompositeSerializer { 35 35 … … 136 136 addMethod.Invoke(instance, new[] { numberConverter.Parse(value, elementType) }); 137 137 } 138 } 139 catch (InvalidOperationException e) { 138 } catch (InvalidOperationException e) { 140 139 throw new PersistenceException("Insufficient element data to reconstruct number enumerable", e); 141 } 142 catch (InvalidCastException e) { 140 } catch (InvalidCastException e) { 143 141 throw new PersistenceException("Invalid element data during reconstruction of number enumerable", e); 144 142 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/QueueSerializer.cs
r14185 r14927 25 25 using System.Reflection; 26 26 using HeuristicLab.Persistence.Core; 27 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;27 using HeuristicLab.Persistence; 28 28 using HeuristicLab.Persistence.Interfaces; 29 29 30 30 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 31 31 32 [Storable Class]32 [StorableType("7a0dee32-0800-4a78-a1c3-88cd97939ca0")] 33 33 internal sealed class QueueSerializer : ICompositeSerializer { 34 34 -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/StackSerializer.cs
r14185 r14927 25 25 using System.Reflection; 26 26 using HeuristicLab.Persistence.Core; 27 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;27 using HeuristicLab.Persistence; 28 28 using HeuristicLab.Persistence.Interfaces; 29 29 30 30 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 31 31 32 [Storable Class]32 [StorableType("e395b076-6001-417e-925c-8820cc0354df")] 33 33 internal sealed class StackSerializer : ICompositeSerializer { 34 34 … … 76 76 foreach (var tag in tags) 77 77 addMethod.Invoke(instance, new[] { tag.Value }); 78 } 79 catch (Exception e) { 78 } catch (Exception e) { 80 79 throw new PersistenceException("Exception caught while trying to populate enumerable.", e); 81 80 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/Storable/StorableSerializer.cs
r14185 r14927 28 28 using HeuristicLab.Persistence.Core; 29 29 using HeuristicLab.Persistence.Interfaces; 30 using HeuristicLab.Persistence; 30 31 31 32 namespace HeuristicLab.Persistence.Default.CompositeSerializers.Storable { … … 38 39 /// or <c>AllFieldsAndAllProperties</c>. 39 40 /// </summary> 40 [Storable Class]41 [StorableType("ea2bd700-d2c9-4319-9883-b795bd8f078f")] 41 42 public sealed class StorableSerializer : ICompositeSerializer { 42 43 -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/StructSerializer.cs
r14185 r14927 24 24 using System.Reflection; 25 25 using HeuristicLab.Persistence.Core; 26 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;26 using HeuristicLab.Persistence; 27 27 using HeuristicLab.Persistence.Interfaces; 28 28 29 29 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 30 30 31 [Storable Class]31 [StorableType("070243ae-13d3-490e-ad17-81a96941ea3c")] 32 32 internal sealed class StructSerializer : ICompositeSerializer { 33 33 -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/TupleSerializer.cs
r14185 r14927 25 25 using System.Reflection; 26 26 using HeuristicLab.Persistence.Core; 27 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;27 using HeuristicLab.Persistence; 28 28 using HeuristicLab.Persistence.Interfaces; 29 29 30 30 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 31 31 32 [Storable Class]32 [StorableType("604ea532-4a4f-4cf6-af44-1e56cf357997")] 33 33 internal sealed class TupleSerializer : ICompositeSerializer { 34 34 -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/CompositeSerializers/TypeSerializer.cs
r14185 r14927 24 24 using HeuristicLab.Persistence.Auxiliary; 25 25 using HeuristicLab.Persistence.Core; 26 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;26 using HeuristicLab.Persistence; 27 27 using HeuristicLab.Persistence.Interfaces; 28 28 29 29 namespace HeuristicLab.Persistence.Default.CompositeSerializers { 30 30 31 [Storable Class]31 [StorableType("dd23170e-0998-438a-b935-2061a7a4762e")] 32 32 internal sealed class TypeSerializer : ICompositeSerializer { 33 33 … … 66 66 try { 67 67 it.MoveNext(); 68 } 69 catch (InvalidOperationException e) { 68 } catch (InvalidOperationException e) { 70 69 throw new PersistenceException("Insufficient meta information to instantiate Type object", e); 71 70 } 72 71 try { 73 72 return TypeLoader.Load((string)it.Current.Value); 74 } 75 catch (InvalidCastException e) { 73 } catch (InvalidCastException e) { 76 74 throw new PersistenceException("Invalid meta information during reconstruction of Type object", e); 77 } 78 catch (TypeLoadException e) { 75 } catch (TypeLoadException e) { 79 76 throw new PersistenceException(String.Format( 80 77 "Cannot load Type {0}, make sure all required assemblies are available.", -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/DebugString/DebugString.cs
r14185 r14927 20 20 #endregion 21 21 22 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;22 using HeuristicLab.Persistence; 23 23 using HeuristicLab.Persistence.Interfaces; 24 24 … … 28 28 /// Simple write-only format for debugging purposes. 29 29 /// </summary> 30 [Storable Class]30 [StorableType("05a1ee13-75c0-4ff1-b403-57573364d7e3")] 31 31 public class DebugString : ISerialData { 32 32 -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/DebugString/DebugStringFormat.cs
r14185 r14927 20 20 #endregion 21 21 22 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;22 using HeuristicLab.Persistence; 23 23 using HeuristicLab.Persistence.Interfaces; 24 24 … … 28 28 /// Simple write-only format for debugging purposes. 29 29 /// </summary> 30 [Storable Class]30 [StorableType("90f9f859-5c96-4d91-8f17-826a401ecd8f")] 31 31 public class DebugStringFormat : FormatBase<DebugString> { 32 32 /// <summary> -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/DebugString/DebugStringGenerator.cs
r14185 r14927 185 185 /// <returns>A string representation of the complete object graph.</returns> 186 186 public static string Serialize(object o, Configuration configuration) { 187 Serializer s = newSerializer(o, configuration);187 var s = new HeuristicLab.Persistence.Core.Serializer(o, configuration); 188 188 DebugStringGenerator generator = new DebugStringGenerator(); 189 189 StringBuilder sb = new StringBuilder(); -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Compact/ByteArray2XmlSerializer.cs
r14185 r14927 36 36 internal sealed class Bytet2DArray2XmlSerializer : ByteArray2XmlSerializer<byte[,]> { } 37 37 38 internal sealed class Byte3DArray2XmlSerializer : ByteArray2XmlSerializer<byte[, 38 internal sealed class Byte3DArray2XmlSerializer : ByteArray2XmlSerializer<byte[,,]> { } 39 39 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Compact/DoubleArray2XmlSerializer.cs
r14185 r14927 39 39 internal sealed class Double2DArray2XmlSerializer : DoubleArray2XmlSerializerBase<double[,]> { } 40 40 41 internal sealed class Double3DArray2XmlSerializer : DoubleArray2XmlSerializerBase<double[, 41 internal sealed class Double3DArray2XmlSerializer : DoubleArray2XmlSerializerBase<double[,,]> { } 42 42 43 43 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Compact/DoubleList2XmlSerializer.cs
r14185 r14927 46 46 } 47 47 return list; 48 } 49 catch (InvalidCastException e) { 48 } catch (InvalidCastException e) { 50 49 throw new PersistenceException("Invalid element data during reconstruction of List<double>.", e); 51 } 52 catch (OverflowException e) { 50 } catch (OverflowException e) { 53 51 throw new PersistenceException("Overflow during element parsing while trying to reconstruct List<double>.", e); 54 52 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Compact/IntArray2XmlSerializer.cs
r14185 r14927 38 38 internal class Int2DArray2XmlSerializer : IntArray2XmlSerializerBase<int[,]> { } 39 39 40 internal class Int3DArray2XmlSerializer : IntArray2XmlSerializerBase<int[, 40 internal class Int3DArray2XmlSerializer : IntArray2XmlSerializerBase<int[,,]> { } 41 41 42 42 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Compact/NumberArray2XmlSerializerBase.cs
r14185 r14927 27 27 using HeuristicLab.Persistence.Auxiliary; 28 28 using HeuristicLab.Persistence.Core; 29 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;29 using HeuristicLab.Persistence; 30 30 31 31 namespace HeuristicLab.Persistence.Default.Xml.Compact { 32 32 33 [Storable Class]33 [StorableType("ed511bc6-4889-4be1-bb57-c819d3e9e7be")] 34 34 internal abstract class NumberArray2XmlSerializerBase<T> : CompactXmlSerializerBase<T> where T : class { 35 35 … … 108 108 throw new PersistenceException("Insufficient number of elements while trying to fill number array."); 109 109 return (T)(object)a; 110 } 111 catch (InvalidOperationException e) { 110 } catch (InvalidOperationException e) { 112 111 throw new PersistenceException("Insufficient information to rebuild number array.", e); 113 } 114 catch (InvalidCastException e) { 112 } catch (InvalidCastException e) { 115 113 throw new PersistenceException("Invalid element data or meta data to reconstruct number array.", e); 116 } 117 catch (OverflowException e) { 114 } catch (OverflowException e) { 118 115 throw new PersistenceException("Overflow during element parsing while trying to reconstruct number array.", e); 119 116 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Compact/NumberEnumeration2XmlSerializerBase.cs
r14185 r14927 25 25 using HeuristicLab.Persistence.Auxiliary; 26 26 using HeuristicLab.Persistence.Core; 27 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;27 using HeuristicLab.Persistence; 28 28 29 29 namespace HeuristicLab.Persistence.Default.Xml.Compact { 30 30 31 [Storable Class]31 [StorableType("a0910e86-de41-4862-abf5-82bbed54de70")] 32 32 internal abstract class NumberEnumeration2XmlSerializerBase<T> : CompactXmlSerializerBase<T> where T : IEnumerable { 33 33 … … 54 54 } 55 55 return (T)enumeration; 56 } 57 catch (InvalidCastException e) { 56 } catch (InvalidCastException e) { 58 57 throw new PersistenceException("Invalid element data during reconstruction of number enumerable.", e); 59 } 60 catch (OverflowException e) { 58 } catch (OverflowException e) { 61 59 throw new PersistenceException("Overflow during element parsing while trying to reconstruct number enumerable.", e); 62 60 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/EasyXmlGenerator.cs
r14185 r14927 154 154 File.Copy(tempfile, filename, true); 155 155 File.Delete(tempfile); 156 } 157 catch (Exception) { 156 } catch (Exception) { 158 157 Logger.Warn("Exception caught, no data has been written."); 159 158 throw; … … 181 180 try { 182 181 using (StreamWriter writer = new StreamWriter(stream)) { 183 Serializer serializer = newSerializer(obj, config);182 var serializer = new HeuristicLab.Persistence.Core.Serializer(obj, config); 184 183 serializer.InterleaveTypeInformation = true; 185 184 ReadableXmlGenerator generator = new ReadableXmlGenerator(); … … 190 189 writer.Flush(); 191 190 } 192 } 193 catch (PersistenceException) { 191 } catch (PersistenceException) { 194 192 throw; 195 } 196 catch (Exception e) { 193 } catch (Exception e) { 197 194 throw new PersistenceException("Unexpected exception during Serialization.", e); 198 195 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Primitive/Char2XmlFormatter.cs
r14185 r14927 37 37 38 38 private static string ToBase64String(char c) { 39 return string.Format("<Base64>{0}</Base64>", Convert.ToBase64String(Encoding.ASCII.GetBytes(new[] { c})));39 return string.Format("<Base64>{0}</Base64>", Convert.ToBase64String(Encoding.ASCII.GetBytes(new[] { c }))); 40 40 } 41 41 -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Primitive/DateTime2XmlSerializer.cs
r14185 r14927 34 34 try { 35 35 return new DateTime(long.Parse(x.Data)); 36 } 37 catch (Exception e) { 36 } catch (Exception e) { 38 37 throw new PersistenceException("Exception caugth while trying to reconstruct DateTime object.", e); 39 38 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Primitive/Guid2XmlSerializer.cs
r14185 r14927 36 36 try { 37 37 return new Guid(t.Data); 38 } 39 catch (FormatException x) { 38 } catch (FormatException x) { 40 39 throw new PersistenceException("Cannot parse Guid string representation.", x); 41 } 42 catch (OverflowException x) { 40 } catch (OverflowException x) { 43 41 throw new PersistenceException("Overflow during Guid parsing.", x); 44 42 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Primitive/SimpleNumber2XmlSerializerBase.cs
r14185 r14927 44 44 try { 45 45 return (T)ParseMethod.Invoke(null, new[] { x.Data }); 46 } 47 catch (Exception e) { 46 } catch (Exception e) { 48 47 throw new PersistenceException("Could not parse simple number.", e); 49 48 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Primitive/System.Drawing/Bitmap2XmlSerializer.cs
r14185 r14927 28 28 internal sealed class Bitmap2XmlSerializer : PrimitiveXmlSerializerBase<Bitmap> { 29 29 30 public override XmlString Format(Bitmap o) { 30 public override XmlString Format(Bitmap o) { 31 31 MemoryStream stream = new MemoryStream(); 32 32 lock (o) -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/Primitive/TimeSpan2XmlSerializer.cs
r14185 r14927 35 35 try { 36 36 return TimeSpan.Parse(t.Data); 37 } 38 catch (FormatException x) { 37 } catch (FormatException x) { 39 38 throw new PersistenceException("Cannot parse TimeSpan string representation.", x); 40 } 41 catch (OverflowException x) { 39 } catch (OverflowException x) { 42 40 throw new PersistenceException("Overflow during TimeSpan parsing.", x); 43 41 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/XmlFormat.cs
r14185 r14927 20 20 #endregion 21 21 22 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;22 using HeuristicLab.Persistence; 23 23 using HeuristicLab.Persistence.Interfaces; 24 24 … … 29 29 /// or save to a file. 30 30 /// </summary> 31 [Storable Class]31 [StorableType("8c79e9a6-02d6-471c-8787-43d96d61c1db")] 32 32 public class XmlFormat : FormatBase<XmlString> { 33 33 /// <summary> -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/XmlGenerator.cs
r14185 r14927 61 61 } 62 62 63 protected enum NodeType { Start, End, Inline } 63 protected enum NodeType { Start, End, Inline }; 64 64 65 65 protected static void AddXmlTagContent(StringBuilder sb, string name, Dictionary<string, string> attributes) { … … 256 256 {"typeName", lastTypeToken.TypeName }, 257 257 {"serializer", lastTypeToken.Serializer }}); 258 } 259 finally { 258 } finally { 260 259 lastTypeToken = null; 261 260 } … … 313 312 private static void Serialize(object obj, Stream stream, Configuration config, bool includeAssemblies 314 313 , CompressionLevel compression) { 315 Serializer serializer = newSerializer(obj, config);314 var serializer = new HeuristicLab.Persistence.Core.Serializer(obj, config); 316 315 Serialize(stream, includeAssemblies, compression, serializer); 317 316 } 318 317 319 private static void Serialize(Stream stream, bool includeAssemblies, CompressionLevel compression, Serializer serializer) {318 private static void Serialize(Stream stream, bool includeAssemblies, CompressionLevel compression, HeuristicLab.Persistence.Core.Serializer serializer) { 320 319 try { 321 320 DateTime start = DateTime.Now; … … 360 359 Logger.Info(String.Format("serialization took {0} seconds with compression level {1}", 361 360 (DateTime.Now - start).TotalSeconds, compression)); 362 } 363 catch (Exception) { 361 } catch (Exception) { 364 362 Logger.Warn("Exception caught, no data has been serialized."); 365 363 throw; … … 385 383 File.Copy(tempfile, filename, true); 386 384 File.Delete(tempfile); 387 } 388 catch (Exception) { 385 } catch (Exception) { 389 386 Logger.Warn("Exception caught, no data has been written."); 390 387 throw; … … 426 423 CompressionType compressionType = CompressionType.GZip) { 427 424 try { 428 Serializer serializer = newSerializer(obj, config);425 var serializer = new HeuristicLab.Persistence.Core.Serializer(obj, config); 429 426 if (compressionType == CompressionType.Zip) { 430 427 Serialize(obj, stream, config, includeAssemblies, CompressionLevel.Optimal); … … 432 429 Serialize(stream, serializer); 433 430 } 434 } 435 catch (PersistenceException) { 431 } catch (PersistenceException) { 436 432 throw; 437 } 438 catch (Exception e) { 433 } catch (Exception e) { 439 434 throw new PersistenceException("Unexpected exception during Serialization.", e); 440 435 } … … 453 448 CompressionType compressionType = CompressionType.GZip) { 454 449 try { 455 Serializer serializer = newSerializer(obj, config);450 var serializer = new HeuristicLab.Persistence.Core.Serializer(obj, config); 456 451 if (compressionType == CompressionType.Zip) { 457 452 Serialize(stream, includeAssemblies, CompressionLevel.Optimal, serializer); … … 460 455 } 461 456 types = serializer.SerializedTypes; 462 } 463 catch (PersistenceException) { 457 } catch (PersistenceException) { 464 458 throw; 465 } 466 catch (Exception e) { 459 } catch (Exception e) { 467 460 throw new PersistenceException("Unexpected exception during Serialization.", e); 468 461 } 469 462 } 470 463 471 private static void Serialize(Stream stream, Serializer serializer) {464 private static void Serialize(Stream stream, HeuristicLab.Persistence.Core.Serializer serializer) { 472 465 using (StreamWriter writer = new StreamWriter(new GZipStream(stream, CompressionMode.Compress))) { 473 466 serializer.InterleaveTypeInformation = true; -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/XmlParser.cs
r14185 r14927 81 81 try { 82 82 iterator = handlers[reader.Name].Invoke(); 83 } 84 catch (KeyNotFoundException) { 83 } catch (KeyNotFoundException) { 85 84 throw new PersistenceException(String.Format( 86 85 "Invalid XML tag \"{0}\" in persistence file.", … … 182 181 } 183 182 return typeCache; 184 } 185 catch (PersistenceException) { 183 } catch (PersistenceException) { 186 184 throw; 187 } 188 catch (Exception e) { 185 } catch (Exception e) { 189 186 throw new PersistenceException("Unexpected exception during type cache parsing.", e); 190 187 } … … 204 201 } 205 202 } 206 } 207 finally { 203 } finally { 208 204 TimeSpan end = System.Diagnostics.Process.GetCurrentProcess().TotalProcessorTime; 209 205 Tracing.Logger.Info(string.Format( … … 251 247 return deserializer.Deserialize(parser); 252 248 } 253 } 254 catch (PersistenceException) { 249 } catch (PersistenceException) { 255 250 throw; 256 } 257 catch (Exception x) { 251 } catch (Exception x) { 258 252 throw new PersistenceException("Unexpected exception during deserialization", x); 259 253 } … … 279 273 280 274 return result; 281 } 282 catch (PersistenceException) { 275 } catch (PersistenceException) { 283 276 throw; 284 } 285 catch (Exception e) { 277 } catch (Exception e) { 286 278 throw new PersistenceException("Unexpected exception during deserialization", e); 287 279 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/Default/Xml/XmlString.cs
r14185 r14927 21 21 22 22 using System.Text; 23 using HeuristicLab.Persistence .Default.CompositeSerializers.Storable;23 using HeuristicLab.Persistence; 24 24 using HeuristicLab.Persistence.Interfaces; 25 25 … … 29 29 /// XML friendly encapsulation of string data. 30 30 /// </summary> 31 [Storable Class]31 [StorableType("a358bb95-a494-4512-b1fe-53c66c77423c")] 32 32 public class XmlString : ISerialData { 33 33 -
branches/PersistenceReintegration/HeuristicLab.Persistence/3.3/HeuristicLab.Persistence-3.3.csproj
r14926 r14927 134 134 <None Include="Plugin.cs.frame" /> 135 135 <Compile Include="Core\Configuration.cs" /> 136 <Compile Include="Core\PersistenceException.cs" />137 136 <Compile Include="Core\PrimitiveSerializerBase.cs" /> 138 137 <Compile Include="Core\FormatBase.cs" /> … … 157 156 <Compile Include="Default\CompositeSerializers\Storable\StorableReflection.cs" /> 158 157 <Compile Include="Default\CompositeSerializers\Storable\StorableMemberInfo.cs" /> 159 <Compile Include="Core\DataMemberAccessor.cs" />160 158 <Compile Include="Default\CompositeSerializers\Storable\StorableSerializer.cs" /> 161 159 <Compile Include="Default\CompositeSerializers\StructSerializer.cs" /> -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Core/ComponentInfo.cs
r13347 r14927 21 21 22 22 using System.Reflection; 23 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;24 23 25 24 namespace HeuristicLab.Persistence { -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Core/DataMemberAccessor.cs
r14921 r14927 24 24 using System.Reflection.Emit; 25 25 26 namespace HeuristicLab.Persistence .Core{26 namespace HeuristicLab.Persistence { 27 27 28 28 /// <summary> -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Core/PersistenceException.cs
r14921 r14927 25 25 using System.Text; 26 26 27 namespace HeuristicLab.Persistence .Core{27 namespace HeuristicLab.Persistence { 28 28 29 29 /// <summary> -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Core/StaticCache.cs
r14739 r14927 26 26 using System.Linq; 27 27 using Google.ProtocolBuffers; 28 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;29 28 using HeuristicLab.PluginInfrastructure; 30 29 … … 50 49 foreach (var transformer in ApplicationManager.Manager.GetInstances<ITransformer>()) 51 50 RegisterTransformer(transformer); 52 53 54 //55 //56 //57 //58 //59 //60 //61 //62 //63 //64 // "0F24C888-AF34-4318-9472-187B9AA85F3C"65 66 67 51 68 52 RegisterType(new Guid("ECAEA154-6BFF-419F-8BE6-2565E9314825"), typeof(object)); -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Core/StorableAttribute.cs
r14925 r14927 1 1 #region License Information 2 2 /* HeuristicLab 3 * Copyright (C) 2002-201 6Heuristic and Evolutionary Algorithms Laboratory (HEAL)3 * Copyright (C) 2002-2015 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 4 4 * 5 5 * This file is part of HeuristicLab. … … 21 21 22 22 using System; 23 using System.Reflection; 23 24 using System.Text; 24 25 25 namespace HeuristicLab.Persistence .Default.CompositeSerializers.Storable{26 namespace HeuristicLab.Persistence { 26 27 27 28 28 29 /// <summary> 29 30 /// Mark the member of a class to be considered by the <c>StorableSerializer</c>. 30 /// The class must be marked as <c>[StorableClass ]</c> and the31 /// <c>Storable ClassType</c> should be set to <c>MarkedOnly</c> for31 /// The class must be marked as <c>[StorableClass("05FE6F11-87C6-435E-800A-166AFACCF5AC")]</c> and the 32 /// <c>StorableMemberSelection</c> should be set to <c>MarkedOnly</c> for 32 33 /// this attribute to kick in. 33 34 /// </summary> … … 37 38 Inherited = false)] 38 39 public class StorableAttribute : Attribute { 40 public static bool IsStorable(MemberInfo memberInfo) { 41 return Attribute.IsDefined(memberInfo, typeof(StorableAttribute), false); 42 } 43 public static StorableAttribute GetStorableAttribute(MemberInfo memberInfo) { 44 return (StorableAttribute)Attribute.GetCustomAttribute(memberInfo, typeof(StorableAttribute), false); 45 } 39 46 40 47 /// <summary> -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Core/StorableConstructorAttribute.cs
r14925 r14927 1 1 #region License Information 2 2 /* HeuristicLab 3 * Copyright (C) 2002-201 6Heuristic and Evolutionary Algorithms Laboratory (HEAL)3 * Copyright (C) 2002-2015 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 4 4 * 5 5 * This file is part of HeuristicLab. … … 21 21 22 22 using System; 23 using System.Reflection; 23 24 24 namespace HeuristicLab.Persistence .Default.CompositeSerializers.Storable{25 namespace HeuristicLab.Persistence { 25 26 26 27 … … 34 35 /// </summary> 35 36 [AttributeUsage(AttributeTargets.Constructor, Inherited = false, AllowMultiple = false)] 36 public sealed class StorableConstructorAttribute : Attribute { } 37 public sealed class StorableConstructorAttribute : Attribute { 38 public static bool IsStorableConstructor(ConstructorInfo constructorInfo) { 39 return Attribute.IsDefined(constructorInfo, typeof(StorableConstructorAttribute)); 40 } 41 } 37 42 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Core/StorableConversionAttribute.cs
r14771 r14927 28 28 public uint SrcVersion { get; set; } 29 29 30 public StorableConversionAttribute(uint srcVersion) 31 { 30 public StorableConversionAttribute(uint srcVersion) { 32 31 this.SrcVersion = srcVersion; 33 32 } -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Core/StorableHookAttribute.cs
r14925 r14927 1 1 #region License Information 2 2 /* HeuristicLab 3 * Copyright (C) 2002-201 6Heuristic and Evolutionary Algorithms Laboratory (HEAL)3 * Copyright (C) 2002-2015 Heuristic and Evolutionary Algorithms Laboratory (HEAL) 4 4 * 5 5 * This file is part of HeuristicLab. … … 21 21 22 22 using System; 23 using System.Linq; 24 using System.Reflection; 23 25 24 namespace HeuristicLab.Persistence .Default.CompositeSerializers.Storable{26 namespace HeuristicLab.Persistence { 25 27 26 28 … … 49 51 /// </summary> 50 52 [AttributeUsage(AttributeTargets.Method, Inherited = false, AllowMultiple = true)] 53 [StorableType("983bf558-1458-4129-b018-7e121ac3840e")] 51 54 public sealed class StorableHookAttribute : Attribute { 55 public static bool IsStorableHook(MethodInfo methodInfo) { 56 return Attribute.IsDefined(methodInfo, typeof(StorableHookAttribute), false); 57 } 58 public static StorableHookAttribute[] GetStorableHookAttributes(MethodInfo methodInfo) { 59 return Attribute.GetCustomAttributes(methodInfo, false).OfType<StorableHookAttribute>().ToArray(); 60 } 52 61 53 62 private readonly HookType hookType; … … 64 73 /// at the <c>HookType</c> time. 65 74 /// </summary> 66 /// <param name="hookType"> Typeof the hook.</param>75 /// <param name="hookType">MemberSelection of the hook.</param> 67 76 public StorableHookAttribute(HookType hookType) { 68 77 this.hookType = hookType; -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Core/TypeInfo.cs
r14711 r14927 25 25 using System.Reflection; 26 26 using System.Reflection.Emit; 27 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;28 27 29 28 namespace HeuristicLab.Persistence { -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/HeuristicLab.Persistence-4.0.csproj
r14926 r14927 48 48 <ItemGroup> 49 49 <Compile Include="Core\ComponentInfo.cs" /> 50 <Compile Include="Core\DataMemberAccessor.cs" /> 50 51 <Compile Include="Core\Index.cs" /> 52 <Compile Include="Core\PersistenceException.cs" /> 51 53 <Compile Include="Core\StaticCache.cs" /> 52 54 <Compile Include="Core\Mapper.cs" /> -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/ISerializer.cs
r13347 r14927 23 23 24 24 namespace HeuristicLab.Persistence { 25 [StorableType("81ac6e7f-1a3e-4a60-a146-c407104c02ca")] 25 26 public interface ISerializer { 26 27 void Serialize(object o, Stream stream); -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/ITransformer.cs
r14549 r14927 23 23 24 24 namespace HeuristicLab.Persistence { 25 [StorableType("51aec2b4-6e18-4e6d-b00b-ee656747be78")] 25 26 public interface ITransformer { 26 27 Guid Guid { get; } -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Transformers/StorableClassTransformer.cs
r14771 r14927 24 24 using System.Linq; 25 25 using System.Reflection; 26 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;27 26 28 27 namespace HeuristicLab.Persistence { 29 28 [Transformer("78556C88-0FEE-4602-95C7-A469B2DDB468", 100)] 29 [StorableType("3a578289-43ca-40f8-9f1e-2bdd255cb8fb")] 30 30 internal sealed class StorableClassBoxTransformer : BoxTransformer<object> { 31 31 public override bool CanTransformType(Type type) { … … 89 89 dict.Add(mapper.GetString(component.Key), mapper.GetObject(component.Value)); 90 90 } 91 91 92 92 // TODO: check that all entries in the dictionary can be mapped to a field or property 93 93 foreach (var convMeth in conversionMethods) { -
branches/PersistenceReintegration/HeuristicLab.Persistence/4.0/Transformers/Transformers.cs
r14771 r14927 31 31 using System.Reflection; 32 32 using Google.ProtocolBuffers; 33 using HeuristicLab.Persistence.Core;34 using HeuristicLab.Persistence.Default.CompositeSerializers.Storable;35 33 36 34 namespace HeuristicLab.Persistence { 35 [StorableType("8c7e99f5-092f-4cef-8b72-8afec1d10236")] 37 36 public abstract class BoxTransformer<T> : Transformer { 38 37 public override bool CanTransformType(Type type) { … … 55 54 56 55 #region Scalar Box Transformers 56 [StorableType("4b800c20-e93d-4186-9ccc-9e8081c028bb")] 57 57 public abstract class BoolBoxTransformer<T> : BoxTransformer<T> { 58 58 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 67 67 protected abstract T ToValueType(bool value, Type type, Mapper mapper); 68 68 } 69 [StorableType("72b92810-3eee-4a35-b87a-0a9b06b58945")] 69 70 public abstract class IntBoxTransformer<T> : BoxTransformer<T> { 70 71 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 79 80 protected abstract T ToValueType(int value, Type type, Mapper mapper); 80 81 } 82 [StorableType("e7344a71-276d-4fc7-9d80-1f0a8b10dde5")] 81 83 public abstract class LongBoxTransformer<T> : BoxTransformer<T> { 82 84 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 91 93 protected abstract T ToValueType(long value, Type type, Mapper mapper); 92 94 } 95 [StorableType("76833301-5d1d-436d-86f6-6cfe1830405e")] 93 96 public abstract class UnsignedIntBoxTransformer<T> : BoxTransformer<T> { 94 97 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 103 106 protected abstract T ToValueType(uint value, Type type, Mapper mapper); 104 107 } 108 [StorableType("4eb19b56-7ac7-497c-b25c-a860d3d72565")] 105 109 public abstract class UnsignedLongBoxTransformer<T> : BoxTransformer<T> { 106 110 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 115 119 protected abstract T ToValueType(ulong value, Type type, Mapper mapper); 116 120 } 121 [StorableType("1a6613b2-772f-4334-b688-8b2a8483123b")] 117 122 public abstract class FloatBoxTransformer<T> : BoxTransformer<T> { 118 123 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 127 132 protected abstract T ToValueType(float value, Type type, Mapper mapper); 128 133 } 134 [StorableType("c7fee156-6310-42a6-9f07-838cef8f405e")] 129 135 public abstract class DoubleBoxTransformer<T> : BoxTransformer<T> { 130 136 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 139 145 protected abstract T ToValueType(double value, Type type, Mapper mapper); 140 146 } 147 [StorableType("f7ea684c-8784-4939-80d4-318558a8b4a4")] 141 148 public abstract class StringBoxTransformer<T> : BoxTransformer<T> { 142 149 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 151 158 protected abstract T ToValueType(string value, Type type, Mapper mapper); 152 159 } 160 [StorableType("cb1680ec-3141-437d-b28d-f17595ca6815")] 153 161 public abstract class BytesBoxTransformer<T> : BoxTransformer<T> { 154 162 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 166 174 167 175 #region Array Box Transformers 176 [StorableType("a6840c61-cf07-4e0a-a13c-392565e7326e")] 168 177 public abstract class ByteArrayBoxTransformer<T> : BoxTransformer<T> { 169 178 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 178 187 protected abstract T FromByteString(ByteString byteString); 179 188 } 189 [StorableType("543de8f9-bf32-431d-af52-8dd95cfd876f")] 180 190 public abstract class BoolArrayBoxTransformer<T> : BoxTransformer<T> { 181 191 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 190 200 protected abstract T ToValueType(IEnumerable<bool> value, Type type, Mapper mapper); 191 201 } 202 [StorableType("fb338e93-09c1-4e6e-8731-c5fefbb7fa82")] 192 203 public abstract class IntArrayBoxTransformer<T> : BoxTransformer<T> { 193 204 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 202 213 protected abstract T ToValueType(IEnumerable<int> value, Type type, Mapper mapper); 203 214 } 215 [StorableType("f751fbbd-ddd9-4f22-bf5e-9336d8913ab0")] 204 216 public abstract class LongArrayBoxTransformer<T> : BoxTransformer<T> { 205 217 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 214 226 protected abstract T ToValueType(IEnumerable<long> value, Type type, Mapper mapper); 215 227 } 228 [StorableType("912793f8-0136-4621-880c-5d6da0bbefa5")] 216 229 public abstract class UnsignedIntArrayBoxTransformer<T> : BoxTransformer<T> { 217 230 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 226 239 protected abstract T ToValueType(IEnumerable<uint> value, Type type, Mapper mapper); 227 240 } 241 [StorableType("e9b844a1-9f14-438f-abd8-8af0fdb73d77")] 228 242 public abstract class UnsignedLongArrayBoxTransformer<T> : BoxTransformer<T> { 229 243 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 238 252 protected abstract T ToValueType(IEnumerable<ulong> value, Type type, Mapper mapper); 239 253 } 254 [StorableType("f08a787d-d695-44ee-a9ac-e8b966f98c34")] 240 255 public abstract class FloatArrayBoxTransformer<T> : BoxTransformer<T> { 241 256 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 250 265 protected abstract T ToValueType(IEnumerable<float> value, Type type, Mapper mapper); 251 266 } 267 [StorableType("622efa85-484e-459e-b79d-4462ba225394")] 252 268 public abstract class DoubleArrayBoxTransformer<T> : BoxTransformer<T> { 253 269 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 262 278 protected abstract T ToValueType(IEnumerable<double> value, Type type, Mapper mapper); 263 279 } 280 [StorableType("5dfba6f6-2762-4d08-9c34-f6d10cc20913")] 264 281 public abstract class StringArrayBoxTransformer<T> : BoxTransformer<T> { 265 282 protected override void Populate(Box.Builder box, T value, Mapper mapper) { … … 277 294 278 295 [Transformer("11B822C9-46A0-4B65-AE4A-D12F63DDE9F6", 50)] 296 [StorableType("7d783c07-2e05-4d89-9c06-b243c546e667")] 279 297 internal sealed class TypeTransformer : Transformer { 280 298 public override bool CanTransformType(Type type) { … … 321 339 #region Primitive Value Types 322 340 [Transformer("268617FE-3F0F-4029-8248-EDA420901FB6", 10000)] 341 [StorableType("320cba58-1aaf-492b-be3b-f59eea085ebe")] 323 342 internal sealed class ObjectTransformer : BoxTransformer<object> { 324 343 protected override void Populate(Box.Builder box, object value, Mapper mapper) { } … … 327 346 328 347 [Transformer("9FA1C6A8-517E-4623-AC1B-7E9AEF6ED13D", 200)] 348 [StorableType("be3c6d74-5c67-4a54-ab3c-f1040795d364")] 329 349 internal sealed class BoolTransformer : BoolBoxTransformer<bool> { 330 350 protected override bool ToBoxType(bool value, Mapper mapper) { return value; } … … 333 353 334 354 [Transformer("059633E9-12CB-43EC-8544-57746536E281", 201)] 355 [StorableType("3f1e111d-3ea8-4318-884f-185ef96bdfe4")] 335 356 internal sealed class ByteTransformer : UnsignedIntBoxTransformer<byte> { 336 357 protected override uint ToBoxType(byte value, Mapper mapper) { return value; } … … 339 360 340 361 [Transformer("5DC2F3AC-0852-4B57-A861-D29CC814A94C", 202)] 362 [StorableType("498da443-43d3-4bc4-9ee9-c41416bb5c6b")] 341 363 internal sealed class SByteTransformer : IntBoxTransformer<sbyte> { 342 364 protected override int ToBoxType(sbyte value, Mapper mapper) { return value; } … … 345 367 346 368 [Transformer("B862E642-A94A-4870-8065-06126A35A9E1", 203)] 369 [StorableType("9f9ea850-1dd5-4dc0-abb5-8e75b22a0ffe")] 347 370 internal sealed class ShortTransformer : IntBoxTransformer<short> { 348 371 protected override int ToBoxType(short value, Mapper mapper) { return value; } … … 351 374 352 375 [Transformer("D1D3062D-F1BB-4189-AE50-D6986E1DEB4E", 204)] 376 [StorableType("4b70fdb5-a2ed-4a08-ab17-10fb5db11ada")] 353 377 internal sealed class UShortTransformer : UnsignedIntBoxTransformer<ushort> { 354 378 protected override uint ToBoxType(ushort value, Mapper mapper) { return value; } … … 357 381 358 382 [Transformer("6C444645-3062-4D15-AD01-E6E1B0692A2B", 205)] 383 [StorableType("fdf24c34-7c10-49bb-aad2-a668c1490381")] 359 384 internal sealed class CharTransformer : UnsignedIntBoxTransformer<char> { 360 385 protected override uint ToBoxType(char value, Mapper mapper) { return value; } … … 363 388 364 389 [Transformer("649E73B2-EFA6-4E01-BCB4-4B29D652C9CB", 206)] 390 [StorableType("0b2bcdf7-5787-4027-acd4-46f5f7641bff")] 365 391 internal sealed class IntTransformer : IntBoxTransformer<int> { 366 392 protected override int ToBoxType(int value, Mapper mapper) { return value; } … … 369 395 370 396 [Transformer("BCF25010-81A2-49BC-88CC-407D3F393D5B", 207)] 397 [StorableType("eec933ec-f705-435e-9b7e-e4fc4d90c21e")] 371 398 internal sealed class UIntTransformer : UnsignedIntBoxTransformer<uint> { 372 399 protected override uint ToBoxType(uint value, Mapper mapper) { return value; } … … 375 402 376 403 [Transformer("B6F6ACAE-755C-47EE-B8BF-7CDECBE19C30", 208)] 404 [StorableType("b0edffdd-8a00-48e1-a7a1-808ddec3b933")] 377 405 internal sealed class LongTransformer : LongBoxTransformer<long> { 378 406 protected override long ToBoxType(long value, Mapper mapper) { return value; } … … 381 409 382 410 [Transformer("82333ACA-F041-44E0-B365-27C399594BA7", 209)] 411 [StorableType("0ebd1d6b-aa2d-442b-b524-68558d77e22e")] 383 412 internal sealed class ULongTransformer : UnsignedLongBoxTransformer<ulong> { 384 413 protected override ulong ToBoxType(ulong value, Mapper mapper) { return value; } … … 387 416 388 417 [Transformer("8FE91ECF-2261-4934-BECD-C38923B7A703", 210)] 418 [StorableType("d9f05b32-218f-4b8e-9ec7-ab5dcbbaf0fc")] 389 419 internal sealed class FloatTransformer : FloatBoxTransformer<float> { 390 420 protected override float ToBoxType(float value, Mapper mapper) { return value; } … … 393 423 394 424 [Transformer("070D23EA-7F38-46B7-A667-219BEF914E49", 211)] 425 [StorableType("70b79b46-2713-42ac-ace6-a55ffb0624be")] 395 426 internal sealed class DoubleTransformer : DoubleBoxTransformer<double> { 396 427 protected override double ToBoxType(double value, Mapper mapper) { return value; } … … 399 430 400 431 [Transformer("BA55C7A6-C91E-4351-A889-E4A7E647F16D", 212)] 432 [StorableType("4ed946fd-aac8-407b-bb9e-093048024d15")] 401 433 internal sealed class DateTimeTransformer : LongBoxTransformer<DateTime> { 402 434 protected override long ToBoxType(DateTime value, Mapper mapper) { return value.Ticks; } … … 405 437 406 438 [Transformer("0C91441B-2D97-432B-B493-D6EC483FC5AD", 213)] 439 [StorableType("bbc20151-b695-43dc-a38a-a610c8410fd2")] 407 440 internal sealed class TimeSpanTransformer : LongBoxTransformer<TimeSpan> { 408 441 protected override long ToBoxType(TimeSpan value, Mapper mapper) { return value.Ticks; } … … 411 444 412 445 [Transformer("0B540EAC-79AB-40CF-8277-D2C81135FEB6", 214)] 446 [StorableType("aac1fee2-ea34-46b4-9db7-3ae8da8927eb")] 413 447 internal sealed class ColorTransformers : IntBoxTransformer<Color> { 414 448 protected override int ToBoxType(Color value, Mapper mapper) { return value.ToArgb(); } … … 417 451 418 452 [Transformer("2E6D4A40-B4BE-425F-8E35-2D7C00054639", 215)] 453 [StorableType("11a33d00-5edc-4c49-884a-9f2809c23b30")] 419 454 internal sealed class PointTransformer : IntArrayBoxTransformer<Point> { 420 455 protected override IEnumerable<int> ToBoxType(Point value, Mapper mapper) { return new int[] { value.X, value.Y }; } … … 423 458 424 459 [Transformer("97B5CFC8-CDFA-4EB5-B4CD-5B3CFA5CD844", 216)] 460 [StorableType("993238c2-a2ed-4e0d-84ae-ad025f2f20f4")] 425 461 internal sealed class KeyValuePairTransformer : BoxTransformer<object> { 426 462 public override bool CanTransformType(Type type) { … … 452 488 453 489 [Transformer("EBD8BF65-D97D-4FD4-BF4F-9D58A72B6249", 217)] 490 [StorableType("b7725dfa-94fb-4169-b375-6e46b7ca4810")] 454 491 internal sealed class DecimalTransformer : UnsignedIntBoxTransformer<decimal> { 455 492 protected override uint ToBoxType(decimal value, Mapper mapper) { … … 478 515 #region String 479 516 [Transformer("E75A594C-0034-4DAB-B28E-8F84F9F6DE8D", 218)] 517 [StorableType("ba52fce8-bf0c-47ad-95dd-df5d9281942d")] 480 518 internal sealed class StringTransformer : UnsignedIntBoxTransformer<string> { 481 519 protected override uint ToBoxType(string value, Mapper mapper) { return mapper.GetStringId(value); } … … 486 524 #region Enum 487 525 [Transformer("93FF076B-BC4B-4C39-8C40-15E004468C98", 219)] 526 [StorableType("f8a7dbb4-e1ce-4db8-905e-f3a05f5ca000")] 488 527 internal sealed class EnumTransformer : Transformer { 489 528 public override bool CanTransformType(Type type) { … … 512 551 #region Struct 513 552 [Transformer("89DAAFC5-726C-48D4-A4E0-2B0D27329642", 220)] 553 [StorableType("c3c4ad38-7110-439c-b73c-d33466db3db4")] 514 554 internal sealed class StructTransformer : Transformer { 515 555 public override bool CanTransformType(Type type) { … … 552 592 foreach (var t in components) { 553 593 string name = mapper.GetString(t.Key); 554 MemberInfo[] mis = type.GetMember(name, BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic); 594 MemberInfo[] mis = type.GetMember(name, BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic); 555 595 if (mis.Length != 1) 556 596 throw new Exception("ambiguous struct member name " + name); 557 597 MemberInfo mi = mis[0]; 558 if (StorableAttribute.IsStorable(mi))598 if (StorableAttribute.IsStorable(mi)) 559 599 throw new PersistenceException("Don't use stroable attributes for structs as all fields are serialized automatically."); 560 600 if (mi.MemberType == MemberTypes.Field) … … 571 611 #region Tuple 572 612 [Transformer("63A19D57-EEEF-4346-9F06-B35B15EBFFA3", 221)] 613 [StorableType("ab537f25-dc21-4585-b743-0350a5cf1e54")] 573 614 internal sealed class TupleTransformer : Transformer { 574 615 private static readonly HashSet<Type> supportedTypes = new HashSet<Type> { … … 616 657 #region Bitmap 617 658 [Transformer("D0ADB806-2DFD-459D-B5DA-14B5F1152534", 222)] 659 [StorableType("b13d6153-e71d-4b76-9893-81d3570403e8")] 618 660 internal sealed class BitmapTransformer : ByteArrayBoxTransformer<Bitmap> { 619 661 protected override ByteString ToByteString(Bitmap value) { … … 636 678 #region Font 637 679 [Transformer("AFF27987-3301-4D70-9601-EFCA31BDA0DB", 223)] 680 [StorableType("b9f9a371-4dcb-478b-b0d4-6f87a15c02b5")] 638 681 internal sealed class FontTransformer : UnsignedIntArrayBoxTransformer<Font> { 639 682 … … 680 723 #region Array Types 681 724 [Transformer("FF89F6D1-CDE3-498E-9166-F70AC6EB01F1", 301)] 725 [StorableType("59d8363a-7e6c-4d29-9432-8274acd2145f")] 682 726 internal sealed class ByteArrayTransformer : ByteArrayBoxTransformer<byte[]> { 683 727 protected override ByteString ToByteString(byte[] value) { … … 690 734 691 735 [Transformer("B49B3F2D-2E97-4BAB-8705-8D29DA707C6A", 302)] 736 [StorableType("304c7463-4575-481b-8922-6a54957305c7")] 692 737 internal sealed class SByteArrayTransformer : ByteArrayBoxTransformer<sbyte[]> { 693 738 protected override ByteString ToByteString(sbyte[] value) { … … 700 745 701 746 [Transformer("F25A73B2-6B67-4493-BD59-B836AF4455D1", 300)] 747 [StorableType("06fdb68c-ec5e-4cb5-9ad1-063fca0b9c2e")] 702 748 internal sealed class BoolArrayTransformer : BoolArrayBoxTransformer<bool[]> { 703 749 protected override IEnumerable<bool> ToBoxType(bool[] value, Mapper mapper) { return value; } … … 706 752 707 753 [Transformer("2811FDD4-6800-4CBA-86D7-9071ED5775ED", 303)] 754 [StorableType("832d8971-51b1-4264-b7eb-07d6e836bf7b")] 708 755 internal sealed class ShortArrayTransformer : ByteArrayBoxTransformer<short[]> { 709 756 protected override ByteString ToByteString(short[] value) { … … 726 773 727 774 [Transformer("1AAC2625-356C-40BC-8CB4-15CB3D047EB8", 304)] 775 [StorableType("c303b4cf-ffd0-47e2-9d94-07f2d558d17f")] 728 776 internal sealed class UShortArrayTransformer : ByteArrayBoxTransformer<ushort[]> { 729 777 protected override ByteString ToByteString(ushort[] value) { … … 746 794 747 795 [Transformer("12F19098-5D49-4C23-8897-69087F1C146D", 305)] 796 [StorableType("55f7c8b0-f2aa-4830-857d-6ce2807da138")] 748 797 internal sealed class CharArrayTransformer : ByteArrayBoxTransformer<char[]> { 749 798 protected override ByteString ToByteString(char[] value) { … … 766 815 767 816 [Transformer("5F6DC3BC-4433-4AE9-A636-4BD126F7DACD", 306)] 817 [StorableType("e7089621-5236-4d37-a592-c8a0816c59fa")] 768 818 internal sealed class IntArrayTransformer : IntArrayBoxTransformer<int[]> { 769 819 protected override IEnumerable<int> ToBoxType(int[] value, Mapper mapper) { return value; } … … 772 822 773 823 [Transformer("3F10274F-D350-4C82-89EA-A5EB36D4EFCC", 307)] 824 [StorableType("0972d235-5e21-4abf-84f8-aad1bbfdff40")] 774 825 internal sealed class UIntArrayTransformer : UnsignedIntArrayBoxTransformer<uint[]> { 775 826 protected override IEnumerable<uint> ToBoxType(uint[] value, Mapper mapper) { return value; } … … 778 829 779 830 [Transformer("E9D550E2-57F7-47F3-803D-37A619DA1A5C", 308)] 831 [StorableType("0c656d5d-11dc-4a75-895a-06701048cd70")] 780 832 internal sealed class LongArrayTransformer : LongArrayBoxTransformer<long[]> { 781 833 protected override IEnumerable<long> ToBoxType(long[] value, Mapper mapper) { return value; } … … 784 836 785 837 [Transformer("C02A205B-2176-4282-AC2B-ADEF96DDBE24", 309)] 838 [StorableType("c5f87514-a6c1-400b-9a6c-8adcf980f701")] 786 839 internal sealed class ULongArrayTransformer : UnsignedLongArrayBoxTransformer<ulong[]> { 787 840 protected override IEnumerable<ulong> ToBoxType(ulong[] value, Mapper mapper) { return value; } … … 790 843 791 844 [Transformer("3C4590D9-C76E-4AFB-98FD-E50D3D051648", 310)] 845 [StorableType("ecc63624-1b78-4bef-8326-74c1a43078ff")] 792 846 internal sealed class FloatArrayTransformer : FloatArrayBoxTransformer<float[]> { 793 847 protected override IEnumerable<float> ToBoxType(float[] value, Mapper mapper) { return value; } … … 796 850 797 851 [Transformer("FB98C399-9323-4470-9A85-9186C2B2D5D4", 311)] 852 [StorableType("03025baa-f57a-48de-b0e2-8e6dc10740ee")] 798 853 internal sealed class DoubleArrayTransformer : DoubleArrayBoxTransformer<double[]> { 799 854 protected override IEnumerable<double> ToBoxType(double[] value, Mapper mapper) { return value; } … … 802 857 803 858 [Transformer("68332513-9CF1-47FA-A093-6DDB663186EC", 312)] 859 [StorableType("791ea34d-e071-4ef2-812b-eb8e2faced45")] 804 860 internal sealed class StringArrayTransformer : StringArrayBoxTransformer<string[]> { 805 861 protected override IEnumerable<string> ToBoxType(string[] value, Mapper mapper) { return value; } … … 808 864 809 865 [Transformer("B01ADF0A-ACAA-444E-9F82-0C7C2AF1F490", 400)] 866 [StorableType("56ae4f46-9fc1-4243-a07f-7b7c24e30545")] 810 867 internal sealed class ArrayTransformer : Transformer { 811 868 public override bool CanTransformType(Type type) { … … 897 954 898 955 [Transformer("4FA5EAAF-ECC7-4A9C-84E7-6583DA96F3B9", 500)] 956 [StorableType("b19c0fe5-6bba-4492-af91-c111edce77dc")] 899 957 internal sealed class EnumerableTransformer : Transformer { 900 958 private static readonly HashSet<Type> supportedTypes = new HashSet<Type> { … … 922 980 var comparer = propertyInfo.GetValue(value); 923 981 var comparerType = comparer.GetType(); 924 if ( Default.CompositeSerializers.Storable.StorableTypeAttribute.IsStorableType(comparerType))982 if (StorableTypeAttribute.IsStorableType(comparerType)) 925 983 uIntArrayBox.AddValues(mapper.GetBoxId(comparer)); 926 984 else if (comparerType.GetFields(BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.FlattenHierarchy).Any()) … … 970 1028 971 1029 [Transformer("C47A62F5-F113-4A43-A8EE-CF817EC799A2", 501)] 1030 [StorableType("ba53df84-dc97-4d8d-a493-868972ed1002")] 972 1031 internal sealed class DictionaryTransformer : Transformer { 973 1032 public override bool CanTransformType(Type type) { … … 992 1051 993 1052 var comparerType = comparer.GetType(); 994 if ( Default.CompositeSerializers.Storable.StorableTypeAttribute.IsStorableType(comparerType))1053 if (StorableTypeAttribute.IsStorableType(comparerType)) 995 1054 dictionaryBox.SetComparerId(mapper.GetBoxId(comparer)); 996 1055 else if (comparerType.GetFields(BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.FlattenHierarchy).Any())
Note: See TracChangeset
for help on using the changeset viewer.