rust-stdf

Documentation

A Rust STDF library for process STDF datalogs of Version V4 and V4-2007.

```

Cargo.toml

[dependencies] rust-stdf = "0.3.0" ```

Features

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", ...]}


Example

```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);

} ```