[PATCH weston v5 2/3] Implement data_device interface destructor

Derek Foreman derekf at osg.samsung.com
Thu Oct 16 09:43:43 PDT 2014


I apologize in advance for only commenting on the whitespace :)

On 13/10/14 12:05 AM, kabeer khan wrote:
> window : compare version and call appropriate destructor
> 
> Signed-off-by: kabeer khan <kabeer.khan at samsung.com>
> ---
>  clients/window.c | 15 ++++++++++-----
>  1 file changed, 10 insertions(+), 5 deletions(-)
> 
> diff --git a/clients/window.c b/clients/window.c
> index 139c7f9..12851ba 100644
> --- a/clients/window.c
> +++ b/clients/window.c
> @@ -133,6 +133,7 @@ struct display {
>  
>  	int has_rgb565;
>  	int seat_version;
> +	int data_device_manager_version;
>  };
>  
>  struct window_output {
> @@ -5148,9 +5149,12 @@ input_destroy(struct input *input)
>  	if (input->selection_offer)
>  		data_offer_destroy(input->selection_offer);
>  
> -	if (input->data_device)
> -		wl_data_device_destroy(input->data_device);
> -
> +	if (input->data_device) {
> +		if(input->display->data_device_manager_version >= 2)
> +			wl_data_device_release(input->data_device);
> +        	else
> +            		wl_data_device_destroy(input->data_device);

These last two lines ^ should use tabs exclusively... instead of spaces
followed by tabs.

> +	}
>  	if (input->display->seat_version >= 3) {
>  		if (input->pointer)
>  			wl_pointer_release(input->pointer);
> @@ -5234,9 +5238,10 @@ registry_handle_global(void *data, struct wl_registry *registry, uint32_t id,
>  		d->shm = wl_registry_bind(registry, id, &wl_shm_interface, 1);
>  		wl_shm_add_listener(d->shm, &shm_listener, d);
>  	} else if (strcmp(interface, "wl_data_device_manager") == 0) {
> +        	d->data_device_manager_version = MIN(version, 2);

Same here ^

>  		d->data_device_manager =
> -			wl_registry_bind(registry, id,
> -					 &wl_data_device_manager_interface, 1);
> +			wl_registry_bind(registry, id, 
> +					 &wl_data_device_manager_interface, d->data_device_manager_version);
>  	} else if (strcmp(interface, "xdg_shell") == 0) {
>  		d->xdg_shell = wl_registry_bind(registry, id,
>  						&xdg_shell_interface, 1);
> 



More information about the wayland-devel mailing list