@@ -1,3 +1,4 @@
+use crate::element::LayoutContext;
use util::ResultExt;
use crate::element::AnyElement;
@@ -12,16 +13,22 @@ impl<V: 'static> gpui::Element<V> for Adapter<V> {
&mut self,
constraint: gpui::SizeConstraint,
view: &mut V,
- cx: &mut gpui::LayoutContext<V>,
+ legacy_cx: &mut gpui::LayoutContext<V>,
) -> (gpui::geometry::vector::Vector2F, Self::LayoutState) {
- cx.push_layout_engine();
- if let Some(node) = self.0.layout(view, cx).log_err() {
- cx.layout_engine()
+ legacy_cx.push_layout_engine();
+ let node = self
+ .0
+ .layout(view, &mut LayoutContext { legacy_cx })
+ .log_err();
+
+ if let Some(node) = node {
+ legacy_cx
+ .layout_engine()
.unwrap()
.compute_layout(node, constraint.max)
.log_err();
}
- cx.pop_layout_engine();
+ legacy_cx.pop_layout_engine();
(constraint.max, ())
}
@@ -1,14 +1,27 @@
use crate::style::{DefinedLength, Display, Overflow, Position, Style};
use anyhow::Result;
-use gpui::{Layout, LayoutContext, PaintContext};
+use derive_more::{Deref, DerefMut};
+use gpui::{Layout, LayoutContext as LegacyLayoutContext, PaintContext as LegacyPaintContext};
use playground_macros::tailwind_lengths;
pub use taffy::tree::NodeId;
+#[derive(Deref, DerefMut)]
+pub struct LayoutContext<'a, 'b, 'c, 'd, V> {
+ pub(crate) legacy_cx: &'d mut LegacyLayoutContext<'a, 'b, 'c, V>,
+}
+
+#[derive(Deref, DerefMut)]
+pub struct PaintContext<'a, 'b, 'c, 'd, V> {
+ #[deref]
+ #[deref_mut]
+ pub(crate) legacy_cx: &'d mut LegacyPaintContext<'a, 'b, 'c, V>,
+ scene: &'d mut gpui::SceneBuilder,
+}
+
pub trait Element<V> {
fn style_mut(&mut self) -> &mut Style;
fn layout(&mut self, view: &mut V, cx: &mut LayoutContext<V>) -> Result<NodeId>;
- fn paint(&mut self, layout: Layout, view: &mut V, cx: &mut gpui::PaintContext<V>)
- -> Result<()>;
+ fn paint(&mut self, layout: Layout, view: &mut V, cx: &mut PaintContext<V>) -> Result<()>;
/// Convert to a dynamically-typed element suitable for layout and paint.
fn into_any(self) -> AnyElement<V>
@@ -2,7 +2,7 @@ use anyhow::{anyhow, Result};
use gpui::{Layout, LayoutNodeId};
use crate::{
- element::{AnyElement, Element},
+ element::{AnyElement, Element, LayoutContext, PaintContext},
style::Style,
};
@@ -23,11 +23,7 @@ impl<V: 'static> Element<V> for Frame<V> {
&mut self.style
}
- fn layout(
- &mut self,
- view: &mut V,
- cx: &mut gpui::LayoutContext<V>,
- ) -> Result<taffy::tree::NodeId> {
+ fn layout(&mut self, view: &mut V, cx: &mut LayoutContext<V>) -> Result<taffy::tree::NodeId> {
let child_layout_node_ids = self
.children
.iter_mut()
@@ -40,12 +36,7 @@ impl<V: 'static> Element<V> for Frame<V> {
.add_node(self.style.to_taffy(rem_size), child_layout_node_ids)
}
- fn paint(
- &mut self,
- layout: Layout,
- view: &mut V,
- cx: &mut gpui::PaintContext<V>,
- ) -> Result<()> {
+ fn paint(&mut self, layout: Layout, view: &mut V, cx: &mut PaintContext<V>) -> Result<()> {
for child in &mut self.children {
child.paint(view, cx)?;
}