Resolve the names "SW_MAX" and friends
authorPeter Hutterer <peter.hutterer@who-t.net>
Mon, 18 Jun 2018 04:18:07 +0000 (14:18 +1000)
committerPeter Hutterer <peter.hutterer@who-t.net>
Mon, 9 Jul 2018 01:57:57 +0000 (11:57 +1000)
Some of the *_MAX names are duplicates and have a real define. These were not
resolved until now.

Fixes https://gitlab.freedesktop.org/libevdev/libevdev/issues/3

Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
Reviewed-by: Benjamin Tissoires <benjamin.tissoires@gmail.com>
libevdev/make-event-names.py
test/test-event-codes.c

index faee720..38b44cf 100755 (executable)
@@ -9,7 +9,8 @@ import re
 import sys
 
 class Bits(object):
-       pass
+       def __init__(self):
+               self.max_codes = {}
 
 prefixes = [
                "EV_",
@@ -113,6 +114,12 @@ def print_lookup(bits, prefix):
        if prefix == "btn":
                names = names + btn_additional;
 
+       # We need to manually add the _MAX codes because some are
+       # duplicates
+       maxname = "%s_MAX" % (prefix.upper())
+       if maxname in duplicates:
+               names.append((bits.max_codes[maxname], maxname))
+
        for val, name in sorted(names, key=lambda e: e[1]):
                print(" { .name = \"%s\", .value = %s }," % (name, name))
 
@@ -161,9 +168,6 @@ def parse_define(bits, line):
 
        name = m.group(1)
 
-       if name in duplicates:
-               return
-
        try:
                value = int(m.group(2), 0)
        except ValueError:
@@ -173,6 +177,12 @@ def parse_define(bits, line):
                if not name.startswith(prefix):
                        continue
 
+               if name.endswith("_MAX"):
+                       bits.max_codes[name] = value
+
+               if name in duplicates:
+                       return
+
                attrname = prefix[:-1].lower()
 
                if not hasattr(bits, attrname):
index 8e85df8..8b587d9 100644 (file)
@@ -99,6 +99,21 @@ START_TEST(test_code_names_invalid)
 }
 END_TEST
 
+START_TEST(test_code_names_max)
+{
+       ck_assert_int_eq(libevdev_event_code_from_name(EV_SYN, "SYN_MAX"), SYN_MAX);
+       ck_assert_int_eq(libevdev_event_code_from_name(EV_KEY, "KEY_MAX"), KEY_MAX);
+       ck_assert_int_eq(libevdev_event_code_from_name(EV_REL, "REL_MAX"), REL_MAX);
+       ck_assert_int_eq(libevdev_event_code_from_name(EV_ABS, "ABS_MAX"), ABS_MAX);
+       ck_assert_int_eq(libevdev_event_code_from_name(EV_MSC, "MSC_MAX"), MSC_MAX);
+       ck_assert_int_eq(libevdev_event_code_from_name(EV_SW, "SW_MAX"), SW_MAX);
+       ck_assert_int_eq(libevdev_event_code_from_name(EV_LED, "LED_MAX"), LED_MAX);
+       ck_assert_int_eq(libevdev_event_code_from_name(EV_SND, "SND_MAX"), SND_MAX);
+       ck_assert_int_eq(libevdev_event_code_from_name(EV_REP, "REP_MAX"), REP_MAX);
+       ck_assert_int_eq(libevdev_event_code_from_name(EV_FF, "FF_MAX"), FF_MAX);
+}
+END_TEST
+
 START_TEST(test_properties)
 {
        struct prop {
@@ -143,6 +158,7 @@ TEST_SUITE(event_code_suite)
        tc = tcase_create("code tests");
        tcase_add_test(tc, test_code_names);
        tcase_add_test(tc, test_code_names_invalid);
+       tcase_add_test(tc, test_code_names_max);
        suite_add_tcase(s, tc);
 
        tc = tcase_create("property tests");