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::Signal16;
#[derive(Copy, Clone, Default, PartialEq, Eq)]
pub struct Signal15 {
pub values: i16,
}
impl Signal15 {
pub const TRUE: Self = Self {
values: 0b111_1111_1111_1111,
};
pub const FALSE: Self = Self { values: 0 };
pub fn new(values: i16) -> Self {
Self {
values: values & 0b111_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 Signal15 {
fn from(value: i16) -> Self {
Self::new(value)
}
}
impl From<i32> for Signal15 {
fn from(value: i32) -> Self {
Self::new(value as i16)
}
}
impl From<Signal16> for Signal15 {
fn from(signal: Signal16) -> Self {
Self::new(signal.values)
}
}
impl From<Signal15> for u16 {
fn from(signal: Signal15) -> u16 {
unsafe { std::mem::transmute(signal.values) }
}
}
impl From<Signal15> for i16 {
fn from(signal: Signal15) -> i16 {
signal.values as i16
}
}
impl From<Signal15> for usize {
fn from(signal: Signal15) -> Self {
u16::from(signal) as usize
}
}
impl Not for Signal15 {
type Output = Signal15;
fn not(self) -> Self::Output {
Signal15::new(!self.values)
}
}
impl BitAnd for Signal15 {
type Output = Signal15;
fn bitand(self, rhs: Self) -> Self::Output {
Self::new(self.values & rhs.values)
}
}
impl Debug for Signal15 {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.write_fmt(format_args!("{:015b}", self.values))
}
}
impl Display for Signal15 {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.write_fmt(format_args!("{:015b}", self.values))
}
}