2024-03-23 02:22:52 +00:00
|
|
|
#![cfg_attr(docsrs, feature(doc_auto_cfg))]
|
2024-03-25 18:52:50 +00:00
|
|
|
#![doc(
|
|
|
|
html_logo_url = "https://bevyengine.org/assets/icon.png",
|
|
|
|
html_favicon_url = "https://bevyengine.org/assets/icon.png"
|
|
|
|
)]
|
2024-03-23 02:22:52 +00:00
|
|
|
|
2024-03-19 00:56:49 +00:00
|
|
|
//! This crate provides panic handlers for [Bevy](https://bevyengine.org)
|
|
|
|
//! apps, and automatically configures platform specifics (i.e. WASM or Android).
|
|
|
|
//!
|
|
|
|
//! By default, the [`PanicHandlerPlugin`] from this crate is included in Bevy's `DefaultPlugins`.
|
|
|
|
//!
|
|
|
|
//! For more fine-tuned control over panic behavior, disable the [`PanicHandlerPlugin`] or
|
|
|
|
//! `DefaultPlugins` during app initialization.
|
|
|
|
|
|
|
|
use bevy_app::{App, Plugin};
|
|
|
|
|
|
|
|
/// Adds sensible panic handlers to Apps. This plugin is part of the `DefaultPlugins`. Adding
|
|
|
|
/// this plugin will setup a panic hook appropriate to your target platform:
|
|
|
|
/// * On WASM, uses [`console_error_panic_hook`](https://crates.io/crates/console_error_panic_hook), logging
|
|
|
|
/// to the browser console.
|
|
|
|
/// * Other platforms are currently not setup.
|
|
|
|
///
|
|
|
|
/// ```no_run
|
|
|
|
/// # use bevy_app::{App, NoopPluginGroup as MinimalPlugins, PluginGroup};
|
|
|
|
/// # use bevy_panic_handler::PanicHandlerPlugin;
|
|
|
|
/// fn main() {
|
|
|
|
/// App::new()
|
|
|
|
/// .add_plugins(MinimalPlugins)
|
|
|
|
/// .add_plugins(PanicHandlerPlugin)
|
|
|
|
/// .run();
|
|
|
|
/// }
|
|
|
|
/// ```
|
|
|
|
///
|
|
|
|
/// If you want to setup your own panic handler, you should disable this
|
|
|
|
/// plugin from `DefaultPlugins`:
|
|
|
|
/// ```no_run
|
|
|
|
/// # use bevy_app::{App, NoopPluginGroup as DefaultPlugins, PluginGroup};
|
|
|
|
/// # use bevy_panic_handler::PanicHandlerPlugin;
|
|
|
|
/// fn main() {
|
|
|
|
/// App::new()
|
|
|
|
/// .add_plugins(DefaultPlugins.build().disable::<PanicHandlerPlugin>())
|
|
|
|
/// .run();
|
|
|
|
/// }
|
|
|
|
/// ```
|
|
|
|
#[derive(Default)]
|
|
|
|
pub struct PanicHandlerPlugin;
|
|
|
|
|
|
|
|
impl Plugin for PanicHandlerPlugin {
|
|
|
|
fn build(&self, _app: &mut App) {
|
|
|
|
#[cfg(target_arch = "wasm32")]
|
|
|
|
{
|
|
|
|
console_error_panic_hook::set_once();
|
|
|
|
}
|
|
|
|
#[cfg(not(target_arch = "wasm32"))]
|
|
|
|
{
|
|
|
|
// Use the default target panic hook - Do nothing.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|