about summary refs log tree commit diff
path: root/library/std/src/sys/unix/android.rs
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2021-07-10 21:42:40 +0000
committerbors <bors@rust-lang.org>2021-07-10 21:42:40 +0000
commitdfd7b8d03fb93d0e03147d28b3be6d93260fa94d (patch)
tree4a4310069f11ed4d0f2fdd3aadaf02fbc67a5fb3 /library/std/src/sys/unix/android.rs
parent432e145bd5a974c5b6f4dd9b352891bd7502b69d (diff)
parent5999a5fbdc91ac07d4103095ed532d8cd4d3443b (diff)
downloadrust-dfd7b8d03fb93d0e03147d28b3be6d93260fa94d.tar.gz
rust-dfd7b8d03fb93d0e03147d28b3be6d93260fa94d.zip
Auto merge of #85953 - inquisitivecrystal:weak-linkat-in-fs-hardlink, r=joshtriplett
Fix linker error

Currently, `fs::hard_link` determines whether platforms have `linkat` based on the OS, and uses `link` if they don't. However, this heuristic does not work well if a platform provides `linkat` on newer versions but not on older ones. On old MacOS, this currently causes a linking error.

This commit fixes `fs::hard_link` by telling it to use `weak!` on macOS. This means that, on  that operating system, we now check for `linkat` at runtime and use `link` if it is not available.

Fixes #80804.

`@rustbot` label T-libs-impl
Diffstat (limited to 'library/std/src/sys/unix/android.rs')
-rw-r--r--library/std/src/sys/unix/android.rs2
1 files changed, 1 insertions, 1 deletions
diff --git a/library/std/src/sys/unix/android.rs b/library/std/src/sys/unix/android.rs
index cf6aa31b7cf..6a46525f682 100644
--- a/library/std/src/sys/unix/android.rs
+++ b/library/std/src/sys/unix/android.rs
@@ -21,7 +21,7 @@
 use libc::{c_int, c_void, sighandler_t, size_t, ssize_t};
 use libc::{ftruncate, pread, pwrite};
 
-use super::{cvt, cvt_r};
+use super::{cvt, cvt_r, weak::weak};
 use crate::io;
 
 // The `log2` and `log2f` functions apparently appeared in android-18, or at