A Rust STDF library for process STDF datalogs of Version V4 and V4-2007.
```
[dependencies] rust-stdf = "0.3.0" ```
Available features are listed below:
- gzip
: gzip compression (.gz) support powered by flate2
- bzip
: bzip compression (.bz2) support powered by bzip2
- zipfile
: zip compression (.zip) support powered by zip
- atdf
: ATDF reader + STDF -> ATDF convertor (in dev)
- serialize
: serialize STDF records by serde
Note: zipfile
feature contains unsafe Rust code, and STDF Reader will only open the first file in the zip archive with no password.
rust-stdf
enable gzip
and bzip
by default, you can also control features by yourself.
rust-stdf = { version="0.3.0", default-features = false, features = ["gzip", ...]}
```rust use ruststdf::{stdffile::, stdf_record_type::, StdfRecord};
fn main() { let stdfpath = "demofile.stdf"; // "demofile.stdf.gz" "demofile.stdf.bz2" let mut reader = match StdfReader::new(&stdf_path) { Ok(r) => r, Err(e) => { println!("{}", e); return; } };
// we will count total DUT# in the file
// and put test result of PTR named
// "continuity test" in a vector.
let mut dut_count: u64 = 0;
let mut continuity_rlt = vec![];
// use type filter to work on certain types,
// use `|` to combine multiple typs
let rec_types = REC_PIR | REC_PTR;
// iterator starts from current file position,
// if file hits EOF, it will NOT redirect to 0.
for rec in reader
.get_record_iter()
.map(|x| x.unwrap())
.filter(|x| x.is_type(rec_types))
{
match rec {
StdfRecord::PIR(_) => {dut_count += 1;}
StdfRecord::PTR(ref ptr_rec) => {
if ptr_rec.test_txt == "continuity test" {
continuity_rlt.push(ptr_rec.result);
}
}
_ => {}
}
}
println!("Total duts {} \n continuity result {:?}",
dut_count,
continuity_rlt);
} ```