Auto merge of #123723 - madsmtm:apple-std-os, r=dtolnay

Make `std::os::darwin` public

I'm not sure of the reasoning behind them not being public before, but I think they should be, just like `std::os::ios` and `std::os::macos` are public.

Additionally, I've merged their source code, as it was otherwise just a bunch of unnecessary duplication.

Ultimately, I've done this PR to fix `./x build library --target=aarch64-apple-tvos,aarch64-apple-watchos,aarch64-apple-visionos`, as that currently fails because of dead code warnings.

Since you reviewed https://github.com/rust-lang/rust/pull/121419
r? davidtwco

Fixes https://github.com/rust-lang/rust/issues/121640.

`@rustbot` label O-tvos O-watchos O-visionos
This commit is contained in:
bors 2024-11-03 22:25:11 +00:00
commit 42188c3ca8
6 changed files with 37 additions and 15 deletions

View File

@ -1,7 +1,8 @@
#![allow(dead_code)] //! Darwin-specific extension traits to [`fs`].
//!
//! [`fs`]: crate::fs
#![stable(feature = "metadata_ext", since = "1.1.0")]
#[allow(deprecated)]
use super::raw;
use crate::fs::{self, Metadata}; use crate::fs::{self, Metadata};
use crate::sealed::Sealed; use crate::sealed::Sealed;
use crate::sys_common::{AsInner, AsInnerMut, IntoInner}; use crate::sys_common::{AsInner, AsInnerMut, IntoInner};
@ -25,7 +26,10 @@ pub trait MetadataExt {
methods of this trait" methods of this trait"
)] )]
#[allow(deprecated)] #[allow(deprecated)]
fn as_raw_stat(&self) -> &raw::stat; // Only available on macOS and iOS, since they were stably exposed there.
#[cfg(any(doc, target_os = "macos", target_os = "ios"))]
#[doc(cfg(any(target_os = "macos", target_os = "ios")))]
fn as_raw_stat(&self) -> &super::raw::stat;
#[stable(feature = "metadata_ext2", since = "1.8.0")] #[stable(feature = "metadata_ext2", since = "1.8.0")]
fn st_dev(&self) -> u64; fn st_dev(&self) -> u64;
@ -77,8 +81,9 @@ pub trait MetadataExt {
#[stable(feature = "metadata_ext", since = "1.1.0")] #[stable(feature = "metadata_ext", since = "1.1.0")]
impl MetadataExt for Metadata { impl MetadataExt for Metadata {
#[allow(deprecated)] #[allow(deprecated)]
fn as_raw_stat(&self) -> &raw::stat { #[cfg(any(doc, target_os = "macos", target_os = "ios"))]
unsafe { &*(self.as_inner().as_inner() as *const libc::stat as *const raw::stat) } fn as_raw_stat(&self) -> &super::raw::stat {
unsafe { &*(self.as_inner().as_inner() as *const libc::stat as *const super::raw::stat) }
} }
fn st_dev(&self) -> u64 { fn st_dev(&self) -> u64 {
self.as_inner().as_inner().st_dev as u64 self.as_inner().as_inner().st_dev as u64

View File

@ -13,7 +13,10 @@
//! `aarch64-apple-darwin` target names, which are mostly named that way for //! `aarch64-apple-darwin` target names, which are mostly named that way for
//! legacy reasons. //! legacy reasons.
pub(crate) mod fs; #![stable(feature = "os_darwin", since = "CURRENT_RUSTC_VERSION")]
#![doc(cfg(target_vendor = "apple"))]
pub mod fs;
// deprecated, but used for public reexport under `std::os::unix::raw`, as // deprecated, but used for public reexport under `std::os::unix::raw`, as
// well as `std::os::macos`/`std::os::ios`, because those modules precede the // well as `std::os::macos`/`std::os::ios`, because those modules precede the
// decision to remove these. // decision to remove these.

View File

@ -4,10 +4,8 @@
#[stable(feature = "metadata_ext", since = "1.1.0")] #[stable(feature = "metadata_ext", since = "1.1.0")]
pub mod fs { pub mod fs {
#[doc(inline)]
#[stable(feature = "file_set_times", since = "1.75.0")] #[stable(feature = "file_set_times", since = "1.75.0")]
pub use crate::os::darwin::fs::FileTimesExt; pub use crate::os::darwin::fs::FileTimesExt;
#[doc(inline)]
#[stable(feature = "metadata_ext", since = "1.1.0")] #[stable(feature = "metadata_ext", since = "1.1.0")]
pub use crate::os::darwin::fs::MetadataExt; pub use crate::os::darwin::fs::MetadataExt;
} }

View File

@ -4,10 +4,8 @@
#[stable(feature = "metadata_ext", since = "1.1.0")] #[stable(feature = "metadata_ext", since = "1.1.0")]
pub mod fs { pub mod fs {
#[doc(inline)]
#[stable(feature = "file_set_times", since = "1.75.0")] #[stable(feature = "file_set_times", since = "1.75.0")]
pub use crate::os::darwin::fs::FileTimesExt; pub use crate::os::darwin::fs::FileTimesExt;
#[doc(inline)]
#[stable(feature = "metadata_ext", since = "1.1.0")] #[stable(feature = "metadata_ext", since = "1.1.0")]
pub use crate::os::darwin::fs::MetadataExt; pub use crate::os::darwin::fs::MetadataExt;
} }

View File

@ -15,7 +15,16 @@
// documented don't compile (missing things in `libc` which is empty), // documented don't compile (missing things in `libc` which is empty),
// so just omit them with an empty module and add the "unstable" attribute. // so just omit them with an empty module and add the "unstable" attribute.
// unix, linux, wasi and windows are handled a bit differently. // darwin, unix, linux, wasi and windows are handled a bit differently.
#[cfg(all(
doc,
any(
all(target_arch = "wasm32", not(target_os = "wasi")),
all(target_vendor = "fortanix", target_env = "sgx")
)
))]
#[unstable(issue = "none", feature = "std_internals")]
pub mod darwin {}
#[cfg(all( #[cfg(all(
doc, doc,
any( any(
@ -53,6 +62,17 @@ pub mod wasi {}
#[unstable(issue = "none", feature = "std_internals")] #[unstable(issue = "none", feature = "std_internals")]
pub mod windows {} pub mod windows {}
// darwin
#[cfg(not(all(
doc,
any(
all(target_arch = "wasm32", not(target_os = "wasi")),
all(target_vendor = "fortanix", target_env = "sgx")
)
)))]
#[cfg(any(target_vendor = "apple", doc))]
pub mod darwin;
// unix // unix
#[cfg(not(all( #[cfg(not(all(
doc, doc,
@ -105,8 +125,6 @@ pub mod windows {}
pub mod aix; pub mod aix;
#[cfg(target_os = "android")] #[cfg(target_os = "android")]
pub mod android; pub mod android;
#[cfg(target_vendor = "apple")]
pub(crate) mod darwin;
#[cfg(target_os = "dragonfly")] #[cfg(target_os = "dragonfly")]
pub mod dragonfly; pub mod dragonfly;
#[cfg(target_os = "emscripten")] #[cfg(target_os = "emscripten")]

View File

@ -42,7 +42,7 @@ mod platform {
#[cfg(target_os = "android")] #[cfg(target_os = "android")]
pub use crate::os::android::*; pub use crate::os::android::*;
#[cfg(target_vendor = "apple")] #[cfg(target_vendor = "apple")]
pub(super) use crate::os::darwin::*; pub use crate::os::darwin::*;
#[cfg(target_os = "dragonfly")] #[cfg(target_os = "dragonfly")]
pub use crate::os::dragonfly::*; pub use crate::os::dragonfly::*;
#[cfg(target_os = "emscripten")] #[cfg(target_os = "emscripten")]