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
490 downloads per month
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
- Data must be UTF-8 compatible.
- Indicators and subfield codes must have a byte length of 1.
- Tags must have a byte length of 3.
- Leaders must have a byte length of 24.
- 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