Skip to content

Commit

Permalink
Improve documentation for Process:kill* and Process::wait methods
Browse files Browse the repository at this point in the history
  • Loading branch information
GuillaumeGomez committed Dec 27, 2024
1 parent bbbdb23 commit 22206e6
Showing 1 changed file with 22 additions and 20 deletions.
42 changes: 22 additions & 20 deletions src/common/system.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1128,15 +1128,16 @@ impl Process {
/// Sends [`Signal::Kill`] to the process (which is the only signal supported on all supported
/// platforms by this crate).
///
/// Returns `true` if the signal was sent successfully.
/// Returns `true` if the signal was sent successfully. If you want to wait for this process
/// to end, you can use [`Process::wait`].
///
/// ⚠️ Even if this function returns `true`, it doesn't necessarily mean that the process will
/// be killed. It just means that the signal was sent successfully.
///
/// ⚠️ Please note that some processes might not be "killable", like if they run with higher
/// levels than the current process for example.
///
/// If you want to send another signal, take a look at [`Process::kill_with`].
/// If you want to use another signal, take a look at [`Process::kill_with`].
///
/// To get the list of the supported signals on this system, use
/// [`SUPPORTED_SIGNALS`][crate::SUPPORTED_SIGNALS].
Expand All @@ -1157,7 +1158,8 @@ impl Process {
/// it'll do nothing and will return `None`. Otherwise it'll return `Some(bool)`. The boolean
/// value will depend on whether or not the signal was sent successfully.
///
/// If you just want to kill the process, use [`Process::kill`] directly.
/// If you just want to kill the process, use [`Process::kill`] directly. If you want to wait
/// for this process to end, you can use [`Process::wait`].
///
/// ⚠️ Please note that some processes might not be "killable", like if they run with higher
/// levels than the current process for example.
Expand All @@ -1179,6 +1181,23 @@ impl Process {
self.inner.kill_with(signal)
}

/// Wait for process termination.
///
/// ```no_run
/// use sysinfo::{Pid, System};
///
/// let mut s = System::new_all();
///
/// if let Some(process) = s.process(Pid::from(1337)) {
/// println!("Waiting for pid 1337");
/// process.wait();
/// println!("Pid 1337 exited");
/// }
/// ```
pub fn wait(&self) {
self.inner.wait()
}

/// Returns the name of the process.
///
/// **⚠️ Important ⚠️**
Expand Down Expand Up @@ -1562,23 +1581,6 @@ impl Process {
self.inner.effective_group_id()
}

/// Wait for process termination.
///
/// ```no_run
/// use sysinfo::{Pid, System};
///
/// let mut s = System::new_all();
///
/// if let Some(process) = s.process(Pid::from(1337)) {
/// println!("Waiting for pid 1337");
/// process.wait();
/// println!("Pid 1337 exited");
/// }
/// ```
pub fn wait(&self) {
self.inner.wait()
}

/// Returns the session ID for the current process or `None` if it couldn't
/// be retrieved.
///
Expand Down

0 comments on commit 22206e6

Please sign in to comment.