#xml #json-xml #structs #json-parser #json #convert-json #parser

bin+lib schema_generator

schema_generator is a Rust crate initially created for parsing XML files containing forestry data and generating corresponding Rust structs. It parses XML documents and automatically generates Rust data structures that map XML elements to fields, including attributes, child elements, and text content. It integrates with the serde library for serialization and deserialization. This crate is a part of the ClimateForest project, which takes place between 01.03.2024–28.02.2027. It is funded by Interreg Aurora and supported by its contributors, including Metsäkeskus, Lapland University of Applied Sciences, Luke luonnonvarakeskus, Luleå Tekniska Universitet, Skoggstyrelsen, and SLU. While it was originally designed for forestry-related XML data, it can be used with any XML data structure, making it a versatile tool for developers working with XML. Additionally, schema_generator supports JSON to XML conversion.

2 unstable releases

new 0.2.0 Jan 18, 2025
0.1.9 Jan 18, 2025

#1800 in Parser implementations

Download history 220/week @ 2025-01-03 229/week @ 2025-01-10

449 downloads per month

MIT license

7MB
1.5K SLoC

schema_generator

  • Converts XML file into data structures in Rust (structs) by reading the file forestpropertydata.xml located in the root of the project. The structs are saved in the file src/file_structs.rs.
  • Converts XML that is fetched from API into structs and saves the the structs to the file src/url_structs.rs.
  • Uses the structs to read the XML file's data and creates a Json file containing that data using quick-xml and Serde.
  • Converts the Json file back into XML using a recursive function. The recursive function is not dependent on the structs.

Known bugs in Json to XML conversion:

If the first nested element has attributes and the parent element also has attributes, the nested element will sometimes inherit the same prefix from the parent (and sometimes update to its own prefix as its meant to). This is likely due to the recursive nature of the function.

Reasons why the generated XML file might have fewer rows than the original XML file:

These are not exactly bugs, since the generated file will still contain all the relevant information from the original file.

Other mentions

Some namespaces are not included in the XML. The following namespace prefixes were manually added:

  • SpecialFeatures
  • SpecialFeature
  • TreeStrata

xlink:type attribute in gml:polygonProperty tags will show up as __type in Json

License

MIT License

Dependencies

~8–21MB
~281K SLoC