Skip to content

Commit

Permalink
Merge pull request #65 from tiosgz/map-pointer-output
Browse files Browse the repository at this point in the history
  • Loading branch information
Niclas authored Jul 25, 2022
2 parents 08b8f27 + a12e670 commit 1e30855
Show file tree
Hide file tree
Showing 6 changed files with 124 additions and 4 deletions.
1 change: 1 addition & 0 deletions include/input/input.h
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@

struct kiwmi_input {
struct wl_list keyboards; // struct kiwmi_keyboard::link
struct wl_list pointers; // struct kiwmi_pointer::link
struct wl_listener new_input;
struct kiwmi_cursor *cursor;
struct kiwmi_seat *seat;
Expand Down
27 changes: 27 additions & 0 deletions include/input/pointer.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
/* Copyright (c), Niclas Meyer <[email protected]>
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at https://mozilla.org/MPL/2.0/.
*/

#ifndef KIWMI_INPUT_POINTER_H
#define KIWMI_INPUT_POINTER_H

#include <wayland-server.h>
#include <wlr/types/wlr_input_device.h>

#include "server.h"

struct kiwmi_pointer {
struct wlr_input_device *device;
struct wl_list link;

struct wl_listener device_destroy;
};

struct kiwmi_pointer *
pointer_create(struct kiwmi_server *server, struct wlr_input_device *device);
void pointer_destroy(struct kiwmi_pointer *pointer);

#endif /* KIWMI_INPUT_POINTER_H */
11 changes: 10 additions & 1 deletion kiwmi/desktop/output.c
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
#include "desktop/view.h"
#include "input/cursor.h"
#include "input/input.h"
#include "input/pointer.h"
#include "server.h"

static void
Expand Down Expand Up @@ -351,9 +352,17 @@ new_output_notify(struct wl_listener *listener, void *data)
wlr_output->data = output;

struct kiwmi_cursor *cursor = server->input.cursor;

wlr_xcursor_manager_load(cursor->xcursor_manager, wlr_output->scale);

struct kiwmi_pointer *pointer;
wl_list_for_each (pointer, &server->input.pointers, link) {
if (pointer->device->output_name
&& strcmp(pointer->device->output_name, wlr_output->name) == 0) {
wlr_cursor_map_input_to_output(
cursor->cursor, pointer->device, wlr_output);
}
}

wl_list_insert(&desktop->outputs, &output->link);

wlr_output_layout_add_auto(desktop->output_layout, wlr_output);
Expand Down
21 changes: 18 additions & 3 deletions kiwmi/input/input.c
Original file line number Diff line number Diff line change
Expand Up @@ -19,13 +19,21 @@
#include "desktop/desktop.h"
#include "input/cursor.h"
#include "input/keyboard.h"
#include "input/pointer.h"
#include "input/seat.h"
#include "server.h"

static void
new_pointer(struct kiwmi_input *input, struct wlr_input_device *device)
{
wlr_cursor_attach_input_device(input->cursor->cursor, device);
struct kiwmi_server *server = wl_container_of(input, server, input);

struct kiwmi_pointer *pointer = pointer_create(server, device);
if (!pointer) {
return;
}

wl_list_insert(&input->pointers, &pointer->link);
}

static void
Expand Down Expand Up @@ -86,6 +94,7 @@ input_init(struct kiwmi_input *input)
}

wl_list_init(&input->keyboards);
wl_list_init(&input->pointers);

input->new_input.notify = new_input_notify;
wl_signal_add(&server->backend->events.new_input, &input->new_input);
Expand All @@ -99,11 +108,17 @@ void
input_fini(struct kiwmi_input *input)
{
struct kiwmi_keyboard *keyboard;
struct kiwmi_keyboard *tmp;
wl_list_for_each_safe (keyboard, tmp, &input->keyboards, link) {
struct kiwmi_keyboard *tmp_keyboard;
wl_list_for_each_safe (keyboard, tmp_keyboard, &input->keyboards, link) {
keyboard_destroy(keyboard);
}

struct kiwmi_pointer *pointer;
struct kiwmi_pointer *tmp_pointer;
wl_list_for_each_safe (pointer, tmp_pointer, &input->pointers, link) {
pointer_destroy(pointer);
}

seat_destroy(input->seat);

cursor_destroy(input->cursor);
Expand Down
67 changes: 67 additions & 0 deletions kiwmi/input/pointer.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
/* Copyright (c), Niclas Meyer <[email protected]>
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at https://mozilla.org/MPL/2.0/.
*/

#include "input/pointer.h"

#include <stdlib.h>
#include <string.h>

#include <wayland-server.h>
#include <wlr/types/wlr_cursor.h>
#include <wlr/types/wlr_input_device.h>

#include "desktop/output.h"
#include "input/cursor.h"
#include "input/input.h"
#include "server.h"

static void
pointer_destroy_notify(struct wl_listener *listener, void *UNUSED(data))
{
struct kiwmi_pointer *pointer =
wl_container_of(listener, pointer, device_destroy);

pointer_destroy(pointer);
}

struct kiwmi_pointer *
pointer_create(struct kiwmi_server *server, struct wlr_input_device *device)
{
wlr_cursor_attach_input_device(server->input.cursor->cursor, device);

struct kiwmi_pointer *pointer = malloc(sizeof(*pointer));
if (!pointer) {
return NULL;
}

pointer->device = device;

pointer->device_destroy.notify = pointer_destroy_notify;
wl_signal_add(&device->events.destroy, &pointer->device_destroy);

if (device->output_name) {
struct kiwmi_output *output;
wl_list_for_each (output, &server->desktop.outputs, link) {
if (strcmp(device->output_name, output->wlr_output->name) == 0) {
wlr_cursor_map_input_to_output(
server->input.cursor->cursor, device, output->wlr_output);
break;
}
}
}

return pointer;
}

void
pointer_destroy(struct kiwmi_pointer *pointer)
{
wl_list_remove(&pointer->device_destroy.link);
wl_list_remove(&pointer->link);

free(pointer);
}
1 change: 1 addition & 0 deletions kiwmi/meson.build
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ kiwmi_sources = files(
'input/cursor.c',
'input/input.c',
'input/keyboard.c',
'input/pointer.c',
'input/seat.c',
'luak/ipc.c',
'luak/kiwmi_cursor.c',
Expand Down

0 comments on commit 1e30855

Please sign in to comment.