1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
use std::collections::HashMap;
use crate::core::block::Block;
use crate::core::check_logic_loops::check_logic_loops;
use crate::core::prelude::check_connected;
#[derive(Clone, Debug, PartialEq)]
pub struct OpenConnection {
pub path: String,
pub name: String,
}
pub type OpenMap = HashMap::<usize, OpenConnection>;
#[derive(Clone, Debug, PartialEq)]
pub struct LogicLoop {
pub path: String,
pub name: String,
}
pub type LoopMap = Vec<LogicLoop>;
#[derive(Debug, Clone, PartialEq)]
pub enum CheckError {
OpenSignal(OpenMap),
LogicLoops(LoopMap),
}
pub fn check_all(uut: &dyn Block) -> Result<(), CheckError> {
check_connected(uut)?;
check_logic_loops(uut)?;
Ok(())
}