Struct gix_features::progress::ThroughputOnDrop
source · pub struct ThroughputOnDrop<T>(_, _)
where
T: Progress;Available on crate feature
progress only.Expand description
Emit a message with throughput information when the instance is dropped.
Implementations§
source§impl<T> ThroughputOnDrop<T>where
T: Progress,
impl<T> ThroughputOnDrop<T>where T: Progress,
sourcepub fn new(inner: T) -> ThroughputOnDrop<T>
pub fn new(inner: T) -> ThroughputOnDrop<T>
Create a new instance by providing the inner Progress implementation.
Trait Implementations§
source§impl<T> Drop for ThroughputOnDrop<T>where
T: Progress,
impl<T> Drop for ThroughputOnDrop<T>where T: Progress,
source§impl<T> Progress for ThroughputOnDrop<T>where
T: Progress,
impl<T> Progress for ThroughputOnDrop<T>where T: Progress,
§type SubProgress = <T as Progress>::SubProgress
type SubProgress = <T as Progress>::SubProgress
The type of progress returned by
add_child().source§fn add_child(
&mut self,
name: impl Into<String>
) -> <ThroughputOnDrop<T> as Progress>::SubProgress
fn add_child( &mut self, name: impl Into<String> ) -> <ThroughputOnDrop<T> as Progress>::SubProgress
Adds a new child, whose parent is this instance, with the given
name. Read moresource§fn add_child_with_id(
&mut self,
name: impl Into<String>,
id: [u8; 4]
) -> <ThroughputOnDrop<T> as Progress>::SubProgress
fn add_child_with_id( &mut self, name: impl Into<String>, id: [u8; 4] ) -> <ThroughputOnDrop<T> as Progress>::SubProgress
source§fn init(&mut self, max: Option<usize>, unit: Option<Unit>)
fn init(&mut self, max: Option<usize>, unit: Option<Unit>)
Initialize the Item for receiving progress information. Read more
source§fn set(&mut self, step: usize)
fn set(&mut self, step: usize)
Set the current progress to the given
step. The cost of this call is negligible,
making manual throttling not necessary. Read moresource§fn max(&self) -> Option<usize>
fn max(&self) -> Option<usize>
Returns the maximum about of items we expect, as provided with the
init(…) callsource§fn set_max(&mut self, max: Option<usize>) -> Option<usize>
fn set_max(&mut self, max: Option<usize>) -> Option<usize>
Set the maximum value to
max and return the old maximum value.source§fn inc_by(&mut self, step: usize)
fn inc_by(&mut self, step: usize)
Increment the current progress to the given
step.
The cost of this call is negligible, making manual throttling not necessary.source§fn set_name(&mut self, name: impl Into<String>)
fn set_name(&mut self, name: impl Into<String>)
Set the name of the instance, altering the value given when crating it with
add_child(…)
The progress is allowed to discard it.source§fn name(&self) -> Option<String>
fn name(&self) -> Option<String>
Get the name of the instance as given when creating it with
add_child(…)
The progress is allowed to not be named, thus there is no guarantee that a previously set names ‘sticks’.source§fn id(&self) -> [u8; 4]
fn id(&self) -> [u8; 4]
Get a stable identifier for the progress instance.
Note that it could be unknown.
source§fn counter(&self) -> Option<Arc<AtomicUsize>>
fn counter(&self) -> Option<Arc<AtomicUsize>>
If available, return an atomic counter for direct access to the underlying state. Read more
source§fn inc(&mut self)
fn inc(&mut self)
Increment the current progress to the given 1. The cost of this call is negligible,
making manual throttling not necessary.
source§fn info(&self, message: impl Into<String>)
fn info(&self, message: impl Into<String>)
Create a message providing additional information about the progress thus far.
source§fn done(&self, message: impl Into<String>)
fn done(&self, message: impl Into<String>)
Create a message indicating the task is done successfully
source§fn show_throughput(&self, start: Instant)
fn show_throughput(&self, start: Instant)
A shorthand to print throughput information
source§fn show_throughput_with(
&self,
start: Instant,
step: usize,
unit: Unit,
level: MessageLevel
)
fn show_throughput_with( &self, start: Instant, step: usize, unit: Unit, level: MessageLevel )
A shorthand to print throughput information, with the given step and unit, and message level.
Auto Trait Implementations§
impl<T> RefUnwindSafe for ThroughputOnDrop<T>where T: RefUnwindSafe,
impl<T> Send for ThroughputOnDrop<T>
impl<T> Sync for ThroughputOnDrop<T>
impl<T> Unpin for ThroughputOnDrop<T>where T: Unpin,
impl<T> UnwindSafe for ThroughputOnDrop<T>where T: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<T> RawProgress for Twhere
T: Progress,
impl<T> RawProgress for Twhere T: Progress,
source§fn init(&mut self, max: Option<usize>, unit: Option<Unit>)
fn init(&mut self, max: Option<usize>, unit: Option<Unit>)
Initialize the Item for receiving progress information. Read more
source§fn set(&mut self, step: usize)
fn set(&mut self, step: usize)
Set the current progress to the given
step. The cost of this call is negligible,
making manual throttling not necessary. Read moresource§fn max(&self) -> Option<usize>
fn max(&self) -> Option<usize>
Returns the maximum about of items we expect, as provided with the
init(…) callsource§fn set_max(&mut self, max: Option<usize>) -> Option<usize>
fn set_max(&mut self, max: Option<usize>) -> Option<usize>
Set the maximum value to
max and return the old maximum value.source§fn inc_by(&mut self, step: usize)
fn inc_by(&mut self, step: usize)
Increment the current progress to the given
step.
The cost of this call is negligible, making manual throttling not necessary.source§fn inc(&mut self)
fn inc(&mut self)
Increment the current progress to the given 1. The cost of this call is negligible,
making manual throttling not necessary.
source§fn set_name(&mut self, name: String)
fn set_name(&mut self, name: String)
Set the name of the instance, altering the value given when crating it with
add_child(…)
The progress is allowed to discard it.source§fn name(&self) -> Option<String>
fn name(&self) -> Option<String>
Get the name of the instance as given when creating it with
add_child(…)
The progress is allowed to not be named, thus there is no guarantee that a previously set names ‘sticks’.source§fn id(&self) -> [u8; 4]
fn id(&self) -> [u8; 4]
Get a stable identifier for the progress instance.
Note that it could be unknown.
source§fn message(&self, level: MessageLevel, message: String)
fn message(&self, level: MessageLevel, message: String)
source§fn counter(&self) -> Option<Arc<AtomicUsize>>
fn counter(&self) -> Option<Arc<AtomicUsize>>
If available, return an atomic counter for direct access to the underlying state. Read more
source§fn info(&self, message: String)
fn info(&self, message: String)
Create a message providing additional information about the progress thus far.
source§fn show_throughput(&self, start: Instant)
fn show_throughput(&self, start: Instant)
A shorthand to print throughput information
source§fn show_throughput_with(
&self,
start: Instant,
step: usize,
unit: Unit,
level: MessageLevel
)
fn show_throughput_with( &self, start: Instant, step: usize, unit: Unit, level: MessageLevel )
A shorthand to print throughput information, with the given step and unit, and message level.