diff options
Diffstat (limited to '')
| -rw-r--r-- | native/src/program.rs | 11 | ||||
| -rw-r--r-- | native/src/program/state.rs | 7 | 
2 files changed, 12 insertions, 6 deletions
| diff --git a/native/src/program.rs b/native/src/program.rs index 9ee72703..066c29d8 100644 --- a/native/src/program.rs +++ b/native/src/program.rs @@ -1,5 +1,5 @@  //! Build interactive programs using The Elm Architecture. -use crate::{Command, Element, Renderer}; +use crate::{Clipboard, Command, Element, Renderer};  mod state; @@ -13,6 +13,9 @@ pub trait Program: Sized {      /// The type of __messages__ your [`Program`] will produce.      type Message: std::fmt::Debug + Send; +    /// The type of [`Clipboard`] your [`Program`] will use. +    type Clipboard: Clipboard; +      /// Handles a __message__ and updates the state of the [`Program`].      ///      /// This is where you define your __update logic__. All the __messages__, @@ -21,7 +24,11 @@ pub trait Program: Sized {      ///      /// Any [`Command`] returned will be executed immediately in the      /// background by shells. -    fn update(&mut self, message: Self::Message) -> Command<Self::Message>; +    fn update( +        &mut self, +        message: Self::Message, +        clipboard: &mut Self::Clipboard, +    ) -> Command<Self::Message>;      /// Returns the widgets to display in the [`Program`].      /// diff --git a/native/src/program/state.rs b/native/src/program/state.rs index 3f5f6069..fd1f2b52 100644 --- a/native/src/program/state.rs +++ b/native/src/program/state.rs @@ -1,6 +1,5 @@  use crate::{ -    Cache, Clipboard, Command, Debug, Event, Point, Program, Renderer, Size, -    UserInterface, +    Cache, Command, Debug, Event, Point, Program, Renderer, Size, UserInterface,  };  /// The execution state of a [`Program`]. It leverages caching, event @@ -92,7 +91,7 @@ where          bounds: Size,          cursor_position: Point,          renderer: &mut P::Renderer, -        clipboard: &mut dyn Clipboard, +        clipboard: &mut P::Clipboard,          debug: &mut Debug,      ) -> Option<Command<P::Message>> {          let mut user_interface = build_user_interface( @@ -136,7 +135,7 @@ where                      debug.log_message(&message);                      debug.update_started(); -                    let command = self.program.update(message); +                    let command = self.program.update(message, clipboard);                      debug.update_finished();                      command | 
