diff options
author | Thomas Jansen <mithi@mithi.net> | 2008-11-10 14:13:46 +0100 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2008-11-10 14:13:46 +0100 |
commit | 65804e73eaed005b0f8114e5c6f03fa59341a2bc (patch) | |
tree | 293df2bec18223dda8cffbc6c70c50be6ced24dc /src/lirc.c | |
parent | 237fc6e8d2a4e6d1b958fbd40322a8b99b9525d2 (diff) | |
download | mpd-65804e73eaed005b0f8114e5c6f03fa59341a2bc.tar.gz mpd-65804e73eaed005b0f8114e5c6f03fa59341a2bc.tar.xz mpd-65804e73eaed005b0f8114e5c6f03fa59341a2bc.zip |
lirc: refactored event handler
* moved lirc_event to lirc.c and split out the parts that depend on
variables in main.c into three separate functions
* changed keyboard_event accordingly to avoid duplicate code
* merged lirc_event with ncmpc_lirc_get_command
Diffstat (limited to '')
-rw-r--r-- | src/lirc.c | 28 |
1 files changed, 17 insertions, 11 deletions
diff --git a/src/lirc.c b/src/lirc.c index 4e7e423d1..aeb86650c 100644 --- a/src/lirc.c +++ b/src/lirc.c @@ -1,12 +1,13 @@ #include <lirc/lirc_client.h> #include "lirc.h" +#include "ncmpc.h" static struct lirc_config *lc = NULL; -static int lirc_socket = 0; int ncmpc_lirc_open() { char prog[] = "ncmpc"; + int lirc_socket = 0; if ((lirc_socket = lirc_init(prog, 0)) == -1) return -1; @@ -26,18 +27,23 @@ void ncmpc_lirc_close() lirc_deinit(); } -command_t ncmpc_lirc_get_command() +gboolean +lirc_event(mpd_unused GIOChannel *source, + mpd_unused GIOCondition condition, mpd_unused gpointer data) { - char *code = NULL, *cmd = NULL; + char *code, *txt; + command_t cmd; - if (lirc_nextcode(&code) != 0) - return CMD_NONE; + begin_input_event(); - if (lirc_code2char(lc, code, &cmd) != 0) - return CMD_NONE; - - if (!cmd) - return CMD_NONE; + if (lirc_nextcode(&code) == 0) { + while (lirc_code2char(lc, code, &txt) == 0 && txt != NULL) { + cmd = get_key_command_from_name(txt); + if (do_input_event(cmd) != 0) + return FALSE; + } + } - return get_key_command_from_name(cmd); + end_input_event(); + return TRUE; } |