@ -58,7 +58,6 @@ struct nested {
struct program * texture_program ;
struct program * texture_program ;
struct wl_list surface_list ;
struct wl_list surface_list ;
struct wl_list frame_callback_list ;
} ;
} ;
struct nested_region {
struct nested_region {
@ -87,6 +86,8 @@ struct nested_surface {
struct wl_list link ;
struct wl_list link ;
cairo_surface_t * cairo_surface ;
cairo_surface_t * cairo_surface ;
struct wl_list frame_callback_list ;
struct {
struct {
/* wl_surface.attach */
/* wl_surface.attach */
int newly_attached ;
int newly_attached ;
@ -191,23 +192,33 @@ nested_buffer_reference(struct nested_buffer_reference *ref,
}
}
static void
static void
frame_callback ( void * data , struct wl_callback * callback , uint32_t time )
flush_surface_frame_callback_list ( struct nested_surface * surface ,
uint32_t time )
{
{
struct nested * nested = data ;
struct nested_frame_callback * nc , * next ;
struct nested_frame_callback * nc , * next ;
if ( callback )
wl_list_for_each_safe ( nc , next , & surface - > frame_callback_list , link ) {
wl_callback_destroy ( callback ) ;
wl_list_for_each_safe ( nc , next , & nested - > frame_callback_list , link ) {
wl_callback_send_done ( nc - > resource , time ) ;
wl_callback_send_done ( nc - > resource , time ) ;
wl_resource_destroy ( nc - > resource ) ;
wl_resource_destroy ( nc - > resource ) ;
}
}
wl_list_init ( & nested - > frame_callback_list ) ;
wl_list_init ( & surface - > frame_callback_list ) ;
/* FIXME: toytoolkit need a pre-block handler where we can
/* FIXME: toytoolkit need a pre-block handler where we can
* call this . */
* call this . */
wl_display_flush_clients ( nested - > child_display ) ;
wl_display_flush_clients ( surface - > nested - > child_display ) ;
}
static void
frame_callback ( void * data , struct wl_callback * callback , uint32_t time )
{
struct nested * nested = data ;
struct nested_surface * surface ;
wl_list_for_each ( surface , & nested - > surface_list , link )
flush_surface_frame_callback_list ( surface , time ) ;
if ( callback )
wl_callback_destroy ( callback ) ;
}
}
static const struct wl_callback_listener frame_listener = {
static const struct wl_callback_listener frame_listener = {
@ -368,6 +379,10 @@ destroy_surface(struct wl_resource *resource)
struct nested_surface * surface = wl_resource_get_user_data ( resource ) ;
struct nested_surface * surface = wl_resource_get_user_data ( resource ) ;
struct nested_frame_callback * cb , * next ;
struct nested_frame_callback * cb , * next ;
wl_list_for_each_safe ( cb , next ,
& surface - > frame_callback_list , link )
wl_resource_destroy ( cb - > resource ) ;
wl_list_for_each_safe ( cb , next ,
wl_list_for_each_safe ( cb , next ,
& surface - > pending . frame_callback_list , link )
& surface - > pending . frame_callback_list , link )
wl_resource_destroy ( cb - > resource ) ;
wl_resource_destroy ( cb - > resource ) ;
@ -558,7 +573,7 @@ surface_commit(struct wl_client *client, struct wl_resource *resource)
empty_region ( & surface - > pending . damage ) ;
empty_region ( & surface - > pending . damage ) ;
/* wl_surface.frame */
/* wl_surface.frame */
wl_list_insert_list ( & nested - > frame_callback_list ,
wl_list_insert_list ( & surface - > frame_callback_list ,
& surface - > pending . frame_callback_list ) ;
& surface - > pending . frame_callback_list ) ;
wl_list_init ( & surface - > pending . frame_callback_list ) ;
wl_list_init ( & surface - > pending . frame_callback_list ) ;
@ -608,6 +623,8 @@ compositor_create_surface(struct wl_client *client,
surface - > nested = nested ;
surface - > nested = nested ;
wl_list_init ( & surface - > frame_callback_list ) ;
wl_list_init ( & surface - > pending . frame_callback_list ) ;
wl_list_init ( & surface - > pending . frame_callback_list ) ;
surface - > pending . buffer_destroy_listener . notify =
surface - > pending . buffer_destroy_listener . notify =
surface_handle_pending_buffer_destroy ;
surface_handle_pending_buffer_destroy ;
@ -724,7 +741,6 @@ nested_init_compositor(struct nested *nested)
int fd , ret ;
int fd , ret ;
wl_list_init ( & nested - > surface_list ) ;
wl_list_init ( & nested - > surface_list ) ;
wl_list_init ( & nested - > frame_callback_list ) ;
nested - > child_display = wl_display_create ( ) ;
nested - > child_display = wl_display_create ( ) ;
loop = wl_display_get_event_loop ( nested - > child_display ) ;
loop = wl_display_get_event_loop ( nested - > child_display ) ;
fd = wl_event_loop_get_fd ( loop ) ;
fd = wl_event_loop_get_fd ( loop ) ;