2024-03-19 10:10:47 +00:00
|
|
|
#![feature(rustc_private)]
|
|
|
|
|
|
|
|
#[cfg(unix)]
|
|
|
|
extern crate libc;
|
2024-03-19 10:04:32 +00:00
|
|
|
|
|
|
|
#[cfg(unix)]
|
|
|
|
use std::os::unix::fs::PermissionsExt;
|
|
|
|
use std::path::Path;
|
|
|
|
|
2024-07-17 13:31:38 +00:00
|
|
|
use run_make_support::{aux_build, rfs};
|
2024-07-29 08:13:50 +10:00
|
|
|
|
2024-03-19 10:04:32 +00:00
|
|
|
fn main() {
|
2024-03-19 10:10:47 +00:00
|
|
|
#[cfg(unix)]
|
|
|
|
unsafe {
|
|
|
|
libc::umask(0o002);
|
|
|
|
}
|
|
|
|
|
2024-03-19 10:04:32 +00:00
|
|
|
aux_build().arg("foo.rs").run();
|
2024-06-06 21:34:34 +02:00
|
|
|
verify(Path::new("libfoo.rlib"));
|
2024-03-19 10:04:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
fn verify(path: &Path) {
|
2024-07-17 12:42:06 +00:00
|
|
|
let perm = rfs::metadata(path).permissions();
|
2024-03-19 10:04:32 +00:00
|
|
|
|
|
|
|
assert!(!perm.readonly());
|
|
|
|
|
|
|
|
// Check that the file is readable for everyone
|
|
|
|
#[cfg(unix)]
|
|
|
|
assert_eq!(perm.mode(), 0o100664);
|
|
|
|
}
|