}
static bool
-is_double_click(long double_click_speed, uint32_t button, struct view *view)
+is_double_click(long double_click_speed, uint32_t button,
+ struct cursor_context *ctx)
{
+ static enum ssd_part_type last_type;
static uint32_t last_button;
static struct view *last_view;
static struct timespec last_click;
long ms = (now.tv_sec - last_click.tv_sec) * 1000 +
(now.tv_nsec - last_click.tv_nsec) / 1000000;
last_click = now;
- if (last_button != button || last_view != view) {
+ if (last_button != button || last_view != ctx->view
+ || last_type != ctx->type) {
last_button = button;
- last_view = view;
+ last_view = ctx->view;
+ last_type = ctx->type;
return false;
}
if (ms < double_click_speed && ms >= 0) {
*/
last_button = 0;
last_view = NULL;
+ last_type = 0;
return true;
}
return false;
uint32_t button, uint32_t resize_edges)
{
struct mousebind *mousebind;
- bool double_click = is_double_click(rc.doubleclick_time, button, ctx->view);
+ bool double_click = is_double_click(rc.doubleclick_time, button, ctx);
bool consumed_by_frame_context = false;
uint32_t modifiers = wlr_keyboard_get_modifiers(