diff options
Diffstat (limited to 'native/src/layout')
-rw-r--r-- | native/src/layout/debugger.rs | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/native/src/layout/debugger.rs b/native/src/layout/debugger.rs new file mode 100644 index 00000000..e4b21609 --- /dev/null +++ b/native/src/layout/debugger.rs @@ -0,0 +1,26 @@ +use crate::{Color, Layout, Point, Renderer, Widget}; + +/// A renderer able to graphically explain a [`Layout`]. +/// +/// [`Layout`]: struct.Layout.html +pub trait Debugger: Renderer { + /// Explains the [`Layout`] of an [`Element`] for debugging purposes. + /// + /// This will be called when [`Element::explain`] has been used. It should + /// _explain_ the given [`Layout`] graphically. + /// + /// A common approach consists in recursively rendering the bounds of the + /// [`Layout`] and its children. + /// + /// [`Layout`]: struct.Layout.html + /// [`Element`]: ../struct.Element.html + /// [`Element::explain`]: ../struct.Element.html#method.explain + fn explain<Message>( + &mut self, + defaults: &Self::Defaults, + widget: &dyn Widget<Message, Self>, + layout: Layout<'_>, + cursor_position: Point, + color: Color, + ) -> Self::Output; +} |