Code

lirc: refactored event handler
[ncmpc.git] / src / lirc.c
index 4e7e423d115055776cc4beb81de8a6d34579b85c..aeb86650ca411f89f957aabbb65e6d0289e80f63 100644 (file)
@@ -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;
 }