xref: /aosp_15_r20/external/crosvm/base/src/errno.rs (revision bb4ee6a4ae7042d18b07a98463b9c8b875e44b39)
1*bb4ee6a4SAndroid Build Coastguard Worker // Copyright 2017 The ChromiumOS Authors
2*bb4ee6a4SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*bb4ee6a4SAndroid Build Coastguard Worker // found in the LICENSE file.
4*bb4ee6a4SAndroid Build Coastguard Worker 
5*bb4ee6a4SAndroid Build Coastguard Worker use std::convert::From;
6*bb4ee6a4SAndroid Build Coastguard Worker use std::convert::TryInto;
7*bb4ee6a4SAndroid Build Coastguard Worker use std::fmt;
8*bb4ee6a4SAndroid Build Coastguard Worker use std::fmt::Display;
9*bb4ee6a4SAndroid Build Coastguard Worker use std::io;
10*bb4ee6a4SAndroid Build Coastguard Worker use std::result;
11*bb4ee6a4SAndroid Build Coastguard Worker 
12*bb4ee6a4SAndroid Build Coastguard Worker use serde::Deserialize;
13*bb4ee6a4SAndroid Build Coastguard Worker use serde::Serialize;
14*bb4ee6a4SAndroid Build Coastguard Worker use thiserror::Error;
15*bb4ee6a4SAndroid Build Coastguard Worker 
16*bb4ee6a4SAndroid Build Coastguard Worker /// A system error
17*bb4ee6a4SAndroid Build Coastguard Worker /// In Unix systems, retrieved from errno (man 3 errno), set by a libc
18*bb4ee6a4SAndroid Build Coastguard Worker /// function that returned an error.
19*bb4ee6a4SAndroid Build Coastguard Worker /// On Windows, retrieved from GetLastError, set by a Windows function
20*bb4ee6a4SAndroid Build Coastguard Worker /// that returned an error
21*bb4ee6a4SAndroid Build Coastguard Worker #[derive(Error, Serialize, Deserialize, Clone, Copy, Debug, PartialEq, Eq)]
22*bb4ee6a4SAndroid Build Coastguard Worker #[serde(transparent)]
23*bb4ee6a4SAndroid Build Coastguard Worker pub struct Error(i32);
24*bb4ee6a4SAndroid Build Coastguard Worker pub type Result<T> = result::Result<T, Error>;
25*bb4ee6a4SAndroid Build Coastguard Worker 
26*bb4ee6a4SAndroid Build Coastguard Worker impl Error {
27*bb4ee6a4SAndroid Build Coastguard Worker     /// Constructs a new error with the given error number.
new<T: TryInto<i32>>(e: T) -> Error28*bb4ee6a4SAndroid Build Coastguard Worker     pub fn new<T: TryInto<i32>>(e: T) -> Error {
29*bb4ee6a4SAndroid Build Coastguard Worker         // A value outside the bounds of an i32 will never be a valid
30*bb4ee6a4SAndroid Build Coastguard Worker         // errno/GetLastError
31*bb4ee6a4SAndroid Build Coastguard Worker         Error(e.try_into().unwrap_or_default())
32*bb4ee6a4SAndroid Build Coastguard Worker     }
33*bb4ee6a4SAndroid Build Coastguard Worker 
34*bb4ee6a4SAndroid Build Coastguard Worker     /// Constructs an Error from the most recent system error.
35*bb4ee6a4SAndroid Build Coastguard Worker     ///
36*bb4ee6a4SAndroid Build Coastguard Worker     /// The result of this only has any meaning just after a libc/Windows call that returned
37*bb4ee6a4SAndroid Build Coastguard Worker     /// a value indicating errno was set.
last() -> Error38*bb4ee6a4SAndroid Build Coastguard Worker     pub fn last() -> Error {
39*bb4ee6a4SAndroid Build Coastguard Worker         Error(io::Error::last_os_error().raw_os_error().unwrap())
40*bb4ee6a4SAndroid Build Coastguard Worker     }
41*bb4ee6a4SAndroid Build Coastguard Worker 
42*bb4ee6a4SAndroid Build Coastguard Worker     /// Gets the errno for this error
errno(self) -> i3243*bb4ee6a4SAndroid Build Coastguard Worker     pub fn errno(self) -> i32 {
44*bb4ee6a4SAndroid Build Coastguard Worker         self.0
45*bb4ee6a4SAndroid Build Coastguard Worker     }
46*bb4ee6a4SAndroid Build Coastguard Worker }
47*bb4ee6a4SAndroid Build Coastguard Worker 
48*bb4ee6a4SAndroid Build Coastguard Worker impl From<io::Error> for Error {
from(e: io::Error) -> Self49*bb4ee6a4SAndroid Build Coastguard Worker     fn from(e: io::Error) -> Self {
50*bb4ee6a4SAndroid Build Coastguard Worker         Error(e.raw_os_error().unwrap_or_default())
51*bb4ee6a4SAndroid Build Coastguard Worker     }
52*bb4ee6a4SAndroid Build Coastguard Worker }
53*bb4ee6a4SAndroid Build Coastguard Worker 
54*bb4ee6a4SAndroid Build Coastguard Worker impl From<Error> for io::Error {
from(e: Error) -> io::Error55*bb4ee6a4SAndroid Build Coastguard Worker     fn from(e: Error) -> io::Error {
56*bb4ee6a4SAndroid Build Coastguard Worker         io::Error::from_raw_os_error(e.0)
57*bb4ee6a4SAndroid Build Coastguard Worker     }
58*bb4ee6a4SAndroid Build Coastguard Worker }
59*bb4ee6a4SAndroid Build Coastguard Worker 
60*bb4ee6a4SAndroid Build Coastguard Worker impl From<Error> for Box<dyn std::error::Error + Send> {
from(e: Error) -> Self61*bb4ee6a4SAndroid Build Coastguard Worker     fn from(e: Error) -> Self {
62*bb4ee6a4SAndroid Build Coastguard Worker         Box::new(e)
63*bb4ee6a4SAndroid Build Coastguard Worker     }
64*bb4ee6a4SAndroid Build Coastguard Worker }
65*bb4ee6a4SAndroid Build Coastguard Worker 
66*bb4ee6a4SAndroid Build Coastguard Worker impl Display for Error {
fmt(&self, f: &mut fmt::Formatter) -> fmt::Result67*bb4ee6a4SAndroid Build Coastguard Worker     fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
68*bb4ee6a4SAndroid Build Coastguard Worker         Into::<io::Error>::into(*self).fmt(f)
69*bb4ee6a4SAndroid Build Coastguard Worker     }
70*bb4ee6a4SAndroid Build Coastguard Worker }
71*bb4ee6a4SAndroid Build Coastguard Worker 
72*bb4ee6a4SAndroid Build Coastguard Worker /// Returns the last errno as a Result that is always an error.
errno_result<T>() -> Result<T>73*bb4ee6a4SAndroid Build Coastguard Worker pub fn errno_result<T>() -> Result<T> {
74*bb4ee6a4SAndroid Build Coastguard Worker     Err(Error::last())
75*bb4ee6a4SAndroid Build Coastguard Worker }
76