aboutsummaryrefslogtreecommitdiffstats
path: root/src/lirc.c
diff options
context:
space:
mode:
authorThomas Jansen <mithi@mithi.net>2008-11-10 14:13:46 +0100
committerMax Kellermann <max@duempel.org>2008-11-10 14:13:46 +0100
commit65804e73eaed005b0f8114e5c6f03fa59341a2bc (patch)
tree293df2bec18223dda8cffbc6c70c50be6ced24dc /src/lirc.c
parent237fc6e8d2a4e6d1b958fbd40322a8b99b9525d2 (diff)
downloadmpd-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.c28
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;
}