From ac5590e9786b616da9e7bf5c5f6bd7a747dc1df9 Mon Sep 17 00:00:00 2001 From: Jakob Hellermann Date: Tue, 23 Aug 2022 17:41:39 +0000 Subject: [PATCH] register missing reflect types (#5747) # Objective - While generating https://github.com/jakobhellermann/bevy_reflect_ts_type_export/blob/main/generated/types.ts, I noticed that some types that implement `Reflect` did not register themselves - `Viewport` isn't reflect but can be (there's a TODO) ## Solution - register all reflected types - derive `Reflect` for `Viewport` ## Changelog - more types are not registered in the type registry - remove `Serialize`, `Deserialize` impls from `Viewport` I also decided to remove the `Serialize, Deserialize` from the `Viewport`, since they were (AFAIK) only used for reflection, which now is done without serde. So this is technically a breaking change for people who relied on that impl directly. Personally I don't think that every bevy type should implement `Serialize, Deserialize`, as that would lead to a ton of code generation that mostly isn't necessary because we can do the same with `Reflect`, but if this is deemed controversial I can remove it from this PR. ## Migration Guide - `KeyCode` now implements `Reflect` not as `reflect_value`, but with proper struct reflection. The `Serialize` and `Deserialize` impls were removed, now that they are no longer required for scene serialization. --- crates/bevy_core/src/lib.rs | 6 ++++-- crates/bevy_core_pipeline/src/core_3d/mod.rs | 1 + crates/bevy_core_pipeline/src/lib.rs | 7 ++++++- crates/bevy_input/Cargo.toml | 1 + crates/bevy_render/src/camera/camera.rs | 6 ++---- crates/bevy_render/src/camera/mod.rs | 1 + crates/bevy_sprite/src/lib.rs | 1 + crates/bevy_text/src/lib.rs | 2 ++ crates/bevy_time/src/lib.rs | 2 ++ 9 files changed, 20 insertions(+), 7 deletions(-) diff --git a/crates/bevy_core/src/lib.rs b/crates/bevy_core/src/lib.rs index 527332ab97def3..bd4b54d4cef27c 100644 --- a/crates/bevy_core/src/lib.rs +++ b/crates/bevy_core/src/lib.rs @@ -16,7 +16,7 @@ pub mod prelude { use bevy_app::prelude::*; use bevy_ecs::entity::Entity; -use bevy_utils::HashSet; +use bevy_utils::{Duration, HashSet, Instant}; use std::borrow::Cow; use std::ops::Range; @@ -45,7 +45,9 @@ fn register_rust_types(app: &mut App) { .register_type::() .register_type::>() .register_type::>() - .register_type::>(); + .register_type::>() + .register_type::() + .register_type::(); } fn register_math_types(app: &mut App) { diff --git a/crates/bevy_core_pipeline/src/core_3d/mod.rs b/crates/bevy_core_pipeline/src/core_3d/mod.rs index c69e8104dc15fd..a78528b46f0f5b 100644 --- a/crates/bevy_core_pipeline/src/core_3d/mod.rs +++ b/crates/bevy_core_pipeline/src/core_3d/mod.rs @@ -43,6 +43,7 @@ pub struct Core3dPlugin; impl Plugin for Core3dPlugin { fn build(&self, app: &mut App) { app.register_type::() + .register_type::() .add_plugin(ExtractComponentPlugin::::default()); let render_app = match app.get_sub_app_mut(RenderApp) { diff --git a/crates/bevy_core_pipeline/src/lib.rs b/crates/bevy_core_pipeline/src/lib.rs index 28304608e76615..0cc46286148d81 100644 --- a/crates/bevy_core_pipeline/src/lib.rs +++ b/crates/bevy_core_pipeline/src/lib.rs @@ -11,7 +11,11 @@ pub mod prelude { }; } -use crate::{clear_color::ClearColor, core_2d::Core2dPlugin, core_3d::Core3dPlugin}; +use crate::{ + clear_color::{ClearColor, ClearColorConfig}, + core_2d::Core2dPlugin, + core_3d::Core3dPlugin, +}; use bevy_app::{App, Plugin}; use bevy_render::extract_resource::ExtractResourcePlugin; @@ -21,6 +25,7 @@ pub struct CorePipelinePlugin; impl Plugin for CorePipelinePlugin { fn build(&self, app: &mut App) { app.register_type::() + .register_type::() .init_resource::() .add_plugin(ExtractResourcePlugin::::default()) .add_plugin(Core2dPlugin) diff --git a/crates/bevy_input/Cargo.toml b/crates/bevy_input/Cargo.toml index 3fc8b049fb2412..e3f500db46e099 100644 --- a/crates/bevy_input/Cargo.toml +++ b/crates/bevy_input/Cargo.toml @@ -18,6 +18,7 @@ bevy_app = { path = "../bevy_app", version = "0.9.0-dev" } bevy_ecs = { path = "../bevy_ecs", version = "0.9.0-dev" } bevy_math = { path = "../bevy_math", version = "0.9.0-dev" } bevy_utils = { path = "../bevy_utils", version = "0.9.0-dev" } +bevy_reflect = { path = "../bevy_reflect", version = "0.9.0-dev" } # other serde = { version = "1", features = ["derive"], optional = true } diff --git a/crates/bevy_render/src/camera/camera.rs b/crates/bevy_render/src/camera/camera.rs index 0bfd3c5a7de039..30fd1651f21450 100644 --- a/crates/bevy_render/src/camera/camera.rs +++ b/crates/bevy_render/src/camera/camera.rs @@ -23,7 +23,6 @@ use bevy_reflect::FromReflect; use bevy_transform::components::GlobalTransform; use bevy_utils::HashSet; use bevy_window::{WindowCreated, WindowId, WindowResized, Windows}; -use serde::{Deserialize, Serialize}; use std::{borrow::Cow, ops::Range}; use wgpu::Extent3d; @@ -32,9 +31,8 @@ use wgpu::Extent3d; /// The viewport defines the area on the render target to which the camera renders its image. /// You can overlay multiple cameras in a single window using viewports to create effects like /// split screen, minimaps, and character viewers. -// TODO: remove reflect_value when possible -#[derive(Reflect, FromReflect, Debug, Clone, Serialize, Deserialize)] -#[reflect_value(Default, Serialize, Deserialize)] +#[derive(Reflect, FromReflect, Debug, Clone)] +#[reflect(Default)] pub struct Viewport { /// The physical position to render this viewport to within the [`RenderTarget`] of this [`Camera`]. /// (0,0) corresponds to the top-left corner diff --git a/crates/bevy_render/src/camera/mod.rs b/crates/bevy_render/src/camera/mod.rs index 6004bb9cb7fe30..fbaed28a8f3aee 100644 --- a/crates/bevy_render/src/camera/mod.rs +++ b/crates/bevy_render/src/camera/mod.rs @@ -21,6 +21,7 @@ pub struct CameraPlugin; impl Plugin for CameraPlugin { fn build(&self, app: &mut App) { app.register_type::() + .register_type::() .register_type::() .register_type::() .register_type::() diff --git a/crates/bevy_sprite/src/lib.rs b/crates/bevy_sprite/src/lib.rs index a7be1a4ab983bc..bf0da021b8941a 100644 --- a/crates/bevy_sprite/src/lib.rs +++ b/crates/bevy_sprite/src/lib.rs @@ -57,6 +57,7 @@ impl Plugin for SpritePlugin { shaders.set_untracked(SPRITE_SHADER_HANDLE, sprite_shader); app.add_asset::() .register_type::() + .register_type::() .register_type::() .add_plugin(Mesh2dRenderPlugin) .add_plugin(ColorMaterialPlugin); diff --git a/crates/bevy_text/src/lib.rs b/crates/bevy_text/src/lib.rs index 4dc1fc3b34070c..36d727d408ae9a 100644 --- a/crates/bevy_text/src/lib.rs +++ b/crates/bevy_text/src/lib.rs @@ -43,6 +43,8 @@ impl Plugin for TextPlugin { app.add_asset::() .add_asset::() .register_type::() + .register_type::() + .register_type::() .register_type::() .register_type::() .init_asset_loader::() diff --git a/crates/bevy_time/src/lib.rs b/crates/bevy_time/src/lib.rs index 7da0e54a07f75e..018a760793c473 100644 --- a/crates/bevy_time/src/lib.rs +++ b/crates/bevy_time/src/lib.rs @@ -36,6 +36,8 @@ impl Plugin for TimePlugin { app.init_resource::