Implement feedback
This commit is contained in:
parent
3ad7b146eb
commit
21e1cc9ab4
|
@ -11,7 +11,7 @@
|
||||||
#include <wlr/types/wlr_tablet_v2.h>
|
#include <wlr/types/wlr_tablet_v2.h>
|
||||||
#include <wlr/util/log.h>
|
#include <wlr/util/log.h>
|
||||||
|
|
||||||
static struct wlr_tablet_pad_v2_grab_interface default_pad_interface;
|
static struct wlr_tablet_pad_v2_grab_interface default_pad_grab_interface;
|
||||||
|
|
||||||
struct tablet_pad_auxiliary_user_data {
|
struct tablet_pad_auxiliary_user_data {
|
||||||
struct wlr_tablet_pad_client_v2 *pad;
|
struct wlr_tablet_pad_client_v2 *pad;
|
||||||
|
@ -368,7 +368,7 @@ struct wlr_tablet_v2_tablet_pad *wlr_tablet_pad_create(
|
||||||
if (!pad) {
|
if (!pad) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
pad->default_grab.interface = &default_pad_interface;
|
pad->default_grab.interface = &default_pad_grab_interface;
|
||||||
pad->default_grab.pad = pad;
|
pad->default_grab.pad = pad;
|
||||||
pad->grab = &pad->default_grab;
|
pad->grab = &pad->default_grab;
|
||||||
|
|
||||||
|
@ -631,10 +631,8 @@ void wlr_tablet_v2_start_grab(struct wlr_tablet_v2_tablet_pad *pad,
|
||||||
struct wlr_tablet_pad_v2_grab *prev = pad->grab;
|
struct wlr_tablet_pad_v2_grab *prev = pad->grab;
|
||||||
grab->pad = pad;
|
grab->pad = pad;
|
||||||
pad->grab = grab;
|
pad->grab = grab;
|
||||||
if (prev) {
|
if (prev && prev->interface->cancel) {
|
||||||
if (prev->interface->cancel) {
|
prev->interface->cancel(prev);
|
||||||
prev->interface->cancel(prev);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -685,7 +683,7 @@ static void default_pad_cancel(struct wlr_tablet_pad_v2_grab *grab) {
|
||||||
// Do nothing, the default cancel can be ignored.
|
// Do nothing, the default cancel can be ignored.
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct wlr_tablet_pad_v2_grab_interface default_pad_interface = {
|
static struct wlr_tablet_pad_v2_grab_interface default_pad_grab_interface = {
|
||||||
.enter = default_pad_enter,
|
.enter = default_pad_enter,
|
||||||
.button = default_pad_button,
|
.button = default_pad_button,
|
||||||
.strip = default_pad_strip,
|
.strip = default_pad_strip,
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
#include <wlr/types/wlr_tablet_v2.h>
|
#include <wlr/types/wlr_tablet_v2.h>
|
||||||
#include <wlr/util/log.h>
|
#include <wlr/util/log.h>
|
||||||
|
|
||||||
static const struct wlr_tablet_tool_v2_grab_interface default_tool_interface;
|
static const struct wlr_tablet_tool_v2_grab_interface default_tool_grab_interface;
|
||||||
|
|
||||||
static const struct wlr_surface_role tablet_tool_cursor_surface_role = {
|
static const struct wlr_surface_role tablet_tool_cursor_surface_role = {
|
||||||
.name = "wp_tablet_tool-cursor",
|
.name = "wp_tablet_tool-cursor",
|
||||||
|
@ -209,7 +209,7 @@ struct wlr_tablet_v2_tablet_tool *wlr_tablet_tool_create(
|
||||||
tool->wlr_tool = wlr_tool;
|
tool->wlr_tool = wlr_tool;
|
||||||
wl_list_init(&tool->clients);
|
wl_list_init(&tool->clients);
|
||||||
tool->default_grab.tool = tool;
|
tool->default_grab.tool = tool;
|
||||||
tool->default_grab.interface = &default_tool_interface;
|
tool->default_grab.interface = &default_tool_grab_interface;
|
||||||
tool->grab = &tool->default_grab;
|
tool->grab = &tool->default_grab;
|
||||||
|
|
||||||
|
|
||||||
|
@ -602,7 +602,8 @@ void wlr_tablet_v2_tablet_tool_notify_button(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wlr_tablet_tool_v2_start_grab(struct wlr_tablet_v2_tablet_tool *tool, struct wlr_tablet_tool_v2_grab *grab) {
|
void wlr_tablet_tool_v2_start_grab(struct wlr_tablet_v2_tablet_tool *tool,
|
||||||
|
struct wlr_tablet_tool_v2_grab *grab) {
|
||||||
wlr_tablet_tool_v2_end_grab(tool);
|
wlr_tablet_tool_v2_end_grab(tool);
|
||||||
tool->grab = grab;
|
tool->grab = grab;
|
||||||
}
|
}
|
||||||
|
@ -630,7 +631,7 @@ static void default_tool_up(struct wlr_tablet_tool_v2_grab *grab) {
|
||||||
}
|
}
|
||||||
|
|
||||||
static void default_tool_motion(
|
static void default_tool_motion(
|
||||||
struct wlr_tablet_tool_v2_grab *grab, double x, double y) {
|
struct wlr_tablet_tool_v2_grab *grab, double x, double y) {
|
||||||
wlr_send_tablet_v2_tablet_tool_motion(grab->tool, x, y);
|
wlr_send_tablet_v2_tablet_tool_motion(grab->tool, x, y);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -678,7 +679,8 @@ static void default_tool_cancel(struct wlr_tablet_tool_v2_grab *grab) {
|
||||||
/* Do nothing. Default grab can't be canceled */
|
/* Do nothing. Default grab can't be canceled */
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct wlr_tablet_tool_v2_grab_interface default_tool_interface = {
|
static const struct wlr_tablet_tool_v2_grab_interface
|
||||||
|
default_tool_grab_interface = {
|
||||||
.proximity_in = default_tool_proximity_in,
|
.proximity_in = default_tool_proximity_in,
|
||||||
.down = default_tool_down,
|
.down = default_tool_down,
|
||||||
.up = default_tool_up,
|
.up = default_tool_up,
|
||||||
|
@ -779,7 +781,8 @@ static void implicit_tool_cancel(struct wlr_tablet_tool_v2_grab *grab) {
|
||||||
free(grab);
|
free(grab);
|
||||||
}
|
}
|
||||||
|
|
||||||
const struct wlr_tablet_tool_v2_grab_interface implicit_tool_interface = {
|
static const struct wlr_tablet_tool_v2_grab_interface
|
||||||
|
implicit_tool_grab_interface = {
|
||||||
.proximity_in = implicit_tool_proximity_in,
|
.proximity_in = implicit_tool_proximity_in,
|
||||||
.down = implicit_tool_down,
|
.down = implicit_tool_down,
|
||||||
.up = implicit_tool_up,
|
.up = implicit_tool_up,
|
||||||
|
@ -796,11 +799,11 @@ const struct wlr_tablet_tool_v2_grab_interface implicit_tool_interface = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static bool tool_has_implicit_grab(struct wlr_tablet_v2_tablet_tool *tool) {
|
static bool tool_has_implicit_grab(struct wlr_tablet_v2_tablet_tool *tool) {
|
||||||
return tool->grab->interface == &implicit_tool_interface;
|
return tool->grab->interface == &implicit_tool_grab_interface;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wlr_tablet_tool_v2_start_implicit_grab(struct wlr_tablet_v2_tablet_tool *tool) {
|
void wlr_tablet_tool_v2_start_implicit_grab(
|
||||||
/* Durr */
|
struct wlr_tablet_v2_tablet_tool *tool) {
|
||||||
if (tool_has_implicit_grab(tool) || !tool->focused_surface) {
|
if (tool_has_implicit_grab(tool) || !tool->focused_surface) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -816,7 +819,7 @@ void wlr_tablet_tool_v2_start_implicit_grab(struct wlr_tablet_v2_tablet_tool *to
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
grab->interface = &implicit_tool_interface;
|
grab->interface = &implicit_tool_grab_interface;
|
||||||
grab->tool = tool;
|
grab->tool = tool;
|
||||||
struct implicit_grab_state *state = calloc(1, sizeof(struct implicit_grab_state));
|
struct implicit_grab_state *state = calloc(1, sizeof(struct implicit_grab_state));
|
||||||
if (!state) {
|
if (!state) {
|
||||||
|
|
Loading…
Reference in New Issue