4 releases

0.2.2 Aug 16, 2024
0.2.1 Aug 7, 2024
0.2.0 Jul 27, 2024
0.1.0 Jul 26, 2024

#2591 in Parser implementations

Download history 206/week @ 2024-07-22 76/week @ 2024-07-29 126/week @ 2024-08-05 162/week @ 2024-08-12 10/week @ 2024-08-19

389 downloads per month

MPL-2.0 license

23KB
476 lines

ilex

crates.io docs

Simple tree structure XML library. Allows reading and writing.

Documentation

Example

use ilex_xml::{items_to_string, parse_trimmed, Tag, Item};

let xml = r#"
    <!-- The cat is cute. -->
    <parent>
        <child likes="orange">Alice</child>
        <child likes="teal">Bob</child>
    </parent>
"#;

let mut items = parse_trimmed(xml).unwrap();

{ // Get comment content
    let Item::Comment(comment) = &items[0] else {
        panic!(
            "Huh, odd. Let's look at the first item's raw XML: {}",
            items[0]
        );
    };

    println!("I found a useful comment:{}", comment.get_value().unwrap());
}

let Item::Element(parent) = &mut items[1] else {
    panic!("Pretty sure the second item is an element.")
};

{ // Print attributes and text contents of children
    for item in &parent.children {
        let Item::Element(child) = item else {
            panic!("The children are elements, too.")
        };

        let name = child.get_text_content().unwrap();
        let color = child.get_attribute("likes").unwrap().unwrap();

        println!("{name}'s favorite color is {color}!");
    }
}

println!("Hey, their name isn't Bob! It's Peter!");

{ // Change child

    // Get child
    let Item::Element(child) = &mut parent.children[1] else {
        panic!();
    };

    // Remove the wrong name
    child.children.pop();
    // Add the correct name
    child.children.push(Item::new_text("Peter"));

    println!(
        "Lets take another look at the raw XML, now that the name is fixed: {}",
        items_to_string(&items)
    );

}

Dependencies

~1.5MB
~21K SLoC