X-Git-Url: http://git.ipfire.org/?a=blobdiff_plain;f=Makefile.am;h=88943f1e454caa4a3c86066d3681fdec7ecfd5c7;hb=5a528e2c6ff9735266fc2607c359e925b074bf2c;hp=8b8d5a95da218f07bb78988ddc14b0834683d893;hpb=c7f753901f45bffdf39506e4f19bba4c37659ccc;p=thirdparty%2Futil-linux.git diff --git a/Makefile.am b/Makefile.am index 8b8d5a95da..88943f1e45 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,6 +1,36 @@ -include $(top_srcdir)/config/include-Makefile.am +AM_CPPFLAGS = \ + -include config.h \ + -I$(top_srcdir)/include \ + -DLOCALEDIR=\"$(localedir)\" \ + -D_PATH_RUNSTATEDIR=\"${runstatedir}\" \ + -D_PATH_SYSCONFSTATICDIR=\"${sysconfstaticdir}\" -pkgconfigdir = $(usrlib_execdir)/pkgconfig +AM_CFLAGS = -fsigned-char $(WARN_CFLAGS) +AM_LDFLAGS = $(ASAN_LDFLAGS) + +# Add gettext stuff to the global LDADD for systems with separate libintl +# library. The LTLIBINTL is generated by AM_GNU_GETTEXT macro. +# +LDADD = $(LTLIBINTL) + +# Automake (at least up to 1.10) mishandles dist_man_MANS inside conditionals. +# Unlike with other dist primaries, the files are not distributed if the +# conditional is false. +# Work the bug around until it is fixed: +dist_noinst_DATA = $(dist_man_MANS) + +# Paths to in-tree libraries (use ul_ prefix to avoid possible collisions) Note +# that blkid.h, libmount.h, libfdisk.h and libsmartcols.h are generated and +# stored in build dirs. +# +ul_libblkid_incdir = $(top_builddir)/libblkid/src +ul_libmount_incdir = $(top_builddir)/libmount/src +ul_libsmartcols_incdir = $(top_builddir)/libsmartcols/src +ul_libfdisk_incdir = $(top_builddir)/libfdisk/src + +ul_libuuid_incdir = $(top_srcdir)/libuuid/src + +bashcompletiondir = @bashcompletiondir@ dist_noinst_HEADERS = noinst_PROGRAMS = @@ -14,32 +44,27 @@ usrlib_exec_LTLIBRARIES = bin_PROGRAMS = sbin_PROGRAMS = dist_usrbin_exec_SCRIPTS = +systemdsystemunit_DATA = +dist_bashcompletion_DATA = +check_PROGRAMS = +dist_check_SCRIPTS = + +PATHFILES = INSTALL_EXEC_HOOKS = UNINSTALL_HOOKS = INSTALL_DATA_HOOKS = +CLEAN_LOCALS = +CHECK_LOCALS = EXTRA_DIST = CLEANFILES = -MAN_DIRS = man/ru - -SUBDIRS = \ - $(MAN_DIRS) \ - disk-utils \ - fdisk \ - getopt \ - misc-utils \ - po \ - tests +SUBDIRS = po RCS_FIND_IGNORE = \( -name SCCS -o -name BitKeeper -o -name .svn -o \ -name CVS -o -name .pc -o -name .hg -o -name .git \) -prune -o -if BUILD_PARTX -SUBDIRS += partx -endif - ACLOCAL_AMFLAGS = -I m4 EXTRA_DIST += \ @@ -49,19 +74,93 @@ EXTRA_DIST += \ po/update-potfiles \ README.licensing - +include tools/Makemodule.am include include/Makemodule.am include lib/Makemodule.am include libuuid/Makemodule.am include libblkid/Makemodule.am include libmount/Makemodule.am +include libsmartcols/Makemodule.am +include libfdisk/Makemodule.am include schedutils/Makemodule.am include text-utils/Makemodule.am include term-utils/Makemodule.am include login-utils/Makemodule.am -include mount-deprecated/Makemodule.am include sys-utils/Makemodule.am +include misc-utils/Makemodule.am +include disk-utils/Makemodule.am + +include bash-completion/Makemodule.am + +include tests/Makemodule.am + +# pylibmountexec module must be installed after usrlib_exec libraries, +# otherwise the libtool relink step will fail to find libmount.la and +# will try -lmount which is possibly not available. +# +# So introduce this dependency rule: +# install-pylibmountexecLTLIBRARIES: install-usrlib_execLTLIBRARIES +@verbatim_pylibmount_dependency@ + +# +# Don't rely on configure.ac AC_CONFIG_FILES for install paths. +# +# The paths should be expanded at make time rather than configure: +# - to support 'make install prefix=/foo DESTDIR=/foo' +# - to recursively expands the paths (e.g. AC_CONFIG_FILES expands +# '@usrsbin_execdir@' to ${exec_prefix}/sbin') +# +edit_cmd = sed \ + -e 's|@prefix[@]|$(prefix)|g' \ + -e 's|@exec_prefix[@]|$(exec_prefix)|g' \ + -e 's|@sysconfdir[@]|$(sysconfdir)|g' \ + -e 's|@datadir[@]|$(datadir)|g' \ + -e 's|@sbindir[@]|$(sbindir)|g' \ + -e 's|@bindir[@]|$(bindir)|g' \ + -e 's|@docdir[@]|$(docdir)|g' \ + -e 's|@includedir[@]|$(includedir)|g' \ + -e 's|@runstatedir[@]|$(runstatedir)|g' \ + -e 's|@usrlib_execdir[@]|$(usrlib_execdir)|g' \ + -e 's|@usrbin_execdir[@]|$(usrbin_execdir)|g' \ + -e 's|@usrsbin_execdir[@]|$(usrsbin_execdir)|g' \ + -e 's|@VERSION[@]|$(VERSION)|g' \ + -e 's|@ADJTIME_PATH[@]|$(ADJTIME_PATH)|g' \ + -e 's|@LIBUUID_VERSION[@]|$(LIBUUID_VERSION)|g' \ + -e 's|@LIBMOUNT_VERSION[@]|$(LIBMOUNT_VERSION)|g' \ + -e 's|@LIBMOUNT_MAJOR_VERSION[@]|$(LIBMOUNT_MAJOR_VERSION)|g' \ + -e 's|@LIBMOUNT_MINOR_VERSION[@]|$(LIBMOUNT_MINOR_VERSION)|g' \ + -e 's|@LIBMOUNT_PATCH_VERSION[@]|$(LIBMOUNT_PATCH_VERSION)|g' \ + -e 's|@LIBSMARTCOLS_VERSION[@]|$(LIBSMARTCOLS_VERSION)|g' \ + -e 's|@LIBFDISK_PC_REQUIRES[@]|$(LIBFDISK_PC_REQUIRES)|g' \ + -e 's|@LIBFDISK_VERSION[@]|$(LIBFDISK_VERSION)|g' \ + -e 's|@LIBFDISK_MAJOR_VERSION[@]|$(LIBFDISK_MAJOR_VERSION)|g' \ + -e 's|@LIBFDISK_MINOR_VERSION[@]|$(LIBFDISK_MINOR_VERSION)|g' \ + -e 's|@LIBFDISK_PATCH_VERSION[@]|$(LIBFDISK_PATCH_VERSION)|g' \ + -e 's|@LIBBLKID_VERSION[@]|$(LIBBLKID_VERSION)|g' + +if HAVE_SELINUX +edit_cmd += -e 's|@LIBSELINUX[@]|libselinux|g' +else +edit_cmd += -e 's|@LIBSELINUX[@]||g' +endif + +if HAVE_CRYPTSETUP +edit_cmd += -e 's|@LIBCRYPTSETUP[@]|libcryptsetup|g' +else +edit_cmd += -e 's|@LIBCRYPTSETUP[@]||g' +endif + +CLEANFILES += $(PATHFILES) +EXTRA_DIST += $(PATHFILES:=.in) + +$(PATHFILES): Makefile + @ rm -f $@ $@.tmp + $(AM_V_at) $(MKDIR_P) $$(dirname $@) + $(AM_V_GEN) srcdir=''; \ + test -f ./$@.in || srcdir=$(srcdir)/; \ + $(edit_cmd) $${srcdir}$@.in >$@.tmp + @ mv $@.tmp $@ # Arrange so that .tarball-version appears only in the distribution # tarball, and never in a checked-out repository. @@ -94,11 +193,37 @@ checkxalloc: checkdecl: @ $(top_srcdir)/tools/checkdecl.sh -ENABLE_ALL = --enable-static-programs --enable-most-builds -DISTCHECK_CONFIGURE_FLAGS = --enable-gtk-doc --disable-use-tty-group \ - --disable-silent-rules $(ENABLE_ALL) \ - --with-systemdsystemunitdir=$$dc_install_base/$(systemdsystemunitdir) +checkcompletion: + @ $(top_srcdir)/tools/checkcompletion.sh $(top_srcdir) + +checkusage: + @ $(top_srcdir)/tools/checkusage.sh \ + $(bin_PROGRAMS) $(sbin_PROGRAMS) \ + $(usrbin_exec_PROGRAMS) $(usrsbin_exec_PROGRAMS) +checklibdoc: + @ $(top_srcdir)/tools/checklibdocs.sh \ + $(top_srcdir)/libmount/src/libmount.sym \ + $(top_srcdir)/libmount/docs/libmount-sections.txt + @ $(top_srcdir)/tools/checklibdocs.sh \ + $(top_srcdir)/libfdisk/src/libfdisk.sym \ + $(top_srcdir)/libfdisk/docs/libfdisk-sections.txt + @ $(top_srcdir)/tools/checklibdocs.sh \ + $(top_srcdir)/libsmartcols/src/libsmartcols.sym \ + $(top_srcdir)/libsmartcols/docs/libsmartcols-sections.txt + @ $(top_srcdir)/tools/checklibdocs.sh \ + $(top_srcdir)/libblkid/src/libblkid.sym \ + $(top_srcdir)/libblkid/docs/libblkid-sections.txt +DISTCHECK_CONFIGURE_FLAGS = \ + --disable-use-tty-group \ + --disable-silent-rules \ + --enable-all-programs \ + --disable-makeinstall-chown \ + --enable-static-programs \ + --enable-gtk-doc \ + --with-python \ + --with-bashcompletiondir=$$dc_install_base/$(bashcompletiondir) \ + --with-systemdsystemunitdir=$$dc_install_base/$(systemdsystemunitdir) BUILT_SOURCES = .version .version: @@ -115,6 +240,14 @@ $(CHANGELOG_FILE): @ echo "--------------------------------------------" >> $(CHANGELOG_FILE) @ echo >> $(CHANGELOG_FILE) $(AM_V_GEN) git log --stat v$(PREVIOUS_VERSION)..HEAD >> $(CHANGELOG_FILE) +# +# +# smatch scan -- smatch and cgcc are expected in $PATH +# +checksmatch: + $(MAKE) CHECK="smatch --data=$(abs_top_srcdir)/tools/smatch-data" CC=cgcc + +check-programs: $(check_PROGRAMS) changelog: $(CHANGELOG_FILE) @@ -124,3 +257,6 @@ uninstall-hook: $(UNINSTALL_HOOKS) install-data-hook: $(INSTALL_DATA_HOOKS) +clean-local: $(CLEAN_LOCALS) + +check-local: $(CHECK_LOCALS)