mirror of
https://github.com/brl/mutter.git
synced 2024-11-29 19:40:43 -05:00
tests/test-client: Use draw_surface for subsurface corner case tests
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3388>
This commit is contained in:
parent
b59fb7c08c
commit
87907674f5
@ -77,19 +77,9 @@ static const struct xdg_toplevel_listener xdg_toplevel_listener = {
|
||||
static void
|
||||
draw_toplevel (void)
|
||||
{
|
||||
struct wl_buffer *buffer;
|
||||
void *buffer_data;
|
||||
int size;
|
||||
uint32_t *pixels;
|
||||
|
||||
if (!create_shm_buffer (display, window_width, window_height,
|
||||
&buffer, &buffer_data, &size))
|
||||
g_error ("Failed to create shm buffer");
|
||||
|
||||
for (pixels = buffer_data; size > 0; size -= 4)
|
||||
*pixels++ = 0xffffffffu;
|
||||
|
||||
wl_surface_attach (toplevel_surface, buffer, 0, 0);
|
||||
draw_surface (display, toplevel_surface,
|
||||
window_width, window_height,
|
||||
0xffffffffu);
|
||||
}
|
||||
|
||||
static void
|
||||
@ -106,35 +96,20 @@ static const struct xdg_surface_listener xdg_surface_listener = {
|
||||
handle_xdg_surface_configure,
|
||||
};
|
||||
|
||||
static void
|
||||
draw_descendant (struct wl_surface *descendant,
|
||||
uint32_t color)
|
||||
{
|
||||
struct wl_buffer *buffer;
|
||||
void *buffer_data;
|
||||
int size;
|
||||
uint32_t *pixels;
|
||||
|
||||
if (!create_shm_buffer (display, window_width / 2, window_height / 2,
|
||||
&buffer, &buffer_data, &size))
|
||||
g_error ("Failed to create shm buffer");
|
||||
|
||||
for (pixels = buffer_data; size > 0; size -= 4)
|
||||
*pixels++ = color;
|
||||
|
||||
wl_surface_attach (descendant, buffer, 0, 0);
|
||||
}
|
||||
|
||||
static void
|
||||
draw_child (void)
|
||||
{
|
||||
draw_descendant (child_surface, 0xff000000u);
|
||||
draw_surface (display, child_surface,
|
||||
window_width / 2, window_height / 2,
|
||||
0xff000000u);
|
||||
}
|
||||
|
||||
static void
|
||||
draw_grandchild (void)
|
||||
{
|
||||
draw_descendant (grandchild_surface, 0xffff0000u);
|
||||
draw_surface (display, grandchild_surface,
|
||||
window_width / 2, window_height / 2,
|
||||
0xffff0000u);
|
||||
}
|
||||
|
||||
static void
|
||||
|
Loading…
Reference in New Issue
Block a user