errno

Crates.ioerrno
lib.rserrno
version0.3.9
sourcesrc
created_at2015-03-19 21:26:09.647306
updated_at2024-05-08 16:26:21.674944
descriptionCross-platform interface to the `errno` variable.
homepage
repositoryhttps://github.com/lambda-fairy/rust-errno
max_upload_size
id1612
size33,112
Dan Gohman (sunfishcode)

documentation

https://docs.rs/errno

README

errno CI Cargo

Cross-platform interface to the errno variable. Works on Rust 1.56 or newer.

Documentation is available at https://docs.rs/errno.

Dependency

Add to your Cargo.toml:

[dependencies]
errno = "*"

Comparison with std::io::Error

The standard library provides Error::last_os_error which fetches errno in the same way.

This crate provides these extra features:

  • No heap allocations
  • Optional #![no_std] support
  • A set_errno function

Examples

extern crate errno;
use errno::{Errno, errno, set_errno};

// Get the current value of errno
let e = errno();

// Set the current value of errno
set_errno(e);

// Extract the error code as an i32
let code = e.0;

// Display a human-friendly error message
println!("Error {}: {}", code, e);

#![no_std]

Enable #![no_std] support by disabling the default std feature:

[dependencies]
errno = { version = "*", default-features = false }

The Error impl will be unavailable.

Commit count: 154

cargo fmt