splinter 0.6.14

Splinter is a privacy-focused platform for distributed applications that provides a blockchain-inspired networking environment for communication and transactions between organizations.
Documentation
// Copyright 2018-2022 Cargill Incorporated
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

//! An error wrapper for the errors generated throughout the module.

/// General error wrapper
#[derive(Debug)]
pub struct CircuitTemplateError {
    /// Human-readable description of the action attempted, which caused the error.
    context: String,
    /// Optional field which provides a `source` error, in case an exception must be handled.
    source: Option<Box<dyn std::error::Error>>,
}

impl CircuitTemplateError {
    /// Builds a `CircuitTemplateError` with a `context`. This sets the `source` field to `None`.
    pub fn new(context: &str) -> Self {
        Self {
            context: context.into(),
            source: None,
        }
    }

    /// Builds a `CircuitTemplateError` with a `context`, and a `source` error.
    pub fn new_with_source(context: &str, err: Box<dyn std::error::Error>) -> Self {
        Self {
            context: context.into(),
            source: Some(err),
        }
    }
}

impl std::error::Error for CircuitTemplateError {}

impl std::fmt::Display for CircuitTemplateError {
    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
        if let Some(ref err) = self.source {
            write!(f, "{}: {}", self.context, err)
        } else {
            f.write_str(&self.context)
        }
    }
}

impl From<serde_yaml::Error> for CircuitTemplateError {
    fn from(err: serde_yaml::Error) -> Self {
        Self::new_with_source("Error deserializing template", err.into())
    }
}