#gldf #lighting #json-format #product #parser-writer #definition #luminaire

gldf-rs

GLDF (General Lighting Data Format) parser and writer for Rust, specifically for the Rust/WASM target as such designed for JSON format

5 releases

0.2.3 Oct 7, 2024
0.2.2 Sep 24, 2023
0.2.1 Sep 1, 2023
0.2.0 Sep 1, 2023
0.1.0 Jun 25, 2023

#1323 in Parser implementations


Used in 4 crates

GPL-3.0-or-later

205KB
2.5K SLoC

Contains (Zip file, 33KB) tests/data/test.gldf, (Zip file, 2KB) tests/data/R2MCOBSIK-30.gldf

CI

gldf-rs

Process GLDF

Release notes: 0.2.3

  • added new header definition, because FormatVersion changed
  • added Logger to pass into some methods
  • added test to completely check and compare to URL based gldf
  • bumped up versions of dependencies

0.2.2

  • added support meta-information.xml

0.2.1

  • added better documentation fo the main page
  • for wasm support some refactoring was needed, to use reqwest::blocking

0.2.0

  • refactored gldf.rs into submodules
  • added support for BOM encoded UTF8 product.xml
  • added support for url file_types
  • added better documentation

A cross platform GLDF processing library.

For the GLDF new Luminaire / Sensor Container Definition.

Basically .gldf is a zip Container, containing the product.xml for the Definition

and as well the needed binaries, e.g. images and soem Eulumdat / or IES files, as well as 3D Models characterising the luminaire.

More:

https://gldf.io

This rust lib for now can read the product.xml definition directly from the .gldf Container and is able to represent the content as well as JSON, which is the preferred way for feeding some content of it into Search Engines or in General as JSON Storage now is quite common, last but not least Postgres.

let loaded: GldfProduct = GldfProduct::load_gldf("./tests/data/test.gldf").unwrap();
println!("{:?}", loaded);
// Display pretty printed XML
let x_serialized = loaded.to_xml().unwrap();
println!("{}", x_serialized);
let json_str = loaded.to_json().unwrap();
println!("{}", json_str);
let j_loaded: GldfProduct = GldfProduct::from_json(&json_str).unwrap();
let x_reserialized =  j_loaded.to_xml().unwrap();
println!("{}", x_reserialized);
assert_eq!(x_serialized, x_reserialized);

Passes OK, so we are able to read xml, convert to JSON and again into the same XML.

For processing for now there are some implemantations already:

let phot_files = loaded.get_phot_files().unwrap();
let mut ldc_contents: Vec<String> = Vec::new();
for f in phot_files.iter(){
    let mut ldc_content = "".to_owned();
    let file_id = f.id.to_string();
    ldc_content.push_str(&loaded.get_ldc_by_id(file_id).unwrap().to_owned());
    ldc_contents.push(ldc_content);
    println!("{}", f.file_name)
}

Here it is shown how to read the ldc files from the GLDF Container.

Dependencies

~9–23MB
~333K SLoC