CLEANFILES = \
udev-$(VERSION).tar.gz udev-$(VERSION).tar.bz2
+BUILT_SOURCES =
+
ACLOCAL_AMFLAGS = -I m4
AM_MAKEFLAGS = --no-print-directory
@ cat ChangeLog.tmp >> ChangeLog
@ rm ChangeLog.tmp
-test-run:
- cd test && ./udev-test.pl
-
test-install:
rm -rf $(PWD)/udev-test-install/
make DESTDIR=$(PWD)/udev-test-install install
rsync -av --delete libudev/docs/html/ master.kernel.org:/pub/linux/utils/kernel/hotplug/libudev/
rsync -av --delete extras/gudev/docs/html/ master.kernel.org:/pub/linux/utils/kernel/hotplug/gudev/
+INSTALL_EXEC_HOOKS = libudev-install-move-hook
+UNINSTALL_EXEC_HOOKS = libudev-uninstall-move-hook
+
include_HEADERS = libudev/libudev.h
# ------------------------------------------------------------------------------
extras_v4l_id_v4l_id_SOURCES = extras/v4l_id/v4l_id.c
extras_v4l_id_v4l_id_LDADD = libudev/libudev-private.la
+extras_hid2hci_hid2hci_SOURCES = extras/hid2hci/hid2hci.c
+extras_hid2hci_hid2hci_CPPFLAGS = $(AM_CPPFLAGS) $(LIBUSB_CFLAGS)
+extras_hid2hci_hid2hci_LDADD = libudev/libudev-private.la $(LIBUSB_LIBS)
+
+extras_udev_acl_udev_acl_SOURCES = extras/udev-acl/udev-acl.c
+extras_udev_acl_udev_acl_CPPFLAGS = $(AM_CPPFLAGS) $(GLIB_CFLAGS)
+extras_udev_acl_udev_acl_LDADD = libudev/libudev-private.la -lacl $(GLIB_LIBS)
+
+extras_usb_db_usb_db_SOURCES = extras/usb-db/usb-db.c
+extras_usb_db_usb_db_CPPFLAGS = $(AM_CPPFLAGS) -DUSB_DATABASE=\"$(USB_DATABASE)\" -DBUILD_FOR_USB
+extras_usb_db_usb_db_LDADD = libudev/libudev-private.la
+
+extras_usb_db_pci_db_SOURCES = extras/usb-db/usb-db.c
+extras_usb_db_pci_db_CPPFLAGS = $(AM_CPPFLAGS) -DPCI_DATABASE=\"$(USB_DATABASE)\" -DBUILD_FOR_PCI
+extras_usb_db_pci_db_LDADD = libudev/libudev-private.la
+
+extras_modem_modeswitch_modem_modeswitch_SOURCES =\
+ extras/modem-modeswitch/modem-modeswitch.c \
+ extras/modem-modeswitch/utils.c \
+ extras/modem-modeswitch/utils.h \
+ extras/modem-modeswitch/ma8280p_us.c \
+ extras/modem-modeswitch/ma8280p_us.h \
+ extras/modem-modeswitch/option.c \
+ extras/modem-modeswitch/option.h
+extras_modem_modeswitch_modem_modeswitch_CPPFLAGS = $(AM_CPPFLAGS) $(LIBUSB_CFLAGS)
+extras_modem_modeswitch_modem_modeswitch_LDADD = libudev/libudev-private.la $(LIBUSB_LIBS)
+
+extras_keymap_keymap_SOURCES = extras/keymap/keymap.c
+nodist_extras_keymap_keymap_SOURCES = \
+ extras/keymap/keys-from-name.h \
+ extras/keymap/keys-to-name.h
+
# ------------------------------------------------------------------------------
# Tests
# ------------------------------------------------------------------------------
+
+TESTS = test/udev-test.pl
+
check_PROGRAMS = \
libudev/test-libudev \
udev/test-udev
endif
if ENABLE_EXTRAS
+INSTALL_EXEC_HOOKS += udevacl-install-hook
+
dist_udevrules_DATA += \
rules/rules.d/75-net-description.rules \
rules/rules.d/75-tty-description.rules \
- rules/rules.d/78-sound-card.rules
+ rules/rules.d/78-sound-card.rules \
+ extras/hid2hci/70-hid2hci.rules \
+ extras/modem-modeswitch/61-option-modem-modeswitch.rules \
+ extras/modem-modeswitch/61-mobile-action.rules \
+ extras/keymap/95-keymap.rules
+
+libexec_PROGRAMS += \
+ extras/hid2hci/hid2hci \
+ extras/udev-acl/udev-acl \
+ extras/usb-db/usb-db \
+ extras/usb-db/pci-db \
+ extras/modem-modeswitch/modem-modeswitch \
+ extras/keymap/keymap
+
+dist_libexec_SCRIPTS += \
+ extras/keymap/findkeyboards
+
+BUILT_SOURCES += \
+ extras/keymap/keys-from-name.h \
+ extras/keymap/keys-to-name.h
+
+TESTS += extras/keymap/check-keymaps.sh
+
+check_DATA = extras/keymap/keys.txt
+
+CLEANFILES += \
+ extras/keymap/keys.txt \
+ extras/keymap/keys-from-name.gperf \
+ extras/keymap/keys-from-name.h \
+ extras/keymap/keys-to-name.h
+
+dist_doc_DATA = extras/keymap/README.keymap.txt
+
+udevkeymapdir = $(libexecdir)/keymaps
+dist_udevkeymap_DATA = \
+ extras/keymap/keymaps/acer \
+ extras/keymap/keymaps/acer-aspire_5920g \
+ extras/keymap/keymaps/acer-travelmate_c300 \
+ extras/keymap/keymaps/asus \
+ extras/keymap/keymaps/compaq-e_evo \
+ extras/keymap/keymaps/dell \
+ extras/keymap/keymaps/everex-xt5000 \
+ extras/keymap/keymaps/fujitsu-amilo_pa_2548 \
+ extras/keymap/keymaps/fujitsu-amilo_pro_edition_v3505 \
+ extras/keymap/keymaps/fujitsu-amilo_pro_v3205 \
+ extras/keymap/keymaps/fujitsu-amilo_si_1520 \
+ extras/keymap/keymaps/fujitsu-esprimo_mobile_v5 \
+ extras/keymap/keymaps/fujitsu-esprimo_mobile_v6 \
+ extras/keymap/keymaps/hewlett-packard \
+ extras/keymap/keymaps/hewlett-packard-2510p_2530p \
+ extras/keymap/keymaps/hewlett-packard-compaq_elitebook \
+ extras/keymap/keymaps/hewlett-packard-pavilion \
+ extras/keymap/keymaps/hewlett-packard-presario-2100 \
+ extras/keymap/keymaps/hewlett-packard-tablet \
+ extras/keymap/keymaps/hewlett-packard-tx2 \
+ extras/keymap/keymaps/inventec-symphony_6.0_7.0 \
+ extras/keymap/keymaps/lenovo-3000 \
+ extras/keymap/keymaps/lenovo-thinkpad_x6_tablet \
+ extras/keymap/keymaps/lenovo-thinkpad_x200_tablet \
+ extras/keymap/keymaps/maxdata-pro_7000 \
+ extras/keymap/keymaps/medion-fid2060 \
+ extras/keymap/keymaps/medionnb-a555 \
+ extras/keymap/keymaps/micro-star \
+ extras/keymap/keymaps/module-asus-w3j \
+ extras/keymap/keymaps/module-ibm \
+ extras/keymap/keymaps/module-lenovo \
+ extras/keymap/keymaps/module-sony \
+ extras/keymap/keymaps/module-sony-old \
+ extras/keymap/keymaps/oqo-model2 \
+ extras/keymap/keymaps/samsung-other \
+ extras/keymap/keymaps/samsung-sq1us \
+ extras/keymap/keymaps/samsung-sx20s \
+ extras/keymap/keymaps/toshiba-satellite_a100 \
+ extras/keymap/keymaps/toshiba-satellite_a110 \
+ extras/keymap/keymaps/zepto-znote
SUBDIRS += \
- extras/udev-acl \
- extras/usb-db \
- extras/hid2hci \
- extras/keymap \
- extras/modem-modeswitch \
extras/gudev
endif
# ------------------------------------------------------------------------------
# Install and uninstall hooks
# ------------------------------------------------------------------------------
+install-exec-hook: $(INSTALL_EXEC_HOOKS)
+
+uninstall-hook: $(UNINSTALL_EXEC_HOOKS)
+
# move lib from $(libdir) to $(rootlib_execdir) and update devel link, if needed
-install-exec-hook:
+libudev-install-move-hook:
if test "$(libdir)" != "$(rootlib_execdir)"; then \
mkdir -p $(DESTDIR)$(rootlib_execdir) && \
so_img_name=$$(readlink $(DESTDIR)$(libdir)/libudev.so) && \
mv $(DESTDIR)$(libdir)/libudev.so.* $(DESTDIR)$(rootlib_execdir); \
fi
-uninstall-hook:
+libudev-uninstall-move-hook:
rm -f $(DESTDIR)$(rootlib_execdir)/libudev.so*
+udevacl-install-hook:
+ mkdir -p $(DESTDIR)$(prefix)/lib/ConsoleKit/run-session.d
+ ln -sf $(libexecdir)/udev-acl $(DESTDIR)$(prefix)/lib/ConsoleKit/run-session.d/udev-acl.ck
+
+# ------------------------------------------------------------------------------
+# Custom rules
+# ------------------------------------------------------------------------------
+
+extras/keymap/keys.txt: /usr/include/linux/input.h
+ $(AWK) '/^#define.*KEY_/ { if ($$2 != "KEY_MAX" && $$2 != "KEY_CNT") { print $$2 } }' < $< > $@
+
+extras/keymap/keys-from-name.gperf: extras/keymap/keys.txt
+ $(AWK) 'BEGIN{ print "struct key { const char* name; unsigned short id; };"; print "%null-strings"; print "%%";} { print $$1 ", " $$1 }' < $< > $@
+
+extras/keymap/keys-from-name.h: extras/keymap/keys-from-name.gperf Makefile
+ $(GPERF) -t --ignore-case -N lookup_key -H hash_key_name -p -C < $< > $@
+
+extras/keymap/keys-to-name.h: extras/keymap/keys.txt Makefile
+ $(AWK) 'BEGIN{ print "const char* const key_names[KEY_CNT] = { "} { print "[" $$1 "] = \"" $$1 "\"," } END{print "};"}' < $< > $@