
# Objective - Prevent usage of `println!`, `eprintln!` and the like because they require `std` - Fixes #17446 ## Solution - Enable the `print_stdout` and `print_stderr` clippy lints - Replace all `println!` and `eprintln!` occurrences with `log::*` where applicable or alternatively ignore the warnings ## Testing - Run `cargo clippy --workspace` to ensure that there are no warnings relating to printing to `stdout` or `stderr`
38 lines
1.1 KiB
Rust
38 lines
1.1 KiB
Rust
//! This sample demonstrates creating a thread pool with 4 tasks and spawning 40 tasks that spin
|
|
//! for 100ms. It's expected to take about a second to run (assuming the machine has >= 4 logical
|
|
//! cores)
|
|
|
|
#![expect(clippy::print_stdout, reason = "Allowed in examples.")]
|
|
|
|
use bevy_platform_support::time::Instant;
|
|
use bevy_tasks::TaskPoolBuilder;
|
|
use core::time::Duration;
|
|
|
|
fn main() {
|
|
let pool = TaskPoolBuilder::new()
|
|
.thread_name("Busy Behavior ThreadPool".to_string())
|
|
.num_threads(4)
|
|
.build();
|
|
|
|
let t0 = Instant::now();
|
|
pool.scope(|s| {
|
|
for i in 0..40 {
|
|
s.spawn(async move {
|
|
let now = Instant::now();
|
|
while Instant::now() - now < Duration::from_millis(100) {
|
|
// spin, simulating work being done
|
|
}
|
|
|
|
println!(
|
|
"Thread {:?} index {} finished",
|
|
std::thread::current().id(),
|
|
i
|
|
);
|
|
});
|
|
}
|
|
});
|
|
|
|
let t1 = Instant::now();
|
|
println!("all tasks finished in {} secs", (t1 - t0).as_secs_f32());
|
|
}
|