parent
e12d8fb906
commit
a272608e11
6 changed files with 1326 additions and 8 deletions
@ -0,0 +1,206 @@ |
|||||||
|
# SYNOPSIS |
||||||
|
# |
||||||
|
# Check if a module exists: |
||||||
|
# AX_CXX_CHECK_QT([qt_prefix], [list-of-qt-modules], [optional-modules]) |
||||||
|
# |
||||||
|
# Abort if a module does not exist: |
||||||
|
# AX_CXX_REQUIRE_QT([qt_prefix], [list-of-qt-modules], [optional-modules]) |
||||||
|
# |
||||||
|
# DESCRIPTIONS |
||||||
|
# |
||||||
|
# qt_prefix |
||||||
|
# |
||||||
|
# Each call to AX_CXX_CHECK_QT should have a different prefix |
||||||
|
# value (with a few exceptions discussed later on). This value, |
||||||
|
# usually provided in uppercase, is used as prefix to the |
||||||
|
# variables holding the compiler flags and libraries reported by |
||||||
|
# pkg-config. |
||||||
|
# |
||||||
|
# For instance, if your prefix was to be FOO you'll be provided |
||||||
|
# two variables FOO_CFLAGS and FOO_LIBS. |
||||||
|
# |
||||||
|
# This will also be used as message during the configure checks: |
||||||
|
# checking for FOO.... |
||||||
|
# |
||||||
|
# list-of-modules |
||||||
|
# |
||||||
|
# A single call to the macro can check for the presence of one or |
||||||
|
# more qt modules; you'll see later how to make good use of this |
||||||
|
# feature. Each entry in the list can have a version comparison |
||||||
|
# specifier, with the same syntax as the Requires keyword in the |
||||||
|
# data files themselves. |
||||||
|
# |
||||||
|
# optional-modules |
||||||
|
# |
||||||
|
# Optional list of more, optional modules, e.g. modules that |
||||||
|
# exist only in Qt5, but not in Qt4, such as QtWidgets or |
||||||
|
# QtWebKitWidgets |
||||||
|
|
||||||
|
|
||||||
|
AC_DEFUN([AX_CXX_QT_TOOL], [ |
||||||
|
if test -z "$HAVE_$1"; then |
||||||
|
HAVE_$1=1 |
||||||
|
AC_MSG_CHECKING([for $2]) |
||||||
|
AC_ARG_VAR([$1], [path to Qt tool $2]) |
||||||
|
$1=${$1:-$(pkg-config --variable=$2_location Qt5Core)} |
||||||
|
$1=${$1:-$(pkg-config --variable=host_bins Qt5Core)/$2} |
||||||
|
$1=${$1:-$(pkg-config --variable=$2_location QtCore)} |
||||||
|
$1=${$1:-$(pkg-config --variable=host_bins QtCore)/$2} |
||||||
|
if ! which "${$1%% *}" > /dev/null; then |
||||||
|
if which "$2" > /dev/null; then |
||||||
|
$1=$2 |
||||||
|
else |
||||||
|
HAVE_$1=0 |
||||||
|
$1="" |
||||||
|
fi |
||||||
|
fi |
||||||
|
AC_SUBST($1) |
||||||
|
AM_CONDITIONAL(HAVE_$1, test $HAVE_$1 -eq 1) |
||||||
|
if test $HAVE_$1 -eq 1; then |
||||||
|
AC_MSG_RESULT([$$1]) |
||||||
|
else |
||||||
|
AC_MSG_RESULT([not found]) |
||||||
|
fi |
||||||
|
fi |
||||||
|
]) |
||||||
|
|
||||||
|
AC_DEFUN([AX_CXX_QT_TOOLS], [ |
||||||
|
AX_CXX_QT_TOOL(QMAKE, qmake) |
||||||
|
AX_CXX_QT_TOOL(MOC, moc) |
||||||
|
AX_CXX_QT_TOOL(UIC, uic) |
||||||
|
AX_CXX_QT_TOOL(RCC, rcc) |
||||||
|
AX_CXX_QT_TOOL(LUPDATE, lupdate) |
||||||
|
AX_CXX_QT_TOOL(LRELEASE, lrelease) |
||||||
|
]) |
||||||
|
|
||||||
|
AC_DEFUN([AX_CHECK_VALID_FLAG], [ |
||||||
|
AC_MSG_CHECKING([m4_default([$2], [for valid flag in "$1"])]) |
||||||
|
save_cxxflags="$CXXFLAGS" |
||||||
|
newflag="no" |
||||||
|
for test_flag in $1; do |
||||||
|
CXXFLAGS+=" ${test_flag}" |
||||||
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM()], [ |
||||||
|
newflag="$test_flag" |
||||||
|
AM_CXXFLAGS+=" ${test_flag}" |
||||||
|
CXXFLAGS="$save_cxxflags" |
||||||
|
break; |
||||||
|
]) |
||||||
|
CXXFLAGS="$save_cxxflags" |
||||||
|
done |
||||||
|
AC_SUBST(AM_CXXFLAGS) |
||||||
|
AC_MSG_RESULT([$newflag]) |
||||||
|
]) |
||||||
|
|
||||||
|
AC_DEFUN([AX_CHECK_QT], [ |
||||||
|
qt_modules="$2" |
||||||
|
qt_modules_optional="$3" |
||||||
|
AX_CXX_QT_TOOLS |
||||||
|
HAVE_$1=0 |
||||||
|
PKG_PROG_PKG_CONFIG |
||||||
|
PKG_CHECK_MODULES([$1]5, [${qt_modules//Qt/Qt5}], [ |
||||||
|
HAVE_$1=1 |
||||||
|
AC_DEFINE([HAVE_$1]) |
||||||
|
AM_CPPFLAGS+=" ${[$1]5_CFLAGS}" |
||||||
|
MOC_FLAGS+=" -DHAVE_$1=1 ${[$1]5_CFLAGS}" |
||||||
|
AM_CXXFLAGS+=" ${[$1]5_CFLAGS}" |
||||||
|
LIBS+=" ${[$1]5_LIBS}" |
||||||
|
PKG_REQUIREMENTS+=" ${qt_modules//Qt/Qt5}" |
||||||
|
if test -n "${qt_modules_optional}"; then |
||||||
|
PKG_CHECK_MODULES([$1]5_OPTIONAL, [${qt_modules_optional//Qt/Qt5}], [ |
||||||
|
AM_CPPFLAGS+=" ${[$1]5_OPTIONAL_CFLAGS}" |
||||||
|
MOC_FLAGS+=" ${[$1]5_OPTIONAL_CFLAGS}" |
||||||
|
AM_CXXFLAGS+=" ${[$1]5_OPTIONAL_CFLAGS}" |
||||||
|
LIBS+=" ${[$1]5_OPTIONAL_LIBS}" |
||||||
|
PKG_REQUIREMENTS+=" ${qt_modules_optional//Qt/Qt5}" |
||||||
|
], [ |
||||||
|
AC_MSG_NOTICE([Not found: ${qt_modules_optional//Qt/Qt5}]) |
||||||
|
]) |
||||||
|
fi |
||||||
|
], [ |
||||||
|
PKG_CHECK_MODULES([$1], [${qt_modules}], [ |
||||||
|
HAVE_$1=1 |
||||||
|
AC_DEFINE([HAVE_$1]) |
||||||
|
AM_CPPFLAGS+=" ${$1_CFLAGS}" |
||||||
|
MOC_FLAGS+=" -DHAVE_$1=1 ${$1_CFLAGS}" |
||||||
|
AM_CXXFLAGS+=" ${$1_CFLAGS}" |
||||||
|
LIBS+=" ${$1_LIBS}" |
||||||
|
PKG_REQUIREMENTS+=" ${qt_modules}" |
||||||
|
if test -n "$3"; then |
||||||
|
PKG_CHECK_MODULES($1_OPTIONAL, [${qt_modules_optional}], [ |
||||||
|
AM_CPPFLAGS+=" ${$1_OPTIONAL_CFLAGS}" |
||||||
|
MOC_FLAGS+=" ${$1_OPTIONAL_CFLAGS}" |
||||||
|
AM_CXXFLAGS+=" ${$1_OPTIONAL_CFLAGS}" |
||||||
|
LIBS+=" ${$1_OPTIONAL_LIBS}" |
||||||
|
PKG_REQUIREMENTS+=" ${qt_modules_optional}" |
||||||
|
], [ |
||||||
|
AC_MSG_NOTICE([Not found: ${qt_modules_optional}]) |
||||||
|
]) |
||||||
|
fi |
||||||
|
], [HAVE_$1=0]) |
||||||
|
]) |
||||||
|
AM_CONDITIONAL(HAVE_$1, test $HAVE_$1 -eq 1) |
||||||
|
AX_CHECK_VALID_FLAG([-fPIC -fPIE], [position independent code flag]) |
||||||
|
AC_SUBST(AM_CPPFLAGS) |
||||||
|
AC_SUBST(MOC_FLAGS) |
||||||
|
AC_SUBST(AM_CXXFLAGS) |
||||||
|
AC_SUBST(PKG_REQUIREMENTS) |
||||||
|
AX_ADDITIONAL_QT_RULES_HACK=' |
||||||
|
ui_%.hxx: %.ui |
||||||
|
$(UIC) -o [$][@] $< |
||||||
|
|
||||||
|
moc_%.cxx: %.hxx |
||||||
|
$(MOC) $(MOC_FLAGS) -o [$][@] $< |
||||||
|
|
||||||
|
qrc_%.cxx: %.qrc |
||||||
|
$(RCC) -o [$][@] $<' |
||||||
|
AC_SUBST(AX_ADDITIONAL_QT_RULES_HACK) |
||||||
|
]) |
||||||
|
|
||||||
|
# SYNOPSIS |
||||||
|
# |
||||||
|
# AX_CXX_CHECK_QT([qt_prefix], [list-of-qt-modules], [optional-modules]) |
||||||
|
# |
||||||
|
# DESCRIPTIONS |
||||||
|
# |
||||||
|
# qt_prefix |
||||||
|
# |
||||||
|
# Each call to AX_CXX_CHECK_QT should have a different prefix |
||||||
|
# value (with a few exceptions discussed later on). This value, |
||||||
|
# usually provided in uppercase, is used as prefix to the |
||||||
|
# variables holding the compiler flags and libraries reported by |
||||||
|
# pkg-config. |
||||||
|
# |
||||||
|
# For instance, if your prefix was to be FOO you'll be provided |
||||||
|
# two variables FOO_CFLAGS and FOO_LIBS. |
||||||
|
# |
||||||
|
# This will also be used as message during the configure checks: |
||||||
|
# checking for FOO.... |
||||||
|
# |
||||||
|
# list-of-modules |
||||||
|
# |
||||||
|
# A single call to the macro can check for the presence of one or |
||||||
|
# more qt modules; you'll see later how to make good use of this |
||||||
|
# feature. Each entry in the list can have a version comparison |
||||||
|
# specifier, with the same syntax as the Requires keyword in the |
||||||
|
# data files themselves. |
||||||
|
# |
||||||
|
# optional-modules |
||||||
|
# |
||||||
|
# Optional list of more, optional modules, e.g. modules that |
||||||
|
# exist only in Qt5, but not in Qt4, such as QtWidgets or |
||||||
|
# QtWebKitWidgets |
||||||
|
|
||||||
|
AC_DEFUN([AX_REQUIRE_QT], [ |
||||||
|
AX_CHECK_QT([$1], [$2], [$3]) |
||||||
|
if ! test "$HAVE_$1" -eq 1; then |
||||||
|
AC_MSG_ERROR([Required Qt modules not found: $2]) |
||||||
|
fi |
||||||
|
]) |
||||||
|
|
||||||
|
|
||||||
|
# Omit Qt Keywords |
||||||
|
# AX_QT_NO_KEYWORDS |
||||||
|
|
||||||
|
AC_DEFUN([AX_QT_NO_KEYWORDS], [ |
||||||
|
AM_CPPFLAGS+=" -DQT_NO_KEYWORDS" |
||||||
|
]) |
@ -0,0 +1,464 @@ |
|||||||
|
## @id $Id$ |
||||||
|
|
||||||
|
## 1 2 3 4 5 6 7 8 |
||||||
|
## 45678901234567890123456789012345678901234567890123456789012345678901234567890 |
||||||
|
|
||||||
|
# define least version number from subversion's revision number: |
||||||
|
# it is taken modulo 256 due to a bug on Apple's MacOSX |
||||||
|
m4_define(x_least, m4_esyscmd_s( |
||||||
|
SVN_REVISION="ERROR-UNDEFINED-REVISION-to-be-built-in-subdirectory-of-svn-checkout" |
||||||
|
for path in . .. ../..; do |
||||||
|
if svn info $path 2>&1 > /dev/null; then |
||||||
|
SVN_REVISION=$(LANG= svn info $path | sed -n 's/Last Changed Rev: //p') |
||||||
|
(cd $path && svn2cl) |
||||||
|
break; |
||||||
|
fi |
||||||
|
done |
||||||
|
# Mac does not support LEAST > 255 |
||||||
|
echo $ECHO_N $(($SVN_REVISION%256)) |
||||||
|
)) |
||||||
|
# define version number from subversion's revision number: |
||||||
|
# it is taken modulo 256 due to a bug on Apple's MacOSX |
||||||
|
# add to x_minor if revision number is > 256 |
||||||
|
m4_define(x_minor_fixed, m4_esyscmd_s( |
||||||
|
SVN_REVISION="ERROR-UNDEFINED-REVISION-to-be-built-in-subdirectory-of-svn-checkout" |
||||||
|
for path in . .. ../..; do |
||||||
|
if svn info $path 2>&1 > /dev/null; then |
||||||
|
SVN_REVISION=$(LANG= svn info $path | sed -n 's/Last Changed Rev: //p') |
||||||
|
(cd $path && svn2cl) |
||||||
|
break; |
||||||
|
fi |
||||||
|
done |
||||||
|
# Mac does not support LEAST > 255 |
||||||
|
echo $ECHO_N $((x_minor+$SVN_REVISION/256)) |
||||||
|
)) |
||||||
|
# setup version number |
||||||
|
m4_define(x_version, m4_esyscmd_s( |
||||||
|
echo $ECHO_N x_major.x_minor_fixed.x_least |
||||||
|
)) |
||||||
|
|
||||||
|
## bugreport mail address is taken from <user@host> in first line of AUTHORS |
||||||
|
m4_define(x_bugreport, m4_esyscmd_s( |
||||||
|
head -1 AUTHORS | \ |
||||||
|
sed -n 's,.*<\([-_.a-z0-9A-Z]*@[-_.a-z0-9A-Z]*\)>.*,\1,gp' |
||||||
|
)) |
||||||
|
|
||||||
|
m4_include(ax_check_qt.m4) |
||||||
|
|
||||||
|
AC_ALIAS([AC_DEFINE_DIR], [AX_DEFINE_DIR]) |
||||||
|
AC_DEFUN([AX_DEFINE_DIR], [ |
||||||
|
prefix_NONE= |
||||||
|
exec_prefix_NONE= |
||||||
|
test "x$prefix" = xNONE && prefix_NONE=yes && prefix=$ac_default_prefix |
||||||
|
test "x$exec_prefix" = xNONE && exec_prefix_NONE=yes && exec_prefix=$prefix |
||||||
|
dnl In Autoconf 2.60, ${datadir} refers to ${datarootdir}, which in turn |
||||||
|
dnl refers to ${prefix}. Thus we have to use `eval' twice. |
||||||
|
eval ax_define_dir="\"[$]$2\"" |
||||||
|
eval ax_define_dir="\"$ax_define_dir\"" |
||||||
|
AC_SUBST($1, "$ax_define_dir") |
||||||
|
AC_DEFINE_UNQUOTED($1, "$ax_define_dir", [$3]) |
||||||
|
test "$prefix_NONE" && prefix=NONE |
||||||
|
test "$exec_prefix_NONE" && exec_prefix=NONE |
||||||
|
]) |
||||||
|
|
||||||
|
# add target dependencies to an existing makefile.in |
||||||
|
# - parameters: |
||||||
|
# $1 = existing target |
||||||
|
# $2 = new dependency for that target |
||||||
|
# $3 = filename of makefile.in |
||||||
|
AC_DEFUN([AX_ADD_MAKEFILE_TARGET_DEP], [ |
||||||
|
sh_add_makefile_target_dep() { |
||||||
|
sed -i -e ':a;/^'${1}':.*\\$/{N;s/\\\n//;ta};s/^'${1}':.*$/& '${2}'/' "${srcdir}/${3}" |
||||||
|
if ! egrep -q "${1}:.* ${2}" "${srcdir}/${3}"; then |
||||||
|
echo "${1}: ${2}" >> "${srcdir}/${3}" |
||||||
|
fi |
||||||
|
} |
||||||
|
sh_add_makefile_target_dep "$1" "$2" "$3" |
||||||
|
if test "$1" != ".PHONY"; then |
||||||
|
sh_add_makefile_target_dep ".PHONY" "$2" "$3" |
||||||
|
fi |
||||||
|
]) |
||||||
|
|
||||||
|
# Same as AC_SUBST, but adds -Dname="value" option to CPPFLAGS |
||||||
|
# - parameters: |
||||||
|
# $1 = variable name |
||||||
|
AC_DEFUN([AX_SUBST], [ |
||||||
|
AC_SUBST([$1]) |
||||||
|
tmp_var=$(echo "${$1}" | awk 1 ORS='\\n') |
||||||
|
tmp_var=${tmp_var//\"/\\\"} |
||||||
|
tmp_var=${tmp_var//\'/\'\"\'\"\'} |
||||||
|
tmp_var=${tmp_var//#/\\#} |
||||||
|
AM_CPPFLAGS+=" '-D$1=\"${tmp_var}\"'" |
||||||
|
AC_SUBST(AM_CPPFLAGS) |
||||||
|
]) |
||||||
|
|
||||||
|
# must be called on the right position in configure.ac |
||||||
|
# |
||||||
|
# configure.ac must start with: |
||||||
|
# |
||||||
|
# m4_define(x_package_name, YOUR_PACKAGE_NAME) # project's name |
||||||
|
# m4_define(x_major, MAJOR_NUMBER) # project's major version |
||||||
|
# m4_define(x_minor, MINOR_NUMBER) # project's minor version |
||||||
|
# m4_include(ax_init_standard_project.m4) |
||||||
|
# AC_INIT(x_package_name, x_version, x_bugreport, x_package_name) |
||||||
|
# AM_INIT_AUTOMAKE([1.9 tar-pax]) |
||||||
|
# AX_INIT_STANDARD_PROJECT |
||||||
|
# |
||||||
|
# you change nothing but: YOUR_PACKAGE_NAME, MAJOR_NUMBER, MINOR_NUMBER |
||||||
|
# |
||||||
|
# configures the basic environment |
||||||
|
AC_DEFUN([AX_INIT_STANDARD_PROJECT], [ |
||||||
|
AM_CPPFLAGS+=" '-DMAKE_STRING(X)=\#X' '-DNAMESPACE=${PACKAGE_NAME}'" |
||||||
|
AX_SUBST(NUMBERS) |
||||||
|
AX_SUBST(HOME) |
||||||
|
README=$(tail -n +3 README) |
||||||
|
AX_SUBST(README) |
||||||
|
_AM_SUBST_NOTMAKE([README]) |
||||||
|
DESCRIPTION=$(head -1 README) |
||||||
|
AX_SUBST(DESCRIPTION) |
||||||
|
_AM_SUBST_NOTMAKE([DESCRIPTION]) |
||||||
|
AUTHOR=$(head -1 AUTHORS) |
||||||
|
AX_SUBST(AUTHOR) |
||||||
|
_AM_SUBST_NOTMAKE([AUTHOR]) |
||||||
|
DISTRO=$(lsb_release -sc) |
||||||
|
AX_SUBST(DISTRO) |
||||||
|
BUILD_NUMBER=${BUILD_NUMBER:-1} |
||||||
|
AX_SUBST(BUILD_NUMBER) |
||||||
|
BUILD_DATE=$(LANG= date +"%a, %d %B %Y %H:%M:%S %z") |
||||||
|
AX_SUBST(BUILD_DATE) |
||||||
|
if test -f "${PROJECT_NAME}-logo.png"; then |
||||||
|
PROJECT_LOGO="${PROJECT_NAME}-logo.png" |
||||||
|
fi |
||||||
|
AX_SUBST(PROJECT_LOGO) |
||||||
|
if test -f "${PROJECT_NAME}-icon.png"; then |
||||||
|
PROJECT_ICON="${PROJECT_NAME}-icon.png" |
||||||
|
fi |
||||||
|
AX_SUBST(PROJECT_ICON) |
||||||
|
AC_CONFIG_FILES([makefile]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([clean-am], [clean-standard-project-targets], [makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([distclean-am], [distclean-standard-project-targets], [makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([maintainer-clean-am], [maintainer-clean-standard-project-targets], [makefile.in]) |
||||||
|
test -f makefile.in && cat >> makefile.in <<EOF |
||||||
|
#### Begin: Appended by $0 |
||||||
|
EXTRA_DIST = bootstrap.sh |
||||||
|
doc_DATA = AUTHORS NEWS README COPYING INSTALL ChangeLog |
||||||
|
clean-standard-project-targets: |
||||||
|
-rm -rf \${PACKAGE_NAME}-\${PACKAGE_VERSION} |
||||||
|
-rm \${PACKAGE_TARNAME}-\${PACKAGE_VERSION}.tar.gz |
||||||
|
distclean-standard-project-targets: |
||||||
|
-rm -r autom4te.cache |
||||||
|
-rm aclocal.m4 config.guess config.sub configure depcomp compile install-sh ltmain.sh makefile missing mkinstalldirs |
||||||
|
maintainer-clean-standard-project-targets: |
||||||
|
-rm makefile.in |
||||||
|
#### End: $0 |
||||||
|
EOF |
||||||
|
]) |
||||||
|
|
||||||
|
# use this in configure.ac to support C++ |
||||||
|
AC_DEFUN([AX_USE_CXX], [ |
||||||
|
m4_include(ax_cxx_compile_stdcxx_11.m4) |
||||||
|
AC_LANG(C++) |
||||||
|
AX_CXX_COMPILE_STDCXX_11(noext, optional) |
||||||
|
AC_PROG_CXX |
||||||
|
AC_PROG_CPP |
||||||
|
|
||||||
|
AC_CONFIG_FILES([src/makefile]) |
||||||
|
|
||||||
|
AM_CPPFLAGS+=' -I ${top_srcdir}/src -I ${top_builddir}/src -I ${srcdir} -I ${builddir}' |
||||||
|
AM_LDFLAGS+=' -L ${top_srcdir}/src -L ${top_builddir}/src' |
||||||
|
|
||||||
|
# Get rid of that stupid -O2 -g opions! |
||||||
|
CXXFLAGS="${CXXFLAGS:-}" |
||||||
|
|
||||||
|
# pass compile flags to make distcheck |
||||||
|
AM_DISTCHECK_CONFIGURE_FLAGS="CXXFLAGS='${CXXFLAGS}' CPPFLAGS='${CPPFLAGS}' CFLAGS='${CFLAGS}' LDFLAGS='${LDFLAGS}'" |
||||||
|
AC_SUBST(AM_DISTCHECK_CONFIGURE_FLAGS) |
||||||
|
|
||||||
|
AC_ARG_ENABLE(pedantic, |
||||||
|
[AS_HELP_STRING([--enable-pedantic], |
||||||
|
[enable all warnings and checks, abort on warnings])], |
||||||
|
[have_pedantic="$enableval"; test "$enableval" = "yes" && \ |
||||||
|
AM_CXXFLAGS="${AM_CXXFLAGS:-} -pedantic-errors -Wall -W -Wfloat-equal -Wundef -Wendif-labels -Wpointer-arith -Wcast-align -Wwrite-strings -Wconversion -Wsign-compare -Wmissing-format-attribute -Wno-multichar -Wpacked -Wredundant-decls -Werror -Wshadow -Wcast-qual -Wno-ctor-dtor-privacy"]) |
||||||
|
dnl problem in libs: -Wshadow -Wcast-qual |
||||||
|
dnl auto.hpp: -Wno-ctor-dtor-privacy (removed) |
||||||
|
AM_CONDITIONAL(PEDANTIC, test "$enableval" = "yes") |
||||||
|
if test "$have_pedantic" == "yes"; then |
||||||
|
AC_MSG_NOTICE([Pedantic compile mode enabled! |
||||||
|
- all warnings for GNU g++ are enabled |
||||||
|
- all warnings result in an error |
||||||
|
- doxygen warnings are treated as error too]); fi |
||||||
|
|
||||||
|
MINGW32=no |
||||||
|
MAC=no |
||||||
|
case $host_os in |
||||||
|
*mingw32*) MINGW32=yes;; |
||||||
|
*darwin* | *rhapsody* | *macosx*) MAC=yes;; |
||||||
|
esac |
||||||
|
AM_CONDITIONAL(MINGW32, test "$MINGW32" = "yes") |
||||||
|
AM_CONDITIONAL(MAC, test "$MAC" = "yes") |
||||||
|
|
||||||
|
AC_SUBST(AM_CXXFLAGS) |
||||||
|
AC_SUBST(AM_CPPFLAGS) |
||||||
|
AC_SUBST(AM_LDFLAGS) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([maintainer-clean-am], [maintainer-clean-cxx-targets], [src/makefile.in]) |
||||||
|
test -f src/makefile.in && cat >> src/makefile.in <<EOF |
||||||
|
#### Begin: Appended by $0 |
||||||
|
maintainer-clean-cxx-targets: |
||||||
|
-rm makefile.in |
||||||
|
#### End: $0 |
||||||
|
EOF |
||||||
|
]) |
||||||
|
|
||||||
|
# use this in configure.ac to support CppUnit for C++ unit tests |
||||||
|
AC_DEFUN([AX_USE_CPPUNIT], [ |
||||||
|
AM_PATH_CPPUNIT([1.0.0], [have_cppunit="yes"], [have_cppunit="no"]) |
||||||
|
# infos and warnings |
||||||
|
if test "$have_cppunit" = "no"; then |
||||||
|
AC_MSG_WARN([Missing cppunit development library! |
||||||
|
- you cannot check the library using "make check" |
||||||
|
- everything else works perfectly]); fi |
||||||
|
AC_CONFIG_FILES([test/makefile]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([maintainer-clean-am], [maintainer-clean-test-targets], [test/makefile.in]) |
||||||
|
test -f test/makefile.in && cat >> test/makefile.in <<EOF |
||||||
|
#### Begin: Appended by $0 |
||||||
|
maintainer-clean-test-targets: |
||||||
|
-rm makefile.in |
||||||
|
#### End: $0 |
||||||
|
EOF |
||||||
|
]) |
||||||
|
|
||||||
|
# use this in configure.ac to support C++ examples |
||||||
|
AC_DEFUN([AX_BUILD_EXAMPLES], [ |
||||||
|
AC_CONFIG_FILES([examples/makefile]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([maintainer-clean-am], [maintainer-clean-example-targets], [examples/makefile.in]) |
||||||
|
test -f examples/makefile.in && cat >> examples/makefile.in <<EOF |
||||||
|
#### Begin: Appended by $0 |
||||||
|
maintainer-clean-example-targets: |
||||||
|
-rm makefile.in |
||||||
|
#### End: $0 |
||||||
|
EOF |
||||||
|
]) |
||||||
|
|
||||||
|
# use this in configure.ac to support C++ libraries |
||||||
|
AC_DEFUN([AX_USE_LIBTOOL], [ |
||||||
|
# libtool versioning |
||||||
|
LIB_MAJOR=m4_eval(x_major+x_minor_fixed) |
||||||
|
LIB_MINOR=x_least |
||||||
|
LIB_LEAST=x_minor_fixed |
||||||
|
LIB_VERSION="${LIB_MAJOR}:${LIB_MINOR}:${LIB_LEAST}" |
||||||
|
AM_LDFLAGS="-version-info ${LIB_VERSION}" |
||||||
|
AC_SUBST(AM_LDFLAGS) |
||||||
|
AC_SUBST(LIB_VERSION) |
||||||
|
AC_PROG_LIBTOOL |
||||||
|
AC_CONFIG_FILES([src/${PACKAGE_NAME}.pc]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([install-data-am], [install-data-libtool-pkg], [src/makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([uninstall-am], [uninstall-data-am], [src/makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([uninstall-data-am], [uninstall-data-libtool-pkg], [src/makefile.in]) |
||||||
|
test -f src/makefile.in && cat >> src/makefile.in <<EOF |
||||||
|
#### Begin: Appended by $0 |
||||||
|
install-data-libtool-pkg: |
||||||
|
test -d \$(DESTDIR)\${libdir}/pkgconfig || mkdir -p \$(DESTDIR)\${libdir}/pkgconfig |
||||||
|
chmod -R u+w \$(DESTDIR)\${libdir}/pkgconfig |
||||||
|
cp \${PACKAGE_NAME}.pc \$(DESTDIR)\${libdir}/pkgconfig/ |
||||||
|
uninstall-data-libtool-pkg: |
||||||
|
-chmod -R u+w \$(DESTDIR)\${libdir}/pkgconfig |
||||||
|
-rm -f \$(DESTDIR)\${libdir}/pkgconfig/\${PACKAGE_NAME}.pc |
||||||
|
#### End: $0 |
||||||
|
EOF |
||||||
|
]) |
||||||
|
|
||||||
|
# use this in configure.ac to support debian packages |
||||||
|
AC_DEFUN([AX_USE_DEBIAN_PACKAGING], [ |
||||||
|
README_DEB=$(tail -n +3 README | sed -e 's/^$/./g' -e 's/^/ /g') |
||||||
|
AC_SUBST(README_DEB) |
||||||
|
_AM_SUBST_NOTMAKE([README_DEB]) |
||||||
|
AC_CONFIG_FILES([debian/changelog debian/control]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([clean-am], [clean-debian-targets], [makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([distclean-am], [distclean-debian-targets], [makefile.in]) |
||||||
|
test -f makefile.in && cat >> makefile.in <<EOF |
||||||
|
#### Begin: Appended by $0 |
||||||
|
EXTRA_DIST += debian |
||||||
|
clean-debian-targets: |
||||||
|
-rm -rf \${PACKAGE_NAME}_\${PACKAGE_VERSION}~\${DISTRO}.\${BUILD_NUMBER}.{dsc,tar.gz} \${PACKAGE_NAME}_\${PACKAGE_VERSION}~\${DISTRO}.\${BUILD_NUMBER}*.changes \$\$(sed -n 's,Package: \(.*\),\1_${PACKAGE_VERSION}~${DISTRO}.${BUILD_NUMBER}*.deb,p;' debian/control) |
||||||
|
deb: distdir |
||||||
|
cd \${PACKAGE_NAME}-\${PACKAGE_VERSION} && ( export CFLAGS="\${CFLAGS}"; export CPPFLAGS="\${CPPFLAGS}"; export CXXFLAGS="\${CXXFLAGS}"; export LDFLAGS="\${LDFLAGS}"; export DEB_CFLAGS_APPEND="\${CFLAGS}"; export DEB_CPPFLAGS_APPEND="\${CPPFLAGS}"; export DEB_CXXFLAGS_APPEND="\${CXXFLAGS}"; export DEB_LDFLAGS_APPEND="\${LDFLAGS}"; dpkg-buildpackage ) |
||||||
|
distclean-debian-targets: |
||||||
|
-rm debian/changelog debian/control |
||||||
|
#### End: $0 |
||||||
|
EOF |
||||||
|
]) |
||||||
|
|
||||||
|
# use this in configure.ac to support RPM packages |
||||||
|
AC_DEFUN([AX_USE_RPM_PACKAGING], [ |
||||||
|
# m4_include(ax_rpm_rules.m4) |
||||||
|
AC_CONFIG_FILES([${PACKAGE_NAME}.spec]) |
||||||
|
#AX_ADD_MAKEFILE_TARGET_DEP([clean-am], [clean-debian-targets], [makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([.PHONY], [rpm], [makefile.in]) |
||||||
|
test -f makefile.in && cat >> makefile.in <<EOF |
||||||
|
#### Begin: Appended by $0 |
||||||
|
rpm: dist |
||||||
|
rpmbuild -ba --define "_topdir \$(pwd)" --define "_sourcedir \$(pwd)" \${PACKAGE_NAME}.spec |
||||||
|
#### End: $0 |
||||||
|
EOF |
||||||
|
]) |
||||||
|
|
||||||
|
# use this in configure.ac to support scripts, e.g. bash scripts |
||||||
|
AC_DEFUN([AX_USE_SCRIPTS], [ |
||||||
|
AC_CONFIG_FILES([scripts/makefile]) |
||||||
|
]) |
||||||
|
|
||||||
|
# use this in configure.ac to support Doxygen documentation generation |
||||||
|
AC_DEFUN([AX_USE_DOXYGEN], [ |
||||||
|
AC_CHECK_PROG(have_doxygen, doxygen, yes, no) |
||||||
|
AC_CHECK_PROG(have_dot, dot, yes, no) |
||||||
|
AC_CHECK_PROG(have_mscgen, mscgen, yes, no) |
||||||
|
PDF_DOC=${PACKAGE_NAME}-${PACKAGE_VERSION}.pdf |
||||||
|
AC_SUBST(PDF_DOC) |
||||||
|
if test "$have_doxygen" = "no"; then |
||||||
|
AC_MSG_WARN([Missing program doxygen! |
||||||
|
- you cannot rebuild the documentation |
||||||
|
- there are precompiled derived files in the distribution]); fi |
||||||
|
if test "$have_dot" = "no"; then |
||||||
|
AC_MSG_WARN([Missing program dot! |
||||||
|
- when you rebild documentation, there are no generated images |
||||||
|
- there are precompiled derived files in the distribution]); fi |
||||||
|
if test "$have_mscgen" = "no"; then |
||||||
|
AC_MSG_WARN([Missing program mscgen! |
||||||
|
- when you rebild documentation, there are no message state charts |
||||||
|
- there are precompiled derived files in the distribution]); fi |
||||||
|
AC_CONFIG_FILES([doc/makefile doc/doxyfile]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([clean-am], [clean-documentation], [doc/makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([distclean-am], [distclean-documentation], [doc/makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([maintainer-clean-am], [maintainer-clean-documentation], [doc/makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([install-data-am], [install-data-documentation], [doc/makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([uninstall-am], [uninstall-documentation], [doc/makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([all], [doc], [doc/makefile.in]) |
||||||
|
AX_ADD_MAKEFILE_TARGET_DEP([.PHONY], [pdf], [doc/makefile.in]) |
||||||
|
test -f doc/makefile.in && cat >> doc/makefile.in <<EOF |
||||||
|
#### Begin: Appended by $0 |
||||||
|
doc: doxyfile |
||||||
|
doxygen doxyfile |
||||||
|
@PEDANTIC_TRUE@ test \! -s doxygen.errors |
||||||
|
|
||||||
|
clean-documentation: |
||||||
|
-rm doxygen.errors @PDF_DOC@ |
||||||
|
distclean-documentation: |
||||||
|
-rm -r html latex |
||||||
|
-rm @PACKAGE_NAME@.doxytag |
||||||
|
maintainer-clean-documentation: |
||||||
|
-rm makefile.in |
||||||
|
install-data-documentation: |
||||||
|
test -d \$(DESTDIR)\${docdir} || mkdir -p \$(DESTDIR)\${docdir} |
||||||
|
chmod -R u+w \$(DESTDIR)\${docdir} |
||||||
|
cp -r html \$(DESTDIR)\${docdir}/ |
||||||
|
uninstall-documentation: |
||||||
|
-chmod -R u+w \$(DESTDIR)\${docdir} |
||||||
|
-rm -rf \$(DESTDIR)\${docdir}/* |
||||||
|
#### End: $0 |
||||||
|
EOF |
||||||
|
]) |
||||||
|
|
||||||
|
# require a specific package, with fallback: test for a header |
||||||
|
# - parameter: |
||||||
|
# $1 = unique id (no special characters) |
||||||
|
# $2 = module name |
||||||
|
# $3 = a header file to find (optional) |
||||||
|
# $4 = alternative module names (space separated, optional) |
||||||
|
# |
||||||
|
# uses PKG_CHECK_MODULES to test for a module |
||||||
|
# then, if given, looks for the header file |
||||||
|
# if header file is not found, searches in alternative modules |
||||||
|
# sets all flags, so that the module can be used everywhere |
||||||
|
# fails if not found |
||||||
|
AC_DEFUN([AX_PKG_REQUIRE], [ |
||||||
|
PKG_PROG_PKG_CONFIG |
||||||
|
$1_found=0 |
||||||
|
PKG_CHECK_MODULES([$1], [$2], [ |
||||||
|
$1_found=1 |
||||||
|
PKG_REQUIREMENTS+=" $2" |
||||||
|
], [ |
||||||
|
if test -n "$4"; then |
||||||
|
AC_MSG_WARN([Recommended package $2 for feature $1 not installed, trying $4]) |
||||||
|
for pkg in $4; do |
||||||
|
PKG_CHECK_MODULES([$1], [$pkg], [ |
||||||
|
PKG_REQUIREMENTS+=" $pkg" |
||||||
|
$1_found=1 |
||||||
|
break; |
||||||
|
], [ |
||||||
|
AC_MSG_WARN([Recommended package $pkg for feature $1 not installed]) |
||||||
|
]) |
||||||
|
done |
||||||
|
fi |
||||||
|
]) |
||||||
|
AC_SUBST(AM_CPPFLAGS) |
||||||
|
AC_SUBST(AM_CXXFLAGS) |
||||||
|
AC_SUBST(PKG_REQUIREMENTS) |
||||||
|
if test -n "$3"; then |
||||||
|
$1_found=0 |
||||||
|
old_CPPFLAGS=${CPPFLAGS} |
||||||
|
CPPFLAGS=" ${$1_CFLAGS} ${CPPFLAGS}" |
||||||
|
AC_CHECK_HEADER([$3], [ |
||||||
|
$1_found=1 |
||||||
|
], [ |
||||||
|
for x in ${$1_CFLAGS}; do |
||||||
|
AC_MSG_NOTICE([search for $3 in ${x[#]-I}]) |
||||||
|
for f in $(find ${x[#]-I} -name "$3"); do |
||||||
|
if test -f "$f"; then |
||||||
|
$1_found=1 |
||||||
|
$1_CFLAGS+=" -I${f%/*}" |
||||||
|
AC_MSG_NOTICE([added path ${f%/*}]) |
||||||
|
break; |
||||||
|
fi |
||||||
|
done |
||||||
|
if test ${$1_found} -eq 1; then |
||||||
|
break; |
||||||
|
fi |
||||||
|
done |
||||||
|
]) |
||||||
|
CPPFLAGS=${old_CPPFLAGS} |
||||||
|
fi |
||||||
|
if test ${$1_found} -eq 0; then |
||||||
|
if test -n "$3"; then |
||||||
|
if test -n "$4"; then |
||||||
|
AC_MSG_ERROR([Feature $1 not found, need header $3 in modules $2 or $4]) |
||||||
|
else |
||||||
|
AC_MSG_ERROR([Feature $1 not found, need header $3 in module $2]) |
||||||
|
fi |
||||||
|
else |
||||||
|
AC_MSG_ERROR([Feature $1 not found please install module $2]) |
||||||
|
fi |
||||||
|
fi |
||||||
|
AM_CPPFLAGS+=" ${$1_CFLAGS}" |
||||||
|
AM_CXXFLAGS+=" ${$1_CFLAGS}" |
||||||
|
LIBS+=" ${$1_LIBS}" |
||||||
|
]) |
||||||
|
|
||||||
|
# check if a specific package exists |
||||||
|
# - parameter: |
||||||
|
# $1 = unique id (no special characters) |
||||||
|
# $2 = module name (optional, if different from id) |
||||||
|
# |
||||||
|
# uses PKG_CHECK_MODULES to test for a module |
||||||
|
# sets automake conditional HAVE_$1 to 0 (not found) or 1 (found) |
||||||
|
# sets all flags, so that the module can be used everywhere |
||||||
|
AC_DEFUN([AX_PKG_CHECK], [ |
||||||
|
PKG_PROG_PKG_CONFIG |
||||||
|
PKG_CHECK_MODULES([$1], [m4_default([$2], [$1])], [ |
||||||
|
HAVE_$1=1 |
||||||
|
AM_CPPFLAGS+=" ${$1_CFLAGS}" |
||||||
|
AM_CXXFLAGS+=" ${$1_CFLAGS}" |
||||||
|
LIBS+=" ${$1_LIBS}" |
||||||
|
if test -z "$PKG_REQUIREMENTS"; then |
||||||
|
PKG_REQUIREMENTS="m4_default([$2], [$1])" |
||||||
|
else |
||||||
|
PKG_REQUIREMENTS="${PKG_REQUIREMENTS}, m4_default([$2], [$1])" |
||||||
|
fi |
||||||
|
], [ |
||||||
|
HAVE_$1=0 |
||||||
|
]) |
||||||
|
AM_CONDITIONAL(HAVE_$1, test $HAVE_$1 -eq 1) |
||||||
|
AC_SUBST(HAVE_$1) |
||||||
|
AC_SUBST(AM_CPPFLAGS) |
||||||
|
AC_SUBST(AM_CXXFLAGS) |
||||||
|
AC_SUBST(PKG_REQUIREMENTS) |
||||||
|
]) |
Loading…
Reference in new issue