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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
use crate::element::Element;
use crate::vhdl::port::Port;
use crate::vhdl::keywords::PORT;
pub struct PortList {
ports : Vec< Port >
}
impl PortList {
pub fn new() -> PortList {
PortList { ports : Vec::new() }
}
pub fn add_port( & mut self, port : Port ) {
self.ports.push( port );
}
}
impl Element for PortList {
fn to_source_code( & self, indent : usize ) -> String {
let mut source = String::new();
if self.ports.is_empty() {
return source;
}
let indent_str = crate::util::indent( indent + 1 );
source.push_str( & format!( "{}{} (\n", indent_str, PORT ) );
for ( pos, port ) in self.ports.iter().enumerate() {
source.push_str( & port.to_source_code( indent + 2 ) );
if pos < self.ports.len() - 1 {
source.push_str( ";" );
}
source.push_str( "\n" );
}
source.push_str( & format!( "{});\n", indent_str ) );
return source;
}
}
#[cfg(test)]
mod tests {
use super::*;
use crate::vhdl::direction::Direction;
const PORTS : &'static str = concat!( " port (\n", " a : in integer := 0;\n",
" b : out std_logic := '0';\n", " c : inout boolean;\n",
" d : buffer positive\n", " );\n" );
#[test]
fn port_list() {
let mut generic_list = PortList::new();
generic_list.add_port( Port::new_with_default( "a", Direction::IN, "integer", "0" ) );
generic_list.add_port( Port::new_with_default( "b", Direction::OUT, "std_logic", "'0'" ) );
generic_list.add_port( Port::new( "c", Direction::INOUT, "boolean" ) );
generic_list.add_port( Port::new( "d", Direction::BUFFER, "positive" ) );
assert_eq!(
generic_list.to_source_code( 0 ),
format!( "{}", PORTS )
);
}
}