Skip to content

Commit

Permalink
applied pointerConstraints patch
Browse files Browse the repository at this point in the history
  • Loading branch information
faerryn committed Jun 7, 2022
1 parent d3af8a4 commit 6f68632
Show file tree
Hide file tree
Showing 3 changed files with 90 additions and 2 deletions.
7 changes: 6 additions & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -23,13 +23,18 @@ LDLIBS = `pkg-config --libs $(PKGS)`
all: dwl
dwl: dwl.o util.o
$(CC) $(LDLIBS) $(LDFLAGS) -o $@ dwl.o util.o
dwl.o: dwl.c config.mk config.h client.h xdg-shell-protocol.h wlr-layer-shell-unstable-v1-protocol.h idle-protocol.h
dwl.o: dwl.c config.mk config.h client.h xdg-shell-protocol.h pointer-constraints-unstable-v1-protocol.h wlr-layer-shell-unstable-v1-protocol.h idle-protocol.h
util.o: util.c util.h

# wayland scanner rules to generate .h / .c files
xdg-shell-protocol.h:
$(WAYLAND_SCANNER) server-header \
$(WAYLAND_PROTOCOLS)/stable/xdg-shell/xdg-shell.xml $@

pointer-constraints-unstable-v1-protocol.h:
$(WAYLAND_SCANNER) server-header \
$(WAYLAND_PROTOCOLS)/unstable/pointer-constraints/pointer-constraints-unstable-v1.xml $@

wlr-layer-shell-unstable-v1-protocol.h:
$(WAYLAND_SCANNER) server-header \
protocols/wlr-layer-shell-unstable-v1.xml $@
Expand Down
3 changes: 3 additions & 0 deletions config.def.h
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@ static const float rootcolor[] = {0.3, 0.3, 0.3, 1.0};
static const float bordercolor[] = {0.5, 0.5, 0.5, 1.0};
static const float focuscolor[] = {1.0, 0.0, 0.0, 1.0};

/* pointer constraints */
static const int allow_constrain = 1;

/* tagging */
static const char *tags[] = { "1", "2", "3", "4", "5", "6", "7", "8", "9" };

Expand Down
82 changes: 81 additions & 1 deletion dwl.c
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
* See LICENSE file for copyright and license details.
*/
#define _POSIX_C_SOURCE 200809L
#include <assert.h>
#include <getopt.h>
#include <libinput.h>
#include <linux/input-event-codes.h>
Expand Down Expand Up @@ -33,8 +34,10 @@
#include <wlr/types/wlr_output_management_v1.h>
#include <wlr/types/wlr_pointer.h>
#include <wlr/types/wlr_presentation_time.h>
#include <wlr/types/wlr_pointer_constraints_v1.h>
#include <wlr/types/wlr_primary_selection.h>
#include <wlr/types/wlr_primary_selection_v1.h>
#include <wlr/types/wlr_relative_pointer_v1.h>
#include <wlr/types/wlr_scene.h>
#include <wlr/types/wlr_screencopy_v1.h>
#include <wlr/types/wlr_seat.h>
Expand Down Expand Up @@ -195,6 +198,14 @@ typedef struct {
enum wl_output_transform rr;
} MonitorRule;

struct pointer_constraint {
struct wlr_pointer_constraint_v1 *constraint;

struct wl_listener set_region;
struct wl_listener destroy;
};


typedef struct {
const char *id;
const char *title;
Expand Down Expand Up @@ -228,17 +239,20 @@ static void createlayersurface(struct wl_listener *listener, void *data);
static void createmon(struct wl_listener *listener, void *data);
static void createnotify(struct wl_listener *listener, void *data);
static void createpointer(struct wlr_input_device *device);
static void createpointerconstraint(struct wl_listener *listener, void *data);
static void cursorframe(struct wl_listener *listener, void *data);
static void destroyidleinhibitor(struct wl_listener *listener, void *data);
static void destroylayersurfacenotify(struct wl_listener *listener, void *data);
static void destroynotify(struct wl_listener *listener, void *data);
static void destroypointerconstraint(struct wl_listener *listener, void *data);
static Monitor *dirtomon(enum wlr_direction dir);
static void dragicondestroy(struct wl_listener *listener, void *data);
static void focusclient(Client *c, int lift);
static void focusmon(const Arg *arg);
static void focusstack(const Arg *arg);
static Client *focustop(Monitor *m);
static void fullscreennotify(struct wl_listener *listener, void *data);
static void handleconstraintcommit(struct wl_listener *listener, void *data);
static void incnmaster(const Arg *arg);
static void inputdevice(struct wl_listener *listener, void *data);
static int keybinding(uint32_t mods, xkb_keysym_t sym);
Expand Down Expand Up @@ -332,6 +346,11 @@ static struct wlr_box sgeom;
static struct wl_list mons;
static Monitor *selmon;

struct wlr_pointer_constraints_v1 *pointer_constraints;
struct wlr_pointer_constraint_v1 *active_constraint;
static struct wl_listener constraint_commit;
struct wlr_relative_pointer_manager_v1 *relative_pointer_manager;

/* global event handlers */
static struct wl_listener cursor_axis = {.notify = axisnotify};
static struct wl_listener cursor_button = {.notify = buttonpress};
Expand All @@ -345,6 +364,7 @@ static struct wl_listener new_input = {.notify = inputdevice};
static struct wl_listener new_virtual_keyboard = {.notify = virtualkeyboard};
static struct wl_listener new_output = {.notify = createmon};
static struct wl_listener new_xdg_surface = {.notify = createnotify};
static struct wl_listener pointer_constraint_create = {.notify = createpointerconstraint};
static struct wl_listener new_layer_shell_surface = {.notify = createlayersurface};
static struct wl_listener output_mgr_apply = {.notify = outputmgrapply};
static struct wl_listener output_mgr_test = {.notify = outputmgrtest};
Expand Down Expand Up @@ -958,6 +978,28 @@ createmon(struct wl_listener *listener, void *data)
}
}

void
createpointerconstraint(struct wl_listener *listener, void *data)
{
struct wlr_pointer_constraint_v1 *constraint = data;
struct pointer_constraint *pointer_constraint = calloc(1, sizeof(struct pointer_constraint));
pointer_constraint->constraint = constraint;

pointer_constraint->destroy.notify = destroypointerconstraint;
wl_signal_add(&constraint->events.destroy, &pointer_constraint->destroy);

if (client_surface(selclient()) == constraint->surface) {
if (allow_constrain == 0 || active_constraint == constraint)
return;

active_constraint = constraint;
wlr_pointer_constraint_v1_send_activated(constraint);

constraint_commit.notify = handleconstraintcommit;
wl_signal_add(&constraint->surface->events.commit, &constraint_commit);
}
}

void
createnotify(struct wl_listener *listener, void *data)
{
Expand Down Expand Up @@ -1038,6 +1080,25 @@ createpointer(struct wlr_input_device *device)
wlr_cursor_attach_input_device(cursor, device);
}

void
destroypointerconstraint(struct wl_listener *listener, void *data)
{
struct wlr_pointer_constraint_v1 *constraint = data;
struct pointer_constraint *pointer_constraint = wl_container_of(listener, pointer_constraint, destroy);

wl_list_remove(&pointer_constraint->destroy.link);

if (active_constraint == constraint) {
if (constraint_commit.link.next != NULL) {
wl_list_remove(&constraint_commit.link);
}
wl_list_init(&constraint_commit.link);
active_constraint = NULL;
}

free(pointer_constraint);
}

void
cursorframe(struct wl_listener *listener, void *data)
{
Expand Down Expand Up @@ -1264,6 +1325,12 @@ fullscreennotify(struct wl_listener *listener, void *data)
setfullscreen(c, fullscreen);
}

void
handleconstraintcommit(struct wl_listener *listener, void *data)
{
assert(active_constraint->surface == data);
}

void
incnmaster(const Arg *arg)
{
Expand Down Expand Up @@ -1525,7 +1592,15 @@ motionrelative(struct wl_listener *listener, void *data)
* special configuration applied for the specific input device which
* generated the event. You can pass NULL for the device if you want to move
* the cursor around without any input. */
wlr_cursor_move(cursor, event->device, event->delta_x, event->delta_y);
wlr_relative_pointer_manager_v1_send_relative_motion(
relative_pointer_manager,
seat, (uint64_t)event->time_msec * 1000,
event->delta_x, event->delta_y, event->unaccel_dx, event->unaccel_dy);

if (!active_constraint) {
wlr_cursor_move(cursor, event->device,
event->delta_x, event->delta_y);
}
motionnotify(event->time_msec);
}

Expand Down Expand Up @@ -2059,6 +2134,11 @@ setup(void)
WLR_SERVER_DECORATION_MANAGER_MODE_SERVER);
wlr_xdg_decoration_manager_v1_create(dpy);

pointer_constraints = wlr_pointer_constraints_v1_create(dpy);
wl_signal_add(&pointer_constraints->events.new_constraint, &pointer_constraint_create);

relative_pointer_manager = wlr_relative_pointer_manager_v1_create(dpy);

/*
* Creates a cursor, which is a wlroots utility for tracking the cursor
* image shown on screen.
Expand Down

0 comments on commit 6f68632

Please sign in to comment.