diff options
| author | 2024-03-25 21:36:44 +0100 | |
|---|---|---|
| committer | 2024-03-25 21:36:44 +0100 | |
| commit | a2a8381a49ac2dd1cd65eb382b9ee02bbfa17286 (patch) | |
| tree | e6c24928a42e23ff91eea0fc30b4fbbcb6da024b /tiny_skia/src/window | |
| parent | 3013463baa71504488a20436beb3db87ecb66df0 (diff) | |
| parent | 6a4f5ac2081699f7cf20c917b367366ab49eeef1 (diff) | |
| download | iced-a2a8381a49ac2dd1cd65eb382b9ee02bbfa17286.tar.gz iced-a2a8381a49ac2dd1cd65eb382b9ee02bbfa17286.tar.bz2 iced-a2a8381a49ac2dd1cd65eb382b9ee02bbfa17286.zip | |
Merge pull request #2351 from iced-rs/custom-renderer-injection
Type-Driven Renderer Fallback
Diffstat (limited to 'tiny_skia/src/window')
| -rw-r--r-- | tiny_skia/src/window/compositor.rs | 24 | 
1 files changed, 17 insertions, 7 deletions
| diff --git a/tiny_skia/src/window/compositor.rs b/tiny_skia/src/window/compositor.rs index a98825f1..25c57dc1 100644 --- a/tiny_skia/src/window/compositor.rs +++ b/tiny_skia/src/window/compositor.rs @@ -1,11 +1,11 @@  use crate::core::{Color, Rectangle, Size};  use crate::graphics::compositor::{self, Information};  use crate::graphics::damage; -use crate::graphics::{Error, Viewport}; +use crate::graphics::error::{self, Error}; +use crate::graphics::{self, Viewport};  use crate::{Backend, Primitive, Renderer, Settings};  use std::collections::VecDeque; -use std::future::{self, Future};  use std::num::NonZeroU32;  pub struct Compositor { @@ -25,15 +25,25 @@ pub struct Surface {  }  impl crate::graphics::Compositor for Compositor { -    type Settings = Settings;      type Renderer = Renderer;      type Surface = Surface; -    fn new<W: compositor::Window>( -        settings: Self::Settings, +    async fn with_backend<W: compositor::Window>( +        settings: graphics::Settings,          compatible_window: W, -    ) -> impl Future<Output = Result<Self, Error>> { -        future::ready(Ok(new(settings, compatible_window))) +        backend: Option<&str>, +    ) -> Result<Self, Error> { +        match backend { +            None | Some("tiny-skia") | Some("tiny_skia") => { +                Ok(new(settings.into(), compatible_window)) +            } +            Some(backend) => Err(Error::GraphicsAdapterNotFound { +                backend: "tiny-skia", +                reason: error::Reason::DidNotMatch { +                    preferred_backend: backend.to_owned(), +                }, +            }), +        }      }      fn create_renderer(&self) -> Self::Renderer { | 
