[PATCH v4l-utils] ir-ctl: warn if keycode has multiple definitions

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Signed-off-by: Sean Young <sean@xxxxxxxx>
---
 utils/ir-ctl/ir-ctl.c | 52 ++++++++++++++++++++++++-------------------
 1 file changed, 29 insertions(+), 23 deletions(-)

diff --git a/utils/ir-ctl/ir-ctl.c b/utils/ir-ctl/ir-ctl.c
index 28d8d97a..e884b4f8 100644
--- a/utils/ir-ctl/ir-ctl.c
+++ b/utils/ir-ctl/ir-ctl.c
@@ -727,17 +727,22 @@ static error_t parse_opt(int k, char *arg, struct argp_state *state)
 	return 0;
 }
 
-// FIXME: keymaps can have multiple definitions of the same keycode
 static struct send* convert_keycode(struct keymap *map, const char *keycode)
 {
-	struct send *s;
+	struct send *s = NULL;
+	int count = 0;
+
+	for (;map; map = map->next) {
+		struct scancode_entry *se;
+		struct raw_entry *re;
 
-	while (map) {
-		struct raw_entry *re = map->raw;
-		struct scancode_entry *se = map->scancode;
+		for (re = map->raw; re; re = re->next) {
+			if (strcmp(re->keycode, keycode))
+				continue;
 
-		while (re) {
-			if (!strcmp(re->keycode, keycode)) {
+			count++;
+
+			if (!s) {
 				s = malloc(sizeof(*s) + re->raw_length * sizeof(int));
 				s->len = re->raw_length;
 				memcpy(s->buf, re->raw, s->len * sizeof(int));
@@ -745,17 +750,18 @@ static struct send* convert_keycode(struct keymap *map, const char *keycode)
 				s->is_keycode = false;
 				s->carrier = keymap_param(map, "carrier", 0);
 				s->next = NULL;
-
-				return s;
 			}
-
-			re = re->next;
 		}
 
-		while (se) {
-			if (!strcmp(se->keycode, keycode)) {
-				enum rc_proto proto;
+		for (se = map->scancode; se; se = se->next) {
+			if (strcmp(se->keycode, keycode))
+				continue;
+
+			count++;
+
+			if (!s) {
 				const char *proto_str;
+				enum rc_proto proto;
 
 				proto_str = map->variant ?: map->protocol;
 
@@ -770,17 +776,19 @@ static struct send* convert_keycode(struct keymap *map, const char *keycode)
 				s->is_scancode = true;
 				s->is_keycode = false;
 				s->next = NULL;
-
-				return s;
 			}
-
-			se = se->next;
 		}
+	}
 
-		map = map->next;
+	if (!s) {
+		fprintf(stderr, _("error: keycode `%s' not found in keymap\n"), keycode);
+		return NULL;
 	}
 
-	return NULL;
+	if (count > 1)
+		fprintf(stderr, _("warning: keycode `%s' has %d definitions in keymaps, using first\n"), keycode, count);
+
+	return s;
 }
 
 static const struct argp argp = {
@@ -1022,10 +1030,8 @@ static int lirc_send(struct arguments *args, int fd, unsigned features, struct s
 		}
 
 		f = convert_keycode(map, keycode);
-		if (!f) {
-			fprintf(stderr, _("error: keycode `%s' not found in keymap\n"), keycode);
+		if (!f)
 			return EX_DATAERR;
-		}
 	}
 
 	if (f->is_scancode) {
-- 
2.21.0




[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux