Crates.io | thisdiagnostic |
lib.rs | thisdiagnostic |
version | 0.1.0 |
source | src |
created_at | 2021-08-01 06:04:26.094842 |
updated_at | 2021-08-01 06:04:26.094842 |
description | Add nice user-facing diagnostics to your errors without being weird about it. |
homepage | |
repository | https://github.com/zkat/thisdiagnostic |
max_upload_size | |
id | 429901 |
size | 26,707 |
thisdiagnostic
is a Rust library for adding rich diagnostic metadata to
errors, for some really fancy and customizable error reporting!
use thisdiagnostic::Diagnostic;
use thiserror::Error;
#[derive(Error, Debug, Diagnostic)]
pub enum ApiError {
/// Returned when a generic http client-related error has occurred.
#[label("mytool::api::generic_http")]
#[error("Request error:\n\t{0}")]
HttpError(Box<dyn std::error::Error + Send + Sync>, String),
/// Returned when a URL failed to parse.
#[label("mytool::api::invalid_url")]
#[help("Check the URL syntax. URLs must include the protocol part (https://, etc)")]
#[error(transparent)]
UrlParseError(#[from] Box<dyn std::error::Error + Send + Sync>),
/// An API key is required.
#[label("mytool::api::needs_api_key")]
#[help("Please supply an API key.")]
#[error("Endpoint operation requires an API key.")]
NeedsApiKey,
/// Unexpected response
#[label("mytool::api::unexpected_response")]
#[help("This is likely a bug with the server API (or its documentation). Please report it.")]
#[error("Unexpected or undocumented response.")]
BadResponse,
}
$ ./mytool
Error: mytool::api::needs_api_key
Endpoint operation requires an API key.
help: Please supply an API key.
This project and any contributions to it are licensed under Apache 2.0.