Add seat selection

vencrypt
Andri Yngvason 2019-12-31 13:55:25 +00:00
parent 8444adc8d5
commit a6f979e93a
6 changed files with 190 additions and 24 deletions

View File

@ -34,7 +34,7 @@ struct pointer {
uint32_t height;
};
int pointer_init(struct pointer* self);
int pointer_init(struct pointer* self, struct wl_seat* seat);
void pointer_destroy(struct pointer* self);
void pointer_set(struct pointer* self, uint32_t x, uint32_t y,

35
include/seat.h 100644
View File

@ -0,0 +1,35 @@
/*
* Copyright (c) 2019 Andri Yngvason
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
* REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
* AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
* INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
* LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
* OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
* PERFORMANCE OF THIS SOFTWARE.
*/
#pragma once
#include <stdint.h>
#include <wayland-client.h>
struct seat {
struct wl_seat* wl_seat;
struct wl_list link;
uint32_t capabilities;
char name[256];
};
struct seat* seat_new(struct wl_seat* wl_seat);
void seat_destroy(struct seat* self);
void seat_list_destroy(struct wl_list* list);
struct seat* seat_find_by_name(struct wl_list* list, const char* name);
struct seat* seat_first(struct wl_list* list);

View File

@ -49,6 +49,7 @@ sources = [
'src/output.c',
'src/pointer.c',
'src/keyboard.c',
'src/seat.c',
'src/smooth.c',
]

View File

@ -44,6 +44,7 @@
#include "output.h"
#include "pointer.h"
#include "keyboard.h"
#include "seat.h"
#define DEFAULT_ADDRESS "127.0.0.1"
#define DEFAULT_PORT 5900
@ -58,12 +59,13 @@ struct wayvnc {
struct wl_display* display;
struct wl_registry* registry;
struct wl_list outputs;
struct wl_seat* seat;
struct wl_list seats;
struct zwp_virtual_keyboard_manager_v1* keyboard_manager;
struct renderer renderer;
const struct output* selected_output;
const struct seat* selected_seat;
struct dmabuf_capture dmabuf_backend;
struct screencopy screencopy_backend;
@ -163,8 +165,18 @@ static void registry_add(void* data, struct wl_registry* registry,
}
if (strcmp(interface, wl_seat_interface.name) == 0) {
self->seat =
struct wl_seat* wl_seat =
wl_registry_bind(registry, id, &wl_seat_interface, 7);
if (!wl_seat)
return;
struct seat* seat = seat_new(wl_seat);
if (!seat) {
wl_seat_destroy(wl_seat);
return;
}
wl_list_insert(&self->seats, &seat->link);
return;
}
@ -194,8 +206,8 @@ static void registry_remove(void* data, struct wl_registry* registry,
void wayvnc_destroy(struct wayvnc* self)
{
output_list_destroy(&self->outputs);
seat_list_destroy(&self->seats);
wl_seat_destroy(self->seat);
wl_shm_destroy(self->screencopy_backend.wl_shm);
zwp_virtual_keyboard_v1_destroy(self->keyboard_backend.virtual_keyboard);
@ -225,6 +237,7 @@ static int init_wayland(struct wayvnc* self)
return -1;
wl_list_init(&self->outputs);
wl_list_init(&self->seats);
self->registry = wl_display_get_registry(self->display);
if (!self->registry)
@ -247,23 +260,6 @@ static int init_wayland(struct wayvnc* self)
self->screencopy_backend.frame_capture.on_done = on_capture_done;
self->screencopy_backend.frame_capture.userdata = self;
if (self->pointer_backend.manager) {
self->pointer_backend.vnc = self->nvnc;
pointer_init(&self->pointer_backend);
} else {
log_error("Compositor does not support %s.\n",
zwlr_virtual_pointer_manager_v1_interface.name);
}
assert(self->seat);
assert(self->keyboard_manager);
self->keyboard_backend.virtual_keyboard =
zwp_virtual_keyboard_manager_v1_create_virtual_keyboard(
self->keyboard_manager, self->seat);
keyboard_init(&self->keyboard_backend, self->kb_layout);
return 0;
export_manager_failure:
@ -509,6 +505,7 @@ int wayvnc_usage(FILE* stream, int rc)
" -c,--frame-capturing=screencopy|dmabuf Select frame capturing backend.\n"
" -o,--output=<id> Select output to capture.\n"
" -k,--keyboard=<layout> Select keyboard layout.\n"
" -s,--seat=<name> Select seat by name.\n"
" -h,--help Get help (this text).\n"
"\n";
@ -527,13 +524,15 @@ int main(int argc, char* argv[])
int output_id = -1;
enum frame_capture_backend_type fcbackend =
FRAME_CAPTURE_BACKEND_SCREENCOPY;
const char* seat_name = NULL;
static const char* shortopts = "c:o:k:h";
static const char* shortopts = "c:o:k:s:h";
static const struct option longopts[] = {
{ "frame-capturing", required_argument, NULL, 'c' },
{ "output", required_argument, NULL, 'o' },
{ "keyboard", required_argument, NULL, 'k' },
{ "seat", required_argument, NULL, 's' },
{ "help", no_argument, NULL, 'h' },
{ NULL, 0, NULL, 0 }
};
@ -559,6 +558,9 @@ int main(int argc, char* argv[])
case 'k':
self.kb_layout = optarg;
break;
case 's':
seat_name = optarg;
break;
case 'h':
return wayvnc_usage(stdout, 0);
default:
@ -600,7 +602,23 @@ int main(int argc, char* argv[])
}
}
struct seat* seat;
if (seat_name) {
seat = seat_find_by_name(&self.seats, seat_name);
if (!seat) {
log_error("No such seat\n");
goto failure;
}
} else {
seat = seat_first(&self.seats);
if (!seat) {
log_error("No seat found\n");
goto failure;
}
}
self.selected_output = out;
self.selected_seat = seat;
self.dmabuf_backend.fc.wl_output = out->wl_output;
self.screencopy_backend.frame_capture.wl_output = out->wl_output;
@ -609,6 +627,22 @@ int main(int argc, char* argv[])
self.pointer_backend.height = out->height;
}
assert(self.keyboard_manager);
self.keyboard_backend.virtual_keyboard =
zwp_virtual_keyboard_manager_v1_create_virtual_keyboard(
self.keyboard_manager, self.selected_seat->wl_seat);
keyboard_init(&self.keyboard_backend, self.kb_layout);
if (self.pointer_backend.manager) {
self.pointer_backend.vnc = self.nvnc;
pointer_init(&self.pointer_backend, self.selected_seat->wl_seat);
} else {
log_error("Compositor does not support %s.\n",
zwlr_virtual_pointer_manager_v1_interface.name);
goto failure;
}
if (renderer_init(&self.renderer, self.selected_output->width,
self.selected_output->height) < 0) {

View File

@ -23,10 +23,10 @@
#include "wlr-virtual-pointer-unstable-v1.h"
#include "time-util.h"
int pointer_init(struct pointer* self)
int pointer_init(struct pointer* self, struct wl_seat* seat)
{
self->pointer =
zwlr_virtual_pointer_manager_v1_create_virtual_pointer(self->manager, NULL);
zwlr_virtual_pointer_manager_v1_create_virtual_pointer(self->manager, seat);
zwlr_virtual_pointer_v1_axis_source(self->pointer,
WL_POINTER_AXIS_SOURCE_WHEEL);

96
src/seat.c 100644
View File

@ -0,0 +1,96 @@
/*
* Copyright (c) 2019 Andri Yngvason
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
* REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
* AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
* INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
* LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
* OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
* PERFORMANCE OF THIS SOFTWARE.
*/
#include <stdint.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <wayland-client-protocol.h>
#include <wayland-client.h>
#include "seat.h"
#include "strlcpy.h"
static void seat_capabilities(void* data, struct wl_seat* wl_seat,
uint32_t capabilities)
{
struct seat* self = data;
self->capabilities = capabilities;
}
static void seat_name(void* data, struct wl_seat* wl_seat, const char* name)
{
struct seat* self = data;
strlcpy(self->name, name, sizeof(self->name));
}
static const struct wl_seat_listener seat_listener = {
.capabilities = seat_capabilities,
.name = seat_name,
};
struct seat* seat_new(struct wl_seat* wl_seat)
{
struct seat* self = calloc(1, sizeof(*self));
if (!self)
return NULL;
self->wl_seat = wl_seat;
wl_seat_add_listener(wl_seat, &seat_listener, self);
return self;
}
void seat_destroy(struct seat* self)
{
wl_seat_destroy(self->wl_seat);
free(self);
}
void seat_list_destroy(struct wl_list* list)
{
struct seat* seat;
struct seat* tmp;
wl_list_for_each_safe(seat, tmp, list, link) {
wl_list_remove(&seat->link);
seat_destroy(seat);
}
}
struct seat* seat_find_by_name(struct wl_list* list, const char* name)
{
struct seat* seat;
wl_list_for_each(seat, list, link)
if (strcmp(seat->name, name) == 0)
return seat;
return NULL;
}
struct seat* seat_first(struct wl_list* list)
{
struct seat* seat;
wl_list_for_each(seat, list, link)
return seat;
return NULL;
}