## Copyright (C) 2008-2023 Dirk-Jan C. Binnema ## ## This program is free software; you can redistribute it and/or modify ## it under the terms of the GNU General Public License as published by ## the Free Software Foundation; either version 3 of the License, or ## (at your option) any later version. ## ## This program is distributed in the hope that it will be useful, ## but WITHOUT ANY WARRANTY; without even the implied warranty of ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ## GNU General Public License for more details. ## ## You should have received a copy of the GNU General Public License ## along with this program; if not, write to the Free Software Foundation, ## Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. # Makefile with some useful targets for meson/ninja V ?= 0 BUILDDIR ?= $(CURDIR)/build BUILDDIR_COVERAGE ?= $(CURDIR)/build-coverage BUILDDIR_VALGRIND ?= $(CURDIR)/build-valgrind BUILDDIR_BENCHMARK ?= $(CURDIR)/build-benchmark GENHTML ?= genhtml LCOV ?= lcov MAKEINFO ?= makeinfo MESON ?= meson NINJA ?= ninja VALGRIND ?= valgrind ifneq ($(V),0) VERBOSE=--verbose endif # when MU_HACKER is set, do a debug build # MU_HACKER is for djcb & compatible developers # note that mu uses C++17, we only pass C++23 here # for the better error messages (esp. for fmt). ifneq (${MU_HACKER},) MESON_FLAGS:=$(MESON_FLAGS) '-Dbuildtype=debug' \ '-Db_sanitize=address' \ '-Dreadline=enabled' \ '-Dcpp_std=c++23' endif .PHONY: all build-valgrind .PHONY: check test test-verbose-if-fail test-valgrind test-helgrind .PHONY: benchmark coverage .PHONY: dist install uninstall clean distclean .PHONY: mu4e-doc-html # MESON_FLAGS, e.g. "-Dreadline=enabled" # examples: # 1. build with clang, and the thread-sanitizer # make clean all MESON_FLAGS="-Db_sanitize=thread" CXX=clang++ CC=clang all: $(BUILDDIR) @$(MESON) compile -C $(BUILDDIR) $(VERBOSE) @ln -sf $(BUILDDIR)/compile_commands.json $(CURDIR) || /bin/true $(BUILDDIR): @$(MESON) setup $(MESON_FLAGS) $(BUILDDIR) check: test test: all @$(MESON) test $(VERBOSE) -C $(BUILDDIR) install: $(BUILDDIR) @$(MESON) install -C $(BUILDDIR) $(VERBOSE) uninstall: $(BUILDDIR) @$(NINJA) -C $(BUILDDIR) uninstall clean: @rm -rf $(BUILDDIR) $(BUILDDIR_COVERAGE) $(BUILDDIR_VALGRIND) $(BUILDDIR_BENCHMARK) @rm -rf compile_commands.json # # below targets are just for development/testing/debugging. They may or # may not work on your system. # test-verbose-if-fail: all $(MESON) test -C $(BUILDDIR) || $(MESON) test -C $(BUILDDIR) --verbose build-valgrind: $(BUILDDIR_VALGRIND) @$(MESON) compile -C $(BUILDDIR_VALGRIND) $(VERBOSE) $(BUILDDIR_VALGRIND): @$(MESON) setup --buildtype=debug $(BUILDDIR_VALGRIND) vg_opts:=--enable-debuginfod=no --leak-check=full --error-exitcode=1 test-valgrind: export G_SLICE=always-malloc test-valgrind: export G_DEBUG=gc-friendly test-valgrind: build-valgrind @$(MESON) test -C $(BUILDDIR_VALGRIND) \ --wrap="$(VALGRIND) $(vg_opts)" \ --timeout-multiplier 100 check-valgrind: test-valgrind # we do _not_ pass helgrind; but this seems to be a false-alarm # https://gitlab.gnome.org/GNOME/glib/-/issues/2662 test-helgrind: $(BUILDDIR_VALGRIND) $(MESON) -C $(BUILDDIR_VALGRIND) test \ --wrap="$(VALGRIND) --tool=helgrind --error-exitcode=1" \ --timeout-multiplier 100 check-helgrind: test-helgrind # # benchmarking # $(BUILDDIR_BENCHMARK): @$(MESON) setup --buildtype=debugoptimized $(BUILDDIR_BENCHMARK) build-benchmark-target: $(BUILDDIR_BENCHMARK) @$(MESON) compile -C $(BUILDDIR_BENCHMARK) $(VERBOSE) benchmark: build-benchmark-target $(NINJA) -C $(BUILDDIR_BENCHMARK) benchmark # # coverage # $(BUILDDIR_COVERAGE): $(MESON) setup -Db_coverage=true --buildtype=debug $(BUILDDIR_COVERAGE) covfile:=$(BUILDDIR_COVERAGE)/meson-logs/coverage.info # generate by hand, meson's built-ins are rather inflexible coverage: $(BUILDDIR_COVERAGE) @$(MESON) compile -C $(BUILDDIR_COVERAGE) @$(MESON) test -C $(BUILDDIR_COVERAGE) $(VERBOSE) $(LCOV) --capture --directory . --output-file $(covfile) @$(LCOV) --remove $(covfile) '/usr/*' '*guile*' '*thirdparty*' '*/tests/*' '*mime-object*' --output $(covfile) @$(LCOV) --remove $(covfile) '*mu/mu/*' --output $(covfile) @mkdir -p $(BUILDDIR_COVERAGE)/meson-logs/coverage @$(GENHTML) $(covfile) --output-directory $(BUILDDIR_COVERAGE)/meson-logs/coverage/ @echo "coverage report at: file://$(BUILDDIR_COVERAGE)/meson-logs/coverage/index.html" # # misc # dist: $(BUILDDIR) $(MESON) compile -C $(BUILDDIR) $(VERBOSE) $(MESON) dist -C $(BUILDDIR) $(VERBOSE) distclean: clean HTMLPATH=${BUILDDIR}/mu4e/mu4e mu4e-doc-html: @mkdir -p ${HTMLPATH} && cp mu4e/texinfo-klare.css ${HTMLPATH} @cd mu4e; makeinfo -v -I ${BUILDDIR} -I ${BUILDDIR}/mu4e --html --css-ref=texinfo-klare.css -o ${HTMLPATH} mu4e.texi