Introduce feature flags to enable iced_glow

Also keep `iced_wgpu` as the default renderer for the time being.
This commit is contained in:
Héctor Ramón Jiménez 2020-05-27 05:05:13 +02:00
parent d6bf8955db
commit 22ced3485e
8 changed files with 72 additions and 35 deletions

View File

@ -12,14 +12,21 @@ keywords = ["gui", "ui", "graphics", "interface", "widgets"]
categories = ["gui"] categories = ["gui"]
[features] [features]
default = ["wgpu"]
# Enables the `iced_wgpu` renderer
wgpu = ["iced_wgpu"]
# Enables the `Image` widget # Enables the `Image` widget
image = ["iced_glow/image"] image = ["iced_wgpu/image"]
# Enables the `Svg` widget # Enables the `Svg` widget
svg = ["iced_glow/svg"] svg = ["iced_wgpu/svg"]
# Enables the `Canvas` widget # Enables the `Canvas` widget
canvas = ["iced_glow/canvas"] canvas = ["iced_wgpu/canvas"]
# Enables the `iced_glow` renderer. Overrides `iced_wgpu`
glow = ["iced_glow", "iced_glutin"]
# Enables the `Canvas` widget for `iced_glow`
glow_canvas = ["iced_glow/canvas"]
# Enables a debug view in native platforms (press F12) # Enables a debug view in native platforms (press F12)
debug = ["iced_glutin/debug"] debug = ["iced_winit/debug"]
# Enables `tokio` as the `executor::Default` on native platforms # Enables `tokio` as the `executor::Default` on native platforms
tokio = ["iced_futures/tokio"] tokio = ["iced_futures/tokio"]
# Enables `async-std` as the `executor::Default` on native platforms # Enables `async-std` as the `executor::Default` on native platforms
@ -68,8 +75,10 @@ iced_core = { version = "0.2", path = "core" }
iced_futures = { version = "0.1", path = "futures" } iced_futures = { version = "0.1", path = "futures" }
[target.'cfg(not(target_arch = "wasm32"))'.dependencies] [target.'cfg(not(target_arch = "wasm32"))'.dependencies]
iced_glutin = { version = "0.1", path = "glutin" } iced_winit = { version = "0.1", path = "winit" }
iced_glow = { version = "0.1", path = "glow" } iced_glutin = { version = "0.1", path = "glutin", optional = true }
iced_wgpu = { version = "0.2", path = "wgpu", optional = true }
iced_glow = { version = "0.1", path = "glow", optional = true}
[target.'cfg(target_arch = "wasm32")'.dependencies] [target.'cfg(target_arch = "wasm32")'.dependencies]
iced_web = { version = "0.2", path = "web" } iced_web = { version = "0.2", path = "web" }

View File

@ -9,6 +9,7 @@ repository = "https://github.com/hecrj/iced"
[features] [features]
canvas = ["iced_graphics/canvas"] canvas = ["iced_graphics/canvas"]
# Not supported yet!
image = [] image = []
svg = [] svg = []

View File

@ -188,21 +188,21 @@ pub trait Application: Sized {
{ {
#[cfg(not(target_arch = "wasm32"))] #[cfg(not(target_arch = "wasm32"))]
{ {
let glow_settings = iced_glow::Settings { let renderer_settings = crate::renderer::Settings {
default_font: settings.default_font, default_font: settings.default_font,
antialiasing: if settings.antialiasing { antialiasing: if settings.antialiasing {
Some(iced_glow::settings::Antialiasing::MSAAx4) Some(crate::renderer::settings::Antialiasing::MSAAx4)
} else { } else {
None None
}, },
..iced_glow::Settings::default() ..crate::renderer::Settings::default()
}; };
iced_glutin::application::run::< crate::runtime::application::run::<
Instance<Self>, Instance<Self>,
Self::Executor, Self::Executor,
iced_glow::window::Compositor, crate::renderer::window::Compositor,
>(settings.into(), glow_settings); >(settings.into(), renderer_settings);
} }
#[cfg(target_arch = "wasm32")] #[cfg(target_arch = "wasm32")]
@ -213,11 +213,11 @@ pub trait Application: Sized {
struct Instance<A: Application>(A); struct Instance<A: Application>(A);
#[cfg(not(target_arch = "wasm32"))] #[cfg(not(target_arch = "wasm32"))]
impl<A> iced_glutin::Program for Instance<A> impl<A> iced_winit::Program for Instance<A>
where where
A: Application, A: Application,
{ {
type Renderer = iced_glow::Renderer; type Renderer = crate::renderer::Renderer;
type Message = A::Message; type Message = A::Message;
fn update(&mut self, message: Self::Message) -> Command<Self::Message> { fn update(&mut self, message: Self::Message) -> Command<Self::Message> {
@ -230,7 +230,7 @@ where
} }
#[cfg(not(target_arch = "wasm32"))] #[cfg(not(target_arch = "wasm32"))]
impl<A> iced_glutin::Application for Instance<A> impl<A> crate::runtime::Application for Instance<A>
where where
A: Application, A: Application,
{ {
@ -246,10 +246,10 @@ where
self.0.title() self.0.title()
} }
fn mode(&self) -> iced_glutin::Mode { fn mode(&self) -> iced_winit::Mode {
match self.0.mode() { match self.0.mode() {
window::Mode::Windowed => iced_glutin::Mode::Windowed, window::Mode::Windowed => iced_winit::Mode::Windowed,
window::Mode::Fullscreen => iced_glutin::Mode::Fullscreen, window::Mode::Fullscreen => iced_winit::Mode::Fullscreen,
} }
} }

View File

@ -3,7 +3,7 @@
/// This is an alias of an `iced_native` element with a default `Renderer`. /// This is an alias of an `iced_native` element with a default `Renderer`.
#[cfg(not(target_arch = "wasm32"))] #[cfg(not(target_arch = "wasm32"))]
pub type Element<'a, Message> = pub type Element<'a, Message> =
iced_glutin::Element<'a, Message, iced_glow::Renderer>; crate::runtime::Element<'a, Message, crate::renderer::Renderer>;
#[cfg(target_arch = "wasm32")] #[cfg(target_arch = "wasm32")]
pub use iced_web::Element; pub use iced_web::Element;

View File

@ -197,6 +197,29 @@ pub mod window;
#[cfg_attr(docsrs, doc(cfg(any(feature = "tokio", feature = "async-std"))))] #[cfg_attr(docsrs, doc(cfg(any(feature = "tokio", feature = "async-std"))))]
pub mod time; pub mod time;
#[cfg(all(
not(target_arch = "wasm32"),
not(feature = "glow"),
feature = "wgpu"
))]
use iced_winit as runtime;
#[cfg(all(not(target_arch = "wasm32"), feature = "glow"))]
use iced_glutin as runtime;
#[cfg(all(
not(target_arch = "wasm32"),
not(feature = "glow"),
feature = "wgpu"
))]
use iced_wgpu as renderer;
#[cfg(all(not(target_arch = "wasm32"), feature = "glow"))]
use iced_glow as renderer;
#[cfg(target_arch = "wasm32")]
use iced_web as runtime;
#[doc(no_inline)] #[doc(no_inline)]
pub use widget::*; pub use widget::*;
@ -206,12 +229,6 @@ pub use executor::Executor;
pub use sandbox::Sandbox; pub use sandbox::Sandbox;
pub use settings::Settings; pub use settings::Settings;
#[cfg(not(target_arch = "wasm32"))]
use iced_glutin as runtime;
#[cfg(target_arch = "wasm32")]
use iced_web as runtime;
pub use runtime::{ pub use runtime::{
futures, Align, Background, Color, Command, Font, HorizontalAlignment, futures, Align, Background, Color, Command, Font, HorizontalAlignment,
Length, Point, Rectangle, Size, Subscription, Vector, VerticalAlignment, Length, Point, Rectangle, Size, Subscription, Vector, VerticalAlignment,

View File

@ -51,10 +51,10 @@ impl<Flags> Settings<Flags> {
} }
#[cfg(not(target_arch = "wasm32"))] #[cfg(not(target_arch = "wasm32"))]
impl<Flags> From<Settings<Flags>> for iced_glutin::Settings<Flags> { impl<Flags> From<Settings<Flags>> for iced_winit::Settings<Flags> {
fn from(settings: Settings<Flags>) -> iced_glutin::Settings<Flags> { fn from(settings: Settings<Flags>) -> iced_winit::Settings<Flags> {
iced_glutin::Settings { iced_winit::Settings {
window: iced_glutin::settings::Window { window: iced_winit::settings::Window {
size: settings.window.size, size: settings.window.size,
resizable: settings.window.resizable, resizable: settings.window.resizable,
decorations: settings.window.decorations, decorations: settings.window.decorations,

View File

@ -18,25 +18,28 @@
//! [`text_input::State`]: text_input/struct.State.html //! [`text_input::State`]: text_input/struct.State.html
#[cfg(not(target_arch = "wasm32"))] #[cfg(not(target_arch = "wasm32"))]
mod platform { mod platform {
pub use iced_glow::widget::{ pub use crate::renderer::widget::{
button, checkbox, container, pane_grid, progress_bar, radio, button, checkbox, container, pane_grid, progress_bar, radio,
scrollable, slider, text_input, Column, Row, Space, Text, scrollable, slider, text_input, Column, Row, Space, Text,
}; };
#[cfg(feature = "canvas")] #[cfg(any(feature = "canvas", feature = "glow_canvas"))]
#[cfg_attr(docsrs, doc(cfg(feature = "canvas")))] #[cfg_attr(
pub use iced_glow::widget::canvas; docsrs,
doc(cfg(any(feature = "canvas", feature = "glow_canvas")))
)]
pub use crate::renderer::widget::canvas;
#[cfg_attr(docsrs, doc(cfg(feature = "image")))] #[cfg_attr(docsrs, doc(cfg(feature = "image")))]
pub mod image { pub mod image {
//! Display images in your user interface. //! Display images in your user interface.
pub use iced_glutin::image::{Handle, Image}; pub use crate::runtime::image::{Handle, Image};
} }
#[cfg_attr(docsrs, doc(cfg(feature = "svg")))] #[cfg_attr(docsrs, doc(cfg(feature = "svg")))]
pub mod svg { pub mod svg {
//! Display vector graphics in your user interface. //! Display vector graphics in your user interface.
pub use iced_glutin::svg::{Handle, Svg}; pub use crate::runtime::svg::{Handle, Svg};
} }
#[doc(no_inline)] #[doc(no_inline)]

View File

@ -7,6 +7,8 @@
//! ``` //! ```
//! use iced_wgpu::{button, Button}; //! use iced_wgpu::{button, Button};
//! ``` //! ```
use crate::Renderer;
pub mod button; pub mod button;
pub mod checkbox; pub mod checkbox;
pub mod container; pub mod container;
@ -47,3 +49,8 @@ pub mod canvas;
#[cfg(feature = "canvas")] #[cfg(feature = "canvas")]
#[doc(no_inline)] #[doc(no_inline)]
pub use canvas::Canvas; pub use canvas::Canvas;
pub use iced_native::Space;
pub type Column<'a, Message> = iced_native::Column<'a, Message, Renderer>;
pub type Row<'a, Message> = iced_native::Row<'a, Message, Renderer>;