Archive 19/01/2023.

JSON vs XML

1vanK

I have found that the engine supports JSON. Why not use JSON instead XML for resources (UI, scenes, etc.)? After all JSON is more human-accessible. What are the advantages of XML?

<element>
    <attribute name="Min Size" value="0 16" />
    <attribute name="Max Size" value="2147483647 16" />
    <attribute name="Layout Mode" value="Horizontal" />
    <element type="Text">
        <attribute name="Text" value="Editor settings" />
    </element>
    <element type="Button" style="CloseButton">
        <attribute name="Name" value="CloseButton" />
    </element>
</element>
{
    "Min Size": "0 16",
    "Max Size": "2147483647 16",
    "Layout Mode": "Horizontal",
    {
        "type": "Text",
        "Text": "Editor settings"
    }
    {
        "type": "Button",
        "style": "CloseButton",
        "Name": "CloseButton"
    }
}

or

{
    "Min Size": {0, 16},
    "Max Size": {2147483647, 16},
    "Layout Mode": "Horizontal",
    Text: {
        "Text": "Editor settings"
    },
    Button: {
        "style": "CloseButton",
        "Name": "CloseButton"
    }
}
codingmonkey

the best practice use the binary files :slight_smile: minimum size, fast loading, no parsing

why are using the XML? i guess that because all around in engine and tools based on it

cadaver

It’s mostly a matter of preference and tradition; Urho started using XML.

The JSON API in Urho is a bit cumbersome and should ideally be refactored to just use composition (either array or object) of the supported JSON data types. Compare

github.com/urho3d/Urho3D/blob/m … SONValue.h
with
github.com/cadaver/turso3d/blob … SONValue.h

And codingmonkey is right, for performance binary is the optimal. In my measurements the performance hotspot in both JSON and XML reading has been the parsing of floating-point values from text, not the overhead from the XML/JSON structure or memory allocation.

globus

I do not like XML, too.

Alternatives:

TOML - Tom’s Obvious, Minimal Language
https://github.com/toml-lang/toml

JSMN - is a minimalistic JSON parser in C. It can be easily integrated into the resource-limited projects or embedded systems.
http://zserge.com/jsmn.html

Or INI reader - writer for use with not Big Data settings
For example - MIT licensed http://ndevilla.free.fr/iniparser/index.html

================================
And, yes, for final product need own binary format.

weitjong

I beg to differ. I admit I also hate to close each end tag manually, but that is why there are many tools to author XML file out there. There are other standards surrounding XML usage too. XPath for querying and XSLT for transforming, just to name a few. I am not saying the other format does not have tools to perform the equivalent but my key point here is the standardization. I have added some XPath query in Urho3D code base some time ago and I don’t have to worry about only myself could understand it and maintain it in the future, for example.

I agree that XML is not suitable as the final format to ship the product with, but IMHO there is no problem with XML as an intermediate format for data exchange. Sure XML is “heavier” than JSON. In the context of Client/Server where data is being pushed via the cloud, JSON format is a sure winner because it is lightweight and can be directly ‘eval’-ed by Javascript (long ago I used a similar approach where I have *.pl configuration files that I could “source” into my PERL script to get the data in the configuration files without actually parsing them but too bad none of the PERL gurus/monks give it a fancy name then). Outside of Client/Server context though, JSON is just as good as any other data exchange format currently available in the market. Personally, I would pick one format that I know it will stay around in foreseeable future and that I don’t need to re-learn or train other peoples on how to use it or its tools.

sabotage3d

If it is for readability one can be converted to the other. Do we have support for binary XML and binary JSON ?

cadaver

No. There’s support for Urho’s custom binary format for scene load/save, which is just a binary dump of the attributes.