region 3.0.0

Cross-platform virtual memory API
Documentation
//! Error types and utilities.

use std::error::Error as StdError;
use std::{fmt, io};

/// The result type used by this library.
pub type Result<T> = std::result::Result<T, Error>;

/// A collection of possible errors.
#[derive(Debug)]
pub enum Error {
  /// The queried memory is unmapped.
  ///
  /// This does not necessarily mean that the memory region is available for
  /// allocation. Besides OS-specific semantics, queried addresses outside of a
  /// process' adress range are also identified as unmapped regions.
  UnmappedRegion,
  /// A supplied parameter is invalid.
  InvalidParameter(&'static str),
  /// A procfs region could not be parsed.
  ProcfsInput(String),
  /// A system call failed.
  SystemCall(io::Error),
  /// A macOS kernel call failed
  MachCall(libc::c_int),
}

impl fmt::Display for Error {
  #[inline]
  fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
    match self {
      Error::UnmappedRegion => write!(f, "Queried memory is unmapped"),
      Error::InvalidParameter(param) => write!(f, "Invalid parameter value: {}", param),
      Error::ProcfsInput(ref input) => write!(f, "Invalid procfs input: {}", input),
      Error::SystemCall(ref error) => write!(f, "System call failed: {}", error),
      Error::MachCall(code) => write!(f, "macOS kernel call failed: {}", code),
    }
  }
}

impl StdError for Error {}