Rollup merge of #71921 - RalfJung:open-mode, r=hanna-kruppe
explain the types used in the open64 call Fixes https://github.com/rust-lang/rust/issues/71915, where I learned about this quirk. I don't actually know what I am talking about here. ;)
This commit is contained in:
commit
b86620a558
1 changed files with 4 additions and 0 deletions
|
@ -703,6 +703,10 @@ impl File {
|
|||
| opts.get_access_mode()?
|
||||
| opts.get_creation_mode()?
|
||||
| (opts.custom_flags as c_int & !libc::O_ACCMODE);
|
||||
// The third argument of `open64` is documented to have type `mode_t`. On
|
||||
// some platforms (like macOS, where `open64` is actually `open`), `mode_t` is `u16`.
|
||||
// However, since this is a variadic function, C integer promotion rules mean that on
|
||||
// the ABI level, this still gets passed as `c_int` (aka `u32` on Unix platforms).
|
||||
let fd = cvt_r(|| unsafe { open64(path.as_ptr(), flags, opts.mode as c_int) })?;
|
||||
let fd = FileDesc::new(fd);
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue