19 releases (breaking)

0.16.0 Nov 30, 2024
0.14.0 Aug 16, 2024
0.13.0 May 19, 2024
0.12.1 Feb 1, 2024
0.3.0 Oct 19, 2022

#995 in Parser implementations

Download history 7/week @ 2024-08-22 5/week @ 2024-08-29 1/week @ 2024-09-05 5/week @ 2024-09-19 4/week @ 2024-09-26 1/week @ 2024-10-03 5/week @ 2024-10-10 3/week @ 2024-10-17 333/week @ 2024-10-24 79/week @ 2024-10-31 112/week @ 2024-11-07 6/week @ 2024-11-14 6/week @ 2024-11-21 211/week @ 2024-11-28 68/week @ 2024-12-05

335 downloads per month

MIT/Apache

6MB
54K SLoC

autosar-data

Crates.io Github Actions codecov

This crate provides functionality to read, modify and write Autosar 4 arxml files, both separately and in projects consisting of multiple files.

Features

  • read and write arxml files
  • fully validate all data when it is loaded
  • non-strict mode so that invalid but structurally sound data can be loaded
  • various element operations to modify and create sub-elements, data and attributes
  • support for Autosar paths and cross references
  • all operations are thread safe, e.g. it is possible to load mutliple files on separate threads
  • supports Autosar version 4.0.1 and up.

Example

use autosar_data::*;

/* load a multi-file data model */
let model = AutosarModel::new();
let (file_1, warnings_1) = model.load_file("some_file.arxml", false)?;
let (file_2, warnings_2) = model.load_file("other_file.arxml", false)?;

/* load a buffer */
let (file_3, _) = model.load_buffer(buffer, "filename.arxml", true)?;

/* write all files of the model */
model.write()?;

/* alternatively: */
for file in model.files() {
    let file_data = file.serialize();
    // do something with file_data
}

/* iterate over all elements in all files */
for (depth, element) in model.elements_dfs() {
    if element.is_identifiable() {
        /* the element is identifiable using an Autosar path */
        println!("{depth}: {}, {}", element.element_name(), element.path()?);
    } else {
        println!("{depth}: {}", element.element_name());
    }
}

/* get an element by its Autosar path */
let pdu_element = model.get_element_by_path("/Package/Mid/PduName").unwrap();

/* work with the content of elements */
if let Some(length) = pdu_element
    .get_sub_element(ElementName::Length)
    .and_then(|elem| elem.character_data())
    .and_then(|cdata| cdata.string_value())
{
    println!("Pdu Length: {length}");
}

/* modify the attributes of an element */
pdu_element.set_attribute_string(AttributeName::Uuid, "12ab34cd-1234-1234-1234-12ab34cd56ef");
pdu_element.remove_attribute(AttributeName::Uuid);

Example Programs

Two complete example programs can be found in the examples directory of the source repostitory. They are:

  • businfo, which extracts information about bus settings, frames, pdus and signals from an autosar ECU extract
  • generate_files, which for each Autosar version generates an arxml file containing a least one instance of every specified element

Dependencies

~1.5–7MB
~46K SLoC