[PATCH] image: handle multiple images correctly

Kristian Høgsberg hoegsberg at gmail.com
Mon Aug 13 13:28:45 PDT 2012


On Mon, Aug 13, 2012 at 09:16:47PM +0200, Philipp Brüschweiler wrote:
> Don't stop the application when only one window is closed. Don't stall
> indefinitely if no valid image file is given as input.

Looks good, thanks.

> ---
>  clients/image.c | 29 ++++++++++++++++++++++++++---
>  1 Datei geändert, 26 Zeilen hinzugefügt(+), 3 Zeilen entfernt(-)
> 
> diff --git a/clients/image.c b/clients/image.c
> index c289d76..8579804 100644
> --- a/clients/image.c
> +++ b/clients/image.c
> @@ -44,6 +44,7 @@ struct image {
>  	char *filename;
>  	cairo_surface_t *image;
>  	int fullscreen;
> +	int *image_counter;
>  };
>  
>  static void
> @@ -112,8 +113,25 @@ fullscreen_handler(struct window *window, void *data)
>  	window_set_fullscreen(window, image->fullscreen);
>  }
>  
> +static void
> +close_handler(struct window *window, void *data)
> +{
> +	struct image *image = data;
> +
> +	*image->image_counter -= 1;
> +
> +	if (*image->image_counter == 0)
> +		display_exit(image->display);
> +
> +	widget_destroy(image->widget);
> +	window_destroy(image->window);
> +
> +	free(image);
> +}
> +
>  static struct image *
> -image_create(struct display *display, const char *filename)
> +image_create(struct display *display, const char *filename,
> +	     int *image_counter)
>  {
>  	struct image *image;
>  	char *b, *copy, title[512];;
> @@ -140,12 +158,15 @@ image_create(struct display *display, const char *filename)
>  	image->widget = frame_create(image->window, image);
>  	window_set_title(image->window, title);
>  	image->display = display;
> +	image->image_counter = image_counter;
> +	*image_counter += 1;
>  
>  	window_set_user_data(image->window, image);
>  	widget_set_redraw_handler(image->widget, redraw_handler);
>  	window_set_keyboard_focus_handler(image->window,
>  					  keyboard_focus_handler);
>  	window_set_fullscreen_handler(image->window, fullscreen_handler);
> +	window_set_close_handler(image->window, close_handler);
>  
>  	widget_schedule_resize(image->widget, 500, 400);
>  
> @@ -157,6 +178,7 @@ main(int argc, char *argv[])
>  {
>  	struct display *d;
>  	int i;
> +	int image_counter = 0;
>  
>  	d = display_create(argc, argv);
>  	if (d == NULL) {
> @@ -165,9 +187,10 @@ main(int argc, char *argv[])
>  	}
>  
>  	for (i = 1; i < argc; i++)
> -		image_create (d, argv[i]);
> +		image_create(d, argv[i], &image_counter);
>  
> -	display_run(d);
> +	if (image_counter > 0)
> +		display_run(d);
>  
>  	return 0;
>  }
> -- 
> 1.7.11.4
> 
> _______________________________________________
> wayland-devel mailing list
> wayland-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/wayland-devel


More information about the wayland-devel mailing list