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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
use std::{
fmt::{Debug, Display},
ops::*,
};
use crate::Signal15;
#[derive(Copy, Clone, Default, PartialEq, Eq)]
pub struct Signal14 {
pub values: i16,
}
impl Signal14 {
pub const TRUE: Self = Self {
values: 0b11_1111_1111_1111,
};
pub const FALSE: Self = Self { values: 0 };
pub fn new(values: i16) -> Self {
Self {
values: values & 0b11_1111_1111_1111,
}
}
pub fn get(&self, index: Range<usize>) -> i16 {
let shift = index.start;
let width = index.len() as u32;
let mask_unshifted = 2i16.pow(width) - 1;
let mask = mask_unshifted << shift;
let ret_unshifted = self.values & mask;
ret_unshifted >> shift
}
}
impl From<i16> for Signal14 {
fn from(value: i16) -> Self {
Self::new(value)
}
}
impl From<i32> for Signal14 {
fn from(value: i32) -> Self {
Self::new(value as i16)
}
}
impl From<Signal15> for Signal14 {
fn from(signal: Signal15) -> Self {
Self::new(signal.into())
}
}
impl From<Signal14> for u16 {
fn from(signal: Signal14) -> u16 {
unsafe { std::mem::transmute(signal.values) }
}
}
impl From<Signal14> for i16 {
fn from(signal: Signal14) -> i16 {
signal.values
}
}
impl From<Signal14> for usize {
fn from(signal: Signal14) -> Self {
signal.values as Self
}
}
impl Not for Signal14 {
type Output = Signal14;
fn not(self) -> Self::Output {
Signal14::new(!self.values)
}
}
impl BitAnd for Signal14 {
type Output = Signal14;
fn bitand(self, rhs: Self) -> Self::Output {
Self::new(self.values & rhs.values)
}
}
impl Debug for Signal14 {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
Debug::fmt(&self.values, f)
}
}
impl Display for Signal14 {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
Display::fmt(&self.values, f)
}
}