Skip to content

Commit

Permalink
Fix Client::configure* on unix (#72)
Browse files Browse the repository at this point in the history
* Fix `Client::configure*` on unix

rust-lang#100

Signed-off-by: Jiahao XU <[email protected]>

* Fix linux compilation

Signed-off-by: Jiahao XU <[email protected]>

---------

Signed-off-by: Jiahao XU <[email protected]>
  • Loading branch information
NobodyXu authored Jul 5, 2024
1 parent 8785d86 commit e1f4498
Showing 1 changed file with 41 additions and 18 deletions.
59 changes: 41 additions & 18 deletions src/unix.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,14 +15,19 @@ use libc::c_int;

use crate::Command;

#[derive(Debug)]
enum ClientCreationArg {
Fds { read: c_int, write: c_int },
Fifo(Box<Path>),
}

#[derive(Debug)]
pub struct Client {
/// This fd is set to be nonblocking
read: File,
/// This fd is set to be blocking
write: File,
/// Path to the named fifo if any
path: Option<Box<Path>>,
creation_arg: ClientCreationArg,
/// If the Client owns the fifo, then we should remove it on drop.
owns_fifo: bool,
}
Expand Down Expand Up @@ -78,7 +83,7 @@ impl Client {
let client = Self {
read: file.try_clone()?,
write: file,
path: Some(name.into_boxed_path()),
creation_arg: ClientCreationArg::Fifo(name.into_boxed_path()),
owns_fifo: true,
};

Expand Down Expand Up @@ -131,13 +136,13 @@ impl Client {

/// `--jobserver-auth=fifo:PATH`
fn from_fifo(path: &Path) -> Option<Self> {
let file = open_file_rw(path).ok()?;
let read = open_file_rw(path).ok()?;

if is_pipe(&file)? {
if is_pipe(&read)? {
Some(Self {
read: file.try_clone().ok()?,
write: file,
path: Some(path.into()),
read,
write: open_file_rw(path).ok()?,
creation_arg: ClientCreationArg::Fifo(path.into()),
owns_fifo: false,
})
} else {
Expand All @@ -152,6 +157,8 @@ impl Client {
let read = read.parse().ok()?;
let write = write.parse().ok()?;

let creation_arg = ClientCreationArg::Fds { read, write };

let read = ManuallyDrop::new(File::from_raw_fd(read));
let write = ManuallyDrop::new(File::from_raw_fd(write));

Expand Down Expand Up @@ -183,6 +190,19 @@ impl Client {
//
// I tested this on macOS 14 and Linux 6.5.13
#[cfg(target_os = "linux")]
if let (Ok(read), Ok(write)) = (
File::open(format!("/dev/fd/{}", read.as_raw_fd())),
fs::OpenOptions::new()
.write(true)
.open(format!("/dev/fd/{}", write.as_raw_fd())),
) {
return Some(Client {
read,
write,
creation_arg,
owns_fifo: false,
});
}
if let Some(jobserver) =
Self::from_fifo(Path::new(&format!("/dev/fd/{}", read.as_raw_fd())))
{
Expand All @@ -195,7 +215,7 @@ impl Client {
Some(Self {
read,
write,
path: None,
creation_arg,
owns_fifo: false,
})
}
Expand All @@ -207,7 +227,7 @@ impl Client {
Self {
read: File::from_raw_fd(read),
write: File::from_raw_fd(write),
path: None,
creation_arg: ClientCreationArg::Fds { read, write },
owns_fifo: false,
}
}
Expand Down Expand Up @@ -268,15 +288,18 @@ impl Client {
}

pub fn string_arg(&self) -> Cow<'_, str> {
Cow::Owned(format!(
"{},{}",
self.read.as_raw_fd(),
self.write.as_raw_fd()
))
Cow::Owned(match &self.creation_arg {
ClientCreationArg::Fifo(path) => format!("fifo:{}", path.display()),
ClientCreationArg::Fds { read, write } => format!("{},{}", read, write),
})
}

pub fn get_fifo(&self) -> Option<&Path> {
self.path.as_deref()
if let ClientCreationArg::Fifo(path) = &self.creation_arg {
Some(path)
} else {
None
}
}

pub fn pre_run<Cmd>(&self, cmd: &mut Cmd)
Expand Down Expand Up @@ -309,7 +332,7 @@ impl Client {
}

pub fn is_try_acquire_safe(&self) -> bool {
self.path.is_some()
self.get_fifo().is_some()
}

pub fn set_nonblocking(&self) -> io::Result<()> {
Expand All @@ -325,7 +348,7 @@ impl Client {

impl Drop for Client {
fn drop(&mut self) {
if let Some(path) = &self.path {
if let Some(path) = self.get_fifo() {
if self.owns_fifo {
fs::remove_file(path).ok();
}
Expand Down

0 comments on commit e1f4498

Please sign in to comment.