diff options
author | Claudio Takahasi <claudio.takahasi@openbossa.org> | 2007-02-26 17:45:51 +0000 |
---|---|---|
committer | Claudio Takahasi <claudio.takahasi@openbossa.org> | 2007-02-26 17:45:51 +0000 |
commit | 1f4fd0b880866139504a0e233c7327c8b88dbbbd (patch) | |
tree | d0b4c86d4c2174fcad84f58b052654e0d52b4e41 /input/device.c | |
parent | e67c250c80d1da4e8210c62cf473deeb2ba4e152 (diff) |
Fake input: added uinput send key/event
Diffstat (limited to 'input/device.c')
-rw-r--r-- | input/device.c | 34 |
1 files changed, 28 insertions, 6 deletions
diff --git a/input/device.c b/input/device.c index 7cd595d0..b28ae45b 100644 --- a/input/device.c +++ b/input/device.c @@ -496,15 +496,37 @@ static int decode_key(const char *str) new_gain = strtol(&str[7], NULL, 10); if (new_gain <= gain) - key = (mode == UPDOWN_ENABLED ? KEY_DOWN : KEY_PAGEDOWN); - else key = (mode == UPDOWN_ENABLED ? KEY_UP : KEY_PAGEUP); + else + key = (mode == UPDOWN_ENABLED ? KEY_DOWN : KEY_PAGEDOWN); gain = new_gain; return key; } +static void send_event(int fd, uint16_t type, uint16_t code, int32_t value) +{ + struct uinput_event event; + + memset(&event, 0, sizeof(event)); + event.type = type; + event.code = code; + event.value = value; + + write(fd, &event, sizeof(event)); +} + +static void send_key(int fd, uint16_t key) +{ + /* Key press */ + send_event(fd, EV_KEY, key, 1); + send_event(fd, EV_SYN, SYN_REPORT, 0); + /* Key release */ + send_event(fd, EV_KEY, key, 0); + send_event(fd, EV_SYN, SYN_REPORT, 0); +} + static gboolean rfcomm_io_cb(GIOChannel *chan, GIOCondition cond, gpointer data) { struct fake_input *fake = data; @@ -530,6 +552,8 @@ static gboolean rfcomm_io_cb(GIOChannel *chan, GIOCondition cond, gpointer data) goto failed; } + debug("Received: %s", buf); + if (g_io_channel_write_chars(chan, ok, 6, &bwritten, &gerr) != G_IO_STATUS_NORMAL) { error("IO Channel write error: %s", gerr->message); @@ -538,10 +562,8 @@ static gboolean rfcomm_io_cb(GIOChannel *chan, GIOCondition cond, gpointer data) } key = decode_key(buf); - if (key != KEY_RESERVED) { - /* FIXME: send the key to uinput */ - debug("Key code: %d", key); - } + if (key != KEY_RESERVED) + send_key(fake->uinput, key); return TRUE; |