summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnthony G. Basile <blueness@gentoo.org>2012-11-20 14:44:47 -0500
committerAnthony G. Basile <blueness@gentoo.org>2012-11-20 14:44:47 -0500
commitbcc69ef934c9d14732e16551032242fa599b44e7 (patch)
treeacc183e5e4ba09ab8893a432514b9fc5a1d78736
parent802d021d2e403862f4692ee67956e7e0160c1879 (diff)
Reintroduce keymaps build and test
This commit reintroduces code to 1) build src/keymap 2) test keymap/Makefile.am that it has all the key maps listed 3) test that all the key names in keymap/* are in <linux/input.h> 4) do a syntax check on rules/*.rules which now includes 95-keymap.rules and 95-keyboard-force-release.rules For #4, the regex expressions in rule-syntax-check.py had to be updated. They do not allow trailing comments via # comment, and I did not include that. A rule in 95-keymap.rules had to have its comment moved from the end to another line. Signed-off-by: Anthony G. Basile <blueness@gentoo.org>
-rw-r--r--Makefile.am8
-rw-r--r--configure.ac6
-rw-r--r--keymaps-force-release/Makefile.am2
-rw-r--r--keymaps/Makefile.README3
-rw-r--r--keymaps/Makefile.am4
-rw-r--r--rules/95-keymap.rules3
-rw-r--r--src/Makefile.am8
-rw-r--r--src/keymap/Makefile.am18
-rwxr-xr-xsrc/keymap/check-keymaps.sh15
-rwxr-xr-xtest/rule-syntax-check.py2
10 files changed, 40 insertions, 29 deletions
diff --git a/Makefile.am b/Makefile.am
index 1b30e1e38b..3bed25ce40 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -4,11 +4,15 @@ SUBDIRS = \
src \
rules \
hwdb \
- keymaps \
- keymaps-force-release \
docs \
test
+if ENABLE_KEYMAP
+SUBDIRS += \
+ keymaps \
+ keymaps-force-release
+endif
+
if ENABLE_MANPAGES
SUBDIRS += \
man
diff --git a/configure.ac b/configure.ac
index 492d5e33d6..7df93bfdbe 100644
--- a/configure.ac
+++ b/configure.ac
@@ -297,6 +297,8 @@ AC_CONFIG_FILES([Makefile
src/v4l_id/Makefile
src/gudev/Makefile
src/gudev/gudev-1.0.pc
+ src/keymap/Makefile
+ src/keymap/keyboard-force-release.sh
src/libudev/Makefile
src/libudev/libudev.pc
src/udev/Makefile
@@ -304,8 +306,4 @@ AC_CONFIG_FILES([Makefile
src/test/Makefile
test/Makefile])
-# src/keymap/Makefile
-# src/keymap/keyboard-force-release.sh
-#
-
AC_OUTPUT
diff --git a/keymaps-force-release/Makefile.am b/keymaps-force-release/Makefile.am
index 182a752c5c..c17017bf4b 100644
--- a/keymaps-force-release/Makefile.am
+++ b/keymaps-force-release/Makefile.am
@@ -4,7 +4,6 @@ rootprefix=@rootprefix@
udevlibexecdir=$(rootprefix)/lib/udev
udevkeymapforcereldir = $(udevlibexecdir)/keymaps/force-release
-if ENABLE_KEYMAP
dist_udevkeymapforcerel_DATA = \
dell-touchpad \
dell-xps \
@@ -12,4 +11,3 @@ dist_udevkeymapforcerel_DATA = \
samsung-other \
samsung-90x3a \
common-volume-keys
-endif
diff --git a/keymaps/Makefile.README b/keymaps/Makefile.README
new file mode 100644
index 0000000000..18bd334695
--- /dev/null
+++ b/keymaps/Makefile.README
@@ -0,0 +1,3 @@
+Because of the parsing done by src/keymap/check-keymaps.sh,
+you should not put anything in this directory except for
+keymap files and files begining with Makefile.
diff --git a/keymaps/Makefile.am b/keymaps/Makefile.am
index f2dbb42023..f3f1d9adc1 100644
--- a/keymaps/Makefile.am
+++ b/keymaps/Makefile.am
@@ -4,7 +4,6 @@ rootprefix=@rootprefix@
udevlibexecdir=$(rootprefix)/lib/udev
udevkeymapdir = $(udevlibexecdir)/keymaps
-if ENABLE_KEYMAP
dist_udevkeymap_DATA = \
acer \
acer-aspire_5720 \
@@ -66,6 +65,3 @@ dist_udevkeymap_DATA = \
toshiba-satellite_a110 \
toshiba-satellite_m30x \
zepto-znote
-
-endif
-
diff --git a/rules/95-keymap.rules b/rules/95-keymap.rules
index 506310ef70..0ae8522657 100644
--- a/rules/95-keymap.rules
+++ b/rules/95-keymap.rules
@@ -99,7 +99,8 @@ ENV{DMI_VENDOR}=="Hewlett-Packard", ATTR{[dmi/id]product_name}=="HP G62 Notebook
ENV{DMI_VENDOR}=="Hewlett-Packard", ATTR{[dmi/id]product_name}=="HP ProBook*", RUN+="keymap $name 0xF8 rfkill"
ENV{DMI_VENDOR}=="Hewlett-Packard", ATTR{[dmi/id]product_name}=="HP EliteBook 8440p", RUN+="keymap $name hewlett-packard_elitebook-8440p"
# HP Pavillion dv6315ea has empty DMI_VENDOR
-ATTR{[dmi/id]board_vendor}=="Quanta", ATTR{[dmi/id]board_name}=="30B7", ATTR{[dmi/id]board_version}=="65.2B", RUN+="keymap $name 0x88 media" # "quick play
+# quick play
+ATTR{[dmi/id]board_vendor}=="Quanta", ATTR{[dmi/id]board_name}=="30B7", ATTR{[dmi/id]board_version}=="65.2B", RUN+="keymap $name 0x88 media"
# Gateway clone of Acer Aspire One AOA110/AOA150
ENV{DMI_VENDOR}=="Gateway*", ATTR{[dmi/id]product_name}=="*AOA1*", RUN+="keymap $name acer"
diff --git a/src/Makefile.am b/src/Makefile.am
index 8b5821fa19..80097a31b3 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -16,7 +16,7 @@ SUBDIRS += \
scsi_id \
v4l_id
-#if ENABLE_KEYMAP
-#SUBDIRS += \
-# keymap
-#endif
+if ENABLE_KEYMAP
+SUBDIRS += \
+ keymap
+endif
diff --git a/src/keymap/Makefile.am b/src/keymap/Makefile.am
index 80f87f7344..942009edba 100644
--- a/src/keymap/Makefile.am
+++ b/src/keymap/Makefile.am
@@ -4,6 +4,11 @@ rootprefix=@rootprefix@
udevlibexecdir=$(rootprefix)/lib/udev
udevhomedir = $(udevlibexecdir)
+AM_CPPFLAGS = \
+ -I $(top_srcdir)/src/libudev \
+ -I $(top_srcdir)/src/udev \
+ -DUDEVLIBEXECDIR=\"$(udevlibexecdir)\"
+
udevlibexec_PROGRAMS = \
keymap
@@ -11,7 +16,10 @@ keymap_SOURCES = \
keymap.c
keymap_CPPFLAGS = \
- $(AM_CPPFLAGS) -I keymap
+ $(AM_CPPFLAGS)
+
+keymap_LDADD = \
+ $(top_builddir)/src/udev/libudev-core.la
nodist_keymap_SOURCES = \
keys-from-name.h \
@@ -35,6 +43,10 @@ CLEANFILES = \
keys-from-name.gperf \
keyboard-force-release.sh
+EXTRA_DIST = \
+ check-keymaps.sh \
+ keyboard-force-release.sh.in
+
keys.txt: Makefile
$(AM_V_at)$(MKDIR_P) $(dir $@)
$(AM_V_GEN)$(CPP) $(CFLAGS) $(AM_CPPFLAGS) $(CPPFLAGS) -dM -include linux/input.h - < /dev/null | $(AWK) '/^#define[ \t]+KEY_[^ ]+[ \t]+[0-9]/ { if ($$2 != "KEY_MAX") { print $$2 } }' | sed 's/^KEY_COFFEE$$/KEY_SCREENLOCK/' > $@
@@ -47,7 +59,3 @@ keys-from-name.h: keys-from-name.gperf Makefile
keys-to-name.h: keys.txt Makefile
$(AM_V_GEN)$(AWK) 'BEGIN{ print "const char* const key_names[KEY_CNT] = { "} { print "[" $$1 "] = \"" $$1 "\"," } END{print "};"}' < $< > $@
-
-EXTRA_DIST = \
- check-keymaps.sh \
- keyboard-force-release.sh.in
diff --git a/src/keymap/check-keymaps.sh b/src/keymap/check-keymaps.sh
index c4572745e0..e3abe672d1 100755
--- a/src/keymap/check-keymaps.sh
+++ b/src/keymap/check-keymaps.sh
@@ -3,18 +3,21 @@
# check that all key names in keymaps/* are known in <linux/input.h>
# and that all key maps listed in the rules are valid and present in
# Makefile.am
-SRCDIR=${1:-.}
-KEYLIST=${2:-src/udev/keymap/keys.txt}
-KEYMAPS_DIR=$SRCDIR/keymaps
-RULES=$SRCDIR/src/udev/keymap/95-keymap.rules
+
+SRCDIR=${1:-../..}
+KEYLIST=${2:-${SRCDIR}/src/keymap/keys.txt}
[ -e "$KEYLIST" ] || {
echo "need $KEYLIST please build first" >&2
exit 1
}
+KEYMAPS_DIR=${SRCDIR}/keymaps
+KEYMAPS_LIST=$(ls ${KEYMAPS_DIR}/* | grep -v Makefile)
+RULES=${SRCDIR}/rules/95-keymap.rules
+
missing=$(join -v 2 <(awk '{print tolower(substr($1,5))}' $KEYLIST | sort -u) \
- <(grep -hv '^#' ${KEYMAPS_DIR}/*| awk '{print $2}' | sort -u))
+ <(grep -hv '^#' ${KEYMAPS_LIST}| awk '{print $2}' | sort -u))
[ -z "$missing" ] || {
echo "ERROR: unknown key names in keymaps/*:" >&2
echo "$missing" >&2
@@ -31,7 +34,7 @@ for m in $maps; do
echo "ERROR: unknown map name in $RULES: $m" >&2
exit 1
}
- grep -q "keymaps/$m\>" $SRCDIR/Makefile.am || {
+ grep -q "$m\>" ${SRCDIR}/keymaps/Makefile.am || {
echo "ERROR: map file $m is not added to Makefile.am" >&2
exit 1
}
diff --git a/test/rule-syntax-check.py b/test/rule-syntax-check.py
index 4b602a925a..9a0db2501f 100755
--- a/test/rule-syntax-check.py
+++ b/test/rule-syntax-check.py
@@ -28,7 +28,7 @@ if len(sys.argv) < 2:
no_args_tests = re.compile('(ACTION|DEVPATH|KERNELS?|NAME|SYMLINK|SUBSYSTEMS?|DRIVERS?|TAG|RESULT|TEST)\s*(?:=|!)=\s*"([^"]*)"$')
args_tests = re.compile('(ATTRS?|ENV|TEST){([a-zA-Z0-9/_.*%-]+)}\s*(?:=|!)=\s*"([^"]*)"$')
no_args_assign = re.compile('(NAME|SYMLINK|OWNER|GROUP|MODE|TAG|PROGRAM|RUN|LABEL|GOTO|WAIT_FOR|OPTIONS|IMPORT)\s*(?:\+=|:=|=)\s*"([^"]*)"$')
-args_assign = re.compile('(ATTR|ENV|IMPORT|RUN){([a-zA-Z0-9/_.*%-]+)}\s*(=|\+=)\s*"([^"]*)"$')
+args_assign = re.compile('(ATTR|ENV|IMPORT|RUN){([][a-zA-Z0-9/_.*%-]+)}\s*(=|==|\+=)\s*"([^"]*)"$')
result = 0
buffer = ''