summaryrefslogtreecommitdiffstats
path: root/mk
diff options
context:
space:
mode:
Diffstat (limited to 'mk')
-rw-r--r--mk/common.mk40
-rw-r--r--mk/man.mk71
-rw-r--r--mk/release.mk87
-rw-r--r--mk/tap.mk31
-rw-r--r--mk/unittest.mk19
5 files changed, 248 insertions, 0 deletions
diff --git a/mk/common.mk b/mk/common.mk
new file mode 100644
index 0000000..ac360cc
--- /dev/null
+++ b/mk/common.mk
@@ -0,0 +1,40 @@
+#
+# Copyright 2014-2021 the Pacemaker project contributors
+#
+# The version control history for this file may have further details.
+#
+# This source code is licensed under the GNU General Public License version 2
+# or later (GPLv2+) WITHOUT ANY WARRANTY.
+#
+
+#
+# Some variables to help with silent rules
+# https://www.gnu.org/software/automake/manual/html_node/Automake-silent_002drules-Option.html
+
+V ?= $(AM_DEFAULT_VERBOSITY)
+
+# When a make command is prefixed with one of the AM_V_* macros, it may also be
+# desirable to suffix the command with this, to silence stdout.
+PCMK_quiet = $(pcmk_quiet_$(V))
+pcmk_quiet_0 = >/dev/null
+pcmk_quiet_1 =
+
+# AM_V_GEN is intended to be used in custom pattern rules, and replaces echoing
+# the command used with a more concise line with "GEN" and the name of the file
+# being generated. Our AM_V_* macros are similar but more descriptive.
+AM_V_MAN = $(am__v_MAN_$(V))
+am__v_MAN_0 = @echo " MAN $@";
+am__v_MAN_1 =
+
+AM_V_SCHEMA = $(am__v_SCHEMA_$(V))
+am__v_SCHEMA_0 = @echo " SCHEMA $@";
+am__v_SCHEMA_1 =
+
+AM_V_BOOK = $(am__v_BOOK_$(V))
+am__v_BOOK_0 = @echo " BOOK $(@:%/_build=%): $(BOOK_FORMATS)";
+am__v_BOOK_1 =
+
+MAINTAINERCLEANFILES = Makefile.in
+
+AM_CPPFLAGS = -I$(top_builddir)/include -I$(top_srcdir)/include \
+ -I$(top_builddir)/libltdl -I$(top_srcdir)/libltdl
diff --git a/mk/man.mk b/mk/man.mk
new file mode 100644
index 0000000..51dd1e6
--- /dev/null
+++ b/mk/man.mk
@@ -0,0 +1,71 @@
+#
+# Copyright 2014-2021 the Pacemaker project contributors
+#
+# The version control history for this file may have further details.
+#
+# This source code is licensed under the GNU General Public License version 2
+# or later (GPLv2+) WITHOUT ANY WARRANTY.
+#
+
+#
+# Man page builders
+#
+# We have three types of man pages:
+# - man pages for the tools
+# - man pages for OCF agents
+# - man pages for cluster properties used by daemons
+#
+# "BUILD_HELP" actually means "help2man is available", so it only controls the
+# tool man pages, which are generated by help2man. The other man pages are
+# generated via XSL transforms.
+#
+
+if BUILD_HELP
+man8_MANS = $(sbin_PROGRAMS:%=%.8) $(sbin_SCRIPTS:%=%.8)
+
+HELP2MAN_ARGS = -N --section 8 --name "Part of the Pacemaker cluster resource manager"
+
+# Some of our tools' help are just shell script invocations of another tool's
+# help. Putting the real tool in MAN8DEPS helps detect when the wrapped help
+# needs updating.
+#
+# @TODO Drop MAN8DEPS once we've moved all tool functionality to libpacemaker,
+# and all wrappers are converted from shell scripts to C code.
+%.8: % $(MAN8DEPS)
+ $(AM_V_at)chmod a+x $(abs_builddir)/$<
+ PATH=$(abs_builddir):$$PATH $(abs_builddir)/$< --version >/dev/null
+ if [ -f $(abs_srcdir)/$@.inc ]; then \
+ PATH=$(abs_builddir):$$PATH $(abs_builddir)/$< --help-all >/dev/null; \
+ else \
+ PATH=$(abs_builddir):$$PATH $(abs_builddir)/$< --help >/dev/null; \
+ fi
+ $(AM_V_MAN)if [ -f $(abs_srcdir)/$@.inc ]; then \
+ PATH=$(abs_builddir):$$PATH $(HELP2MAN) $(HELP2MAN_ARGS) \
+ -h --help-all \
+ --no-discard-stderr \
+ -i $(abs_srcdir)/$@.inc $(abs_builddir)/$< \
+ | sed -f $(top_srcdir)/tools/fix-manpages > $@ ; \
+ else \
+ PATH=$(abs_builddir):$$PATH $(HELP2MAN) $(HELP2MAN_ARGS) \
+ --no-discard-stderr \
+ $(abs_builddir)/$< --output $@ ; \
+ fi
+endif
+
+# Save raw XML meta-data from daemon executables, for later conversion into man
+# pages. (Note that more specific rules may override this for creating other
+# types of XML files.)
+%.xml: %
+ $(AM_V_at)$(abs_builddir)/$< metadata > $@
+
+# Process the raw daemon and OCF agent meta-data output using our
+# meta-data-to-docbook-XML tranform.
+%.dbook: %.xml
+ $(AM_V_at)$(XSLTPROC) --nonet --novalid --stringparam man.name $* \
+ $(DBOOK_OPTS) $(top_srcdir)/xml/ocf-meta2man.xsl \
+ $(abs_builddir)/$< > $(abs_builddir)/$@
+
+# Generate the actual man page for an OCF resource agent from the intermediate
+# docbook XML.
+%.7: %.dbook
+ $(AM_V_MAN)$(XSLTPROC) $(MANPAGE_XSLT) $(abs_builddir)/$< $(PCMK_quiet)
diff --git a/mk/release.mk b/mk/release.mk
new file mode 100644
index 0000000..7d7259c
--- /dev/null
+++ b/mk/release.mk
@@ -0,0 +1,87 @@
+#
+# Copyright 2008-2022 the Pacemaker project contributors
+#
+# The version control history for this file may have further details.
+#
+# This source code is licensed under the GNU General Public License version 2
+# or later (GPLv2+) WITHOUT ANY WARRANTY.
+#
+
+# Define variables related to release version and such
+
+COMMIT ?= HEAD
+
+# TAG defaults to DIST when in a source distribution instead of a git checkout,
+# the tag name if COMMIT is tagged, and the full commit ID otherwise.
+TAG ?= $(shell \
+ T=$$(git describe --tags --exact-match '$(COMMIT)' 2>/dev/null); \
+ [ -n "$${T}" ] && echo "$${T}" \
+ || git log --pretty=format:%H -n 1 '$(COMMIT)' 2>/dev/null \
+ || echo DIST)
+
+# If DIRTY=anything is passed to make, generated versions will end in ".mod"
+# as long as there are uncommitted changes and COMMIT is not changed from the
+# default.
+DIRTY_EXT = $(shell [ -n "$(DIRTY)" ] \
+ && [ "$(COMMIT)" == "HEAD" ] \
+ && ! git diff-index --quiet HEAD -- 2>/dev/null \
+ && echo .mod)
+
+# These can be used in case statements to avoid make interpreting parentheses
+lparen = (
+rparen = )
+
+# This will be empty if not in a git checkout
+CHECKOUT = $(shell git rev-parse --git-dir 2>/dev/null)
+
+# VERSION is set by configure, but we allow some make targets to be run without
+# running configure first, so set a reasonable default in that case.
+VERSION ?= $(shell if [ -z "$(CHECKOUT)" ]; then \
+ echo 0.0.0; \
+ else \
+ git tag -l \
+ | sed -n -e 's/^\(Pacemaker-[0-9.]*\)$$/\1/p' \
+ | sort -Vr | head -n 1; \
+ fi)
+
+# What the git tag would be for configured VERSION (such as "Pacemaker-2.1.5")
+LAST_RELEASE ?= Pacemaker-$(VERSION)
+
+# What the git tag would be for the release after the configured VERSION
+# (LAST_RELEASE stripped of its -rc* suffix if present, or with minor-minor
+# version bumped if not; this should be manually overriden when bumping
+# the major or minor version)
+NEXT_RELEASE ?= $(shell case "$(LAST_RELEASE)" in \
+ *-rc*$(rparen) \
+ echo $(LAST_RELEASE) | sed s:-rc.*:: ;; \
+ *$(rparen) \
+ echo $(LAST_RELEASE) | awk -F. \
+ '/[0-9]+\./{$$3+=1;OFS=".";print $$1,$$2,$$3}' \
+ ;; \
+ esac)
+
+# We have two make targets for creating distributions:
+#
+# - "make dist" is automake's native functionality, based on the various
+# dist/nodist make variables; it always uses the current sources
+#
+# - "make export" is a custom target based on "git archive" and relevant
+# entries from .gitattributes; it defaults to current sources but can use any
+# git tag
+#
+# Both targets use the same name for the result, though they generate different
+# contents.
+#
+# The directory is named pacemaker-<version> when in a source distribution
+# instead of a git checkout, pacemaker-<version_part_of_tag> for tagged
+# commits, and pacemaker-<short_commit> otherwise.
+top_distdir = $(PACKAGE)-$(shell \
+ case $(TAG) in \
+ DIST$(rparen) \
+ [ -n "$(VERSION)" ] && echo "$(VERSION)" \
+ || echo DIST;; \
+ Pacemaker-*$(rparen) \
+ echo '$(TAG)' | cut -c11-;; \
+ *$(rparen) \
+ git log --pretty=format:%h -n 1 '$(TAG)';; \
+ esac)$(DIRTY_EXT)
diff --git a/mk/tap.mk b/mk/tap.mk
new file mode 100644
index 0000000..da67813
--- /dev/null
+++ b/mk/tap.mk
@@ -0,0 +1,31 @@
+#
+# Copyright 2021-2022 the Pacemaker project contributors
+#
+# The version control history for this file may have further details.
+#
+# This source code is licensed under the GNU General Public License version 2
+# or later (GPLv2+) WITHOUT ANY WARRANTY.
+#
+
+AM_TESTS_ENVIRONMENT= \
+ G_DEBUG=gc-friendly \
+ MALLOC_CHECK_=2 \
+ MALLOC_PERTURB_=$$(($${RANDOM:-256} % 256))
+LOG_DRIVER = env AM_TAP_AWK='$(AWK)' $(SHELL) $(top_srcdir)/tests/tap-driver.sh
+LOG_COMPILER = $(top_srcdir)/tests/tap-test
+CLEANFILES = *.log *.trs
+
+WRAPPED = calloc \
+ endgrent \
+ fopen \
+ getenv \
+ getpid \
+ getgrent \
+ getpwnam_r \
+ readlink \
+ setenv \
+ setgrent \
+ strdup \
+ uname \
+ unsetenv
+LDFLAGS_WRAP = $(foreach fn,$(WRAPPED),-Wl,--wrap=$(fn))
diff --git a/mk/unittest.mk b/mk/unittest.mk
new file mode 100644
index 0000000..ea397f2
--- /dev/null
+++ b/mk/unittest.mk
@@ -0,0 +1,19 @@
+#
+# Copyright 2022 the Pacemaker project contributors
+#
+# The version control history for this file may have further details.
+#
+# This source code is licensed under the GNU General Public License version 2
+# or later (GPLv2+) WITHOUT ANY WARRANTY.
+#
+
+AM_CPPFLAGS = -I$(top_builddir)/include \
+ -I$(top_srcdir)/include \
+ -I$(top_srcdir)/lib/common
+
+AM_CFLAGS = -DPCMK__UNIT_TESTING
+
+AM_LDFLAGS = $(LDFLAGS_WRAP)
+
+LDADD = $(top_builddir)/lib/common/libcrmcommon_test.la \
+ -lcmocka