#verilog #systemverilog #filelist

sv-filelist-parser

A library to parse a SystemVerilog Filelist and return a list of files, include directories and defines

1 unstable release

Uses new Rust 2021

0.1.3 May 12, 2022

#692 in Parser implementations

Download history 121/week @ 2022-06-06 63/week @ 2022-06-13 85/week @ 2022-06-20 86/week @ 2022-06-27 165/week @ 2022-07-04 96/week @ 2022-07-11 78/week @ 2022-07-18 70/week @ 2022-07-25 144/week @ 2022-08-01 123/week @ 2022-08-08 95/week @ 2022-08-15 81/week @ 2022-08-22 75/week @ 2022-08-29 77/week @ 2022-09-05 79/week @ 2022-09-12 78/week @ 2022-09-19

318 downloads per month
Used in 2 crates (via svlint)

MIT license

12KB
226 lines

SystemVerilog Filelist Parser

A library in Rust to parse a SystemVerilog Filelist and return a list of files, include directories and defines.

Environment variables optionally enclosed in paranthesis or curly braces (i.e. $, $() or ${}) will be automatically substituted.

Example

use sv_filelist_parser;
let filelist = sv_filelist_parser::parse_file("testcase/files.f")
    .expect("Cannot read filelist");
for file in filelist.files {
    println!("{:?}", file);
}
for incdir in filelist.incdirs {
    println!("{:?}", incdir);
}
for (d, t) in filelist.defines {
    match t {
        None => println!("{:?}", d),
        Some(te) => println!("{:?}={:?}", d, te),
    };
}

lib.rs:

SystemVerilog Filelist Parser

A library in Rust to parse a SystemVerilog Filelist and return a list of files, include directories and defines.

Environment variables optionally enclosed in paranthesis or curly braces (i.e. $, $() or ${}) will be automatically substituted.

Example

use sv_filelist_parser;
let filelist = sv_filelist_parser::parse_file("testcase/files.f")
    .expect("Cannot read filelist");
for file in filelist.files {
    println!("{:?}", file);
}
for incdir in filelist.incdirs {
    println!("{:?}", incdir);
}
for (d, t) in filelist.defines {
    match t {
        None => println!("{:?}", d),
        Some(te) => println!("{:?}={:?}", d, te),
    };
}

Dependencies

~1–1.3MB
~37K SLoC