5 unstable releases

0.4.1 Dec 25, 2024
0.3.3 Dec 16, 2024
0.3.2 Dec 3, 2024
0.3.1 Dec 2, 2024
0.2.0 Dec 2, 2024

#588 in Parser implementations

Download history 326/week @ 2024-11-28 97/week @ 2024-12-05 136/week @ 2024-12-12 120/week @ 2024-12-19 66/week @ 2024-12-26

490 downloads per month

Custom license

68KB
1.5K SLoC

Rust MARC XML / Breaker / Binary Toolkit

Tools for parsing and generating MARC21 binary, XML, and breaker text.

Example

use marctk::Record;

// Read a file of MARC records, modify, and print them.

for record in Record::from_binary_file(&file_name).expect("File should be readable") {
    let mut record = record.expect("Record should be parseable");

    if let Some(field) = record.get_fields_mut("245").first_mut() {
        if let Some(sf) = field.get_subfields_mut("a").first_mut() {
            println!("Maintitle => {}", sf.content());
            sf.set_content("I Prefer This Title");
        }
    }

    let f = record.add_data_field("650").unwrap();
    f.set_ind1("0").unwrap();
    f.add_subfield("a", "Hobbitz").unwrap();
    f.add_subfield("b", "So Many Wizards").unwrap();

    println!("{}", record.to_xml_string());
}

Strings & Bytes

For ease of use, the API primarily traffics in &str/String's. Byte counts are enforced where needed, but otherwise the user can generally use Rust strings without concern for bytes and UTF-8 conversions.

Requirements

  1. Data must be UTF-8 compatible.
  2. Indicators and subfield codes must have a byte length of 1.
  3. Tags must have a byte length of 3.
  4. Leaders must have a byte length of 24.
  5. Binary leader/directory metadata must be sane/usable.

In cases where these conditions are not met, routines exit early with explanatory Err()'s.

Dependencies

~1.5MB
~26K SLoC