From d6b93c17249983efbaa65887dc14fbdcfcd98e49 Mon Sep 17 00:00:00 2001 From: Kamal Marhubi Date: Mon, 28 Mar 2016 18:52:59 -0400 Subject: [PATCH] fork: Make Parent a struct-like variant This changes `Fork(pid_t)` to `Fork { child: pid_t }` to make the meaning of the field clearer. For most uses, it can be bound as match fork().unwrap() { Parent { child } => { ... } Child => { ... } } using the shorthand matching syntax for struct-like enum variants. This is a breaking change. --- src/unistd.rs | 8 +++++--- test/sys/test_wait.rs | 10 +++++----- test/test_mq.rs | 4 ++-- test/test_unistd.rs | 16 ++++++++-------- 4 files changed, 20 insertions(+), 18 deletions(-) diff --git a/src/unistd.rs b/src/unistd.rs index 5d57afd1b8..5178146ec7 100644 --- a/src/unistd.rs +++ b/src/unistd.rs @@ -13,7 +13,9 @@ pub use self::linux::*; #[derive(Clone, Copy)] pub enum Fork { - Parent(pid_t), + Parent { + child: pid_t + }, Child } @@ -27,7 +29,7 @@ impl Fork { pub fn is_parent(&self) -> bool { match *self { - Fork::Parent(_) => true, + Fork::Parent {..} => true, _ => false } } @@ -38,7 +40,7 @@ pub fn fork() -> Result { Errno::result(res).map(|res| match res { 0 => Fork::Child, - res => Fork::Parent(res) + res => Fork::Parent { child: res } }) } diff --git a/test/sys/test_wait.rs b/test/sys/test_wait.rs index 01f63dd1b8..c740909e62 100644 --- a/test/sys/test_wait.rs +++ b/test/sys/test_wait.rs @@ -8,9 +8,9 @@ use libc::exit; fn test_wait_signal() { match fork() { Ok(Child) => loop { /* Wait for signal */ }, - Ok(Parent(child_pid)) => { - kill(child_pid, SIGKILL).ok().expect("Error: Kill Failed"); - assert_eq!(waitpid(child_pid, None), Ok(WaitStatus::Signaled(child_pid, SIGKILL, false))); + Ok(Parent { child }) => { + kill(child, SIGKILL).ok().expect("Error: Kill Failed"); + assert_eq!(waitpid(child, None), Ok(WaitStatus::Signaled(child, SIGKILL, false))); }, // panic, fork should never fail unless there is a serious problem with the OS Err(_) => panic!("Error: Fork Failed") @@ -21,8 +21,8 @@ fn test_wait_signal() { fn test_wait_exit() { match fork() { Ok(Child) => unsafe { exit(12); }, - Ok(Parent(child_pid)) => { - assert_eq!(waitpid(child_pid, None), Ok(WaitStatus::Exited(child_pid, 12))); + Ok(Parent { child }) => { + assert_eq!(waitpid(child, None), Ok(WaitStatus::Exited(child, 12))); }, // panic, fork should never fail unless there is a serious problem with the OS Err(_) => panic!("Error: Fork Failed") diff --git a/test/test_mq.rs b/test/test_mq.rs index a7aa9315b0..24ac823e8a 100644 --- a/test/test_mq.rs +++ b/test/test_mq.rs @@ -37,11 +37,11 @@ fn test_mq_send_and_receive() { write(writer, &buf).unwrap(); // pipe result to parent process. Otherwise cargo does not report test failures correctly mq_close(mqd_in_child).unwrap(); } - Ok(Parent(child_pid)) => { + Ok(Parent { child }) => { mq_close(mqd_in_parent).unwrap(); // Wait for the child to exit. - waitpid(child_pid, None).unwrap(); + waitpid(child, None).unwrap(); // Read 1024 bytes. let mut read_buf = [0u8; 32]; read(reader, &mut read_buf).unwrap(); diff --git a/test/test_unistd.rs b/test/test_unistd.rs index 2f361cfe56..d5446cc463 100644 --- a/test/test_unistd.rs +++ b/test/test_unistd.rs @@ -8,13 +8,13 @@ fn test_fork_and_waitpid() { let pid = fork(); match pid { Ok(Child) => {} // ignore child here - Ok(Parent(child_pid)) => { + Ok(Parent { child }) => { // assert that child was created and pid > 0 - assert!(child_pid > 0); - let wait_status = waitpid(child_pid, None); + assert!(child > 0); + let wait_status = waitpid(child, None); match wait_status { // assert that waitpid returned correct status and the pid is the one of the child - Ok(WaitStatus::Exited(pid_t, _)) => assert!(pid_t == child_pid), + Ok(WaitStatus::Exited(pid_t, _)) => assert!(pid_t == child), // panic, must never happen Ok(_) => panic!("Child still alive, should never happen"), @@ -34,11 +34,11 @@ fn test_wait() { let pid = fork(); match pid { Ok(Child) => {} // ignore child here - Ok(Parent(child_pid)) => { + Ok(Parent { child }) => { let wait_status = wait(); // just assert that (any) one child returns with WaitStatus::Exited - assert_eq!(wait_status, Ok(WaitStatus::Exited(child_pid, 0))); + assert_eq!(wait_status, Ok(WaitStatus::Exited(child, 0))); }, // panic, fork should never fail unless there is a serious problem with the OS Err(_) => panic!("Error: Fork Failed") @@ -95,9 +95,9 @@ macro_rules! execve_test_factory( &[CString::new(b"foo=bar".as_ref()).unwrap(), CString::new(b"baz=quux".as_ref()).unwrap()]).unwrap(); }, - Parent(child_pid) => { + Parent { child } => { // Wait for the child to exit. - waitpid(child_pid, None).unwrap(); + waitpid(child, None).unwrap(); // Read 1024 bytes. let mut buf = [0u8; 1024]; read(reader, &mut buf).unwrap();