sgutils2: use thiserror to derive Error
This commit is contained in:
parent
a5322f3c50
commit
164ad7b706
@ -32,6 +32,7 @@ endian_trait = { version = "0.6", features = ["arrays"] }
|
|||||||
env_logger = "0.7"
|
env_logger = "0.7"
|
||||||
flate2 = "1.0"
|
flate2 = "1.0"
|
||||||
anyhow = "1.0"
|
anyhow = "1.0"
|
||||||
|
thiserror = "1.0"
|
||||||
futures = "0.3"
|
futures = "0.3"
|
||||||
h2 = { version = "0.3", features = [ "stream" ] }
|
h2 = { version = "0.3", features = [ "stream" ] }
|
||||||
handlebars = "3.0"
|
handlebars = "3.0"
|
||||||
|
@ -17,16 +17,16 @@ use std::ffi::CStr;
|
|||||||
|
|
||||||
use proxmox::tools::io::ReadExt;
|
use proxmox::tools::io::ReadExt;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(thiserror::Error, Debug)]
|
||||||
pub struct SenseInfo {
|
pub struct SenseInfo {
|
||||||
pub sense_key: u8,
|
pub sense_key: u8,
|
||||||
pub asc: u8,
|
pub asc: u8,
|
||||||
pub ascq: u8,
|
pub ascq: u8,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ToString for SenseInfo {
|
impl std::fmt::Display for SenseInfo {
|
||||||
|
|
||||||
fn to_string(&self) -> String {
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
|
|
||||||
let sense_text = SENSE_KEY_DESCRIPTIONS
|
let sense_text = SENSE_KEY_DESCRIPTIONS
|
||||||
.get(self.sense_key as usize)
|
.get(self.sense_key as usize)
|
||||||
@ -34,43 +34,20 @@ impl ToString for SenseInfo {
|
|||||||
.unwrap_or_else(|| format!("Invalid sense {:02X}", self.sense_key));
|
.unwrap_or_else(|| format!("Invalid sense {:02X}", self.sense_key));
|
||||||
|
|
||||||
if self.asc == 0 && self.ascq == 0 {
|
if self.asc == 0 && self.ascq == 0 {
|
||||||
return sense_text;
|
write!(f, "{}", sense_text)
|
||||||
}
|
} else {
|
||||||
|
|
||||||
let additional_sense_text = get_asc_ascq_string(self.asc, self.ascq);
|
let additional_sense_text = get_asc_ascq_string(self.asc, self.ascq);
|
||||||
|
write!(f, "{}, {}", sense_text, additional_sense_text)
|
||||||
format!("{}, {}", sense_text, additional_sense_text)
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(thiserror::Error, Debug)]
|
||||||
pub enum ScsiError {
|
pub enum ScsiError {
|
||||||
Error(Error),
|
#[error("{0}")]
|
||||||
Sense(SenseInfo),
|
Error(#[from] Error),
|
||||||
}
|
#[error("{0}")]
|
||||||
|
Sense(#[from] SenseInfo),
|
||||||
impl std::fmt::Display for ScsiError {
|
|
||||||
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
|
||||||
match self {
|
|
||||||
ScsiError::Error(err) => write!(f, "{}", err),
|
|
||||||
ScsiError::Sense(sense) => write!(f, "{}", sense.to_string()),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl std::error::Error for ScsiError {
|
|
||||||
fn source(&self) -> Option<&(dyn std::error::Error + 'static)> {
|
|
||||||
match self {
|
|
||||||
ScsiError::Error(err) => err.source(),
|
|
||||||
ScsiError::Sense(_) => None,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<anyhow::Error> for ScsiError {
|
|
||||||
fn from(error: anyhow::Error) -> Self {
|
|
||||||
Self::Error(error)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<std::io::Error> for ScsiError {
|
impl From<std::io::Error> for ScsiError {
|
||||||
|
Loading…
Reference in New Issue
Block a user