Makefile.am 4.08 KB
Newer Older
1
ACLOCAL_AMFLAGS = -I m4macros ${ACLOCAL_FLAGS}
2 3 4
# ^^^^^^^^ This has to be the first line and cannot come later in this
# Makefile.am due to some bork in some versions of autotools.

5
SUBDIRS = compatcheck doc . ext src m4macros
6 7 8
USE_LCOV=@USE_LCOV@
LCOV=@LCOV@
GENHTML=@GENHTML@
9
DISTCHECK_GTEST_CONFIGURE_FLAG=@DISTCHECK_GTEST_CONFIGURE_FLAG@
10
DISTCHECK_CRYPTO_CONFIGURE_FLAG=@DISTCHECK_CRYPTO_CONFIGURE_FLAG@
11
DISTCHECK_BOOST_CONFIGURE_FLAG=@DISTCHECK_BOOST_CONFIGURE_FLAG@
12

13 14
DISTCLEANFILES = config.report

15
# When running distcheck target, do not install the configurations
16
DISTCHECK_CONFIGURE_FLAGS = --disable-install-configurations
17

18 19 20
# Use same --with-gtest flag if set
DISTCHECK_CONFIGURE_FLAGS += $(DISTCHECK_GTEST_CONFIGURE_FLAG)

21 22 23
# Keep the crypto backend config
DISTCHECK_CONFIGURE_FLAGS += $(DISTCHECK_CRYPTO_CONFIGURE_FLAG)

24 25 26
# Keep the Boost configuration which becomes sensible
DISTCHECK_CONFIGURE_FLAGS += $(DISTCHECK_BOOST_CONFIGURE_FLAG)

27 28
dist_doc_DATA = AUTHORS COPYING ChangeLog README

29 30 31 32 33 34 35 36 37 38 39 40
.PHONY: check-valgrind check-valgrind-suppress

check-valgrind:
if HAVE_VALGRIND
	@VALGRIND_COMMAND="$(VALGRIND) -q --gen-suppressions=all --track-origins=yes --num-callers=48 --leak-check=full --fullpath-after=" \
	make -C $(abs_top_builddir) check
else
	@echo "*** Valgrind is required for check-valgrind ***"; exit 1;
endif

check-valgrind-suppress:
if HAVE_VALGRIND
41
	@VALGRIND_COMMAND="$(VALGRIND) -q --gen-suppressions=all --track-origins=yes --error-exitcode=1 --suppressions=$(abs_top_srcdir)/src/valgrind-suppressions --suppressions=$(abs_top_srcdir)/src/valgrind-suppressions.revisit --num-callers=48 --leak-check=full --fullpath-after=" \
42 43 44 45 46
	make -C $(abs_top_builddir) check
else
	@echo "*** Valgrind is required for check-valgrind-suppress ***"; exit 1;
endif

47
clean-cpp-coverage:
48 49
	@if [ $(USE_LCOV) = yes ] ; then \
		$(LCOV) --directory . --zerocounters; \
50
		rm -rf $(abs_top_srcdir)/coverage-cpp-html/; \
51
	else \
52 53
		echo "C++ code coverage not enabled at configuration time." ; \
		echo "Use: ./configure --with-lcov" ; \
54 55 56 57
	fi

perform-coverage: check

58
report-cpp-coverage:
59 60 61
	@if [ $(USE_LCOV) = yes ] ; then \
		$(LCOV) --capture --directory . --output-file all.info ; \
		$(LCOV) --remove all.info \
62 63 64 65 66
			c++/4.4\*/\* \
			c++/4.4\*/backward/\* \
			c++/4.4\*/bits/\* \
			c++/4.4\*/ext/\* \
			c++/4.4\*/\*-\*/bits/\* \
67
			boost/\* \
68
if HAVE_BOTAN
69
			botan/\* \
70
endif
71
			ext/coroutine/\* \
72
			gtest/\* \
73
			include/\* \
74 75 76 77
			log4cplus/\* \
if HAVE_OPENSSL
			openssl/\* \
endif
78 79 80 81
			unittests/\* \
			\*_unittests.cc \
			\*_unittest.cc \
			\*_unittests.h \
82
			--output report.info ; \
83 84
		sed -e "s|$(abs_top_srcdir)|$(abs_top_builddir)|g" < report.info > report.info.2 ; \
		$(GENHTML) --legend -o $(abs_top_builddir)/coverage-cpp-html report.info.2 ; \
85
		echo "Generated C++ Code Coverage report in HTML at $(abs_top_builddir)/coverage-cpp-html" ; \
86 87 88 89
	else \
		echo "C++ code coverage not enabled at configuration time." ; \
		echo "Use: ./configure --with-lcov" ; \
	fi
90

91
# for c++ test coverage
92
coverage: clean-coverage perform-coverage report-coverage
93

94
clean-coverage: clean-cpp-coverage
95

96
report-coverage: report-cpp-coverage
97

98 99
# for static C++ check using cppcheck (when available)
cppcheck:
100
	cppcheck -I./src/lib -I./src/bin --enable=all --suppressions \
101
		src/cppcheck-suppress.lst --inline-suppr \
102 103 104 105
		--quiet --error-exitcode=1 \
		--template '{file}:{line}: check_fail: {message} ({severity},{id})' \
		src

Tomek Mrugalski's avatar
Tomek Mrugalski committed
106 107 108
# These steps are necessary during installation
install-exec-hook:
	mkdir -p $(DESTDIR)${localstatedir}/log/
109
	mkdir -p $(DESTDIR)${localstatedir}/run/${PACKAGE_NAME}
Tomek Mrugalski's avatar
Tomek Mrugalski committed
110

111 112 113
### include tool to generate documentation from log message specifications
### in the distributed tarball:
EXTRA_DIST = tools/system_messages.py
Tomek Mrugalski's avatar
Tomek Mrugalski committed
114
EXTRA_DIST += tools/path_replacer.sh
115
EXTRA_DIST += tools/mk_cfgrpt.sh
116

117
#### include external sources in the distributed tarball:
118
EXTRA_DIST += ext/coroutine/coroutine.h
119 120 121

pkgconfigdir = $(libdir)/pkgconfig
pkgconfig_DATA = dns++.pc
122

123
CLEANFILES = $(abs_top_builddir)/logger_lockfile
124

125 126 127
# config.h may be included by headers supplied for building user-written
# hooks libraries, so we need to include it in the distribution.
pkginclude_HEADERS = config.h