test_input: use new input API

Use new uterm_monitor and input API instead.

Signed-off-by: David Herrmann <dh.herrmann@googlemail.com>
This commit is contained in:
David Herrmann 2012-05-05 22:48:15 +02:00
parent 2d2c92e6c2
commit 3acc23c932

View File

@ -2,6 +2,7 @@
* test_input - Test the input system - hotplug and keypresses * test_input - Test the input system - hotplug and keypresses
* *
* Copyright (c) 2011 Ran Benita <ran234@gmail.com> * Copyright (c) 2011 Ran Benita <ran234@gmail.com>
* Copyright (c) 2012 David Herrmann <dh.herrmann@googlemail.com>
* *
* Permission is hereby granted, free of charge, to any person obtaining * Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files * a copy of this software and associated documentation files
@ -33,58 +34,63 @@
#include <string.h> #include <string.h>
#include <sys/signalfd.h> #include <sys/signalfd.h>
#include <unistd.h> #include <unistd.h>
#include <X11/keysym.h> #include <X11/keysym.h>
#include "eloop.h" #include "eloop.h"
#include "input.h"
#include "kbd.h"
#include "log.h" #include "log.h"
#include "uterm.h"
#include "test_include.h" #include "test_include.h"
extern void kbd_dev_keysym_to_string(uint32_t keysym, char *str, size_t size);
static struct ev_eloop *eloop;
static struct uterm_input *input;
/* Pressing Ctrl-\ should toggle the capturing. */ /* Pressing Ctrl-\ should toggle the capturing. */
static void sig_quit(struct ev_eloop *p, struct signalfd_siginfo *info, static void sig_quit(struct ev_eloop *p,
struct signalfd_siginfo *info,
void *data) void *data)
{ {
struct kmscon_input *input = data; if (!input)
return;
if (kmscon_input_is_asleep(input)) { if (uterm_input_is_awake(input)) {
kmscon_input_wake_up(input); uterm_input_sleep(input);
log_info("Woke Up\n");
} else {
kmscon_input_sleep(input);
log_info("Went to sleep\n"); log_info("Went to sleep\n");
} else {
uterm_input_wake_up(input);
log_info("Woke Up\n");
} }
} }
static void print_modifiers(unsigned int mods) static void print_modifiers(unsigned int mods)
{ {
if (mods & KMSCON_SHIFT_MASK) if (mods & UTERM_SHIFT_MASK)
printf("SHIFT "); printf("SHIFT ");
if (mods & KMSCON_LOCK_MASK) if (mods & UTERM_LOCK_MASK)
printf("LOCK "); printf("LOCK ");
if (mods & KMSCON_CONTROL_MASK) if (mods & UTERM_CONTROL_MASK)
printf("CONTROL "); printf("CONTROL ");
if (mods & KMSCON_MOD1_MASK) if (mods & UTERM_MOD1_MASK)
printf("MOD1 "); printf("MOD1 ");
if (mods & KMSCON_MOD2_MASK) if (mods & UTERM_MOD2_MASK)
printf("MOD2 "); printf("MOD2 ");
if (mods & KMSCON_MOD3_MASK) if (mods & UTERM_MOD3_MASK)
printf("MOD3 "); printf("MOD3 ");
if (mods & KMSCON_MOD4_MASK) if (mods & UTERM_MOD4_MASK)
printf("MOD4 "); printf("MOD4 ");
if (mods & KMSCON_MOD5_MASK) if (mods & UTERM_MOD5_MASK)
printf("MOD5 "); printf("MOD5 ");
printf("\n"); printf("\n");
} }
static void input_arrived(struct kmscon_input *input, static void input_arrived(struct uterm_input *input,
struct kmscon_input_event *ev, void *data) struct uterm_input_event *ev,
void *data)
{ {
char s[16]; char s[16];
if (ev->unicode == KMSCON_INPUT_INVALID) { if (ev->unicode == UTERM_INPUT_INVALID) {
kmscon_kbd_keysym_to_string(ev->keysym, s, sizeof(s)); kbd_dev_keysym_to_string(ev->keysym, s, sizeof(s));
printf("sym %s ", s); printf("sym %s ", s);
} else { } else {
/* /*
@ -96,11 +102,39 @@ static void input_arrived(struct kmscon_input *input,
print_modifiers(ev->mods); print_modifiers(ev->mods);
} }
static void monitor_event(struct uterm_monitor *mon,
struct uterm_monitor_event *ev,
void *data)
{
int ret;
if (ev->type == UTERM_MONITOR_NEW_SEAT) {
if (strcmp(ev->seat_name, "seat0"))
return;
ret = uterm_input_new(&input, eloop);
if (ret)
return;
ret = uterm_input_register_cb(input, input_arrived, NULL);
if (ret)
return;
uterm_input_wake_up(input);
} else if (ev->type == UTERM_MONITOR_FREE_SEAT) {
uterm_input_unregister_cb(input, input_arrived, NULL);
uterm_input_unref(input);
} else if (ev->type == UTERM_MONITOR_NEW_DEV) {
if (ev->dev_type == UTERM_MONITOR_INPUT)
uterm_input_add_dev(input, ev->dev_node);
} else if (ev->type == UTERM_MONITOR_FREE_DEV) {
if (ev->dev_type == UTERM_MONITOR_INPUT)
uterm_input_remove_dev(input, ev->dev_node);
}
}
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
int ret; int ret;
struct ev_eloop *eloop; struct uterm_monitor *mon;
struct kmscon_input *input;
ret = test_prepare(argc, argv, &eloop); ret = test_prepare(argc, argv, &eloop);
if (ret) if (ret)
@ -112,33 +146,22 @@ int main(int argc, char **argv)
goto err_exit; goto err_exit;
} }
ret = kmscon_input_new(&input); ret = uterm_monitor_new(&mon, eloop, monitor_event, NULL);
if (ret) if (ret)
goto err_exit; goto err_exit;
ret = ev_eloop_register_signal_cb(eloop, SIGQUIT, sig_quit, input); ret = ev_eloop_register_signal_cb(eloop, SIGQUIT, sig_quit, NULL);
if (ret) if (ret)
goto err_input; goto err_mon;
ret = kmscon_input_connect_eloop(input, eloop);
if (ret)
goto err_sigquit;
ret = kmscon_input_register_cb(input, input_arrived, NULL);
if (ret)
goto err_sigquit;
kmscon_input_wake_up(input);
system("stty -echo"); system("stty -echo");
uterm_monitor_scan(mon);
ev_eloop_run(eloop, -1); ev_eloop_run(eloop, -1);
system("stty echo"); system("stty echo");
kmscon_input_unregister_cb(input, input_arrived, NULL); ev_eloop_unregister_signal_cb(eloop, SIGQUIT, sig_quit, NULL);
err_sigquit: err_mon:
ev_eloop_unregister_signal_cb(eloop, SIGQUIT, sig_quit, input); uterm_monitor_unref(mon);
err_input:
kmscon_input_unref(input);
err_exit: err_exit:
test_exit(eloop); test_exit(eloop);
err_fail: err_fail: