summaryrefslogtreecommitdiff
path: root/tools/gtk-builder-tool-screenshot.c
diff options
context:
space:
mode:
Diffstat (limited to 'tools/gtk-builder-tool-screenshot.c')
-rw-r--r--tools/gtk-builder-tool-screenshot.c28
1 files changed, 21 insertions, 7 deletions
diff --git a/tools/gtk-builder-tool-screenshot.c b/tools/gtk-builder-tool-screenshot.c
index 17c3731d98..d53f5ac977 100644
--- a/tools/gtk-builder-tool-screenshot.c
+++ b/tools/gtk-builder-tool-screenshot.c
@@ -48,6 +48,7 @@ draw_paintable (GdkPaintable *paintable,
GskRenderNode *node;
GdkTexture *texture;
GskRenderer *renderer;
+ graphene_rect_t bounds;
snapshot = gtk_snapshot_new ();
gdk_paintable_snapshot (paintable,
@@ -62,16 +63,29 @@ draw_paintable (GdkPaintable *paintable,
if (node == NULL)
return;
+ if (gsk_render_node_get_node_type (node) == GSK_CLIP_NODE)
+ {
+ GskRenderNode *child;
+
+ child = gsk_render_node_ref (gsk_clip_node_get_child (node));
+ gsk_render_node_unref (node);
+ node = child;
+ }
+
renderer = gtk_native_get_renderer (
gtk_widget_get_native (
gtk_widget_paintable_get_widget (GTK_WIDGET_PAINTABLE (paintable))));
- texture = gsk_renderer_render_texture (renderer,
- node,
- &GRAPHENE_RECT_INIT (
- 0, 0,
- gdk_paintable_get_intrinsic_width (paintable),
- gdk_paintable_get_intrinsic_height (paintable)
- ));
+
+ gsk_render_node_get_bounds (node, &bounds);
+ graphene_rect_union (&bounds,
+ &GRAPHENE_RECT_INIT (
+ 0, 0,
+ gdk_paintable_get_intrinsic_width (paintable),
+ gdk_paintable_get_intrinsic_height (paintable)
+ ),
+ &bounds);
+
+ texture = gsk_renderer_render_texture (renderer, node, &bounds);
g_object_set_data_full (G_OBJECT (texture),
"source-render-node",
node,