diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-06-07 05:48:48 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-06-07 05:48:48 +0000 |
commit | ef24de24a82fe681581cc130f342363c47c0969a (patch) | |
tree | 0d494f7e1a38b95c92426f58fe6eaa877303a86c /vendor/anstream-0.5.0/src/lockable.rs | |
parent | Releasing progress-linux version 1.74.1+dfsg1-1~progress7.99u1. (diff) | |
download | rustc-ef24de24a82fe681581cc130f342363c47c0969a.tar.xz rustc-ef24de24a82fe681581cc130f342363c47c0969a.zip |
Merging upstream version 1.75.0+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r-- | vendor/anstream-0.5.0/src/lockable.rs | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/vendor/anstream-0.5.0/src/lockable.rs b/vendor/anstream-0.5.0/src/lockable.rs new file mode 100644 index 000000000..19d06a01b --- /dev/null +++ b/vendor/anstream-0.5.0/src/lockable.rs @@ -0,0 +1,51 @@ +/// Explicitly lock a [`std::io::Write`]able +pub trait Lockable { + type Locked; + + /// Get exclusive access to the `AutoStream` + /// + /// Why? + /// - Faster performance when writing in a loop + /// - Avoid other threads interleaving output with the current thread + fn lock(self) -> Self::Locked; +} + +impl Lockable for std::io::Stdout { + type Locked = std::io::StdoutLock<'static>; + + #[inline] + fn lock(self) -> Self::Locked { + #[allow(clippy::needless_borrow)] // Its needed to avoid recursion + (&self).lock() + } +} + +impl Lockable for std::io::Stderr { + type Locked = std::io::StderrLock<'static>; + + #[inline] + fn lock(self) -> Self::Locked { + #[allow(clippy::needless_borrow)] // Its needed to avoid recursion + (&self).lock() + } +} + +#[cfg(all(windows, feature = "wincon"))] +impl Lockable for anstyle_wincon::Console<std::io::Stdout> { + type Locked = anstyle_wincon::Console<std::io::StdoutLock<'static>>; + + #[inline] + fn lock(self) -> Self::Locked { + self.lock() + } +} + +#[cfg(all(windows, feature = "wincon"))] +impl Lockable for anstyle_wincon::Console<std::io::Stderr> { + type Locked = anstyle_wincon::Console<std::io::StderrLock<'static>>; + + #[inline] + fn lock(self) -> Self::Locked { + self.lock() + } +} |