mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2024-12-27 02:20:30 +00:00
Implement Error trait for error enums.
This commit is contained in:
parent
5d266bf31b
commit
93a1b3929c
1 changed files with 75 additions and 0 deletions
|
@ -10,6 +10,8 @@ use StateChangeReturn;
|
|||
use FlowReturn;
|
||||
use PadLinkReturn;
|
||||
use ClockReturn;
|
||||
use std::error::Error;
|
||||
use std::fmt;
|
||||
|
||||
impl StateChangeReturn {
|
||||
pub fn into_result(self) -> Result<StateChangeSuccess, StateChangeError> {
|
||||
|
@ -46,6 +48,18 @@ pub enum StateChangeSuccess {
|
|||
#[must_use]
|
||||
pub struct StateChangeError;
|
||||
|
||||
impl fmt::Display for StateChangeError {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "State-change error")
|
||||
}
|
||||
}
|
||||
|
||||
impl Error for StateChangeError {
|
||||
fn description(&self) -> &str {
|
||||
"Element failed to change its state"
|
||||
}
|
||||
}
|
||||
|
||||
impl FlowReturn {
|
||||
pub fn into_result(self) -> Result<FlowSuccess, FlowError> {
|
||||
match self {
|
||||
|
@ -112,6 +126,28 @@ pub enum FlowError {
|
|||
CustomError2,
|
||||
}
|
||||
|
||||
impl fmt::Display for FlowError {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "Flow error: {}", self.description())
|
||||
}
|
||||
}
|
||||
|
||||
impl Error for FlowError {
|
||||
fn description(&self) -> &str {
|
||||
match *self {
|
||||
FlowError::NotLinked => "Pad is not linked",
|
||||
FlowError::Flushing => "Pad is flushing",
|
||||
FlowError::Eos => "Pad is EOS",
|
||||
FlowError::NotNegotiated => "Pad is not negotiated",
|
||||
FlowError::Error => "Some (fatal) error occurred. Element generating this error should post an error message with more details",
|
||||
FlowError::NotSupported => "This operation is not supported",
|
||||
FlowError::CustomError => "Elements can use values starting from this (and lower) to define custom error codes",
|
||||
FlowError::CustomError1 => "Pre-defined custom error code",
|
||||
FlowError::CustomError2 => "Pre-defined custom error code"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl PadLinkReturn {
|
||||
pub fn into_result(self) -> Result<PadLinkSuccess, PadLinkError> {
|
||||
match self {
|
||||
|
@ -156,6 +192,26 @@ pub enum PadLinkError {
|
|||
Refused,
|
||||
}
|
||||
|
||||
impl fmt::Display for PadLinkError {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "Pad failed to link: {}", self.description())
|
||||
}
|
||||
}
|
||||
|
||||
impl Error for PadLinkError {
|
||||
fn description(&self) -> &str {
|
||||
match *self {
|
||||
PadLinkError::WrongHierarchy => "Pads have no common grandparent",
|
||||
PadLinkError::WasLinked => "Pad was already linked",
|
||||
PadLinkError::WrongDirection => "Pads have wrong direction",
|
||||
PadLinkError::Noformat => "Pads do not have common format",
|
||||
PadLinkError::Nosched => "Pads cannot cooperate in scheduling",
|
||||
PadLinkError::Refused => "Refused for some other reason"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
impl ClockReturn {
|
||||
pub fn into_result(self) -> Result<ClockSuccess, ClockError> {
|
||||
match self {
|
||||
|
@ -206,3 +262,22 @@ pub enum ClockError {
|
|||
Error,
|
||||
Unsupported,
|
||||
}
|
||||
|
||||
impl fmt::Display for ClockError {
|
||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||
write!(f, "Clock error: {}", self.description())
|
||||
}
|
||||
}
|
||||
|
||||
impl Error for ClockError {
|
||||
fn description(&self) -> &str {
|
||||
match *self {
|
||||
ClockError::Early => "The operation was scheduled too late",
|
||||
ClockError::Unscheduled => "The clockID was unscheduled",
|
||||
ClockError::Busy => "The ClockID is busy",
|
||||
ClockError::Badtime => "A bad time was provided to a function",
|
||||
ClockError::Error => "An error occurred",
|
||||
ClockError::Unsupported => "Operation is not supported"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue