use super::{Diagnostic, DiagnosticId, Diagnostics}; use bevy_app::{stage, AppPlugin}; use bevy_core::time::Time; use legion::prelude::*; use std::time::Duration; pub struct PrintDiagnosticsPlugin { pub debug: bool, pub wait_duration: Duration, pub filter: Option>, } pub struct PrintDiagnosticsState { elapsed: f64, wait_seconds: f64, filter: Option>, } impl Default for PrintDiagnosticsPlugin { fn default() -> Self { PrintDiagnosticsPlugin { debug: false, wait_duration: Duration::from_secs(1), filter: None, } } } impl AppPlugin for PrintDiagnosticsPlugin { fn build(&self, app: &mut bevy_app::AppBuilder) { app.add_resource(PrintDiagnosticsState { elapsed: 0.0, wait_seconds: self.wait_duration.as_secs_f64(), filter: self.filter.clone(), }); if self.debug { app.add_system_to_stage( stage::POST_UPDATE, Self::print_diagnostics_debug_system.system(), ); } else { app.add_system_to_stage(stage::POST_UPDATE, Self::print_diagnostics_system.system()); } } } impl PrintDiagnosticsPlugin { pub fn filtered(filter: Vec) -> Self { PrintDiagnosticsPlugin { filter: Some(filter), ..Default::default() } } fn print_diagnostic(diagnostic: &Diagnostic) { if let Some(value) = diagnostic.value() { print!("{:<20}: {:<19.6}", diagnostic.name, value); if let Some(average) = diagnostic.average() { print!(" (avg {:.6})", average); } println!("\n"); } } pub fn print_diagnostics_system( mut state: ResMut, time: Res