diff options
Diffstat (limited to 'native/src/renderer/debugger.rs')
| -rw-r--r-- | native/src/renderer/debugger.rs | 25 | 
1 files changed, 25 insertions, 0 deletions
| diff --git a/native/src/renderer/debugger.rs b/native/src/renderer/debugger.rs new file mode 100644 index 00000000..cb472dd4 --- /dev/null +++ b/native/src/renderer/debugger.rs @@ -0,0 +1,25 @@ +use crate::{Color, Layout, Point, Widget}; + +/// A renderer able to graphically explain a [`Layout`]. +/// +/// [`Layout`]: ../struct.Layout.html +pub trait Debugger: super::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, +        widget: &dyn Widget<Message, Self>, +        layout: Layout<'_>, +        cursor_position: Point, +        color: Color, +    ) -> Self::Primitive; +} | 
