From 2837eb3e945395325d1a594e5052f3b904b400e2 Mon Sep 17 00:00:00 2001 From: Patrick Dobbs Date: Thu, 28 Nov 2024 13:26:07 +0000 Subject: [PATCH 01/11] Update to Bevy 0.15 --- Cargo.toml | 12 ++++++--- README.md | 1 + examples/basic.rs | 2 +- examples/cycle.rs | 56 ++++++++++++++++++----------------------- examples/detection.rs | 2 +- examples/gradient.rs | 2 +- examples/models.rs | 2 +- examples/nishita.rs | 2 +- examples/settings.rs | 2 +- examples/splitscreen.rs | 54 ++++++++++++++++++--------------------- macros/Cargo.toml | 4 +-- src/lib.rs | 2 +- src/plugin.rs | 14 ++++------- 13 files changed, 71 insertions(+), 84 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index a46983d..3528af2 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -11,17 +11,17 @@ repository = "https://github.com/JonahPlusPlus/bevy_atmosphere" exclude = ["/assets/", "/examples/", "/.github/"] [dependencies] -bevy = { version = "0.14", default-features = false, features = [ +bevy = { version = "0.15.0-rc.3", default-features = false, features = [ "bevy_asset", "bevy_render", "bevy_pbr", ] } -bevy_atmosphere_macros = { path = "macros", version = "0.6" } +bevy_atmosphere_macros = { path = "macros", version = "0.7" } cfg-if = "1.0" [dev-dependencies] -bevy_spectator = "0.6" -bevy = { version = "0.14", features = ["bevy_core_pipeline", "x11"] } +bevy_spectator = "0.7" +bevy = { version = "0.15.0-rc.3", features = ["bevy_core_pipeline", "x11"] } [features] default = ["basic", "all_models"] @@ -74,3 +74,7 @@ required-features = ["default"] name = "splitscreen" path = "examples/splitscreen.rs" required-features = ["default"] + +[patch.crates-io] +# TODO: Temporary patch for dev-dep, remove when upstream updates +bevy_spectator = { git = "https://github.com/ptsd/bevy_spectator.git", branch = "bevy-0.15" } diff --git a/README.md b/README.md index a8d4215..72e309d 100644 --- a/README.md +++ b/README.md @@ -40,6 +40,7 @@ For more information on the technicalities, you can check out the [technical doc | bevy | bevy_atmosphere | |------|-----------------| +| 0.15 | 0.11 | | 0.14 | 0.10 | | 0.13 | 0.9 | | 0.12 | 0.8 | diff --git a/examples/basic.rs b/examples/basic.rs index 32999fe..6028b18 100644 --- a/examples/basic.rs +++ b/examples/basic.rs @@ -10,5 +10,5 @@ fn main() { } fn setup(mut commands: Commands) { - commands.spawn((Camera3dBundle::default(), AtmosphereCamera::default())); + commands.spawn((Camera3d::default(), AtmosphereCamera::default())); } diff --git a/examples/cycle.rs b/examples/cycle.rs index c93449f..ad7b328 100644 --- a/examples/cycle.rs +++ b/examples/cycle.rs @@ -4,7 +4,6 @@ use bevy_spectator::{Spectator, SpectatorPlugin}; fn main() { App::new() - .insert_resource(Msaa::Sample4) .insert_resource(AtmosphereModel::default()) // Default Atmosphere material, we can edit it to simulate another planet .insert_resource(CycleTimer(Timer::new( bevy::utils::Duration::from_millis(50), // Update our atmosphere every 50ms (in a real game, this would be much slower, but for the sake of an example we use a faster update) @@ -38,7 +37,7 @@ fn daylight_cycle( timer.0.tick(time.delta()); if timer.0.finished() { - let t = time.elapsed_seconds_wrapped() / 2.0; + let t = time.elapsed_secs_wrapped() / 2.0; atmosphere.sun_position = Vec3::new(0., t.sin(), t.cos()); if let Some((mut light_trans, mut directional)) = query.single_mut().into() { @@ -56,49 +55,42 @@ fn setup_environment( ) { // Our Sun commands.spawn(( - DirectionalLightBundle { - ..Default::default() - }, + DirectionalLight::default(), Sun, // Marks the light as Sun )); // Simple transform shape just for reference - commands.spawn(PbrBundle { - mesh: meshes.add(Cuboid::default()), - material: materials.add(StandardMaterial::from(Color::srgb(0.8, 0.8, 0.8))), - ..Default::default() - }); + commands.spawn(( + Mesh3d(meshes.add(Cuboid::default())), + MeshMaterial3d(materials.add(StandardMaterial::from(Color::srgb(0.8, 0.8, 0.8)))), + )); // X axis - commands.spawn(PbrBundle { - mesh: meshes.add(Cuboid::new(0.5, 0.5, 0.5)), - material: materials.add(StandardMaterial::from(Color::srgb(0.8, 0.0, 0.0))), - transform: Transform::from_xyz(1., 0., 0.), - ..Default::default() - }); + commands.spawn(( + Mesh3d(meshes.add(Cuboid::new(0.5, 0.5, 0.5))), + MeshMaterial3d(materials.add(StandardMaterial::from(Color::srgb(0.8, 0.0, 0.0)))), + Transform::from_xyz(1., 0., 0.), + )); // Y axis - commands.spawn(PbrBundle { - mesh: meshes.add(Cuboid::new(0.5, 0.5, 0.5)), - material: materials.add(StandardMaterial::from(Color::srgb(0.0, 0.8, 0.0))), - transform: Transform::from_xyz(0., 1., 0.), - ..Default::default() - }); + commands.spawn(( + Mesh3d(meshes.add(Cuboid::new(0.5, 0.5, 0.5))), + MeshMaterial3d(materials.add(StandardMaterial::from(Color::srgb(0.0, 0.8, 0.0)))), + Transform::from_xyz(0., 1., 0.), + )); // Z axis - commands.spawn(PbrBundle { - mesh: meshes.add(Cuboid::new(0.5, 0.5, 0.5)), - material: materials.add(StandardMaterial::from(Color::srgb(0.0, 0.0, 0.8))), - transform: Transform::from_xyz(0., 0., 1.), - ..Default::default() - }); + commands.spawn(( + Mesh3d(meshes.add(Cuboid::new(0.5, 0.5, 0.5))), + MeshMaterial3d(materials.add(StandardMaterial::from(Color::srgb(0.0, 0.0, 0.8)))), + Transform::from_xyz(0., 0., 1.), + )); // Spawn our camera commands.spawn(( - Camera3dBundle { - transform: Transform::from_xyz(5., 0., 5.), - ..default() - }, + Camera3d::default(), + Transform::from_xyz(5., 0., 5.), + Msaa::Sample4, AtmosphereCamera::default(), // Marks camera as having a skybox, by default it doesn't specify the render layers the skybox can be seen on Spectator, // Marks camera as spectator (specific to bevy_spectator) )); diff --git a/examples/detection.rs b/examples/detection.rs index 18b858c..f9d076a 100644 --- a/examples/detection.rs +++ b/examples/detection.rs @@ -14,7 +14,7 @@ fn main() { struct PrimaryCamera; fn setup(mut commands: Commands) { - commands.spawn((Camera3dBundle::default(), PrimaryCamera)); + commands.spawn((Camera3d::default(), PrimaryCamera)); } fn update( diff --git a/examples/gradient.rs b/examples/gradient.rs index 6b6ba34..5debb9e 100644 --- a/examples/gradient.rs +++ b/examples/gradient.rs @@ -15,7 +15,7 @@ fn main() { fn setup(mut commands: Commands) { commands.spawn(( - Camera3dBundle::default(), + Camera3d::default(), AtmosphereCamera::default(), Spectator, )); diff --git a/examples/models.rs b/examples/models.rs index 6ec35d1..f43930e 100644 --- a/examples/models.rs +++ b/examples/models.rs @@ -14,7 +14,7 @@ fn main() { fn setup(mut commands: Commands) { commands.spawn(( - Camera3dBundle::default(), + Camera3d::default(), AtmosphereCamera::default(), Spectator, )); diff --git a/examples/nishita.rs b/examples/nishita.rs index eb41bdb..e64888b 100644 --- a/examples/nishita.rs +++ b/examples/nishita.rs @@ -13,7 +13,7 @@ fn main() { fn setup(mut commands: Commands) { commands.spawn(( - Camera3dBundle::default(), + Camera3d::default(), AtmosphereCamera::default(), Spectator, )); diff --git a/examples/settings.rs b/examples/settings.rs index 36e049b..f57db82 100644 --- a/examples/settings.rs +++ b/examples/settings.rs @@ -17,7 +17,7 @@ fn main() { fn setup(mut commands: Commands) { commands.spawn(( - Camera3dBundle::default(), + Camera3d::default(), AtmosphereCamera::default(), Spectator, )); diff --git a/examples/splitscreen.rs b/examples/splitscreen.rs index 052c412..ed5de38 100644 --- a/examples/splitscreen.rs +++ b/examples/splitscreen.rs @@ -12,7 +12,6 @@ use bevy_spectator::{Spectator, SpectatorPlugin, SpectatorSettings}; fn main() { println!("Demonstrates using `AtmosphereCamera.render_layers` to have multiple skyboxes in the scene at once\n\t- E: Switch camera"); App::new() - .insert_resource(Msaa::Sample4) .insert_resource(AtmosphereModel::new(Nishita { rayleigh_coefficient: Vec3::new(22.4e-6, 5.5e-6, 13.0e-6), // Change rayleigh coefficient to change color ..default() @@ -36,34 +35,31 @@ fn setup( mut settings: ResMut, ) { // Plane - commands.spawn(PbrBundle { - mesh: meshes.add(Plane3d::default().mesh().size(100.0, 100.0)), - material: materials.add(Color::srgb(0.3, 0.5, 0.3)), - ..default() - }); + commands.spawn(( + Mesh3d(meshes.add(Plane3d::default().mesh().size(100.0, 100.0))), + MeshMaterial3d(materials.add(Color::srgb(0.3, 0.5, 0.3))), + )); // Light - commands.spawn(DirectionalLightBundle { - transform: Transform::from_rotation(Quat::from_euler( + commands.spawn(( + DirectionalLight { + shadows_enabled: true, + ..default() + }, + Transform::from_rotation(Quat::from_euler( EulerRot::ZYX, 0.0, 1.0, -std::f32::consts::FRAC_PI_4, - )), - directional_light: DirectionalLight { - shadows_enabled: true, - ..default() - }, - ..default() - }); + )) + )); // Spawn left screen camera and make it the default spectator let left = commands .spawn(( - Camera3dBundle { - transform: Transform::from_xyz(0.0, 25.0, -100.0).looking_at(Vec3::ZERO, Vec3::Y), - ..default() - }, + Camera3d::default(), + Transform::from_xyz(0.0, 25.0, -100.0).looking_at(Vec3::ZERO, Vec3::Y), + Msaa::Sample4, RenderLayers::from_layers(&[0, 1]), // To prevent each player from seeing the other skybox, we put each one on a separate render layer (you could also use this render layer for other player specific effects) AtmosphereCamera { render_layers: Some(RenderLayers::layer(1)), @@ -77,19 +73,17 @@ fn setup( // Spawn right screen camera commands.spawn(( - Camera3dBundle { - transform: Transform::from_xyz(100.0, 50.0, 150.0).looking_at(Vec3::ZERO, Vec3::Y), - camera: Camera { - // Renders the right camera after the left camera, which has a default priority of 0 - order: 1, - // Don't clear on the second camera because the first camera already cleared the window - clear_color: ClearColorConfig::None, - ..default() - }, - camera_3d: Camera3d::default(), + Camera { + // Renders the right camera after the left camera, which has a default priority of 0 + order: 1, + // Don't clear on the second camera because the first camera already cleared the window + clear_color: ClearColorConfig::None, ..default() }, - RenderLayers::from_layers(&[0, 2]), + Camera3d::default(), + Transform::from_xyz(100.0, 50.0, 150.0).looking_at(Vec3::ZERO, Vec3::Y), + Msaa::Sample4, + RenderLayers::from_layers(&[0, 2]), // To prevent each player from seeing the other skybox, we put each one on a separate render layer (you could also use this render layer for other player specific effects) AtmosphereCamera { render_layers: Some(RenderLayers::layer(2)), }, diff --git a/macros/Cargo.toml b/macros/Cargo.toml index a900cab..c3f7e05 100644 --- a/macros/Cargo.toml +++ b/macros/Cargo.toml @@ -1,7 +1,7 @@ [package] name = "bevy_atmosphere_macros" description = "Proc macros for bevy_atmosphere" -version = "0.6.0" +version = "0.7.0" edition = "2021" authors = ["JonahPlusPlus <33059163+JonahPlusPlus@users.noreply.github.com>"] license = "MIT OR Apache-2.0" @@ -15,7 +15,7 @@ proc-macro = true [dependencies] proc-macro-crate = "3.1" -bevy_macro_utils = "0.14" +bevy_macro_utils = "0.15.0-rc.3" syn = "2.0" proc-macro2 = "1.0" diff --git a/src/lib.rs b/src/lib.rs index b5e249a..8962e95 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -16,7 +16,7 @@ //! } //! //! fn setup(mut commands: Commands) { -//! commands.spawn((Camera3dBundle::default(), AtmosphereCamera::default())); +//! commands.spawn((Camera3d::default(), AtmosphereCamera::default())); //! } //! ``` //! diff --git a/src/plugin.rs b/src/plugin.rs index 0e07260..f53b2c5 100644 --- a/src/plugin.rs +++ b/src/plugin.rs @@ -109,17 +109,13 @@ fn atmosphere_insert( trace!("Adding skybox to camera entity (ID:{:?})", camera); commands .entity(camera) - .insert(VisibilityBundle { - visibility: Visibility::Visible, - ..default() - }) + .insert(( + Visibility::Visible, + )) .with_children(|c| { let mut child = c.spawn(( - MaterialMeshBundle { - mesh: mesh_assets.add(crate::skybox::mesh(projection.far())), - material: material.0.clone(), - ..default() - }, + Mesh3d(mesh_assets.add(crate::skybox::mesh(projection.far()))), + MeshMaterial3d(material.0.clone()), AtmosphereSkyBox, NotShadowCaster, NotShadowReceiver, From d1beae78624de9af4c65f27f70cfdc4d50561732 Mon Sep 17 00:00:00 2001 From: Patrick Dobbs Date: Fri, 6 Dec 2024 23:53:16 +0000 Subject: [PATCH 02/11] Deps: Move from bevy rc to release. Fix: Add `zero_initialize_workgroup_memory` to `ComputePipelineDescriptor` in `derive_atmospheric` macro. Fix: Invalid `[]` accessor in trace `pipeline::prepare_atmosphere_resources`. Add: Entry for `settings_trace` example with required features. --- Cargo.toml | 9 +++++++-- macros/Cargo.toml | 2 +- macros/src/model.rs | 1 + src/pipeline.rs | 18 ++++++++++++++---- 4 files changed, 23 insertions(+), 7 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 3528af2..1e9f882 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -11,7 +11,7 @@ repository = "https://github.com/JonahPlusPlus/bevy_atmosphere" exclude = ["/assets/", "/examples/", "/.github/"] [dependencies] -bevy = { version = "0.15.0-rc.3", default-features = false, features = [ +bevy = { version = "0.15", default-features = false, features = [ "bevy_asset", "bevy_render", "bevy_pbr", @@ -21,7 +21,7 @@ cfg-if = "1.0" [dev-dependencies] bevy_spectator = "0.7" -bevy = { version = "0.15.0-rc.3", features = ["bevy_core_pipeline", "x11"] } +bevy = { version = "0.15", features = ["bevy_core_pipeline", "x11"] } [features] default = ["basic", "all_models"] @@ -70,6 +70,11 @@ name = "settings" path = "examples/settings.rs" required-features = ["default"] +[[example]] +name = "settings_trace" +path = "examples/settings.rs" +required-features = ["default", "bevy/trace", "bevy/trace_chrome"] + [[example]] name = "splitscreen" path = "examples/splitscreen.rs" diff --git a/macros/Cargo.toml b/macros/Cargo.toml index c3f7e05..495dd95 100644 --- a/macros/Cargo.toml +++ b/macros/Cargo.toml @@ -15,7 +15,7 @@ proc-macro = true [dependencies] proc-macro-crate = "3.1" -bevy_macro_utils = "0.15.0-rc.3" +bevy_macro_utils = "0.15" syn = "2.0" proc-macro2 = "1.0" diff --git a/macros/src/model.rs b/macros/src/model.rs index c95ffac..0116449 100644 --- a/macros/src/model.rs +++ b/macros/src/model.rs @@ -467,6 +467,7 @@ pub fn derive_atmospheric(ast: syn::DeriveInput) -> Result { shader: handle, shader_defs: vec![], entry_point: Cow::from("main"), + zero_initialize_workgroup_memory: true, }); let id = TypeId::of::(); diff --git a/src/pipeline.rs b/src/pipeline.rs index 84cfad5..33bd6e4 100644 --- a/src/pipeline.rs +++ b/src/pipeline.rs @@ -341,10 +341,20 @@ fn prepare_atmosphere_resources( atmosphere_image.array_view = Some(view); update(); #[cfg(feature = "bevy/trace")] - trace!( - "Created new 2D array texture view from atmosphere texture of size {:?}", - &gpu_images[&atmosphere_image.handle].size - ); + { + if let Some(image) = gpu_images.get(&atmosphere_image.handle) { + trace!( + "Created new 2D array texture view from atmosphere texture of size {:?}", + image.size + ); + } else { + trace!( + "Failed to find gpu_image for {:?}", + &atmosphere_image.handle + ); + } + } + } if atmosphere.is_changed() { From 0b80291a7ab7d33602c35b7b3185cc5de5c2e9fa Mon Sep 17 00:00:00 2001 From: Hennadii Chernyshchyk Date: Sat, 7 Dec 2024 02:44:32 +0200 Subject: [PATCH 03/11] Adjust insertion --- src/plugin.rs | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/src/plugin.rs b/src/plugin.rs index f53b2c5..c15a103 100644 --- a/src/plugin.rs +++ b/src/plugin.rs @@ -109,9 +109,7 @@ fn atmosphere_insert( trace!("Adding skybox to camera entity (ID:{:?})", camera); commands .entity(camera) - .insert(( - Visibility::Visible, - )) + .insert(Visibility::Visible) .with_children(|c| { let mut child = c.spawn(( Mesh3d(mesh_assets.add(crate::skybox::mesh(projection.far()))), From aa5a5827fa98e280db54bb20a111029e8ec2803f Mon Sep 17 00:00:00 2001 From: Hennadii Chernyshchyk Date: Sat, 7 Dec 2024 02:44:38 +0200 Subject: [PATCH 04/11] Remove TODO --- Cargo.toml | 4 ---- 1 file changed, 4 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 1e9f882..3509cb9 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -79,7 +79,3 @@ required-features = ["default", "bevy/trace", "bevy/trace_chrome"] name = "splitscreen" path = "examples/splitscreen.rs" required-features = ["default"] - -[patch.crates-io] -# TODO: Temporary patch for dev-dep, remove when upstream updates -bevy_spectator = { git = "https://github.com/ptsd/bevy_spectator.git", branch = "bevy-0.15" } From a161aab608d249acfa5d2152fa5481a8a5dcdec3 Mon Sep 17 00:00:00 2001 From: Hennadii Chernyshchyk Date: Sat, 7 Dec 2024 02:51:26 +0200 Subject: [PATCH 05/11] Apply clippy suggestions --- src/system_param.rs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/system_param.rs b/src/system_param.rs index 5faa99b..f69ef9d 100644 --- a/src/system_param.rs +++ b/src/system_param.rs @@ -21,7 +21,7 @@ pub struct Atmosphere<'w, T: Atmospheric> { // SAFETY: Res only reads a single World resource unsafe impl ReadOnlySystemParam for Atmosphere<'_, T> {} -impl<'w, T: Atmospheric> Deref for Atmosphere<'w, T> { +impl Deref for Atmosphere<'_, T> { type Target = T; fn deref(&self) -> &Self::Target { @@ -63,7 +63,7 @@ pub struct AtmosphereMut<'w, T: Atmospheric> { value: &'w mut T, } -impl<'w, T: Atmospheric> Deref for AtmosphereMut<'w, T> { +impl Deref for AtmosphereMut<'_, T> { type Target = T; fn deref(&self) -> &Self::Target { @@ -71,7 +71,7 @@ impl<'w, T: Atmospheric> Deref for AtmosphereMut<'w, T> { } } -impl<'w, T: Atmospheric> DerefMut for AtmosphereMut<'w, T> { +impl DerefMut for AtmosphereMut<'_, T> { fn deref_mut(&mut self) -> &mut Self::Target { self.value } From ffcbe8daadcb88a174e283a9f414a131d35cf02c Mon Sep 17 00:00:00 2001 From: Hennadii Chernyshchyk Date: Sat, 7 Dec 2024 02:54:07 +0200 Subject: [PATCH 06/11] Always use trace since Bevy already enables it for rendering --- examples/settings.rs | 10 +--------- src/pipeline.rs | 29 ++++++++++------------------- src/plugin.rs | 3 --- 3 files changed, 11 insertions(+), 31 deletions(-) diff --git a/examples/settings.rs b/examples/settings.rs index f57db82..5876b30 100644 --- a/examples/settings.rs +++ b/examples/settings.rs @@ -16,11 +16,7 @@ fn main() { } fn setup(mut commands: Commands) { - commands.spawn(( - Camera3d::default(), - AtmosphereCamera::default(), - Spectator, - )); + commands.spawn((Camera3d::default(), AtmosphereCamera::default(), Spectator)); } // Change the resolution when the user presses a number key @@ -30,8 +26,6 @@ fn change_resolution( keys: Res>, ) { if keys.just_pressed(KeyCode::Space) { - #[cfg(feature = "bevy/trace")] - // enabling "bevy/trace" (via "bevy/trace_chrome" or "bevy/trace_tracy") allows you to debug bevy_atmosphere let _change_dithering_executed_span = info_span!("executed", name = "settings::change_dithering").entered(); if let Some(mut settings) = settings { @@ -69,8 +63,6 @@ fn change_resolution( // A separate `change` fn makes it easier to debug in tracy. fn change(mut commands: Commands, settings: Option>, resolution: u32) { - #[cfg(feature = "bevy/trace")] - // enabling "bevy/trace" (via "bevy/trace_chrome" or "bevy/trace_tracy") allows you to debug bevy_atmosphere let _change_resolution_executed_span = info_span!("executed", name = "settings::change_resolution").entered(); if let Some(mut settings) = settings { diff --git a/src/pipeline.rs b/src/pipeline.rs index 33bd6e4..c18eeee 100644 --- a/src/pipeline.rs +++ b/src/pipeline.rs @@ -165,7 +165,6 @@ fn atmosphere_settings_changed( ) { if let Some(settings) = settings { if settings.is_changed() { - #[cfg(feature = "bevy/trace")] let _atmosphere_settings_changed_executed_span = info_span!( "executed", name = "bevy_atmosphere::pipeline::atmosphere_settings_changed" @@ -186,14 +185,12 @@ fn atmosphere_settings_changed( skybox_material.dithering = settings.dithering; } atmosphere_image.array_view = None; // drop the previous texture view - #[cfg(feature = "bevy/trace")] trace!("Resized image to {:?}", size); } } *settings_existed = true; } else { if *settings_existed { - #[cfg(feature = "bevy/trace")] let _atmosphere_settings_changed_executed_span = info_span!( "executed", name = "bevy_atmosphere::pipeline::atmosphere_settings_changed" @@ -212,7 +209,6 @@ fn atmosphere_settings_changed( image.resize(size); let _ = material_assets.get_mut(&material.0); // `get_mut` tells the material to update atmosphere_image.array_view = None; // drop the previous texture view - #[cfg(feature = "bevy/trace")] trace!("Resized image to {:?}", size); } } @@ -330,7 +326,6 @@ fn prepare_atmosphere_resources( let mut update = || update_events.send(AtmosphereUpdateEvent); if atmosphere_image.array_view.is_none() { - #[cfg(feature = "bevy/trace")] let _prepare_atmosphere_assets_executed_span = info_span!( "executed", name = "bevy_atmosphere::pipeline::prepare_atmosphere_assets" @@ -340,21 +335,17 @@ fn prepare_atmosphere_resources( let view = texture.create_view(&ATMOSPHERE_ARRAY_TEXTURE_VIEW_DESCRIPTOR); atmosphere_image.array_view = Some(view); update(); - #[cfg(feature = "bevy/trace")] - { - if let Some(image) = gpu_images.get(&atmosphere_image.handle) { - trace!( - "Created new 2D array texture view from atmosphere texture of size {:?}", - image.size - ); - } else { - trace!( - "Failed to find gpu_image for {:?}", - &atmosphere_image.handle - ); - } + if let Some(image) = gpu_images.get(&atmosphere_image.handle) { + trace!( + "Created new 2D array texture view from atmosphere texture of size {:?}", + image.size + ); + } else { + trace!( + "Failed to find gpu_image for {:?}", + &atmosphere_image.handle + ); } - } if atmosphere.is_changed() { diff --git a/src/plugin.rs b/src/plugin.rs index c15a103..c7c5242 100644 --- a/src/plugin.rs +++ b/src/plugin.rs @@ -105,7 +105,6 @@ fn atmosphere_insert( atmosphere_cameras: Query<(Entity, &Projection, &AtmosphereCamera), Added>, ) { for (camera, projection, atmosphere_camera) in &atmosphere_cameras { - #[cfg(feature = "bevy/trace")] trace!("Adding skybox to camera entity (ID:{:?})", camera); commands .entity(camera) @@ -138,7 +137,6 @@ fn atmosphere_remove( mut atmosphere_cameras: RemovedComponents, ) { for camera in &mut atmosphere_cameras.read() { - #[cfg(feature = "bevy/trace")] trace!("Removing skybox from camera entity (ID:{:?})", camera); let Ok(children) = parents.get(camera) else { error!("Failed to get skybox children entities from camera entity."); @@ -147,7 +145,6 @@ fn atmosphere_remove( for child in children { let Ok(skybox_entity) = atmosphere_skyboxes.get(*child) else { - #[cfg(feature = "bevy/trace")] trace!("Child wasn't found in skybox entities."); continue; }; From b3c41e5b8e583612a3796026fc8e2422b26205fb Mon Sep 17 00:00:00 2001 From: Hennadii Chernyshchyk Date: Sat, 7 Dec 2024 02:54:29 +0200 Subject: [PATCH 07/11] Apply formatting --- examples/gradient.rs | 6 +----- examples/models.rs | 6 +----- examples/nishita.rs | 6 +----- examples/splitscreen.rs | 2 +- 4 files changed, 4 insertions(+), 16 deletions(-) diff --git a/examples/gradient.rs b/examples/gradient.rs index 5debb9e..4addfd7 100644 --- a/examples/gradient.rs +++ b/examples/gradient.rs @@ -14,11 +14,7 @@ fn main() { } fn setup(mut commands: Commands) { - commands.spawn(( - Camera3d::default(), - AtmosphereCamera::default(), - Spectator, - )); + commands.spawn((Camera3d::default(), AtmosphereCamera::default(), Spectator)); } fn change_gradient(mut commands: Commands, keys: Res>) { diff --git a/examples/models.rs b/examples/models.rs index f43930e..4e0fab5 100644 --- a/examples/models.rs +++ b/examples/models.rs @@ -13,11 +13,7 @@ fn main() { } fn setup(mut commands: Commands) { - commands.spawn(( - Camera3d::default(), - AtmosphereCamera::default(), - Spectator, - )); + commands.spawn((Camera3d::default(), AtmosphereCamera::default(), Spectator)); } fn change_model(mut commands: Commands, keys: Res>) { diff --git a/examples/nishita.rs b/examples/nishita.rs index e64888b..1e4b4bb 100644 --- a/examples/nishita.rs +++ b/examples/nishita.rs @@ -12,11 +12,7 @@ fn main() { } fn setup(mut commands: Commands) { - commands.spawn(( - Camera3d::default(), - AtmosphereCamera::default(), - Spectator, - )); + commands.spawn((Camera3d::default(), AtmosphereCamera::default(), Spectator)); } fn change_nishita(mut commands: Commands, keys: Res>) { diff --git a/examples/splitscreen.rs b/examples/splitscreen.rs index ed5de38..41d797d 100644 --- a/examples/splitscreen.rs +++ b/examples/splitscreen.rs @@ -51,7 +51,7 @@ fn setup( 0.0, 1.0, -std::f32::consts::FRAC_PI_4, - )) + )), )); // Spawn left screen camera and make it the default spectator From eaa11307cec35fa51dcf5a0e34d3a650fb6e0c35 Mon Sep 17 00:00:00 2001 From: Hennadii Chernyshchyk Date: Sat, 7 Dec 2024 02:59:23 +0200 Subject: [PATCH 08/11] Enable png --- Cargo.toml | 1 + 1 file changed, 1 insertion(+) diff --git a/Cargo.toml b/Cargo.toml index 3509cb9..2d7e15e 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -15,6 +15,7 @@ bevy = { version = "0.15", default-features = false, features = [ "bevy_asset", "bevy_render", "bevy_pbr", + "png", # Enable temporary due to 0.15 bug: https://github.com/bevyengine/bevy/issues/16563 ] } bevy_atmosphere_macros = { path = "macros", version = "0.7" } cfg-if = "1.0" From 63e7dde209815e20e3ae46eb7d7b6337bfedeb1f Mon Sep 17 00:00:00 2001 From: Hennadii Chernyshchyk Date: Sat, 7 Dec 2024 03:00:34 +0200 Subject: [PATCH 09/11] Remove tracing example --- Cargo.toml | 5 ----- 1 file changed, 5 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 2d7e15e..29958ba 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -71,11 +71,6 @@ name = "settings" path = "examples/settings.rs" required-features = ["default"] -[[example]] -name = "settings_trace" -path = "examples/settings.rs" -required-features = ["default", "bevy/trace", "bevy/trace_chrome"] - [[example]] name = "splitscreen" path = "examples/splitscreen.rs" From 7e15091ffd47a46f1da9b83d1ba47fb3c8771f72 Mon Sep 17 00:00:00 2001 From: Hennadii Chernyshchyk Date: Sat, 7 Dec 2024 03:04:39 +0200 Subject: [PATCH 10/11] Update deny.toml --- deny.toml | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/deny.toml b/deny.toml index 0c89c3f..b529b5a 100644 --- a/deny.toml +++ b/deny.toml @@ -1,11 +1,16 @@ -[advisories] -unmaintained = "deny" -yanked = "deny" -notice = "deny" - [licenses] -copyleft = "deny" -allow-osi-fsf-free = "either" +allow = [ + "Apache-2.0", + "BSD-2-Clause", + "BSD-3-Clause", + "BSL-1.0", + "CC0-1.0", + "ISC", + "MIT-0", + "MIT", + "Unicode-3.0", + "Zlib", +] [[licenses.clarify]] name = "stretch" From c247480ced8cdfa3d0e77fb128c6213e0c542e53 Mon Sep 17 00:00:00 2001 From: Hennadii Chernyshchyk Date: Sat, 7 Dec 2024 03:04:58 +0200 Subject: [PATCH 11/11] Format Cargo.toml --- Cargo.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Cargo.toml b/Cargo.toml index 29958ba..7cbdff3 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -15,7 +15,7 @@ bevy = { version = "0.15", default-features = false, features = [ "bevy_asset", "bevy_render", "bevy_pbr", - "png", # Enable temporary due to 0.15 bug: https://github.com/bevyengine/bevy/issues/16563 + "png", # Enable temporary due to 0.15 bug: https://github.com/bevyengine/bevy/issues/16563 ] } bevy_atmosphere_macros = { path = "macros", version = "0.7" } cfg-if = "1.0"