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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
#![allow(unused)]
macro_rules! impl_hex_fmt {
($id:ident, $elem_ty:ident) => {
impl ::fmt::LowerHex for $id {
fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
use mem;
write!(f, "{}(", stringify!($id))?;
let n = mem::size_of_val(self) / mem::size_of::<$elem_ty>();
for i in 0..n {
if i > 0 {
write!(f, ", ")?;
}
self.extract(i).fmt(f)?;
}
write!(f, ")")
}
}
impl ::fmt::UpperHex for $id {
fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
write!(f, "{}(", stringify!($id))?;
for i in 0..$id::lanes() {
if i > 0 {
write!(f, ", ")?;
}
self.extract(i).fmt(f)?;
}
write!(f, ")")
}
}
impl ::fmt::Octal for $id {
fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
write!(f, "{}(", stringify!($id))?;
for i in 0..$id::lanes() {
if i > 0 {
write!(f, ", ")?;
}
self.extract(i).fmt(f)?;
}
write!(f, ")")
}
}
impl ::fmt::Binary for $id {
fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result {
write!(f, "{}(", stringify!($id))?;
for i in 0..$id::lanes() {
if i > 0 {
write!(f, ", ")?;
}
self.extract(i).fmt(f)?;
}
write!(f, ")")
}
}
};
}
#[cfg(test)]
macro_rules! test_hex_fmt_impl {
($id:ident, $elem_ty:ident, $($values:expr),+) => {
#[test]
fn hex_fmt() {
use ::std::prelude::v1::*;
use ::coresimd::simd::$id;
for &i in [$($values),+].iter() {
let vec = $id::splat(i as $elem_ty);
let s = format!("{:#x}", vec);
let beg = format!("{}(", stringify!($id));
assert!(s.starts_with(&beg));
assert!(s.ends_with(")"));
let s: Vec<String> = s.replace(&beg, "").replace(")", "").split(",")
.map(|v| v.trim().to_string()).collect();
assert_eq!(s.len(), $id::lanes());
for (index, ss) in s.into_iter().enumerate() {
assert_eq!(ss, format!("{:#x}", vec.extract(index)));
}
}
}
#[test]
fn upper_hex_fmt() {
use ::std::prelude::v1::*;
use ::coresimd::simd::$id;
for &i in [$($values),+].iter() {
let vec = $id::splat(i as $elem_ty);
let s = format!("{:#X}", vec);
let beg = format!("{}(", stringify!($id));
assert!(s.starts_with(&beg));
assert!(s.ends_with(")"));
let s: Vec<String> = s.replace(&beg, "").replace(")", "").split(",")
.map(|v| v.trim().to_string()).collect();
assert_eq!(s.len(), $id::lanes());
for (index, ss) in s.into_iter().enumerate() {
assert_eq!(ss, format!("{:#X}", vec.extract(index)));
}
}
}
#[test]
fn octal_fmt() {
use ::std::prelude::v1::*;
use ::coresimd::simd::$id;
for &i in [$($values),+].iter() {
let vec = $id::splat(i as $elem_ty);
let s = format!("{:#o}", vec);
let beg = format!("{}(", stringify!($id));
assert!(s.starts_with(&beg));
assert!(s.ends_with(")"));
let s: Vec<String> = s.replace(&beg, "").replace(")", "").split(",")
.map(|v| v.trim().to_string()).collect();
assert_eq!(s.len(), $id::lanes());
for (index, ss) in s.into_iter().enumerate() {
assert_eq!(ss, format!("{:#o}", vec.extract(index)));
}
}
}
#[test]
fn binary_fmt() {
use ::std::prelude::v1::*;
use ::coresimd::simd::$id;
for &i in [$($values),+].iter() {
let vec = $id::splat(i as $elem_ty);
let s = format!("{:#b}", vec);
let beg = format!("{}(", stringify!($id));
assert!(s.starts_with(&beg));
assert!(s.ends_with(")"));
let s: Vec<String> = s.replace(&beg, "").replace(")", "").split(",")
.map(|v| v.trim().to_string()).collect();
assert_eq!(s.len(), $id::lanes());
for (index, ss) in s.into_iter().enumerate() {
assert_eq!(ss, format!("{:#b}", vec.extract(index)));
}
}
}
}
}
#[cfg(test)]
macro_rules! test_hex_fmt {
($id:ident, $elem_ty:ident) => {
test_hex_fmt_impl!(
$id,
$elem_ty,
0 as $elem_ty,
!(0 as $elem_ty),
(1 as $elem_ty)
);
};
}