Skip to content

Commit

Permalink
Move the configuration of the WindowPlugin to a resource (bevyengine#…
Browse files Browse the repository at this point in the history
…5227)

# Objective

It is currently hard to configure the `WindowPlugin`, as it is added as part of the `DefaultPlugins`. Ideally this should not be difficult.

## Solution

Remove the configuration from the plugin itself and put it as a `Resource`, similar to how it is done for almost all other plugins.

## Migration Guide

If you are currently configuring the behavior of the `WindowPlugin`, by constructing it manually, then you will need to instead create add the `WindowSettings` as a resource.
  • Loading branch information
TethysSvensson authored and inodentry committed Aug 8, 2022
1 parent 9106e0d commit c408dd4
Showing 1 changed file with 22 additions and 8 deletions.
30 changes: 22 additions & 8 deletions crates/bevy_window/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,12 @@ pub mod prelude {
use bevy_app::prelude::*;
use bevy_ecs::{event::Events, schedule::SystemLabel};

/// A [`Plugin`] that defines an interface for windowing support in Bevy.
pub struct WindowPlugin {
/// The configuration information for the [`WindowPlugin`].
///
/// It can be added as a [`Resource`](bevy_ecs::system::Resource) before the [`WindowPlugin`]
/// runs, to configure how it behaves.
#[derive(Clone)]
pub struct WindowSettings {
/// Whether to create a window when added.
///
/// Note that if there are no windows, by default the App will exit,
Expand All @@ -49,16 +53,20 @@ pub struct WindowPlugin {
pub close_when_requested: bool,
}

impl Default for WindowPlugin {
impl Default for WindowSettings {
fn default() -> Self {
WindowPlugin {
WindowSettings {
add_primary_window: true,
exit_on_all_closed: true,
close_when_requested: true,
}
}
}

/// A [`Plugin`] that defines an interface for windowing support in Bevy.
#[derive(Default)]
pub struct WindowPlugin;

impl Plugin for WindowPlugin {
fn build(&self, app: &mut App) {
app.add_event::<WindowResized>()
Expand All @@ -78,11 +86,17 @@ impl Plugin for WindowPlugin {
.add_event::<WindowMoved>()
.init_resource::<Windows>();

if self.add_primary_window {
let settings = app
.world
.get_resource::<WindowSettings>()
.cloned()
.unwrap_or_default();

if settings.add_primary_window {
let window_descriptor = app
.world
.get_resource::<WindowDescriptor>()
.map(|descriptor| (*descriptor).clone())
.cloned()
.unwrap_or_default();
let mut create_window_event = app.world.resource_mut::<Events<CreateWindow>>();
create_window_event.send(CreateWindow {
Expand All @@ -91,10 +105,10 @@ impl Plugin for WindowPlugin {
});
}

if self.exit_on_all_closed {
if settings.exit_on_all_closed {
app.add_system(exit_on_all_closed);
}
if self.close_when_requested {
if settings.close_when_requested {
app.add_system(close_when_requested);
}
}
Expand Down

0 comments on commit c408dd4

Please sign in to comment.