use super::{error, itron, unsupported}; use crate::ffi::{OsStr, OsString}; use crate::path::{self, PathBuf}; use crate::{fmt, io}; // `solid` directly maps `errno`s to μITRON error codes. impl itron::error::ItronError { #[inline] pub(crate) fn as_io_error(self) -> crate::io::Error { crate::io::Error::from_raw_os_error(self.as_raw()) } } pub fn errno() -> i32 { 0 } pub fn error_string(errno: i32) -> String { if let Some(name) = error::error_name(errno) { name.to_owned() } else { format!("{errno}") } } pub fn getcwd() -> io::Result { unsupported() } pub fn chdir(_: &path::Path) -> io::Result<()> { unsupported() } pub struct SplitPaths<'a>(&'a !); pub fn split_paths(_unparsed: &OsStr) -> SplitPaths<'_> { panic!("unsupported") } impl<'a> Iterator for SplitPaths<'a> { type Item = PathBuf; fn next(&mut self) -> Option { *self.0 } } #[derive(Debug)] pub struct JoinPathsError; pub fn join_paths(_paths: I) -> Result where I: Iterator, T: AsRef, { Err(JoinPathsError) } impl fmt::Display for JoinPathsError { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { "not supported on this platform yet".fmt(f) } } impl crate::error::Error for JoinPathsError {} pub fn current_exe() -> io::Result { unsupported() } pub fn temp_dir() -> PathBuf { panic!("no standard temporary directory on this platform") } pub fn home_dir() -> Option { None } pub fn exit(code: i32) -> ! { rtabort!("exit({}) called", code); } pub fn getpid() -> u32 { panic!("no pids on this platform") }