From fed902018e218410cff5231cfae47b8f8e72bda3 Mon Sep 17 00:00:00 2001 From: Sergio Correia Date: Thu, 19 Dec 2019 14:04:06 -0300 Subject: [PATCH] Move build system to meson Also install asciidoc package in CI, so that it will build the man pages as well. --- .travis.test | 36 ++++++---- Makefile.am | 60 ----------------- README.md | 10 +-- configure.ac | 87 ------------------------- doc/meson.build | 4 ++ meson.build | 85 ++++++++++++++++++++++++ src/meson.build | 14 ++++ tests/meson.build | 22 +++++++ units/meson.build | 31 +++++++++ units/{tangd.socket.in => tangd.socket} | 0 10 files changed, 186 insertions(+), 163 deletions(-) delete mode 100644 Makefile.am delete mode 100644 configure.ac create mode 100644 doc/meson.build create mode 100644 meson.build create mode 100644 src/meson.build create mode 100644 tests/meson.build create mode 100644 units/meson.build rename units/{tangd.socket.in => tangd.socket} (100%) diff --git a/.travis.test b/.travis.test index 89b8b4b..de286cf 100644 --- a/.travis.test +++ b/.travis.test @@ -1,33 +1,47 @@ #!/bin/bash -ex +findexe() { + while [ ${#} -gt 0 ]; do + while read -r -d: path; do + [ -f "${path}/${1}" ] \ + && [ -x "${path}/${1}" ] \ + && echo "${path}/${1}" && return 0 + done <<< "${PATH}:" + shift + done + return 1 +} + PM=dnf case "$1" in centos:7) PM=yum + yum install -y yum-utils + yum -y install epel-release ;; fedora:*) rt=compiler-rt ;; esac -BUILDENV="automake autoconf libtool pkgconfig git gcc make file clang $rt" -BUILDDEP="openssl-devel zlib-devel jansson-devel jose libjose*devel http-parser-devel wget systemd which" +BUILDENV="meson pkgconfig git gcc make file clang $rt" +BUILDDEP="openssl-devel zlib-devel jansson-devel jose libjose*devel http-parser-devel wget systemd which asciidoc" $PM -y --nogpgcheck install $BUILDENV $BUILDDEP -autoreconf -if +mkdir build +cd build -if ! CFLAGS=-coverage LDFLAGS=-lgcov ./configure --prefix=/usr; then - cat ./config.log - exit 1 -fi +export CFLAGS="-g -coverage" -make -j8 -k check V=1 TESTS= - -if ! make -j8 check; then - cat ./test-suite.log +if ! meson ..; then + cat meson-logs/meson-log.txt >&2 exit 1 fi +ninja=$(findexe ninja ninja-build) +"${ninja}" test + bash <(curl -s https://codecov.io/bash) +# vim: set ts=8 shiftwidth=4 softtabstop=4 expandtab smarttab colorcolumn=80: diff --git a/Makefile.am b/Makefile.am deleted file mode 100644 index af30d2f..0000000 --- a/Makefile.am +++ /dev/null @@ -1,60 +0,0 @@ -DISTCHECK_CONFIGURE_FLAGS = --with-systemdsystemunitdir=$$dc_install_base/$(systemdsystemunitdir) -BUILT_SOURCES= -CLEANFILES= -man1_MANS= -man8_MANS= - -AM_CFLAGS = @TANG_CFLAGS@ @jose_CFLAGS@ -LDADD = @jose_LIBS@ @http_parser_LIBS@ - -cachedir = $(localstatedir)/cache/$(PACKAGE_NAME) -jwkdir = $(localstatedir)/db/$(PACKAGE_NAME) - -nodist_systemdsystemunit_DATA = \ - units/tangd@.service \ - units/tangd.socket \ - units/tangd-update.path \ - units/tangd-update.service \ - units/tangd-keygen.service - -dist_libexec_SCRIPTS = src/tangd-update src/tangd-keygen -dist_bin_SCRIPTS = src/tang-show-keys -libexec_PROGRAMS = src/tangd - -man_ADOC_FILES= \ - doc/tang-show-keys.1.adoc \ - doc/tang.8.adoc - -if HAVE_A2X -man_ROFF_FILES = $(man_ADOC_FILES:.adoc=.roff) -BUILT_SOURCES += $(man_ROFF_FILES) -CLEANFILES += $(man_ROFF_FILES) $(man_ROFF_FILES:.roff=) - -$(top_builddir)/%.roff: %.adoc - $(MKDIR_P) $$(dirname $@) - $(A2X) -f manpage $^ -D $(top_builddir)/$$(dirname $@) - $(INSTALL) -m 644 $(top_builddir)/$(@:.roff=) $(top_builddir)/$@ - -man1_MANS += doc/tang-show-keys.1 -man8_MANS += doc/tang.8 -endif - -src_tangd_SOURCES = src/http.c src/http.h src/tangd.c - -%: %.in - $(AM_V_GEN)mkdir -p "`dirname "$@"`" - $(AM_V_GEN)$(SED) \ - -e 's,@libexecdir\@,$(libexecdir),g' \ - -e 's,@jwkdir\@,$(jwkdir),g' \ - -e 's,@cachedir\@,$(cachedir),g' \ - $(srcdir)/$@.in > $@ - -AM_TESTS_ENVIRONMENT = SD_ACTIVATE="@SD_ACTIVATE@" PATH=$(srcdir)/src:$(builddir)/src:$(PATH) -TESTS = tests/adv tests/rec - -CLEANFILES += $(nodist_systemdsystemunit_DATA) -EXTRA_DIST = \ - $(foreach unit,$(nodist_systemdsystemunit_DATA),$(unit).in) \ - COPYING \ - $(TESTS) \ - $(man_ADOC_FILES) diff --git a/README.md b/README.md index 8139816..db5b7c8 100644 --- a/README.md +++ b/README.md @@ -102,14 +102,14 @@ protect. Building Tang is fairly straightforward: - $ autoreconf -if - $ ./configure --prefix=/usr --libdir=/usr/lib64 - $ make - $ sudo make install + $ mkdir build && cd build + $ meson .. --prefix=/usr + $ ninja + $ sudo ninja install You can even run the tests if you'd like: - $ make check + $ meson test ### Server Enablement diff --git a/configure.ac b/configure.ac deleted file mode 100644 index 1ab9e3b..0000000 --- a/configure.ac +++ /dev/null @@ -1,87 +0,0 @@ -AC_PREREQ(2.59) -AC_INIT(tang, 7) -AC_CANONICAL_SYSTEM -AC_PROG_CC_C99 -AC_PROG_SED - -AM_INIT_AUTOMAKE([subdir-objects foreign no-dist-gzip dist-bzip2 parallel-tests]) -AM_SILENT_RULES([yes]) -AM_PROG_CC_C_O - -PKG_PROG_PKG_CONFIG([0.25]) - -AC_CHECK_LIB([dl], [dlopen], [AC_SUBST([dl_LIBS], [-ldl])], - [AC_CHECK_LIB([dl], [dlopen], [AC_SUBST([dl_LIBS], [-ldl])], - [AC_MSG_ERROR([unable to find dlopen])])]) - -AC_CHECK_HEADER([http_parser.h], [], - [AC_MSG_ERROR([http-parser required!])], [ -#include -#ifndef HTTP_STATUS_MAP -#error HTTP_STATUS_MAP not defined! -#endif -]) - -AC_CHECK_LIB([http_parser], [http_parser_execute], - [AC_SUBST(http_parser_LIBS, [-lhttp_parser])], - [AC_MSG_ERROR([http-parser required!])]) - -PKG_CHECK_MODULES([jose], [jose >= 8]) -PKG_CHECK_MODULES([systemd], [systemd]) - -AC_ARG_WITH([systemdsystemunitdir], - [AS_HELP_STRING([--with-systemdsystemunitdir=DIR], [Directory for systemd service files])], - [], - [with_systemdsystemunitdir=$($PKG_CONFIG --variable=systemdsystemunitdir systemd)]) - -AC_SUBST([systemdsystemunitdir], [$with_systemdsystemunitdir]) - -for ac_prog in systemd-socket-activate systemd-activate; do - AC_CHECK_PROG([SD_ACTIVATE], [$ac_prog], [$as_dir/$ac_prog], [], - [$PATH$PATH_SEPARATOR$($PKG_CONFIG --variable=systemdutildir systemd)]) - test -n "$SD_ACTIVATE" && break -done - -test -n "$SD_ACTIVATE" || AC_MSG_ERROR([systemd-socket-activate required!]) - -AC_MSG_CHECKING([systemd-socket-activate inetd flag]) -if $SD_ACTIVATE --help | grep -q inetd; then - SD_ACTIVATE="$SD_ACTIVATE --inetd" - AC_MSG_RESULT([--inetd]) -else - AC_MSG_RESULT([(default)]) -fi - -AC_SUBST(SD_ACTIVATE) - -TANG_CFLAGS="\ --Wall \ --Wextra \ --Werror \ --Wstrict-aliasing \ --Wchar-subscripts \ --Wformat-security \ --Wmissing-declarations \ --Wmissing-prototypes \ --Wnested-externs \ --Wpointer-arith \ --Wshadow \ --Wsign-compare \ --Wstrict-prototypes \ --Wtype-limits \ --Wunused-function \ --Wno-missing-field-initializers \ --Wno-unused-parameter \ -" -AC_SUBST([TANG_CFLAGS]) - -AC_CHECK_PROGS(A2X, [a2x]) - -if test "x$A2X" = "x"; then - AC_MSG_WARN([asciidoc / a2x not found -- man pages will not be generated and installed]) -fi - -AM_CONDITIONAL(HAVE_A2X, [test -n "$A2X"]) - -AC_CONFIG_FILES([Makefile]) -AC_OUTPUT diff --git a/doc/meson.build b/doc/meson.build new file mode 100644 index 0000000..e60b40d --- /dev/null +++ b/doc/meson.build @@ -0,0 +1,4 @@ +mans += join_paths(meson.current_source_dir(), 'tang-show-keys.1') +mans += join_paths(meson.current_source_dir(), 'tang.8') + +# vim:set ts=2 sw=2 et: diff --git a/meson.build b/meson.build new file mode 100644 index 0000000..7f8db96 --- /dev/null +++ b/meson.build @@ -0,0 +1,85 @@ +project('tang', 'c', + version: '7', + license: 'GPL3+', + default_options: [ + 'c_std=c99', + 'prefix=/usr', + 'sysconfdir=/etc', + 'localstatedir=/var', + 'warning_level=3', + 'werror=true' + ] +) + +libexecdir = join_paths(get_option('prefix'), get_option('libexecdir')) +sysconfdir = join_paths(get_option('prefix'), get_option('sysconfdir')) +bindir = join_paths(get_option('prefix'), get_option('bindir')) +systemunitdir = join_paths(get_option('prefix'), 'lib/systemd/system') +licensedir = join_paths(get_option('prefix'), 'share', 'licenses', meson.project_name()) +cachedir = join_paths(get_option('localstatedir'), 'cache', meson.project_name()) +jwkdir = join_paths(get_option('localstatedir'), 'db', meson.project_name()) + +data = configuration_data() +data.set('libexecdir', libexecdir) +data.set('sysconfdir', sysconfdir) +data.set('systemunitdir', systemunitdir) +data.set('cachedir', cachedir) +data.set('jwkdir', jwkdir) + +add_project_arguments( + '-D_POSIX_C_SOURCE=200809L', + '-Wstrict-aliasing', + '-Wchar-subscripts', + '-Wformat-security', + '-Wmissing-declarations', + '-Wmissing-prototypes', + '-Wnested-externs', + '-Wpointer-arith', + '-Wshadow', + '-Wsign-compare', + '-Wstrict-prototypes', + '-Wtype-limits', + '-Wunused-function', + '-Wno-missing-field-initializers', + '-Wno-unused-parameter', + '-Wno-pedantic', + language: 'c' +) + +jose = dependency('jose', version: '>=8') +a2x = find_program('a2x', required: false) +compiler = meson.get_compiler('c') +if not compiler.has_header('http_parser.h') + error('http-parser devel files not found.') +endif +http_parser = compiler.find_library('http_parser') + +licenses = ['COPYING'] +libexecbins = [] +bins = [] +mans = [] +units = [] + +subdir('doc') +subdir('src') +subdir('units') +subdir('tests') + +install_data(libexecbins, install_dir: libexecdir) +install_data(bins, install_dir: bindir) +install_data(units, install_dir: systemunitdir) +install_data(licenses, install_dir: licensedir) + +if a2x.found() + foreach m : mans + custom_target(m.split('/')[-1], input: m + '.adoc', output: m.split('/')[-1], + command: [a2x, '-f', 'manpage', '-D', meson.current_build_dir(), '@INPUT@'], + install_dir: join_paths(get_option('mandir'), 'man' + m.split('.')[-1]), + install: true + ) + endforeach +else + warning('Will not build man pages due to missing a2x (asciidoc) dependency!') +endif + +# vim:set ts=2 sw=2 et: diff --git a/src/meson.build b/src/meson.build new file mode 100644 index 0000000..1eb8baf --- /dev/null +++ b/src/meson.build @@ -0,0 +1,14 @@ +tangd = executable('tangd', + 'http.h', + 'http.c', + 'tangd.c', + dependencies: [jose, http_parser], + install: true, + install_dir: libexecdir +) + +bins += join_paths(meson.current_source_dir(), 'tang-show-keys') +libexecbins += join_paths(meson.current_source_dir(), 'tangd-keygen') +libexecbins += join_paths(meson.current_source_dir(), 'tangd-update') + +# vim:set ts=2 sw=2 et: diff --git a/tests/meson.build b/tests/meson.build new file mode 100644 index 0000000..b03531d --- /dev/null +++ b/tests/meson.build @@ -0,0 +1,22 @@ +sd_activate = find_program( + 'systemd-socket-activate', + 'systemd-activate', + required: false +) + +if sd_activate.found() + env = environment() + env.prepend('PATH', + join_paths(meson.source_root(), 'src'), + join_paths(meson.build_root(), 'src'), + separator: ':' + ) + env.set('SD_ACTIVATE', sd_activate.path() + ' --inetd') + + test('adv', find_program('adv'), env: env) + test('rec', find_program('rec'), env: env) +else + warning('Will not run the tests due to missing dependencies!') +endif + +# vim:set ts=2 sw=2 et: diff --git a/units/meson.build b/units/meson.build new file mode 100644 index 0000000..ada6dd0 --- /dev/null +++ b/units/meson.build @@ -0,0 +1,31 @@ +tangd_keygen_service = configure_file( + input: 'tangd-keygen.service.in', + output: 'tangd-keygen.service', + configuration: data +) + +tangd_service = configure_file( + input: 'tangd@.service.in', + output: 'tangd@.service', + configuration: data +) + +tangd_update_path = configure_file( + input: 'tangd-update.path.in', + output: 'tangd-update.path', + configuration: data +) + +tangd_update_service = configure_file( + input: 'tangd-update.service.in', + output: 'tangd-update.service', + configuration: data +) + +units += join_paths(meson.current_source_dir(), 'tangd.socket') +units += tangd_keygen_service +units += tangd_service +units += tangd_update_path +units += tangd_update_service + +# vim:set ts=2 sw=2 et: diff --git a/units/tangd.socket.in b/units/tangd.socket similarity index 100% rename from units/tangd.socket.in rename to units/tangd.socket