Add no_std
support to bevy_app
(#16874)
# Objective - Contributes to #15460 ## Solution - Added the following features: - `std` (default) - `bevy_tasks` (default) - `downcast ` (default) - `portable-atomic` - `critical-section` - `downcast` and `bevy_tasks` are now optional dependencies for `bevy_app`. ## Testing - CI - Personal UEFI and Raspberry Pi Pico demo applications compile and run against this branch ## Draft Release Notes Bevy's application framework now supports `no_std` platforms. Following up on `bevy_ecs` gaining `no_std` support, `bevy_app` extends the functionality available on these targets to include the powerful `App` and `Plugin` abstractions. With this, library authors now have the option of making their plugins `no_std` compatible, or even offering plugins specifically to improve Bevy on certain embedded platforms! To start making a `no_std` compatible plugin, simply disable default features when including `bevy_app`: ```toml [dependencies] bevy_app = { version = "0.16", default-features = false } ``` We encourage library authors to do this anyway, as it can also help with compile times and binary size on all platforms. Keep an eye out for future `no_std` updates as we continue to improve the parity between `std` and `no_std`. We look forward to seeing what kinds of applications are now possible with Bevy! ## Notes - `downcast-rs` is optional as it isn't compatible with `portable-atomic`. I will investigate making a PR upstream to add support for this functionality, as it should be very straightforward. - In line with the `bevy_ecs` no-std-ification, I've added documentation to all features, and grouped them as well. - ~~Creating this PR in draft while CI runs and so I can polish before review.~~ --------- Co-authored-by: Alice Cecile <alice.i.cecile@gmail.com>
This commit is contained in:
parent
c425fc7f32
commit
f45e78e658
@ -9,31 +9,77 @@ license = "MIT OR Apache-2.0"
|
|||||||
keywords = ["bevy"]
|
keywords = ["bevy"]
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
trace = []
|
default = ["std", "bevy_reflect", "bevy_tasks", "bevy_ecs/default", "downcast"]
|
||||||
bevy_debug_stepping = []
|
|
||||||
default = ["bevy_reflect"]
|
# Functionality
|
||||||
|
|
||||||
|
## Adds runtime reflection support using `bevy_reflect`.
|
||||||
bevy_reflect = ["dep:bevy_reflect", "bevy_ecs/bevy_reflect"]
|
bevy_reflect = ["dep:bevy_reflect", "bevy_ecs/bevy_reflect"]
|
||||||
|
|
||||||
|
## Extends reflection support to functions.
|
||||||
reflect_functions = [
|
reflect_functions = [
|
||||||
"bevy_reflect",
|
"bevy_reflect",
|
||||||
"bevy_reflect/functions",
|
"bevy_reflect/functions",
|
||||||
"bevy_ecs/reflect_functions",
|
"bevy_ecs/reflect_functions",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
## Adds support for running async background tasks
|
||||||
|
bevy_tasks = ["dep:bevy_tasks"]
|
||||||
|
|
||||||
|
## Adds `downcast-rs` integration for `Plugin`
|
||||||
|
downcast = ["dep:downcast-rs"]
|
||||||
|
|
||||||
|
# Debugging Features
|
||||||
|
|
||||||
|
## Enables `tracing` integration, allowing spans and other metrics to be reported
|
||||||
|
## through that framework.
|
||||||
|
trace = ["dep:tracing"]
|
||||||
|
|
||||||
|
## Provides system stepping support, allowing them to be paused, stepped, and
|
||||||
|
## other debug operations which can help with diagnosing certain behaviors.
|
||||||
|
bevy_debug_stepping = []
|
||||||
|
|
||||||
|
# Platform Compatibility
|
||||||
|
|
||||||
|
## Allows access to the `std` crate. Enabling this feature will prevent compilation
|
||||||
|
## on `no_std` targets, but provides access to certain additional features on
|
||||||
|
## supported platforms.
|
||||||
|
std = [
|
||||||
|
"bevy_reflect?/std",
|
||||||
|
"bevy_ecs/std",
|
||||||
|
"dep:ctrlc",
|
||||||
|
"downcast-rs?/std",
|
||||||
|
"bevy_utils/std",
|
||||||
|
"bevy_tasks?/std",
|
||||||
|
]
|
||||||
|
|
||||||
|
## `critical-section` provides the building blocks for synchronization primitives
|
||||||
|
## on all platforms, including `no_std`.
|
||||||
|
critical-section = ["bevy_tasks?/critical-section", "bevy_ecs/critical-section"]
|
||||||
|
|
||||||
|
## `portable-atomic` provides additional platform support for atomic types and
|
||||||
|
## operations, even on targets without native support.
|
||||||
|
portable-atomic = ["bevy_tasks?/portable-atomic", "bevy_ecs/portable-atomic"]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
# bevy
|
# bevy
|
||||||
bevy_derive = { path = "../bevy_derive", version = "0.15.0-dev" }
|
bevy_derive = { path = "../bevy_derive", version = "0.15.0-dev" }
|
||||||
bevy_ecs = { path = "../bevy_ecs", version = "0.15.0-dev", default-features = false }
|
bevy_ecs = { path = "../bevy_ecs", version = "0.15.0-dev", default-features = false }
|
||||||
bevy_reflect = { path = "../bevy_reflect", version = "0.15.0-dev", optional = true }
|
bevy_reflect = { path = "../bevy_reflect", version = "0.15.0-dev", default-features = false, optional = true }
|
||||||
bevy_utils = { path = "../bevy_utils", version = "0.15.0-dev" }
|
bevy_utils = { path = "../bevy_utils", version = "0.15.0-dev", default-features = false, features = [
|
||||||
bevy_tasks = { path = "../bevy_tasks", version = "0.15.0-dev" }
|
"alloc",
|
||||||
|
] }
|
||||||
|
bevy_tasks = { path = "../bevy_tasks", version = "0.15.0-dev", default-features = false, optional = true }
|
||||||
|
|
||||||
# other
|
# other
|
||||||
downcast-rs = "1.2.0"
|
downcast-rs = { version = "1.2.0", default-features = false, optional = true }
|
||||||
thiserror = { version = "2", default-features = false }
|
thiserror = { version = "2", default-features = false }
|
||||||
variadics_please = "1.1"
|
variadics_please = "1.1"
|
||||||
|
tracing = { version = "0.1", default-features = false, optional = true }
|
||||||
|
log = { version = "0.4", default-features = false }
|
||||||
|
|
||||||
[target.'cfg(not(target_arch = "wasm32"))'.dependencies]
|
[target.'cfg(not(target_arch = "wasm32"))'.dependencies]
|
||||||
ctrlc = "3.4.4"
|
ctrlc = { version = "3.4.4", optional = true }
|
||||||
|
|
||||||
[target.'cfg(target_arch = "wasm32")'.dependencies]
|
[target.'cfg(target_arch = "wasm32")'.dependencies]
|
||||||
wasm-bindgen = { version = "0.2" }
|
wasm-bindgen = { version = "0.2" }
|
||||||
|
@ -2,6 +2,10 @@ use crate::{
|
|||||||
First, Main, MainSchedulePlugin, PlaceholderPlugin, Plugin, Plugins, PluginsState, SubApp,
|
First, Main, MainSchedulePlugin, PlaceholderPlugin, Plugin, Plugins, PluginsState, SubApp,
|
||||||
SubApps,
|
SubApps,
|
||||||
};
|
};
|
||||||
|
use alloc::{
|
||||||
|
boxed::Box,
|
||||||
|
string::{String, ToString},
|
||||||
|
};
|
||||||
pub use bevy_derive::AppLabel;
|
pub use bevy_derive::AppLabel;
|
||||||
use bevy_ecs::{
|
use bevy_ecs::{
|
||||||
component::RequiredComponentsError,
|
component::RequiredComponentsError,
|
||||||
@ -11,15 +15,22 @@ use bevy_ecs::{
|
|||||||
schedule::{ScheduleBuildSettings, ScheduleLabel},
|
schedule::{ScheduleBuildSettings, ScheduleLabel},
|
||||||
system::{IntoObserverSystem, SystemId, SystemInput},
|
system::{IntoObserverSystem, SystemId, SystemInput},
|
||||||
};
|
};
|
||||||
#[cfg(feature = "trace")]
|
use bevy_utils::HashMap;
|
||||||
use bevy_utils::tracing::info_span;
|
|
||||||
use bevy_utils::{tracing::debug, HashMap};
|
|
||||||
use core::{fmt::Debug, num::NonZero, panic::AssertUnwindSafe};
|
use core::{fmt::Debug, num::NonZero, panic::AssertUnwindSafe};
|
||||||
|
use log::debug;
|
||||||
|
use thiserror::Error;
|
||||||
|
|
||||||
|
#[cfg(feature = "trace")]
|
||||||
|
use tracing::info_span;
|
||||||
|
|
||||||
|
#[cfg(feature = "std")]
|
||||||
use std::{
|
use std::{
|
||||||
panic::{catch_unwind, resume_unwind},
|
panic::{catch_unwind, resume_unwind},
|
||||||
process::{ExitCode, Termination},
|
process::{ExitCode, Termination},
|
||||||
};
|
};
|
||||||
use thiserror::Error;
|
|
||||||
|
#[cfg(feature = "downcast")]
|
||||||
|
use alloc::vec::Vec;
|
||||||
|
|
||||||
bevy_ecs::define_label!(
|
bevy_ecs::define_label!(
|
||||||
/// A strongly-typed class of labels used to identify an [`App`].
|
/// A strongly-typed class of labels used to identify an [`App`].
|
||||||
@ -458,12 +469,21 @@ impl App {
|
|||||||
.push(Box::new(PlaceholderPlugin));
|
.push(Box::new(PlaceholderPlugin));
|
||||||
|
|
||||||
self.main_mut().plugin_build_depth += 1;
|
self.main_mut().plugin_build_depth += 1;
|
||||||
let result = catch_unwind(AssertUnwindSafe(|| plugin.build(self)));
|
|
||||||
|
let f = AssertUnwindSafe(|| plugin.build(self));
|
||||||
|
|
||||||
|
#[cfg(feature = "std")]
|
||||||
|
let result = catch_unwind(f);
|
||||||
|
|
||||||
|
#[cfg(not(feature = "std"))]
|
||||||
|
f();
|
||||||
|
|
||||||
self.main_mut()
|
self.main_mut()
|
||||||
.plugin_names
|
.plugin_names
|
||||||
.insert(plugin.name().to_string());
|
.insert(plugin.name().to_string());
|
||||||
self.main_mut().plugin_build_depth -= 1;
|
self.main_mut().plugin_build_depth -= 1;
|
||||||
|
|
||||||
|
#[cfg(feature = "std")]
|
||||||
if let Err(payload) = result {
|
if let Err(payload) = result {
|
||||||
resume_unwind(payload);
|
resume_unwind(payload);
|
||||||
}
|
}
|
||||||
@ -499,6 +519,7 @@ impl App {
|
|||||||
/// # app.add_plugins(ImagePlugin::default());
|
/// # app.add_plugins(ImagePlugin::default());
|
||||||
/// let default_sampler = app.get_added_plugins::<ImagePlugin>()[0].default_sampler;
|
/// let default_sampler = app.get_added_plugins::<ImagePlugin>()[0].default_sampler;
|
||||||
/// ```
|
/// ```
|
||||||
|
#[cfg(feature = "downcast")]
|
||||||
pub fn get_added_plugins<T>(&self) -> Vec<&T>
|
pub fn get_added_plugins<T>(&self) -> Vec<&T>
|
||||||
where
|
where
|
||||||
T: Plugin,
|
T: Plugin,
|
||||||
@ -1294,7 +1315,7 @@ type RunnerFn = Box<dyn FnOnce(App) -> AppExit>;
|
|||||||
|
|
||||||
fn run_once(mut app: App) -> AppExit {
|
fn run_once(mut app: App) -> AppExit {
|
||||||
while app.plugins_state() == PluginsState::Adding {
|
while app.plugins_state() == PluginsState::Adding {
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
#[cfg(all(not(target_arch = "wasm32"), feature = "bevy_tasks"))]
|
||||||
bevy_tasks::tick_global_task_pools_on_main_thread();
|
bevy_tasks::tick_global_task_pools_on_main_thread();
|
||||||
}
|
}
|
||||||
app.finish();
|
app.finish();
|
||||||
@ -1364,6 +1385,7 @@ impl From<u8> for AppExit {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "std")]
|
||||||
impl Termination for AppExit {
|
impl Termination for AppExit {
|
||||||
fn report(self) -> ExitCode {
|
fn report(self) -> ExitCode {
|
||||||
match self {
|
match self {
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
html_logo_url = "https://bevyengine.org/assets/icon.png",
|
html_logo_url = "https://bevyengine.org/assets/icon.png",
|
||||||
html_favicon_url = "https://bevyengine.org/assets/icon.png"
|
html_favicon_url = "https://bevyengine.org/assets/icon.png"
|
||||||
)]
|
)]
|
||||||
|
#![cfg_attr(not(feature = "std"), no_std)]
|
||||||
|
|
||||||
//! This crate is about everything concerning the highest-level, application layer of a Bevy app.
|
//! This crate is about everything concerning the highest-level, application layer of a Bevy app.
|
||||||
|
|
||||||
@ -23,7 +24,7 @@ mod plugin;
|
|||||||
mod plugin_group;
|
mod plugin_group;
|
||||||
mod schedule_runner;
|
mod schedule_runner;
|
||||||
mod sub_app;
|
mod sub_app;
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
#[cfg(all(not(target_arch = "wasm32"), feature = "std"))]
|
||||||
mod terminal_ctrl_c_handler;
|
mod terminal_ctrl_c_handler;
|
||||||
|
|
||||||
pub use app::*;
|
pub use app::*;
|
||||||
@ -33,7 +34,7 @@ pub use plugin::*;
|
|||||||
pub use plugin_group::*;
|
pub use plugin_group::*;
|
||||||
pub use schedule_runner::*;
|
pub use schedule_runner::*;
|
||||||
pub use sub_app::*;
|
pub use sub_app::*;
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
#[cfg(all(not(target_arch = "wasm32"), feature = "std"))]
|
||||||
pub use terminal_ctrl_c_handler::*;
|
pub use terminal_ctrl_c_handler::*;
|
||||||
|
|
||||||
/// The app prelude.
|
/// The app prelude.
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
use crate::{App, Plugin};
|
use crate::{App, Plugin};
|
||||||
|
use alloc::{vec, vec::Vec};
|
||||||
use bevy_ecs::{
|
use bevy_ecs::{
|
||||||
schedule::{
|
schedule::{
|
||||||
ExecutorKind, InternedScheduleLabel, IntoSystemSetConfigs, Schedule, ScheduleLabel,
|
ExecutorKind, InternedScheduleLabel, IntoSystemSetConfigs, Schedule, ScheduleLabel,
|
||||||
|
@ -1,8 +1,21 @@
|
|||||||
|
// TODO: Upstream `portable-atomic` support to `downcast_rs` and unconditionally
|
||||||
|
// include it as a dependency.
|
||||||
|
// See https://github.com/marcianx/downcast-rs/pull/22 for details
|
||||||
|
#[cfg(feature = "downcast")]
|
||||||
use downcast_rs::{impl_downcast, Downcast};
|
use downcast_rs::{impl_downcast, Downcast};
|
||||||
|
|
||||||
use crate::App;
|
use crate::App;
|
||||||
use core::any::Any;
|
use core::any::Any;
|
||||||
|
|
||||||
|
/// Dummy trait with the same name as `downcast_rs::Downcast`. This is to ensure
|
||||||
|
/// the `Plugin: Downcast` bound can remain even when `downcast` isn't enabled.
|
||||||
|
#[cfg(not(feature = "downcast"))]
|
||||||
|
#[doc(hidden)]
|
||||||
|
pub trait Downcast {}
|
||||||
|
|
||||||
|
#[cfg(not(feature = "downcast"))]
|
||||||
|
impl<T: ?Sized> Downcast for T {}
|
||||||
|
|
||||||
/// A collection of Bevy app logic and configuration.
|
/// A collection of Bevy app logic and configuration.
|
||||||
///
|
///
|
||||||
/// Plugins configure an [`App`]. When an [`App`] registers a plugin,
|
/// Plugins configure an [`App`]. When an [`App`] registers a plugin,
|
||||||
@ -92,6 +105,7 @@ pub trait Plugin: Downcast + Any + Send + Sync {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "downcast")]
|
||||||
impl_downcast!(Plugin);
|
impl_downcast!(Plugin);
|
||||||
|
|
||||||
impl<T: Fn(&mut App) + Send + Sync + 'static> Plugin for T {
|
impl<T: Fn(&mut App) + Send + Sync + 'static> Plugin for T {
|
||||||
@ -129,6 +143,7 @@ pub trait Plugins<Marker>: sealed::Plugins<Marker> {}
|
|||||||
impl<Marker, T> Plugins<Marker> for T where T: sealed::Plugins<Marker> {}
|
impl<Marker, T> Plugins<Marker> for T where T: sealed::Plugins<Marker> {}
|
||||||
|
|
||||||
mod sealed {
|
mod sealed {
|
||||||
|
use alloc::boxed::Box;
|
||||||
use variadics_please::all_tuples;
|
use variadics_please::all_tuples;
|
||||||
|
|
||||||
use crate::{App, AppError, Plugin, PluginGroup};
|
use crate::{App, AppError, Plugin, PluginGroup};
|
||||||
|
@ -1,9 +1,12 @@
|
|||||||
use crate::{App, AppError, Plugin};
|
use crate::{App, AppError, Plugin};
|
||||||
use bevy_utils::{
|
use alloc::{
|
||||||
tracing::{debug, warn},
|
boxed::Box,
|
||||||
TypeIdMap,
|
string::{String, ToString},
|
||||||
|
vec::Vec,
|
||||||
};
|
};
|
||||||
|
use bevy_utils::TypeIdMap;
|
||||||
use core::any::TypeId;
|
use core::any::TypeId;
|
||||||
|
use log::{debug, warn};
|
||||||
|
|
||||||
/// A macro for generating a well-documented [`PluginGroup`] from a list of [`Plugin`] paths.
|
/// A macro for generating a well-documented [`PluginGroup`] from a list of [`Plugin`] paths.
|
||||||
///
|
///
|
||||||
|
@ -3,7 +3,10 @@ use crate::{
|
|||||||
plugin::Plugin,
|
plugin::Plugin,
|
||||||
PluginsState,
|
PluginsState,
|
||||||
};
|
};
|
||||||
use bevy_utils::{Duration, Instant};
|
use bevy_utils::Duration;
|
||||||
|
|
||||||
|
#[cfg(any(target_arch = "wasm32", feature = "std"))]
|
||||||
|
use bevy_utils::Instant;
|
||||||
|
|
||||||
#[cfg(target_arch = "wasm32")]
|
#[cfg(target_arch = "wasm32")]
|
||||||
use {
|
use {
|
||||||
@ -76,7 +79,7 @@ impl Plugin for ScheduleRunnerPlugin {
|
|||||||
let plugins_state = app.plugins_state();
|
let plugins_state = app.plugins_state();
|
||||||
if plugins_state != PluginsState::Cleaned {
|
if plugins_state != PluginsState::Cleaned {
|
||||||
while app.plugins_state() == PluginsState::Adding {
|
while app.plugins_state() == PluginsState::Adding {
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
#[cfg(all(not(target_arch = "wasm32"), feature = "bevy_tasks"))]
|
||||||
bevy_tasks::tick_global_task_pools_on_main_thread();
|
bevy_tasks::tick_global_task_pools_on_main_thread();
|
||||||
}
|
}
|
||||||
app.finish();
|
app.finish();
|
||||||
@ -95,8 +98,9 @@ impl Plugin for ScheduleRunnerPlugin {
|
|||||||
}
|
}
|
||||||
RunMode::Loop { wait } => {
|
RunMode::Loop { wait } => {
|
||||||
let tick = move |app: &mut App,
|
let tick = move |app: &mut App,
|
||||||
wait: Option<Duration>|
|
_wait: Option<Duration>|
|
||||||
-> Result<Option<Duration>, AppExit> {
|
-> Result<Option<Duration>, AppExit> {
|
||||||
|
#[cfg(any(target_arch = "wasm32", feature = "std"))]
|
||||||
let start_time = Instant::now();
|
let start_time = Instant::now();
|
||||||
|
|
||||||
app.update();
|
app.update();
|
||||||
@ -105,9 +109,11 @@ impl Plugin for ScheduleRunnerPlugin {
|
|||||||
return Err(exit);
|
return Err(exit);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#[cfg(any(target_arch = "wasm32", feature = "std"))]
|
||||||
let end_time = Instant::now();
|
let end_time = Instant::now();
|
||||||
|
|
||||||
if let Some(wait) = wait {
|
#[cfg(any(target_arch = "wasm32", feature = "std"))]
|
||||||
|
if let Some(wait) = _wait {
|
||||||
let exe_time = end_time - start_time;
|
let exe_time = end_time - start_time;
|
||||||
if exe_time < wait {
|
if exe_time < wait {
|
||||||
return Ok(Some(wait - exe_time));
|
return Ok(Some(wait - exe_time));
|
||||||
@ -121,7 +127,10 @@ impl Plugin for ScheduleRunnerPlugin {
|
|||||||
{
|
{
|
||||||
loop {
|
loop {
|
||||||
match tick(&mut app, wait) {
|
match tick(&mut app, wait) {
|
||||||
Ok(Some(delay)) => std::thread::sleep(delay),
|
Ok(Some(_delay)) => {
|
||||||
|
#[cfg(feature = "std")]
|
||||||
|
std::thread::sleep(_delay);
|
||||||
|
}
|
||||||
Ok(None) => continue,
|
Ok(None) => continue,
|
||||||
Err(exit) => return exit,
|
Err(exit) => return exit,
|
||||||
}
|
}
|
||||||
|
@ -1,16 +1,17 @@
|
|||||||
use crate::{App, AppLabel, InternedAppLabel, Plugin, Plugins, PluginsState};
|
use crate::{App, AppLabel, InternedAppLabel, Plugin, Plugins, PluginsState};
|
||||||
|
use alloc::{boxed::Box, string::String, vec::Vec};
|
||||||
use bevy_ecs::{
|
use bevy_ecs::{
|
||||||
event::EventRegistry,
|
event::EventRegistry,
|
||||||
prelude::*,
|
prelude::*,
|
||||||
schedule::{InternedScheduleLabel, ScheduleBuildSettings, ScheduleLabel},
|
schedule::{InternedScheduleLabel, ScheduleBuildSettings, ScheduleLabel},
|
||||||
system::{SystemId, SystemInput},
|
system::{SystemId, SystemInput},
|
||||||
};
|
};
|
||||||
|
|
||||||
#[cfg(feature = "trace")]
|
|
||||||
use bevy_utils::tracing::info_span;
|
|
||||||
use bevy_utils::{HashMap, HashSet};
|
use bevy_utils::{HashMap, HashSet};
|
||||||
use core::fmt::Debug;
|
use core::fmt::Debug;
|
||||||
|
|
||||||
|
#[cfg(feature = "trace")]
|
||||||
|
use tracing::info_span;
|
||||||
|
|
||||||
type ExtractFn = Box<dyn Fn(&mut World, &mut World) + Send>;
|
type ExtractFn = Box<dyn Fn(&mut World, &mut World) + Send>;
|
||||||
|
|
||||||
/// A secondary application with its own [`World`]. These can run independently of each other.
|
/// A secondary application with its own [`World`]. These can run independently of each other.
|
||||||
@ -332,6 +333,7 @@ impl SubApp {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// See [`App::get_added_plugins`].
|
/// See [`App::get_added_plugins`].
|
||||||
|
#[cfg(feature = "downcast")]
|
||||||
pub fn get_added_plugins<T>(&self) -> Vec<&T>
|
pub fn get_added_plugins<T>(&self) -> Vec<&T>
|
||||||
where
|
where
|
||||||
T: Plugin,
|
T: Plugin,
|
||||||
|
@ -63,9 +63,9 @@ impl Plugin for TerminalCtrlCHandlerPlugin {
|
|||||||
match result {
|
match result {
|
||||||
Ok(()) => {}
|
Ok(()) => {}
|
||||||
Err(ctrlc::Error::MultipleHandlers) => {
|
Err(ctrlc::Error::MultipleHandlers) => {
|
||||||
bevy_utils::tracing::info!("Skipping installing `Ctrl+C` handler as one was already installed. Please call `TerminalCtrlCHandlerPlugin::gracefully_exit` in your own `Ctrl+C` handler if you want Bevy to gracefully exit on `Ctrl+C`.");
|
log::info!("Skipping installing `Ctrl+C` handler as one was already installed. Please call `TerminalCtrlCHandlerPlugin::gracefully_exit` in your own `Ctrl+C` handler if you want Bevy to gracefully exit on `Ctrl+C`.");
|
||||||
}
|
}
|
||||||
Err(err) => bevy_utils::tracing::warn!("Failed to set `Ctrl+C` handler: {err}"),
|
Err(err) => log::warn!("Failed to set `Ctrl+C` handler: {err}"),
|
||||||
}
|
}
|
||||||
|
|
||||||
app.add_systems(Update, TerminalCtrlCHandlerPlugin::exit_on_flag);
|
app.add_systems(Update, TerminalCtrlCHandlerPlugin::exit_on_flag);
|
||||||
|
@ -79,7 +79,7 @@ std = [
|
|||||||
## on all platforms, including `no_std`.
|
## on all platforms, including `no_std`.
|
||||||
critical-section = [
|
critical-section = [
|
||||||
"dep:critical-section",
|
"dep:critical-section",
|
||||||
"bevy_tasks/critical-section",
|
"bevy_tasks?/critical-section",
|
||||||
"portable-atomic?/critical-section",
|
"portable-atomic?/critical-section",
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -88,8 +88,9 @@ critical-section = [
|
|||||||
portable-atomic = [
|
portable-atomic = [
|
||||||
"dep:portable-atomic",
|
"dep:portable-atomic",
|
||||||
"dep:portable-atomic-util",
|
"dep:portable-atomic-util",
|
||||||
"bevy_tasks/portable-atomic",
|
"bevy_tasks?/portable-atomic",
|
||||||
"concurrent-queue/portable-atomic",
|
"concurrent-queue/portable-atomic",
|
||||||
|
"spin/portable_atomic",
|
||||||
]
|
]
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
@ -102,6 +102,14 @@ impl Prepare for CompileCheckNoStdCommand {
|
|||||||
"Please fix compiler errors in output above for bevy_ecs no_std compatibility.",
|
"Please fix compiler errors in output above for bevy_ecs no_std compatibility.",
|
||||||
));
|
));
|
||||||
|
|
||||||
|
commands.push(PreparedCommand::new::<Self>(
|
||||||
|
cmd!(
|
||||||
|
sh,
|
||||||
|
"cargo check -p bevy_app --no-default-features --features bevy_reflect --target {target}"
|
||||||
|
),
|
||||||
|
"Please fix compiler errors in output above for bevy_app no_std compatibility.",
|
||||||
|
));
|
||||||
|
|
||||||
commands
|
commands
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user