summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClaudio Takahasi <claudio.takahasi@openbossa.org>2007-02-26 17:45:51 +0000
committerClaudio Takahasi <claudio.takahasi@openbossa.org>2007-02-26 17:45:51 +0000
commit1f4fd0b880866139504a0e233c7327c8b88dbbbd (patch)
treed0b4c86d4c2174fcad84f58b052654e0d52b4e41
parente67c250c80d1da4e8210c62cf473deeb2ba4e152 (diff)
Fake input: added uinput send key/event
-rw-r--r--input/device.c34
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;