jstruct 1.0.5

Struct JSON serializer/deserializer


To use this package, run the following command in your project's root directory:

Manual usage
Put the following dependency into your project's dependences section:

jstruct

Struct JSON serializer/deserializer

D DUB DUB DUB

Usage

Serialization

Below we define a struct called Person:

struct Person
{
    public string firstname, lastname;
    public int age;
    public string[] list;
    public JSONValue extraJSON;
    public EnumType eType;
}

Our enum is defined as:

enum EnumType
{
	DOG,
	CAT
}

Let's create a instance and set some values before we continue:

Person p1;
p1.firstname  = "Tristan";
p1.lastname = "Kildaire";
p1.age = 23;
p1.list = ["1", "2", "3"];
p1.extraJSON = parseJSON(`{"item":1, "items":[1,2,3]}`);
p1.eType = EnumType.CAT;

Now, we make a call to serializeRecord as follows:

JSONValue serialized = serializeRecord(p1);

This returns the following JSON:

{
    "age": 23,
    "eType": "CAT",
    "extraJSON": {
        "item": 1,
        "items": [
            1,
            2,
            3
        ]
    },
    "firstname": "Tristan",
    "lastname": "Kildaire",
    "list": [
        "1",
        "2",
        "3"
    ]
}

Deserialization

Deserialization works by having your predefined struct type and then looking up those field names in the provided JSON. Therefore for this we will be using the following struct type:

struct Person
{
    public string firstname, lastname;
    public int age;
    public bool isMale;
    public JSONValue obj;
    public int[] list;
    public bool[] list2;
    public float[] list3;
    public double[] list4;
    public string[] list5;
    public EnumType animal;
}

Now, let's say we were given the following JSON:

{
    "firstname" : "Tristan",
    "lastname": "Kildaire",
    "age": 23,
    "obj" : {"bruh":1},
    "isMale": true,
    "list": [1,2,3],
    "list2": [true, false],
    "list3": [1.5, 1.4],
    "list4": [1.5, 1.4],
    "list5": ["baba", "booey"],
    "animal": "CAT"
}

We can then deserialize the JSON to our type Person, with the fromJSON method:

// Define our JSON
JSONValue json = parseJSON(`{
"firstname" : "Tristan",
"lastname": "Kildaire",
"age": 23,
"obj" : {"bruh":1},
"isMale": true,
"list": [1,2,3],
"list2": [true, false],
"list3": [1.5, 1.4],
"list4": [1.5, 1.4],
"list5": ["baba", "booey"],
"animal": "CAT"
}
`);

// Deserialize
Person person = fromJSON!(Person)(json);

And we can confirm this with:

writeln(person):

Which will output:

Person("Tristan", "Kildaire", 23, true, {"bruh":1}, [1, 2, 3], [true, false], [1.5, 1.4], [1.5, 1.4], ["baba", "booey"], CAT)

Installing

In order to use jstruct in your project simply run:

dub add jstruct

And then in your D program import as follows:

import jstruct;
Authors:
  • Tristan B. Velloza Kildaire
Dependencies:
none
Versions:
1.0.5 2023-Jun-28
1.0.4 2023-Jun-28
1.0.3 2023-Jun-28
1.0.2 2023-Jun-28
1.0.1 2023-Jun-28
Show all 26 versions
Download Stats:
  • 1 downloads today

  • 1 downloads this week

  • 2 downloads this month

  • 180 downloads total

Score:
0.7
Short URL:
jstruct.dub.pm