These days, we can query it with gsk_vulkan_render_get_context().
Makes quite a few functions require one less argument.
And it also makes the GskVulkanRenderPass empty. Gotta figure out what
to do with it.
graphene_vec2_init (&scale, self->scale, self->scale);
gsk_vulkan_render_pass_op (self,
- self->vulkan,
g_object_ref (self->target),
self->clip,
&scale,
struct _GskVulkanRenderPass
{
- GdkVulkanContext *vulkan;
+ int empty;
};
struct _GskVulkanParseState
};
GskVulkanRenderPass *
-gsk_vulkan_render_pass_new (GdkVulkanContext *context)
+gsk_vulkan_render_pass_new (void)
{
GskVulkanRenderPass *self;
self = g_new0 (GskVulkanRenderPass, 1);
- self->vulkan = g_object_ref (context);
return self;
}
void
gsk_vulkan_render_pass_free (GskVulkanRenderPass *self)
{
- g_object_unref (self->vulkan);
-
g_free (self);
}
result = gsk_vulkan_renderer_get_texture_image (renderer, texture);
if (result == NULL)
{
- result = gsk_vulkan_upload_texture_op (render, self->vulkan, texture);
+ result = gsk_vulkan_upload_texture_op (render, texture);
gsk_vulkan_renderer_add_texture_image (renderer, texture, result);
}
return NULL;
result = gsk_vulkan_upload_cairo_op (render,
- self->vulkan,
node,
&state->scale,
&clipped);
*tex_bounds = clipped;
result = gsk_vulkan_render_pass_op_offscreen (render,
- self->vulkan,
&state->scale,
&clipped,
node);
return TRUE;
image = gsk_vulkan_upload_cairo_op (render,
- self->vulkan,
node,
&state->scale,
&clipped);
image = gsk_vulkan_renderer_get_texture_image (renderer, texture);
if (image == NULL)
{
- image = gsk_vulkan_upload_texture_op (render, self->vulkan, texture);
+ image = gsk_vulkan_upload_texture_op (render, texture);
gsk_vulkan_renderer_add_texture_image (renderer, texture, image);
}
image = gsk_vulkan_renderer_get_texture_image (renderer, texture);
if (image == NULL)
{
- image = gsk_vulkan_upload_texture_op (render, self->vulkan, texture);
+ image = gsk_vulkan_upload_texture_op (render, texture);
gsk_vulkan_renderer_add_texture_image (renderer, texture, image);
}
return TRUE;
image = gsk_vulkan_render_pass_op_offscreen (render,
- self->vulkan,
&state->scale,
child_bounds,
gsk_repeat_node_get_child (node));
void
gsk_vulkan_render_pass_op (GskVulkanRender *render,
- GdkVulkanContext *context,
GskVulkanImage *image,
cairo_region_t *clip,
const graphene_vec2_t *scale,
cairo_region_get_extents (clip, &self->area);
self->viewport_size = viewport->size;
- self->render_pass = gsk_vulkan_render_pass_new (context);
+ self->render_pass = gsk_vulkan_render_pass_new ();
/* This invalidates the self pointer */
gsk_vulkan_render_pass_add (self->render_pass,
GskVulkanImage *
gsk_vulkan_render_pass_op_offscreen (GskVulkanRender *render,
- GdkVulkanContext *context,
const graphene_vec2_t *scale,
const graphene_rect_t *viewport,
GskRenderNode *node)
{
+ GdkVulkanContext *context;
graphene_rect_t view;
GskVulkanImage *image;
cairo_region_t *clip;
ceil (scale_x * viewport->size.width),
ceil (scale_y * viewport->size.height));
+ context = gsk_vulkan_render_get_context (render);
image = gsk_vulkan_image_new_for_offscreen (context,
gdk_vulkan_context_get_offscreen_format (context,
gsk_render_node_get_preferred_depth (node)),
});
gsk_vulkan_render_pass_op (render,
- context,
image,
clip,
scale,
G_BEGIN_DECLS
void gsk_vulkan_render_pass_op (GskVulkanRender *render,
- GdkVulkanContext *context,
GskVulkanImage *image,
cairo_region_t *clip,
const graphene_vec2_t *scale,
VkImageLayout initial_layout,
VkImageLayout final_layout);
GskVulkanImage * gsk_vulkan_render_pass_op_offscreen (GskVulkanRender *render,
- GdkVulkanContext *context,
const graphene_vec2_t *scale,
const graphene_rect_t *viewport,
GskRenderNode *node);
G_BEGIN_DECLS
-GskVulkanRenderPass * gsk_vulkan_render_pass_new (GdkVulkanContext *context);
+GskVulkanRenderPass * gsk_vulkan_render_pass_new (void);
void gsk_vulkan_render_pass_free (GskVulkanRenderPass *self);
GskVulkanImage *
gsk_vulkan_upload_texture_op (GskVulkanRender *render,
- GdkVulkanContext *context,
GdkTexture *texture)
{
GskVulkanUploadTextureOp *self;
self = (GskVulkanUploadTextureOp *) gsk_vulkan_op_alloc (render, &GSK_VULKAN_UPLOAD_TEXTURE_OP_CLASS);
self->texture = g_object_ref (texture);
- self->image = gsk_vulkan_image_new_for_upload (context,
+ self->image = gsk_vulkan_image_new_for_upload (gsk_vulkan_render_get_context (render),
gdk_texture_get_format (texture),
gdk_texture_get_width (texture),
gdk_texture_get_height (texture));
GskVulkanImage *
gsk_vulkan_upload_cairo_op (GskVulkanRender *render,
- GdkVulkanContext *context,
GskRenderNode *node,
const graphene_vec2_t *scale,
const graphene_rect_t *viewport)
self = (GskVulkanUploadCairoOp *) gsk_vulkan_op_alloc (render, &GSK_VULKAN_UPLOAD_CAIRO_OP_CLASS);
self->node = gsk_render_node_ref (node);
- self->image = gsk_vulkan_image_new_for_upload (context,
+ self->image = gsk_vulkan_image_new_for_upload (gsk_vulkan_render_get_context (render),
GDK_MEMORY_DEFAULT,
ceil (graphene_vec2_get_x (scale) * viewport->size.width),
ceil (graphene_vec2_get_y (scale) * viewport->size.height));
G_BEGIN_DECLS
GskVulkanImage * gsk_vulkan_upload_texture_op (GskVulkanRender *render,
- GdkVulkanContext *context,
GdkTexture *texture);
GskVulkanImage * gsk_vulkan_upload_cairo_op (GskVulkanRender *render,
- GdkVulkanContext *context,
GskRenderNode *node,
const graphene_vec2_t *scale,
const graphene_rect_t *viewport);