Skip to content

Commit

Permalink
add missing fmt implementations (rust-lang#380)
Browse files Browse the repository at this point in the history
  • Loading branch information
gnzlbg authored and alexcrichton committed Mar 19, 2018
1 parent c5cf3bc commit ca770fd
Showing 1 changed file with 96 additions and 0 deletions.
96 changes: 96 additions & 0 deletions coresimd/ppsv/api/fmt.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,45 @@ macro_rules! impl_hex_fmt {
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, ")")
}
}
}
}

Expand All @@ -44,6 +83,63 @@ macro_rules! test_hex_fmt_impl {
}
}
}
#[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)));
}
}
}
}
}

Expand Down

0 comments on commit ca770fd

Please sign in to comment.