Report a bug
		
				If you spot a problem with this page, click here to create a GitHub issue.
		
			Improve this page
		
			Quickly fork, edit online, and submit a pull request for this page.
			Requires a signed-in GitHub account. This works well for small changes.
			If you'd like to make larger changes you may want to consider using
			a local clone.
		
	mir.serde
This implements common de/serialization routines.
License: 
Authors: 
Ilya Yaroshenko
- classSerdeException: object.Exception;
- Serde Exception- pure nothrow @nogc @safe this(stringmsg, stringfile= __FILE__, size_tline= __LINE__, Throwablenext= null);
- pure nothrow @nogc @safe this(stringmsg, Throwablenext, stringfile= __FILE__, size_tline= __LINE__);
 
- classSerdeMirException: mir.serde.SerdeException;
- Serde Exception with formatting support
- structSerdeAnnotated(T, string annotation);
- Constructs annotated type.- Tvalue;
 
- enumSerdeTarget: int;
- Helper enumeration for for serializer . Use negative int values for user defined targets.- ion
- json
- cbor
- msgpack
- yaml
- csv
- excel
- bloomberg
- typedJson
 
- structserdeKeys;
- Attribute for key overloading during Serialization and Deserialization. The first argument overloads the key value during serialization unless serdeKeyOut is given.- immutable(string)[]keys;
- pure nothrow @nogc @trusted this(immutable(string)[]keys...);
 
- structserdeKeyOut;
- Attribute for key overloading during serialization.- stringkey;
- pure nothrow @nogc @safe this(stringkey);
 
- enumserdeRegister;
- The attribute should be used as a hind for scripting languages to register type deserializer in the type system.The attribute should be applied to a type definition.
- enumserdeAnnotation;
- The attribute can be applied to a string-like member that should be de/serialized as an annotation / attribute.Also, the attribute can be applied on a type to denote that the type should be used to de/serialize annotated value. This feature is used in mir-ion.
- templateisAnnotated(T)
- Checks if the type marked with serdeAnnotation.
- templateserdeGetAnnotationMembersIn(T)
- Examples:struct S { double data; @serdeAnnotation string a; @serdeAnnotation @serdeIgnoreIn string b; @serdeAnnotation @serdeIgnoreOut string c; @serdeAnnotation @serdeIgnore string d; } static assert(serdeGetAnnotationMembersIn!int == []); static assert(serdeGetAnnotationMembersIn!S == ["a", "c"]); 
- templateserdeGetAnnotationMembersOut(T)
- Examples:struct S { double data; @serdeAnnotation string a; @serdeAnnotation @serdeIgnoreIn string b; @serdeAnnotation @serdeIgnoreOut string c; @serdeAnnotation @serdeIgnore string d; @serdeAnnotation enum string e = "e"; static @serdeAnnotation string f() @safe pure nothrow @nogc @property { return "f"; } } static assert(serdeGetAnnotationMembersOut!int == []); static assert(serdeGetAnnotationMembersOut!S == ["a", "b", "f"]); 
- structserdeAlgebraicAnnotation;
- An annotation / attribute for algebraic types deserialization.This feature is used in mir-ion for mir.algebraic.- stringannotation;
- pure nothrow @nogc @safe this(stringannotation);
 
- templateserdeHasAlgebraicAnnotation(T)
- templateserdeGetAlgebraicAnnotation(T)
- templateserdeDynamicAlgebraic(alias getAlgebraicDeserializerByAnnotation)
- User defined attribute used to attach a function that returns a deserialization delegate.The attribute is usefull for scripting languages and dynamic algebraic types.Examples:static struct _global { alias Deserializer = S delegate(string s, ubyte[] data) @safe pure; Deserializer getDeserializer(string name) { return map[name]; } Deserializer[string] map; @serdeDynamicAlgebraic!getDeserializer struct S {} static assert(serdeIsDynamicAlgebraic!S); static assert(__traits(isSame, serdeGetAlgebraicDeserializer!S, getDeserializer)); } 
- templateserdeIsDynamicAlgebraic(T)
- templateserdeGetAlgebraicDeserializer(T)
- templateserdeGetKeysIn(alias symbol)
 pure nothrow @nogc @trusted immutable(string)[]serdeGetKeysIn(T)(const Tvalue)
 if (is(T == enum));
- Returns:immutable array of the input keys for the symbol or enum valueExamples:struct S { int f; @serdeKeys("D", "t") int d; @serdeIgnore int i; @serdeIgnoreIn int ii; @serdeIgnoreOut int io; void p(int) @property {} } static assert(serdeGetKeysIn!(S.f) == ["f"]); static assert(serdeGetKeysIn!(S.d) == ["D", "t"]); static assert(serdeGetKeysIn!(S.i) == null); static assert(serdeGetKeysIn!(S.ii) == null); static assert(serdeGetKeysIn!(S.io) == ["io"]); static assert(serdeGetKeysIn!(S.p) == ["p"]); Examples:enum E { @serdeKeys("A", "alpha") a, @serdeKeys("B", "beta") b, c, } static assert (serdeGetKeysIn(E.a) == ["A", "alpha"], serdeGetKeysIn(E.a)); static assert (serdeGetKeysIn(E.c) == ["c"]); 
- templateserdeGetKeyOut(alias symbol)
 pure nothrow @nogc @safe stringserdeGetKeyOut(T)(const Tvalue)
 if (is(T == enum));
- Returns:output key for the symbol or enum valueExamples:struct S { int f; @serdeKeys("D", "t") int d; @serdeIgnore int i; @serdeIgnoreIn int ii; @serdeIgnoreOut int io; @serdeKeys("P") @serdeKeyOut("") void p(int) @property {} } static assert(serdeGetKeyOut!(S.f) == "f"); static assert(serdeGetKeyOut!(S.d) == "D"); static assert(serdeGetKeyOut!(S.i) is null); static assert(serdeGetKeyOut!(S.ii) == "ii"); static assert(serdeGetKeyOut!(S.io) is null); static assert(serdeGetKeyOut!(S.p) !is null); static assert(serdeGetKeyOut!(S.p) == ""); Examples:enum E { @serdeKeys("A", "alpha") a, @serdeKeys("B", "beta") @serdeKeyOut("o") b, c, } static assert (serdeGetKeyOut(E.a) == "A"); static assert (serdeGetKeyOut(E.b) == "o"); static assert (serdeGetKeyOut(E.c) == "c"); 
- enumserdeIgnore;
- Attribute to ignore field.See Also:
- enumserdeIgnoreIn;
- Attribute to ignore field during deserialization.See Also:
- enumserdeIgnoreOut;
- Attribute to ignore field during serialization.
- enumserdeIgnoreDefault;
- Attribute to ignore a field during deserialization when equals to its default value. Do not use it on void initialized fields or aggregates with void initialized fields, recursively.Examples:struct S { @serdeIgnoreDefault double d = 0; // skips field if 0 during deserialization } import std.traits: hasUDA; static assert(hasUDA!(S.d, serdeIgnoreDefault)); 
- structserdeProxy(T);
- Serialization proxy.Examples:import mir.small_string; struct S { @serdeProxy!(SmallString!32) double d; } import std.traits: hasUDA; static assert(hasUDA!(S.d, serdeProxy)); static assert(hasUDA!(S.d, serdeProxy!(SmallString!32))); static assert(is(serdeGetProxy!(S.d) == SmallString!32)); 
- templateserdeGetProxy(alias symbol)
- enumserdeScopeStringProxy;
- Can be applied only to fields that can be constructed from strings. Does not allocate new data when deserializeing. Raw data is used for strings instead of new memory allocation. Use this attributes only for strings that would not be used after the input data deallocation.
- structserdeIgnoreOutIf(alias pred);
- Attributes to conditional ignore field during serialization.The predicate should be aplied to the member, to the aggregate type.See Also:
- templateserdeGetIgnoreOutIf(alias symbol)
- structserdeIgnoreOutIfAggregate(alias pred);
- Attributes to conditional ignore field during serialization.The predicate should be aplied to the aggregate value, not to the member.
- templateserdeGetIgnoreOutIfAggregate(alias symbol)
- structserdeIgnoreInIfAggregate(alias pred);
- Attributes to conditional ignore field during deserialization.The attribute should be combined with serdeRealOrderedIn applied on the aggregate.
- templateserdeGetIgnoreInIfAggregate(alias symbol)
- structserdeIgnoreIfAggregate(alias pred);
- Attributes to conditional ignore field during serialization and deserialization.The attribute should be combined with serdeRealOrderedIn applied on the aggregate. The predicate should be aplied to the aggregate value, not to the member.
- templateserdeGetIgnoreIfAggregate(alias symbol)
- enumserdeFlexible;
- Allows to use flexible deserialization rules such as conversion from input string to numeric types.
- enumserdeLikeList;
- Allows serialize / deserialize fields like arrays.A range or a container should be iterable for serialization. Following code should compile:foreach(ref value; yourRangeOrContainer) { ... } put(value) method is used for deserialization.See Also:
- enumserdeLikeStruct;
- Allows serialize / deserialize fields like objects.Object should have opApply method to allow serialization. Following code should compile:foreach(key, value; yourObject) { ... }Object should have only one opApply method with 2 argument to allow automatic value type deduction. opIndexAssign or opIndex is used for deserialization to support required syntax:yourObject["key"] = value;Multiple value types is supported for deserialization.See Also:
- enumserdeFallbackStruct;
- The attribute is used for algebraic deserialization for types like Variant!(string, S) @serdeFallbackStructstruct S {}
- enumserdeFields;
- Force serialize / deserialize on fields instead of Range API.
- enumserdeIgnoreCase;
- Ignore keys for object and enum members. Should be applied to members or enum type itself.
- boolhasSerdeIgnoreCase(T)(Tvalue)
 if (is(T == enum));
- Examples:enum E { @serdeIgnoreCase a, b, @serdeIgnoreCase c, d, } static assert(hasSerdeIgnoreCase(E.a)); static assert(!hasSerdeIgnoreCase(E.b)); static assert(hasSerdeIgnoreCase(E.c)); static assert(!hasSerdeIgnoreCase(E.d)); Examples:@serdeIgnoreCase enum E { a, b, c, d, } static assert(hasSerdeIgnoreCase(E.a)); static assert(hasSerdeIgnoreCase(E.b)); static assert(hasSerdeIgnoreCase(E.c)); static assert(hasSerdeIgnoreCase(E.d)); 
- enumserdeScoped;
- Can be applied only to strings fields. Does not allocate new data when deserializeing. Raw data is used for strings instead of new memory allocation. Use this attributes only for strings or arrays that would not be used after deallocation.
- enumserdeRequired;
- Attribute that force deserializer to throw an exception that the field hasn't been not found in the input.
- enumserdeOptional;
- Attribute that allow deserializer to do not throw an exception if the field hasn't been not found in the input.
- enumserdeAllowMultiple;
- Attribute that allow deserializer to don't throw an exception that the field matches multiple keys in the object.
- structserdeTransformIn(alias fun);
- Attributes for in transformation. Return type of in transformation must be implicitly convertable to the type of the field. In transformation would be applied after serialization proxy if any.
- templateserdeGetTransformIn(alias value)
- Returns:unary function of underlaying alias of serdeTransformIn
- structserdeTransformOut(alias fun);
- Attributes for out transformation. Return type of out transformation may be differ from the type of the field. Out transformation would be applied before serialization proxy if any.
- templateserdeGetTransformOut(alias value)
- Returns:unary function of underlaying alias of serdeTransformOut
- pure nothrow @nogc @safe boolserdeParseEnum(E)(const char[]str, ref Eres);
- Examples:enum E { @serdeKeys("A", "alpha") a, @serdeKeys("B", "beta") b, c, } auto e = E.c; assert(serdeParseEnum("A", e)); assert(e == E.a); assert(serdeParseEnum("alpha", e)); assert(e == E.a); assert(serdeParseEnum("beta", e)); assert(e == E.b); assert(serdeParseEnum("B", e)); assert(e == E.b); assert(serdeParseEnum("c", e)); assert(e == E.c); assert(!serdeParseEnum("C", e)); assert(!serdeParseEnum("Alpha", e)); Examples:Case insensitive@serdeIgnoreCase // supported for the whole type enum E { @serdeKeys("A", "alpha") a, @serdeKeys("B", "beta") b, c, } auto e = E.c; assert(serdeParseEnum("a", e)); assert(e == E.a); assert(serdeParseEnum("alpha", e)); assert(e == E.a); assert(serdeParseEnum("BETA", e)); assert(e == E.b); assert(serdeParseEnum("b", e)); assert(e == E.b); assert(serdeParseEnum("C", e)); assert(e == E.c); 
- templateserdeDeserializationMemberType(T, string member)
 templateserdeDeserializationMemberType(T)
- Deserialization member type
- templateserdeIsDeserializable(T)
- Is deserializable memberExamples:static struct S { @serdeIgnore int i; @serdeKeys("a", "b") int a; } alias serdeIsDeserializableInS = serdeIsDeserializable!S; static assert (!serdeIsDeserializableInS!"i"); static assert (serdeIsDeserializableInS!"a"); - enum boolserdeIsDeserializable(string member);
 
- templateserdeSerializationMemberType(T, string member)
 templateserdeSerializationMemberType(T)
- Serialization member type
- templateserdeIsSerializable(T)
- Is deserializable memberExamples:static struct S { @serdeIgnore int i; @serdeKeys("a", "b") int a; } alias serdeIsSerializableInS = serdeIsSerializable!S; static assert (!serdeIsSerializableInS!"i"); static assert (serdeIsSerializableInS!"a"); - enum boolserdeIsSerializable(string member);
 
- templateserdeGetFinalProxy(T)
- Final proxy typeExamples:@serdeProxy!string static struct A {} @serdeProxy!A static struct B {} @serdeProxy!B static struct C {} static assert (is(serdeGetFinalProxy!C == string), serdeGetFinalProxy!C.stringof); static assert (is(serdeGetFinalProxy!string == string)); 
- templateserdeGetFinalDeepProxy(T)
- Final deep proxy typeExamples:@serdeProxy!string static struct A {} enum E {a,b,c} @serdeProxy!(A[E]) static struct B {} @serdeProxy!(B[]) static struct C {} static assert (is(serdeGetFinalDeepProxy!C == A[E])); static assert (is(serdeGetFinalDeepProxy!string == string)); 
- templateserdeFinalProxyDeserializableMembers(T)
- Final proxy type deserializable membersExamples:static struct A { @serdeIgnore int i; @serdeKeys("a", "b") int m; } @serdeProxy!A static struct B {} @serdeProxy!B static struct C {} static assert (serdeFinalProxyDeserializableMembers!C == ["m"]); 
- templateserdeFinalDeepProxySerializableMembers(T)
- Final deep proxy type serializable membersExamples:static struct A { @serdeIgnore int i; @serdeKeys("a", "b") int m; } @serdeProxy!(A[string]) static struct B {} @serdeProxy!(B[]) static struct C {} static assert (serdeFinalDeepProxySerializableMembers!C == ["m"]); 
- templateserdeFinalProxySerializableMembers(T)
- Final proxy type deserializable membersExamples:static struct A { @serdeIgnore int i; @serdeKeys("a", "b") int m; } @serdeProxy!A static struct B {} @serdeProxy!B static struct C {} static assert (serdeFinalProxySerializableMembers!C == ["m"]); 
- templateserdeFinalDeepProxyDeserializableMembers(T)
- Final deep proxy type serializable membersExamples:static struct A { @serdeIgnore int i; @serdeKeys("a", "b") int m; } @serdeProxy!(A[string]) static struct B {} @serdeProxy!(B[]) static struct C {} static assert (serdeFinalDeepProxyDeserializableMembers!C == ["m"]); 
- templateserdeFinalDeserializationMemberType(T, string member)
 templateserdeFinalDeserializationMemberType(T)
- Deserialization member final proxy typeExamples:static struct A { } @serdeProxy!A static struct B {} @serdeProxy!B static struct C {} @serdeProxy!double struct E {} struct D { C c; @serdeProxy!E int d; } static assert (is(serdeFinalDeserializationMemberType!(D, "c") == A)); static assert (is(serdeFinalDeserializationMemberType!(D, "d") == double)); 
- templateserdeDeserializationFinalProxyMemberTypes(T)
- Deserialization members final proxy typesExamples:static struct A {} @serdeProxy!A static struct B {} @serdeProxy!B static struct C {} @serdeProxy!B static struct E {} static struct D { C c; @serdeProxy!E int d; } import std.meta: AliasSeq; static assert (is(serdeDeserializationFinalProxyMemberTypes!D == AliasSeq!A)); 
- templateserdeFinalSerializationMemberType(T, string member)
 templateserdeFinalSerializationMemberType(T)
- Serialization member final proxy typeExamples:static struct A { } @serdeProxy!A static struct B {} @serdeProxy!B static struct C {} @serdeProxy!double struct E {} struct D { C c; @serdeProxy!E int d; } static assert (is(serdeFinalSerializationMemberType!(D, "c") == A), serdeFinalSerializationMemberType!(D, "c")); static assert (is(serdeFinalSerializationMemberType!(D, "d") == double)); 
- templateserdeSerializationFinalProxyMemberTypes(T)
- Serialization members final proxy typesExamples:static struct A {} @serdeProxy!A static struct B {} @serdeProxy!B static struct C {} @serdeProxy!B static struct E {} static struct D { C c; @serdeProxy!E int d; } import std.meta: AliasSeq; static assert (is(serdeSerializationFinalProxyMemberTypes!D == AliasSeq!A)); 
- templateserdeDeserializationFinalDeepProxyMemberTypes(T)
- Deserialization members final deep proxy typesExamples:static struct A {} @serdeProxy!(A[]) static struct B {} enum R {a, b, c} @serdeProxy!(B[R]) static struct C {} @serdeProxy!(B[string]) static struct E {} static struct D { C c; @serdeProxy!E int d; } import std.meta: AliasSeq; static assert (is(serdeDeserializationFinalDeepProxyMemberTypes!D == AliasSeq!A), serdeDeserializationFinalDeepProxyMemberTypes!D); 
- templateserdeSerializationFinalDeepProxyMemberTypes(T)
- Serialization members final deep proxy typesExamples:static struct A {} @serdeProxy!(A[]) static struct B {} enum R {a, b, c} @serdeProxy!(B[R]) static struct C {} @serdeProxy!(B[string]) static struct E {} static struct D { C c; @serdeProxy!E int d; } import std.meta: AliasSeq; static assert (is(serdeSerializationFinalDeepProxyMemberTypes!D == AliasSeq!A), serdeSerializationFinalDeepProxyMemberTypes!D); 
- templateserdeDeserializationFinalProxyMemberTypesRecurse(T)
- Deserialization members final proxy types (recursive)Examples:static struct A { double g; } @serdeProxy!A static struct B {} @serdeProxy!B static struct C {} @serdeProxy!B static struct E {} static struct D { C c; @serdeProxy!E int d; } @serdeProxy!D static struct F {} import std.meta: AliasSeq; static assert (is(serdeDeserializationFinalProxyMemberTypesRecurse!F == AliasSeq!(D, A, double))); 
- templateserdeDeserializationFinalDeepProxyMemberTypesRecurse(T)
- Deserialization members final deep proxy types (recursive)Examples:static struct A { double g; } @serdeProxy!(A[]) static struct B {} @serdeProxy!(B[string]) static struct C {} @serdeProxy!B static struct E {} static struct D { C c; @serdeProxy!(E[]) int d; } @serdeProxy!D static struct F {} import std.meta: AliasSeq; static assert (is(serdeDeserializationFinalDeepProxyMemberTypesRecurse!F == AliasSeq!(D, A, double))); 
- templateserdeSerializationFinalDeepProxyMemberTypesRecurse(T)
- Serialization members final deep proxy types (recursive)Examples:static struct A { double g; } @serdeProxy!(A[]) static struct B {} @serdeProxy!(B[string]) static struct C {} @serdeProxy!B static struct E {} static struct D { C c; @serdeProxy!(E[]) int d; } @serdeProxy!D static struct F {} import std.meta: AliasSeq; static assert (is(serdeSerializationFinalDeepProxyMemberTypesRecurse!F == AliasSeq!(D, A, double)), serdeSerializationFinalDeepProxyMemberTypesRecurse!F); 
- enum string[]serdeGetSerializationKeysRecurse(T);
- Serialization members final proxy keys (recursive)Examples:enum Y { a, b, c, } static struct A { double g; float d; } @serdeProxy!A static struct B { int f; } @serdeProxy!(B[Y][string]) static union C { int f; } @serdeProxy!(B[]) static interface E { int f() @property; } enum N { a, b } static class D { C c; @serdeProxy!(E[]) int d; N e; } @serdeAlgebraicAnnotation("$F") @serdeProxy!D static struct F { int f; } static assert (serdeGetSerializationKeysRecurse!F == ["a", "b", "c", "d", "e", "g"]); import mir.algebraic; static assert (serdeGetSerializationKeysRecurse!(Nullable!(F, int)) == ["a", "b", "c", "d", "e", "g", "$F"]); 
- enum string[]serdeGetDeserializationKeysRecurse(T);
- Deserialization members final proxy keys (recursive)Examples:static struct A { double g; float d; } @serdeProxy!A static struct B { int f; } @serdeProxy!(B[string]) static union C { int f; } @serdeProxy!(B[]) static interface E { int f() @property; } enum N { a, b } static class D { C c; @serdeProxy!(E[]) int d; N e; } @serdeAlgebraicAnnotation("$F") @serdeProxy!D static struct F { int f; } static assert (serdeGetDeserializationKeysRecurse!N == ["a", "b"], serdeGetDeserializationKeysRecurse!N); static assert (serdeGetDeserializationKeysRecurse!F == ["a", "b", "c", "d", "e", "g"]); import mir.algebraic; static assert (serdeGetDeserializationKeysRecurse!(Nullable!(F, int)) == ["a", "b", "c", "d", "e", "g", "$F"]); 
- enumserdeOrderedIn;
- UDA used to force deserializer to initilize members in the order of their definition in the target object/structure.The attribute force deserializer to create a dummy type (recursively), initializer its fields and then assign them to to the object members (fields and setters) in the order of their definition.See Also:
- enumserdeRealOrderedIn;
- UDA used to force deserializer to initilize members in the order of their definition in the target object/structure.Unlike serdeOrderedIn serdeRealOrderedDummy force deserialzier to iterate all DOM keys for each object deserialization member. It is slower but more universal approach.See Also:
- enumserdeFromDummyByUser;
- UDA used to force deserializer to skip the member final deserialization. A user should finalize the member deserialize using the dummy object provided in serdeFinalizeWithDummy(ref SerdeOrderedDummy!(typeof(this)) dummy) struct method and dummy method serdeFinalizeTargetMember.
- enumserdeAlphabetOut;
- UDA used to force serializer to output members in the alphabetical order of their output keys.
- structSerdeOrderedDummy(T, bool __optionalByDefault = false) if (is(serdeGetFinalProxy!T == T) && isAggregateType!T);
- A dummy structure usefull serdeOrderedIn support.Examples:import std.traits; static struct S { private double _d; @serdeProxy!int void d(double v) @property { _d = v; } string s; } static assert(is(typeof(SerdeOrderedDummy!S.init.d) == double), SerdeOrderedDummy!S.init.d); static assert(is(typeof(SerdeOrderedDummy!S.init.s) == string)); static assert(hasUDA!(S.d, serdeProxy)); static assert(hasUDA!(SerdeOrderedDummy!S.d, serdeProxy)); - voidserdeFinalizeWithFlags(ref scope const SerdeFlags!(typeof(this))flags);
- Initialize target members
- voidserdeFinalizeTarget(ref Tvalue, ref scope SerdeFlags!Tflags);
- Initialize target members
- voidserdeFinalizeTargetMember(string member)(ref Tvalue);
- Initialize target member
 
- structSerdeFlags(T);
- A dummy structure passed to .serdeFinalizeWithFlags finalizer method.
Copyright © 2016-2022 by Ilya Yaroshenko | Page generated by
Ddoc on Tue Jan 11 06:37:12 2022