2022-06-09 01:45:47 +00:00
|
|
|
use chrono::prelude::*;
|
|
|
|
use itertools::Itertools;
|
2022-06-04 01:06:46 +00:00
|
|
|
use std::fs::File;
|
|
|
|
use ::function_name::named;
|
|
|
|
|
2022-06-19 13:44:57 +00:00
|
|
|
use super::*;
|
2022-06-13 02:52:24 +00:00
|
|
|
|
2022-06-19 13:44:57 +00:00
|
|
|
mod combinator_atoms;
|
|
|
|
use combinator_atoms::*;
|
2022-06-04 01:06:46 +00:00
|
|
|
|
2022-06-19 13:44:57 +00:00
|
|
|
mod types;
|
|
|
|
use types::*;
|
2022-06-17 22:16:51 +00:00
|
|
|
|
2022-06-22 01:06:51 +00:00
|
|
|
mod metadata;
|
|
|
|
use metadata::*;
|
2022-06-04 01:06:46 +00:00
|
|
|
|
|
|
|
|
|
|
|
pub fn parse_vcd(file : File) {
|
|
|
|
let mut word_gen = WordReader::new(file);
|
|
|
|
|
2022-06-11 04:01:53 +00:00
|
|
|
let header = parse_metadata(&mut word_gen).unwrap();
|
2022-06-09 01:45:47 +00:00
|
|
|
dbg!(header);
|
2022-06-18 05:00:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
|
|
|
use std::fs::File;
|
|
|
|
#[test]
|
|
|
|
fn headers() {
|
|
|
|
let files = vec![
|
|
|
|
"./test-vcd-files/aldec/SPI_Write.vcd",
|
|
|
|
"./test-vcd-files/ghdl/alu.vcd",
|
|
|
|
"./test-vcd-files/ghdl/idea.vcd",
|
|
|
|
"./test-vcd-files/ghdl/pcpu.vcd",
|
|
|
|
"./test-vcd-files/gtkwave-analyzer/perm_current.vcd",
|
|
|
|
"./test-vcd-files/icarus/CPU.vcd",
|
|
|
|
"./test-vcd-files/icarus/rv32_soc_TB.vcd",
|
|
|
|
"./test-vcd-files/icarus/test1.vcd",
|
|
|
|
"./test-vcd-files/model-sim/CPU_Design.msim.vcd",
|
|
|
|
"./test-vcd-files/model-sim/clkdiv2n_tb.vcd",
|
|
|
|
"./test-vcd-files/my-hdl/Simple_Memory.vcd",
|
|
|
|
"./test-vcd-files/my-hdl/sigmoid_tb.vcd",
|
|
|
|
"./test-vcd-files/my-hdl/top.vcd",
|
|
|
|
// "./test-vcd-files/ncsim/ffdiv_32bit_tb.vcd",
|
|
|
|
// "./test-vcd-files/quartus/mipsHardware.vcd",
|
|
|
|
// "./test-vcd-files/quartus/wave_registradores.vcd",
|
|
|
|
"./test-vcd-files/questa-sim/dump.vcd",
|
|
|
|
"./test-vcd-files/questa-sim/test.vcd",
|
|
|
|
"./test-vcd-files/riviera-pro/dump.vcd",
|
|
|
|
// "./test-vcd-files/systemc/waveform.vcd",
|
|
|
|
// "./test-vcd-files/treadle/GCD.vcd",
|
|
|
|
"./test-vcd-files/vcs/Apb_slave_uvm_new.vcd",
|
|
|
|
"./test-vcd-files/vcs/datapath_log.vcd",
|
|
|
|
"./test-vcd-files/vcs/processor.vcd",
|
|
|
|
"./test-vcd-files/verilator/swerv1.vcd",
|
|
|
|
"./test-vcd-files/verilator/vlt_dump.vcd",
|
|
|
|
// "./test-vcd-files/vivado/iladata.vcd",
|
|
|
|
"./test-vcd-files/xilinx_isim/test.vcd",
|
|
|
|
"./test-vcd-files/xilinx_isim/test1.vcd",
|
|
|
|
"./test-vcd-files/xilinx_isim/test2x2_regex22_string1.vcd"
|
|
|
|
];
|
|
|
|
|
|
|
|
for file in files {
|
|
|
|
let metadata = parse_metadata(
|
|
|
|
&mut WordReader::new(
|
|
|
|
File::open(file)
|
|
|
|
.unwrap()
|
|
|
|
)
|
|
|
|
);
|
|
|
|
assert!(metadata.is_ok());
|
|
|
|
assert!(metadata.unwrap().date.is_some());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2022-06-04 01:06:46 +00:00
|
|
|
}
|