#![allow(missing_docs)] use crate::runtime::futures; use iced_program as program; use iced_widget::core; use iced_widget::runtime; use crate::core::Element; use crate::core::theme; use crate::core::window; use crate::futures::Subscription; use crate::program::Program; use crate::runtime::Task; use std::fmt; pub fn attach(program: impl Program + 'static) -> impl Program { struct Attach

{ program: P, } impl

Program for Attach

where P: Program + 'static, { type State = DevTools

; type Message = Message

; type Theme = P::Theme; type Renderer = P::Renderer; type Executor = P::Executor; fn name() -> &'static str { P::name() } fn boot(&self) -> (Self::State, Task) { let (state, task) = self.program.boot(); (DevTools { state }, task.map(Message::Program)) } fn update( &self, state: &mut Self::State, message: Self::Message, ) -> Task { state.update(&self.program, message) } fn view<'a>( &self, state: &'a Self::State, window: window::Id, ) -> Element<'a, Self::Message, Self::Theme, Self::Renderer> { state.view(&self.program, window) } fn title(&self, state: &Self::State, window: window::Id) -> String { state.title(&self.program, window) } fn subscription( &self, state: &Self::State, ) -> runtime::futures::Subscription { state.subscription(&self.program) } fn theme( &self, state: &Self::State, window: window::Id, ) -> Self::Theme { state.theme(&self.program, window) } fn style( &self, state: &Self::State, theme: &Self::Theme, ) -> theme::Style { state.style(&self.program, theme) } fn scale_factor(&self, state: &Self::State, window: window::Id) -> f64 { state.scale_factor(&self.program, window) } } Attach { program } } struct DevTools

where P: Program, { state: P::State, } impl

DevTools

where P: Program + 'static, { pub fn title(&self, program: &P, window: window::Id) -> String { program.title(&self.state, window) } pub fn update( &mut self, program: &P, message: Message

, ) -> Task> { match message { Message::Program(message) => program .update(&mut self.state, message) .map(Message::Program), } } pub fn view( &self, program: &P, window: window::Id, ) -> Element<'_, Message

, P::Theme, P::Renderer> { program.view(&self.state, window).map(Message::Program) } pub fn subscription(&self, program: &P) -> Subscription> { program.subscription(&self.state).map(Message::Program) } pub fn theme(&self, program: &P, window: window::Id) -> P::Theme { program.theme(&self.state, window) } pub fn style(&self, program: &P, theme: &P::Theme) -> theme::Style { program.style(&self.state, theme) } pub fn scale_factor(&self, program: &P, window: window::Id) -> f64 { program.scale_factor(&self.state, window) } } #[derive(Clone)] enum Message

where P: Program, { Program(P::Message), } impl

fmt::Debug for Message

where P: Program, { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { match self { Message::Program(message) => message.fmt(f), } } }