diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-30 03:57:31 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-30 03:57:31 +0000 |
commit | dc0db358abe19481e475e10c32149b53370f1a1c (patch) | |
tree | ab8ce99c4b255ce46f99ef402c27916055b899ee /vendor/tokio/src/runtime/process.rs | |
parent | Releasing progress-linux version 1.71.1+dfsg1-2~progress7.99u1. (diff) | |
download | rustc-dc0db358abe19481e475e10c32149b53370f1a1c.tar.xz rustc-dc0db358abe19481e475e10c32149b53370f1a1c.zip |
Merging upstream version 1.72.1+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'vendor/tokio/src/runtime/process.rs')
-rw-r--r-- | vendor/tokio/src/runtime/process.rs | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/vendor/tokio/src/runtime/process.rs b/vendor/tokio/src/runtime/process.rs new file mode 100644 index 000000000..df339b0e7 --- /dev/null +++ b/vendor/tokio/src/runtime/process.rs @@ -0,0 +1,44 @@ +#![cfg_attr(not(feature = "rt"), allow(dead_code))] + +//! Process driver. + +use crate::process::unix::GlobalOrphanQueue; +use crate::runtime::driver; +use crate::runtime::signal::{Driver as SignalDriver, Handle as SignalHandle}; + +use std::time::Duration; + +/// Responsible for cleaning up orphaned child processes on Unix platforms. +#[derive(Debug)] +pub(crate) struct Driver { + park: SignalDriver, + signal_handle: SignalHandle, +} + +// ===== impl Driver ===== + +impl Driver { + /// Creates a new signal `Driver` instance that delegates wakeups to `park`. + pub(crate) fn new(park: SignalDriver) -> Self { + let signal_handle = park.handle(); + + Self { + park, + signal_handle, + } + } + + pub(crate) fn park(&mut self, handle: &driver::Handle) { + self.park.park(handle); + GlobalOrphanQueue::reap_orphans(&self.signal_handle); + } + + pub(crate) fn park_timeout(&mut self, handle: &driver::Handle, duration: Duration) { + self.park.park_timeout(handle, duration); + GlobalOrphanQueue::reap_orphans(&self.signal_handle); + } + + pub(crate) fn shutdown(&mut self, handle: &driver::Handle) { + self.park.shutdown(handle) + } +} |