usb_util: convert to ThisError and sort

BUG=b:197143586
TEST=cargo check

Change-Id: I747bd7889182addbe1781a6726f10f140c192d5e
Reviewed-on: https://chromium-review.googlesource.com/c/chromiumos/platform/crosvm/+/3105428
Tested-by: kokoro <noreply+kokoro@google.com>
Commit-Queue: Daniel Verkamp <dverkamp@chromium.org>
Reviewed-by: Dennis Kempin <denniskempin@google.com>
This commit is contained in:
Daniel Verkamp 2021-08-18 14:24:53 -07:00 committed by Commit Bot
parent 1fd68656a2
commit 3878e5c6ba
3 changed files with 15 additions and 26 deletions

1
Cargo.lock generated
View file

@ -1215,6 +1215,7 @@ dependencies = [
"data_model",
"libc",
"remain",
"thiserror",
"usb_sys",
]

View file

@ -9,5 +9,6 @@ assertions = { path = "../assertions" }
data_model = { path = "../data_model" }
libc = "*"
remain = "*"
thiserror = "*"
base = { path = "../base" }
usb_sys = { path = "../usb_sys" }

View file

@ -4,48 +4,35 @@
use base::IoctlNr;
use remain::sorted;
use std::fmt::{self, Display};
use std::io;
use std::num;
use thiserror::Error;
#[sorted]
#[derive(Debug)]
#[derive(Error, Debug)]
pub enum Error {
#[error("parsing descriptors failed")]
DescriptorParse,
#[error("reading descriptors from device failed: {0}")]
DescriptorRead(io::Error),
#[error("File::try_clone() failed: {0}")]
FdCloneFailed(io::Error),
#[error("invalid actual_length in URB: {0}")]
InvalidActualLength(num::TryFromIntError),
#[error("invalid transfer buffer length: {0}")]
InvalidBufferLength(num::TryFromIntError),
#[error("USB ioctl 0x{0:x} failed: {1}")]
IoctlFailed(IoctlNr, base::Error),
#[error("Device has been removed")]
NoDevice,
#[error("Requested descriptor not found")]
NoSuchDescriptor,
#[error("Rc::get_mut failed")]
RcGetMutFailed,
#[error("Rc::try_unwrap failed")]
RcUnwrapFailed,
#[error("attempted to cancel already-completed transfer")]
TransferAlreadyCompleted,
}
impl Display for Error {
#[remain::check]
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
use self::Error::*;
#[sorted]
match self {
DescriptorParse => write!(f, "parsing descriptors failed"),
DescriptorRead(e) => write!(f, "reading descriptors from device failed: {}", e),
FdCloneFailed(e) => write!(f, "File::try_clone() failed: {}", e),
InvalidActualLength(e) => write!(f, "invalid actual_length in URB: {}", e),
InvalidBufferLength(e) => write!(f, "invalid transfer buffer length: {}", e),
IoctlFailed(nr, e) => write!(f, "USB ioctl 0x{:x} failed: {}", nr, e),
NoDevice => write!(f, "Device has been removed"),
NoSuchDescriptor => write!(f, "Requested descriptor not found"),
RcGetMutFailed => write!(f, "Rc::get_mut failed"),
RcUnwrapFailed => write!(f, "Rc::try_unwrap failed"),
TransferAlreadyCompleted => write!(f, "attempted to cancel already-completed transfer"),
}
}
}
pub type Result<T> = std::result::Result<T, Error>;
impl std::error::Error for Error {}