destroy_sprites(d);
- weston_compositor_shutdown(ec);
-
ec->renderer->destroy(ec);
+ weston_compositor_shutdown(ec);
+
if (d->gbm)
gbm_device_destroy(d->gbm);
udev_input_destroy(&compositor->input);
+ compositor->base.renderer->destroy(&compositor->base);
+
/* Destroy the output. */
weston_compositor_shutdown(&compositor->base);
/* Chain up. */
- compositor->base.renderer->destroy(&compositor->base);
weston_launcher_destroy(compositor->base.launcher);
free(compositor);
wl_list_for_each_safe(seat, next, &compositor->base.seat_list, link)
evdev_input_destroy(seat);
+ compositor->base.renderer->destroy(&compositor->base);
+
/* destroys outputs, too */
weston_compositor_shutdown(&compositor->base);
- compositor->base.renderer->destroy(&compositor->base);
weston_launcher_destroy(compositor->base.launcher);
bcm_host_deinit();
wl_event_source_remove(compositor->xcb_source);
x11_input_destroy(compositor);
- weston_compositor_shutdown(ec); /* destroys outputs, too */
-
ec->renderer->destroy(ec);
+ weston_compositor_shutdown(ec); /* destroys outputs, too */
+
XCloseDisplay(compositor->dpy);
free(ec);
}
struct weston_renderer base;
int fragment_shader_debug;
int fan_debug;
+ struct weston_binding *fragment_binding;
+ struct weston_binding *fan_binding;
EGLDisplay egl_display;
EGLContext egl_context;
wl_array_release(&gr->indices);
wl_array_release(&gr->vtxcnt);
+ weston_binding_destroy(gr->fragment_binding);
+ weston_binding_destroy(gr->fan_binding);
+
free(gr);
}
if (compile_shaders(ec))
return -1;
- weston_compositor_add_debug_binding(ec, KEY_S,
- fragment_debug_binding, ec);
- weston_compositor_add_debug_binding(ec, KEY_F,
- fan_debug_repaint_binding, ec);
+ gr->fragment_binding =
+ weston_compositor_add_debug_binding(ec, KEY_S,
+ fragment_debug_binding,
+ ec);
+ gr->fan_binding =
+ weston_compositor_add_debug_binding(ec, KEY_F,
+ fan_debug_repaint_binding,
+ ec);
weston_log("GL ES 2 renderer features:\n");
weston_log_continue(STAMP_SPACE "read-back format: %s\n",
struct pixman_renderer {
struct weston_renderer base;
+
int repaint_debug;
pixman_image_t *debug_color;
+ struct weston_binding *debug_binding;
};
static inline struct pixman_output_state *
static void
pixman_renderer_destroy(struct weston_compositor *ec)
{
- free(ec->renderer);
+ struct pixman_renderer *pr = get_renderer(ec);
+
+ weston_binding_destroy(pr->debug_binding);
+ free(pr);
+
ec->renderer = NULL;
}
ec->capabilities |= WESTON_CAP_ROTATION_ANY;
ec->capabilities |= WESTON_CAP_CAPTURE_YFLIP;
- weston_compositor_add_debug_binding(ec, KEY_R,
- debug_binding, ec);
+ renderer->debug_binding =
+ weston_compositor_add_debug_binding(ec, KEY_R,
+ debug_binding, ec);
wl_display_add_shm_format(ec->wl_display, WL_SHM_FORMAT_RGB565);