-
Notifications
You must be signed in to change notification settings - Fork 31
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Fallible for `username()`, `realname()` and `_os` variants * Minor fixes * Add remaining planned fallible APIs * Compile error fixes * Fix unused imports * Address self-feedback * Address `clippy::needless_doctest_main` https://rust-lang.github.io/rust-clippy/master/index.html#needless_doctest_main * Fix possible memory leak in `distro()` on Windows * More windows bugs * Move fallbacks to lib.rs * Clean up * Fix wasm build
- Loading branch information
1 parent
1c076a5
commit f499c74
Showing
7 changed files
with
422 additions
and
297 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
//! Fallible versions of the whoami APIs. | ||
//! | ||
//! Some of the functions in the root module will return "Unknown" or | ||
//! "localhost" on error. This might not be desirable in some situations. The | ||
//! functions in this module all return a [`Result`]. | ||
use std::ffi::OsString; | ||
|
||
use crate::{platform, Result}; | ||
|
||
/// Get the user's username. | ||
/// | ||
/// On unix-systems this differs from [`realname()`] most notably in that spaces | ||
/// are not allowed in the username. | ||
#[inline(always)] | ||
pub fn username() -> Result<String> { | ||
platform::username() | ||
} | ||
|
||
/// Get the user's username. | ||
/// | ||
/// On unix-systems this differs from [`realname_os()`] most notably in that | ||
/// spaces are not allowed in the username. | ||
#[inline(always)] | ||
pub fn username_os() -> Result<OsString> { | ||
platform::username_os() | ||
} | ||
|
||
/// Get the user's real (full) name. | ||
#[inline(always)] | ||
pub fn realname() -> Result<String> { | ||
platform::realname() | ||
} | ||
|
||
/// Get the user's real (full) name. | ||
#[inline(always)] | ||
pub fn realname_os() -> Result<OsString> { | ||
platform::realname_os() | ||
} | ||
|
||
/// Get the name of the operating system distribution and (possibly) version. | ||
/// | ||
/// Example: "Windows 10" or "Fedora 26 (Workstation Edition)" | ||
#[inline(always)] | ||
pub fn distro() -> Result<String> { | ||
platform::distro() | ||
} | ||
|
||
/// Get the name of the operating system distribution and (possibly) version. | ||
/// | ||
/// Example: "Windows 10" or "Fedora 26 (Workstation Edition)" | ||
#[inline(always)] | ||
pub fn distro_os() -> Result<OsString> { | ||
platform::distro_os() | ||
} | ||
|
||
/// Get the device name (also known as "Pretty Name"). | ||
/// | ||
/// Often used to identify device for bluetooth pairing. | ||
#[inline(always)] | ||
pub fn devicename() -> Result<String> { | ||
platform::devicename() | ||
} | ||
|
||
/// Get the device name (also known as "Pretty Name"). | ||
/// | ||
/// Often used to identify device for bluetooth pairing. | ||
#[inline(always)] | ||
pub fn devicename_os() -> Result<OsString> { | ||
platform::devicename_os() | ||
} | ||
|
||
/// Get the host device's hostname. | ||
/// | ||
/// Limited to a-z (case insensitve), 0-9, and dashes. This limit also applies | ||
/// to `devicename()` when targeting Windows. Since the hostname is | ||
/// case-insensitive, this method normalizes to lowercase (unlike | ||
/// [`devicename()`]). | ||
#[inline(always)] | ||
pub fn hostname() -> Result<String> { | ||
let mut hostname = platform::hostname()?; | ||
|
||
hostname.make_ascii_lowercase(); | ||
|
||
Ok(hostname) | ||
} | ||
|
||
/// Get the host device's hostname. | ||
/// | ||
/// Limited to a-z (case insensitve), 0-9, and dashes. This limit also applies | ||
/// to `devicename()` when targeting Windows. Since the hostname is | ||
/// case-insensitive, this method normalizes to lowercase (unlike | ||
/// [`devicename()`]). | ||
#[inline(always)] | ||
pub fn hostname_os() -> Result<OsString> { | ||
Ok(hostname()?.into()) | ||
} |
Oops, something went wrong.