Skip to content

Commit

Permalink
feat: Make Error trait available in no_std mode
Browse files Browse the repository at this point in the history
  • Loading branch information
sorairolake committed Oct 14, 2024
1 parent e1f6f66 commit f89ed4c
Show file tree
Hide file tree
Showing 7 changed files with 16 additions and 19 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/CI.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ jobs:
- aarch64-apple-darwin
- x86_64-pc-windows-msvc
toolchain:
- 1.74.0 # MSRV
- 1.81.0 # MSRV
- stable
- nightly
include:
Expand Down
7 changes: 7 additions & 0 deletions CHANGELOG.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,13 @@ project adheres to https://semver.org/[Semantic Versioning].

== {compare-url}/v0.8.2\...HEAD[Unreleased]

=== Changed

* Make `Error` trait available in `no_std` mode ({pull-request-url}/116[#116])
* Bump MSRV to 1.81.0 ({pull-request-url}/116[#116])

== {compare-url}/v0.8.2\...HEAD[Unreleased]

=== Added

* Add benchmarks ({pull-request-url}/121[#121])
Expand Down
2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ name = "sysexits"
version = "0.8.2"
authors = ["Shun Sakai <sorairolake@protonmail.ch>"]
edition = "2021"
rust-version = "1.74.0"
rust-version = "1.81.0"
description = "The system exit codes as defined by <sysexits.h>"
documentation = "https://docs.rs/sysexits"
readme = "README.md"
Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ See the [documentation][docs-url] for more details.

## Minimum supported Rust version

The minimum supported Rust version (MSRV) of this library is v1.74.0.
The minimum supported Rust version (MSRV) of this library is v1.81.0.

## Source code

Expand Down
2 changes: 1 addition & 1 deletion clippy.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,4 @@
#
# SPDX-License-Identifier: Apache-2.0 OR MIT

msrv = "1.74.0"
msrv = "1.81.0"
12 changes: 3 additions & 9 deletions src/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@

//! Error types for this crate.
use core::fmt;
use core::{error::Error, fmt};

/// The error type indicating that [`ExitCode`](crate::ExitCode) was out of
/// range.
Expand All @@ -19,8 +19,7 @@ impl fmt::Display for ExitCodeRangeError {
}
}

#[cfg(feature = "std")]
impl std::error::Error for ExitCodeRangeError {}
impl Error for ExitCodeRangeError {}

#[cfg(feature = "std")]
/// An error which can be returned when converting an
Expand Down Expand Up @@ -59,7 +58,7 @@ impl fmt::Display for TryFromExitStatusError {
}

#[cfg(feature = "std")]
impl std::error::Error for TryFromExitStatusError {}
impl Error for TryFromExitStatusError {}

#[cfg(test)]
mod tests {
Expand Down Expand Up @@ -95,11 +94,8 @@ mod tests {
);
}

#[cfg(feature = "std")]
#[test]
fn source_exit_code_range_error() {
use std::error::Error;

assert!(ExitCodeRangeError.source().is_none());
}

Expand Down Expand Up @@ -188,8 +184,6 @@ mod tests {
#[cfg(feature = "std")]
#[test]
fn source_try_from_exit_status_error() {
use std::error::Error;

assert!(TryFromExitStatusError::new(Some(1)).source().is_none());
assert!(TryFromExitStatusError::new(None).source().is_none());
}
Expand Down
8 changes: 2 additions & 6 deletions src/exit_code.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ mod consts;
mod convert;
pub mod result;

use core::fmt;
use core::{error::Error, fmt};

/// `ExitCode` is a type that represents the system exit code constants as
/// defined by [`<sysexits.h>`].
Expand Down Expand Up @@ -288,8 +288,7 @@ impl fmt::Display for ExitCode {
}
}

#[cfg(feature = "std")]
impl std::error::Error for ExitCode {}
impl Error for ExitCode {}

#[cfg(feature = "std")]
impl std::process::Termination for ExitCode {
Expand Down Expand Up @@ -664,11 +663,8 @@ mod tests {
assert!(ExitCode::Config.is_failure());
}

#[cfg(feature = "std")]
#[test]
fn source_exit_code() {
use std::error::Error;

assert!(ExitCode::Ok.source().is_none());
assert!(ExitCode::Usage.source().is_none());
assert!(ExitCode::DataErr.source().is_none());
Expand Down

0 comments on commit f89ed4c

Please sign in to comment.