about summary refs log tree commit diff
path: root/library/std/src/sys/stdio/mod.rs
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2025-03-10 04:32:14 +0000
committerbors <bors@rust-lang.org>2025-03-10 04:32:14 +0000
commit2c6a12ec44d0426c8939123c2f2cf27d2217de13 (patch)
treeba0b33965ad6cdf14ba8d62b1988b9f244bea573 /library/std/src/sys/stdio/mod.rs
parentc8a50720289378f735a0f6fc07cf5ee9dabab08c (diff)
parentc52e0596c5ef1d68bf0f283342fdb05db63248f9 (diff)
downloadrust-2c6a12ec44d0426c8939123c2f2cf27d2217de13.tar.gz
rust-2c6a12ec44d0426c8939123c2f2cf27d2217de13.zip
Auto merge of #136780 - joboet:move_pal_stdio, r=Amanieu
std: move stdio to `sys`

As per #117276, this moves the platform definitions of `Stdout` and friends into `sys`. This PR also unifies the UNIX and Hermit implementations and moves the `__rust_print_err` function needed by libunwind on SGX into the dedicated module for such helper functions.
Diffstat (limited to 'library/std/src/sys/stdio/mod.rs')
-rw-r--r--library/std/src/sys/stdio/mod.rs38
1 files changed, 38 insertions, 0 deletions
diff --git a/library/std/src/sys/stdio/mod.rs b/library/std/src/sys/stdio/mod.rs
new file mode 100644
index 00000000000..2a9167bfe96
--- /dev/null
+++ b/library/std/src/sys/stdio/mod.rs
@@ -0,0 +1,38 @@
+#![forbid(unsafe_op_in_unsafe_fn)]
+
+cfg_if::cfg_if! {
+    if #[cfg(any(
+        target_family = "unix",
+        target_os = "hermit"
+    ))] {
+        mod unix;
+        pub use unix::*;
+    } else if #[cfg(target_os = "windows")] {
+        mod windows;
+        pub use windows::*;
+    } else if #[cfg(all(target_vendor = "fortanix", target_env = "sgx"))] {
+        mod sgx;
+        pub use sgx::*;
+    } else if #[cfg(target_os = "solid_asp3")] {
+        mod solid;
+        pub use solid::*;
+    } else if #[cfg(target_os = "teeos")] {
+        mod teeos;
+        pub use teeos::*;
+    } else if #[cfg(target_os = "uefi")] {
+        mod uefi;
+        pub use uefi::*;
+    } else if #[cfg(target_os = "wasi")] {
+        mod wasi;
+        pub use wasi::*;
+    } else if #[cfg(target_os = "xous")] {
+        mod xous;
+        pub use xous::*;
+    } else if #[cfg(target_os = "zkvm")] {
+        mod zkvm;
+        pub use zkvm::*;
+    } else {
+        mod unsupported;
+        pub use unsupported::*;
+    }
+}