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(())
}