@ -1559,53 +1559,39 @@ weston_input_update_drag_surface(struct wl_input_device *input_device,
int dx , int dy ) ;
int dx , int dy ) ;
static void
static void
clip_pointer_motion ( struct weston_compositor * ec ,
clip_pointer_motion ( struct weston_input_device * device ,
wl_fixed_t * fx , wl_fixed_t * fy )
wl_fixed_t * fx , wl_fixed_t * fy )
{
{
struct weston_output * output ;
struct weston_compositor * ec = device - > compositor ;
wl_fixed_t x , y ;
struct weston_output * output , * prev = NULL ;
int x_valid = 0 , y_valid = 0 ;
int x , y , old_x , old_y , valid = 0 ;
int min_x = INT_MAX , min_y = INT_MAX , max_x = INT_MIN , max_y = INT_MIN ;
x = * fx ;
x = wl_fixed_to_int ( * fx ) ;
y = * fy ;
y = wl_fixed_to_int ( * fy ) ;
old_x = wl_fixed_to_int ( device - > input_device . x ) ;
old_y = wl_fixed_to_int ( device - > input_device . y ) ;
wl_list_for_each ( output , & ec - > output_list , link ) {
wl_list_for_each ( output , & ec - > output_list , link ) {
if ( wl_fixed_from_int ( output - > x ) < = x & &
if ( pixman_region32_contains_point ( & output - > region ,
x < wl_fixed_from_int ( output - > x + output - > current - > width ) )
x , y , NULL ) )
x_valid = 1 ;
valid = 1 ;
if ( pixman_region32_contains_point ( & output - > region ,
if ( wl_fixed_from_int ( output - > y ) < = y & &
old_x , old_y , NULL ) )
y < wl_fixed_from_int ( output - > y + output - > current - > height ) )
prev = output ;
y_valid = 1 ;
/* FIXME: calculate this only on output addition/deletion */
if ( output - > x < min_x )
min_x = output - > x ;
if ( output - > y < min_y )
min_y = output - > y ;
if ( output - > x + output - > current - > width > max_x )
max_x = output - > x + output - > current - > width - 1 ;
if ( output - > y + output - > current - > height > max_y )
max_y = output - > y + output - > current - > height - 1 ;
}
}
if ( ! x_ valid) {
if ( ! valid ) {
if ( x < wl_fixed_from_int ( min_x ) )
if ( x < prev - > x )
x = wl_fixed_from_int ( min_ x) ;
* fx = wl_fixed_from_int ( prev - > x ) ;
else if ( x > = wl_fixed_from_int ( max_x ) )
else if ( x > = prev - > x + prev - > current - > width )
x = wl_fixed_from_int ( max_x ) ;
* fx = wl_fixed_from_int ( prev - > x +
}
prev - > current - > width - 1 ) ;
if ( ! y_valid ) {
if ( y < prev - > y )
if ( y < wl_fixed_from_int ( min_y ) )
* fy = wl_fixed_from_int ( prev - > y ) ;
y = wl_fixed_from_int ( min_y ) ;
else if ( y > = prev - > y + prev - > current - > height )
else if ( y > = max_y )
* fy = wl_fixed_from_int ( prev - > y +
y = wl_fixed_from_int ( max_y ) ;
prev - > current - > height - 1 ) ;
}
}
* fx = x ;
* fy = y ;
}
}
WL_EXPORT void
WL_EXPORT void
@ -1620,7 +1606,7 @@ notify_motion(struct wl_input_device *device,
weston_compositor_activity ( ec ) ;
weston_compositor_activity ( ec ) ;
clip_pointer_motion ( ec , & x , & y ) ;
clip_pointer_motion ( wd , & x , & y ) ;
weston_input_update_drag_surface ( device ,
weston_input_update_drag_surface ( device ,
x - device - > x , y - device - > y ) ;
x - device - > x , y - device - > y ) ;