correct return code on threaded

rust
Avril 4 years ago
parent 6bd5065a33
commit 071012ddb8
Signed by: flanchan
GPG Key ID: 284488987C31F630

@ -1,4 +1,26 @@
use std::{fmt,error};
#[derive(Debug)]
/// There was a non-matching file
pub enum UnmatchError
{
Size,
Data,
Unknown,
}
impl error::Error for UnmatchError{}
impl fmt::Display for UnmatchError
{
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result
{
match self {
Self::Size => write!(f, "size differs"),
Self::Data => write!(f, "data differs"),
_ => write!(f, "unknown error"),
}
}
}
pub trait ResultPrintExt<T> pub trait ResultPrintExt<T>
{ {
@ -6,7 +28,7 @@ pub trait ResultPrintExt<T>
} }
impl<T, E> ResultPrintExt<T> for Result<T,E> impl<T, E> ResultPrintExt<T> for Result<T,E>
where E: std::fmt::Display where E: std::fmt::Display
{ {
fn discard_msg(self, msg: impl AsRef<str>) -> Option<T> { fn discard_msg(self, msg: impl AsRef<str>) -> Option<T> {
match self { match self {

@ -5,6 +5,7 @@
use std::{ use std::{
path::Path, path::Path,
io, fs::{self, OpenOptions,}, io, fs::{self, OpenOptions,},
convert::TryInto,
}; };
use smallvec::SmallVec; use smallvec::SmallVec;
use cfg_if::cfg_if; use cfg_if::cfg_if;
@ -23,22 +24,7 @@ use error::ResultPrintExt as _;
mod map; mod map;
use map::MappedFile as _; use map::MappedFile as _;
#[derive(Debug)] use error::UnmatchError;
/// There was a non-matching file
struct UnmatchError;
const _:() = {
use std::{fmt,error};
impl error::Error for UnmatchError{}
impl fmt::Display for UnmatchError
{
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result
{
write!(f, "files did not match")
}
}
()
};
fn main() { fn main() {
let (map1, rest) = { let (map1, rest) = {
@ -53,6 +39,7 @@ fn main() {
std::process::exit({ std::process::exit({
if let Some(map1) = map::map(&map1).discard_msg(format!("Failed to map file {}", map1)) { if let Some(map1) = map::map(&map1).discard_msg(format!("Failed to map file {}", map1)) {
let slice = map1.as_slice(); let slice = map1.as_slice();
let map1_sz: u64 = slice.len().try_into().expect("File size could not fit into u64. This should never happen.");
let mut ok = true; let mut ok = true;
let chk: SmallVec<[_; 32]> = rest.filter_map(|filename| { let chk: SmallVec<[_; 32]> = rest.filter_map(|filename| {
let path = Path::new(&filename); let path = Path::new(&filename);
@ -73,24 +60,34 @@ fn main() {
if #[cfg(feature="threads")] { if #[cfg(feature="threads")] {
match chk.into_par_iter() match chk.into_par_iter()
.map(|map| { .map(|map| {
if let Ok(stat) = map.as_file().metadata() {
if stat.len() != map1_sz {
return Err(UnmatchError::Size);
}
if !stat.is_file() {
return Err(UnmatchError::Unknown);
}
}
if slice == map.as_slice() { if slice == map.as_slice() {
Ok(()) Ok(())
} else { } else {
Err(UnmatchError) Err(UnmatchError::Data)
} }
}) })
.try_reduce_with(|_, _| Ok(())) .try_reduce_with(|_, _| Ok(()))
{ {
Some(Ok(_)) => 0, Some(Ok(_)) => 0,
Some(Err(_)) => 1, Some(Err(UnmatchError::Data)) => 1,
Some(Err(UnmatchError::Size)) => 2,
None => usage(), None => usage(),
_ => -1,
} }
} else { } else {
match chk.into_iter() match chk.into_iter()
.map(|map| { .map(|map| {
slice == map.as_slice() slice == map.as_slice()
}) })
.try_fold((false, true), |(_, a), b| if a && b {Ok((true, true))} else {Err(UnmatchError)}) .try_fold((false, true), |(_, a), b| if a && b {Ok((true, true))} else {Err(UnmatchError::Data)})
{ {
Ok((true, _)) => 0, Ok((true, _)) => 0,
Ok((false, _)) => usage(), Ok((false, _)) => usage(),

Loading…
Cancel
Save