about summary refs log tree commit diff
path: root/src/libstd
diff options
context:
space:
mode:
authorMichael Kohl <citizen428@gmail.com>2017-05-11 22:49:16 +0700
committerMichael Kohl <citizen428@gmail.com>2017-05-18 16:58:40 +0700
commitb2fc7b1cbeae1e6cb1a5b4797d221733592ae6a4 (patch)
treea44d27fe237aff4f0600c21fadc5a21234ff1d96 /src/libstd
parentfb6f845f33d9ddbca34c7ae26e3a24cadf3c1123 (diff)
downloadrust-b2fc7b1cbeae1e6cb1a5b4797d221733592ae6a4.tar.gz
rust-b2fc7b1cbeae1e6cb1a5b4797d221733592ae6a4.zip
Add documentation for `ExitStatus`
As requested in #29370.
Diffstat (limited to 'src/libstd')
-rw-r--r--src/libstd/process.rs23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/libstd/process.rs b/src/libstd/process.rs
index 3896fc20a2d..d0e7defbbbb 100644
--- a/src/libstd/process.rs
+++ b/src/libstd/process.rs
@@ -754,6 +754,13 @@ impl fmt::Debug for Stdio {
 }
 
 /// Describes the result of a process after it has terminated.
+///
+/// This `struct` is used to represent the exit status of a child process.
+/// Child processes are created via the [`Command`] struct and their exit
+/// status is exposed through the [`status`] method.
+///
+/// [`Command`]: struct.Command.html
+/// [`status`]: struct.Command.html#method.status
 #[derive(PartialEq, Eq, Clone, Copy, Debug)]
 #[stable(feature = "process", since = "1.0.0")]
 pub struct ExitStatus(imp::ExitStatus);
@@ -788,6 +795,22 @@ impl ExitStatus {
     /// On Unix, this will return `None` if the process was terminated
     /// by a signal; `std::os::unix` provides an extension trait for
     /// extracting the signal and other details from the `ExitStatus`.
+    ///
+    /// # Examples
+    ///
+    /// ```no_run
+    /// use std::process::Command;
+    ///
+    /// let status = Command::new("mkdir")
+    ///                      .arg("projects")
+    ///                      .status()
+    ///                      .expect("failed to execute mkdir");
+    ///
+    /// match status.code() {
+    ///     Some(code) => println!("Exited with status code: {}", code),
+    ///     None       => println!("Process terminated by signal")
+    /// }
+    /// ```
     #[stable(feature = "process", since = "1.0.0")]
     pub fn code(&self) -> Option<i32> {
         self.0.code()