fixed dependencies in pkg-config
This commit is contained in:
25
ChangeLog
25
ChangeLog
@@ -1,3 +1,28 @@
|
|||||||
|
2015-03-15 15:57 marc
|
||||||
|
|
||||||
|
* ax_check_qt.m4, ax_cxx_compile_stdcxx_11.m4,
|
||||||
|
ax_init_standard_project.m4, bootstrap.sh, src/makefile.am,
|
||||||
|
src/proxyface.pc.in: fixed pc file
|
||||||
|
|
||||||
|
2015-03-15 15:13 marc
|
||||||
|
|
||||||
|
* ax_check_qt.m4, ax_cxx_compile_stdcxx_11.m4,
|
||||||
|
ax_init_standard_project.m4, bootstrap.sh: fixed MOC_FLAGS for
|
||||||
|
QT4
|
||||||
|
|
||||||
|
2015-03-15 15:10 marc
|
||||||
|
|
||||||
|
* ChangeLog, ax_check_qt.m4, ax_cxx_compile_stdcxx_11.m4,
|
||||||
|
ax_init_standard_project.m4, bootstrap.sh,
|
||||||
|
debian/proxyface-dev.install: added html documentation to debian
|
||||||
|
package
|
||||||
|
|
||||||
|
2015-03-15 14:40 marc
|
||||||
|
|
||||||
|
* README, ax_check_qt.m4, ax_cxx_compile_stdcxx_11.m4,
|
||||||
|
ax_init_standard_project.m4, bootstrap.sh, doc/doxyfile.in:
|
||||||
|
doc/doxyfile.in should be part of the package
|
||||||
|
|
||||||
2015-03-15 14:22 marc
|
2015-03-15 14:22 marc
|
||||||
|
|
||||||
* AUTHORS, COPYING, ChangeLog, INSTALL, README, ax_check_qt.m4,
|
* AUTHORS, COPYING, ChangeLog, INSTALL, README, ax_check_qt.m4,
|
||||||
|
@@ -1,6 +1,10 @@
|
|||||||
# SYNOPSIS
|
# SYNOPSIS
|
||||||
#
|
#
|
||||||
# AX_CXX_CHECK_QT([qt_prefix], [list-of-qt-modules])
|
# 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
|
# DESCRIPTIONS
|
||||||
#
|
#
|
||||||
@@ -25,6 +29,13 @@
|
|||||||
# feature. Each entry in the list can have a version comparison
|
# feature. Each entry in the list can have a version comparison
|
||||||
# specifier, with the same syntax as the Requires keyword in the
|
# specifier, with the same syntax as the Requires keyword in the
|
||||||
# data files themselves.
|
# 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], [
|
AC_DEFUN([AX_CXX_QT_TOOL], [
|
||||||
if test -z "$HAVE_$1"; then
|
if test -z "$HAVE_$1"; then
|
||||||
@@ -93,12 +104,24 @@ AC_DEFUN([AX_CHECK_QT], [
|
|||||||
MOC_FLAGS+=" -DHAVE_$1=1 ${[$1]5_CFLAGS}"
|
MOC_FLAGS+=" -DHAVE_$1=1 ${[$1]5_CFLAGS}"
|
||||||
AM_CXXFLAGS+=" ${[$1]5_CFLAGS}"
|
AM_CXXFLAGS+=" ${[$1]5_CFLAGS}"
|
||||||
LIBS+=" ${[$1]5_LIBS}"
|
LIBS+=" ${[$1]5_LIBS}"
|
||||||
|
modules=${qt_modules//Qt/Qt5}
|
||||||
|
if test -z "$PKG_REQUIREMENTS"; then
|
||||||
|
PKG_REQUIREMENTS="${modules// /, }"
|
||||||
|
else
|
||||||
|
PKG_REQUIREMENTS="${PKG_REQUIREMENTS}, ${modules// /, }"
|
||||||
|
fi
|
||||||
if test -n "${qt_modules_optional}"; then
|
if test -n "${qt_modules_optional}"; then
|
||||||
PKG_CHECK_MODULES([$1]5_OPTIONAL, [${qt_modules_optional//Qt/Qt5}], [
|
PKG_CHECK_MODULES([$1]5_OPTIONAL, [${qt_modules_optional//Qt/Qt5}], [
|
||||||
AM_CPPFLAGS+=" ${[$1]5_OPTIONAL_CFLAGS}"
|
AM_CPPFLAGS+=" ${[$1]5_OPTIONAL_CFLAGS}"
|
||||||
MOC_FLAGS+=" ${[$1]5_OPTIONAL_CFLAGS}"
|
MOC_FLAGS+=" ${[$1]5_OPTIONAL_CFLAGS}"
|
||||||
AM_CXXFLAGS+=" ${[$1]5_OPTIONAL_CFLAGS}"
|
AM_CXXFLAGS+=" ${[$1]5_OPTIONAL_CFLAGS}"
|
||||||
LIBS+=" ${[$1]5_OPTIONAL_LIBS}"
|
LIBS+=" ${[$1]5_OPTIONAL_LIBS}"
|
||||||
|
modules=${qt_modules_optional//Qt/Qt5}
|
||||||
|
if test -z "$PKG_REQUIREMENTS"; then
|
||||||
|
PKG_REQUIREMENTS="${modules// /, }"
|
||||||
|
else
|
||||||
|
PKG_REQUIREMENTS="${PKG_REQUIREMENTS}, ${modules// /, }"
|
||||||
|
fi
|
||||||
], [
|
], [
|
||||||
AC_MSG_NOTICE([Not found: ${qt_modules_optional//Qt/Qt5}])
|
AC_MSG_NOTICE([Not found: ${qt_modules_optional//Qt/Qt5}])
|
||||||
])
|
])
|
||||||
@@ -111,12 +134,24 @@ AC_DEFUN([AX_CHECK_QT], [
|
|||||||
MOC_FLAGS+=" -DHAVE_$1=1 ${$1_CFLAGS}"
|
MOC_FLAGS+=" -DHAVE_$1=1 ${$1_CFLAGS}"
|
||||||
AM_CXXFLAGS+=" ${$1_CFLAGS}"
|
AM_CXXFLAGS+=" ${$1_CFLAGS}"
|
||||||
LIBS+=" ${$1_LIBS}"
|
LIBS+=" ${$1_LIBS}"
|
||||||
|
modules=${qt_modules}
|
||||||
|
if test -z "$PKG_REQUIREMENTS"; then
|
||||||
|
PKG_REQUIREMENTS="${modules// /, }"
|
||||||
|
else
|
||||||
|
PKG_REQUIREMENTS="${PKG_REQUIREMENTS}, ${modules// /, }"
|
||||||
|
fi
|
||||||
if test -n "$3"; then
|
if test -n "$3"; then
|
||||||
PKG_CHECK_MODULES($1_OPTIONAL, [${qt_modules_optional}], [
|
PKG_CHECK_MODULES($1_OPTIONAL, [${qt_modules_optional}], [
|
||||||
AM_CPPFLAGS+=" ${$1_OPTIONAL_CFLAGS}"
|
AM_CPPFLAGS+=" ${$1_OPTIONAL_CFLAGS}"
|
||||||
MOC_FLAGS+=" ${$1_OPTIONAL_CFLAGS}"
|
MOC_FLAGS+=" ${$1_OPTIONAL_CFLAGS}"
|
||||||
AM_CXXFLAGS+=" ${$1_OPTIONAL_CFLAGS}"
|
AM_CXXFLAGS+=" ${$1_OPTIONAL_CFLAGS}"
|
||||||
LIBS+=" ${$1_OPTIONAL_LIBS}"
|
LIBS+=" ${$1_OPTIONAL_LIBS}"
|
||||||
|
modules=${qt_modules_optional}
|
||||||
|
if test -z "$PKG_REQUIREMENTS"; then
|
||||||
|
PKG_REQUIREMENTS="${modules// /, }"
|
||||||
|
else
|
||||||
|
PKG_REQUIREMENTS="${PKG_REQUIREMENTS}, ${modules// /, }"
|
||||||
|
fi
|
||||||
], [
|
], [
|
||||||
AC_MSG_NOTICE([Not found: ${qt_modules_optional}])
|
AC_MSG_NOTICE([Not found: ${qt_modules_optional}])
|
||||||
])
|
])
|
||||||
@@ -128,6 +163,7 @@ AC_DEFUN([AX_CHECK_QT], [
|
|||||||
AC_SUBST(AM_CPPFLAGS)
|
AC_SUBST(AM_CPPFLAGS)
|
||||||
AC_SUBST(MOC_FLAGS)
|
AC_SUBST(MOC_FLAGS)
|
||||||
AC_SUBST(AM_CXXFLAGS)
|
AC_SUBST(AM_CXXFLAGS)
|
||||||
|
AC_SUBST(PKG_REQUIREMENTS)
|
||||||
AX_ADDITIONAL_QT_RULES_HACK='
|
AX_ADDITIONAL_QT_RULES_HACK='
|
||||||
ui_%.hxx: %.ui
|
ui_%.hxx: %.ui
|
||||||
$(UIC) -o [$][@] $<
|
$(UIC) -o [$][@] $<
|
||||||
@@ -140,9 +176,51 @@ qrc_%.cxx: %.qrc
|
|||||||
AC_SUBST(AX_ADDITIONAL_QT_RULES_HACK)
|
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], [
|
AC_DEFUN([AX_REQUIRE_QT], [
|
||||||
AX_CHECK_QT([$1], [$2], [$3])
|
AX_CHECK_QT([$1], [$2], [$3])
|
||||||
if ! test "$HAVE_$1" -eq 1; then
|
if ! test "$HAVE_$1" -eq 1; then
|
||||||
AC_MSG_ERROR([Required Qt modules not found: $2])
|
AC_MSG_ERROR([Required Qt modules not found: $2])
|
||||||
fi
|
fi
|
||||||
])
|
])
|
||||||
|
|
||||||
|
|
||||||
|
# Omit Qt Keywords
|
||||||
|
# AX_QT_NO_KEYWORDS
|
||||||
|
|
||||||
|
AC_DEFUN([AX_QT_NO_KEYWORDS], [
|
||||||
|
AM_CPPFLAGS+=" -DQT_NO_KEYWORDS"
|
||||||
|
])
|
||||||
|
@@ -3,17 +3,41 @@
|
|||||||
## 1 2 3 4 5 6 7 8
|
## 1 2 3 4 5 6 7 8
|
||||||
## 45678901234567890123456789012345678901234567890123456789012345678901234567890
|
## 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(
|
m4_define(x_least, m4_esyscmd_s(
|
||||||
LEAST="ERROR-UNDEFINED-REVISION-to-be-built-in-subdirectory-of-svn-checkout"
|
SVN_REVISION="ERROR-UNDEFINED-REVISION-to-be-built-in-subdirectory-of-svn-checkout"
|
||||||
for path in . .. ../..; do
|
for path in . .. ../..; do
|
||||||
if svn info $path 2>&1 > /dev/null; then
|
if svn info $path 2>&1 > /dev/null; then
|
||||||
LEAST=$(LANG= svn info $path | sed -n 's/Last Changed Rev: //p')
|
SVN_REVISION=$(LANG= svn info $path | sed -n 's/Last Changed Rev: //p')
|
||||||
(cd $path && svn2cl)
|
(cd $path && svn2cl)
|
||||||
break;
|
break;
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
echo -n $LEAST
|
# 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(
|
m4_define(x_bugreport, m4_esyscmd_s(
|
||||||
head -1 AUTHORS | \
|
head -1 AUTHORS | \
|
||||||
sed -n 's,.*<\([-_.a-z0-9A-Z]*@[-_.a-z0-9A-Z]*\)>.*,\1,gp'
|
sed -n 's,.*<\([-_.a-z0-9A-Z]*@[-_.a-z0-9A-Z]*\)>.*,\1,gp'
|
||||||
@@ -37,6 +61,11 @@ dnl refers to ${prefix}. Thus we have to use `eval' twice.
|
|||||||
test "$exec_prefix_NONE" && exec_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], [
|
AC_DEFUN([AX_ADD_MAKEFILE_TARGET_DEP], [
|
||||||
sh_add_makefile_target_dep() {
|
sh_add_makefile_target_dep() {
|
||||||
sed -i ':a;/^'${1}':.*\\$/{N;s/\\\n//;ta};s/^'${1}':.*$/& '${2}'/' "${srcdir}/${3}"
|
sed -i ':a;/^'${1}':.*\\$/{N;s/\\\n//;ta};s/^'${1}':.*$/& '${2}'/' "${srcdir}/${3}"
|
||||||
@@ -50,31 +79,61 @@ AC_DEFUN([AX_ADD_MAKEFILE_TARGET_DEP], [
|
|||||||
fi
|
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], [
|
AC_DEFUN([AX_INIT_STANDARD_PROJECT], [
|
||||||
AC_SUBST(HOME)
|
AM_CPPFLAGS+=" '-DMAKE_STRING(X)=\#X' '-DNAMESPACE=${PACKAGE_NAME}'"
|
||||||
|
AX_SUBST(NUMBERS)
|
||||||
|
AX_SUBST(HOME)
|
||||||
README=$(tail -n +3 README)
|
README=$(tail -n +3 README)
|
||||||
DESCRIPTION=$(head -1 README)
|
AX_SUBST(README)
|
||||||
AUTHOR=$(head -1 AUTHORS)
|
|
||||||
AC_SUBST(AUTHOR)
|
|
||||||
_AM_SUBST_NOTMAKE([AUTHOR])
|
|
||||||
AC_SUBST(DESCRIPTION)
|
|
||||||
_AM_SUBST_NOTMAKE([DESCRIPTION])
|
|
||||||
AC_SUBST(README)
|
|
||||||
_AM_SUBST_NOTMAKE([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)
|
DISTRO=$(lsb_release -sc)
|
||||||
AC_SUBST(DISTRO)
|
AX_SUBST(DISTRO)
|
||||||
BUILD_NUMBER=${BUILD_NUMBER:-1}
|
BUILD_NUMBER=${BUILD_NUMBER:-1}
|
||||||
AC_SUBST(BUILD_NUMBER)
|
AX_SUBST(BUILD_NUMBER)
|
||||||
BUILD_DATE=$(date -R)
|
BUILD_DATE=$(LANG= date +"%a, %d %B %Y %H:%M:%S %z")
|
||||||
AC_SUBST(BUILD_DATE)
|
AX_SUBST(BUILD_DATE)
|
||||||
if test -f "${PROJECT_NAME}-logo.png"; then
|
if test -f "${PROJECT_NAME}-logo.png"; then
|
||||||
PROJECT_LOGO="${PROJECT_NAME}-logo.png"
|
PROJECT_LOGO="${PROJECT_NAME}-logo.png"
|
||||||
fi
|
fi
|
||||||
AC_SUBST(PROJECT_LOGO)
|
AX_SUBST(PROJECT_LOGO)
|
||||||
if test -f "${PROJECT_NAME}-icon.png"; then
|
if test -f "${PROJECT_NAME}-icon.png"; then
|
||||||
PROJECT_ICON="${PROJECT_NAME}-icon.png"
|
PROJECT_ICON="${PROJECT_NAME}-icon.png"
|
||||||
fi
|
fi
|
||||||
AC_SUBST(PROJECT_ICON)
|
AX_SUBST(PROJECT_ICON)
|
||||||
AC_CONFIG_FILES([makefile])
|
AC_CONFIG_FILES([makefile])
|
||||||
AX_ADD_MAKEFILE_TARGET_DEP([clean-am], [clean-standard-project-targets], [makefile.in])
|
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([distclean-am], [distclean-standard-project-targets], [makefile.in])
|
||||||
@@ -82,7 +141,7 @@ AC_DEFUN([AX_INIT_STANDARD_PROJECT], [
|
|||||||
test -f makefile.in && cat >> makefile.in <<EOF
|
test -f makefile.in && cat >> makefile.in <<EOF
|
||||||
#### Begin: Appended by $0
|
#### Begin: Appended by $0
|
||||||
EXTRA_DIST = bootstrap.sh
|
EXTRA_DIST = bootstrap.sh
|
||||||
doc_DATA = AUTHORS NEWS README COPYING INSTALL ChangeLog @PACKAGE_NAME@.spec
|
doc_DATA = AUTHORS NEWS README COPYING INSTALL ChangeLog
|
||||||
clean-standard-project-targets:
|
clean-standard-project-targets:
|
||||||
-rm -rf \${PACKAGE_NAME}-\${PACKAGE_VERSION}
|
-rm -rf \${PACKAGE_NAME}-\${PACKAGE_VERSION}
|
||||||
-rm \${PACKAGE_TARNAME}-\${PACKAGE_VERSION}.tar.gz
|
-rm \${PACKAGE_TARNAME}-\${PACKAGE_VERSION}.tar.gz
|
||||||
@@ -95,6 +154,7 @@ maintainer-clean-standard-project-targets:
|
|||||||
EOF
|
EOF
|
||||||
])
|
])
|
||||||
|
|
||||||
|
# use this in configure.ac to support C++
|
||||||
AC_DEFUN([AX_USE_CXX], [
|
AC_DEFUN([AX_USE_CXX], [
|
||||||
m4_include(ax_cxx_compile_stdcxx_11.m4)
|
m4_include(ax_cxx_compile_stdcxx_11.m4)
|
||||||
AC_LANG(C++)
|
AC_LANG(C++)
|
||||||
@@ -104,8 +164,8 @@ AC_DEFUN([AX_USE_CXX], [
|
|||||||
|
|
||||||
AC_CONFIG_FILES([src/makefile])
|
AC_CONFIG_FILES([src/makefile])
|
||||||
|
|
||||||
AM_CPPFLAGS='-I ${top_srcdir}/src -I ${top_builddir}/src -I ${srcdir} -I ${builddir}'
|
AM_CPPFLAGS+=' -I ${top_srcdir}/src -I ${top_builddir}/src -I ${srcdir} -I ${builddir}'
|
||||||
AM_LDFLAGS='-L ${top_srcdir}/src -L ${top_builddir}/src'
|
AM_LDFLAGS+=' -L ${top_srcdir}/src -L ${top_builddir}/src'
|
||||||
|
|
||||||
# Get rid of that stupid -O2 -g opions!
|
# Get rid of that stupid -O2 -g opions!
|
||||||
CXXFLAGS="${CXXFLAGS:-}"
|
CXXFLAGS="${CXXFLAGS:-}"
|
||||||
@@ -149,6 +209,7 @@ maintainer-clean-cxx-targets:
|
|||||||
EOF
|
EOF
|
||||||
])
|
])
|
||||||
|
|
||||||
|
# use this in configure.ac to support CppUnit for C++ unit tests
|
||||||
AC_DEFUN([AX_USE_CPPUNIT], [
|
AC_DEFUN([AX_USE_CPPUNIT], [
|
||||||
AM_PATH_CPPUNIT([1.0.0], [have_cppunit="yes"], [have_cppunit="no"])
|
AM_PATH_CPPUNIT([1.0.0], [have_cppunit="yes"], [have_cppunit="no"])
|
||||||
# infos and warnings
|
# infos and warnings
|
||||||
@@ -157,8 +218,16 @@ AC_DEFUN([AX_USE_CPPUNIT], [
|
|||||||
- you cannot check the library using "make check"
|
- you cannot check the library using "make check"
|
||||||
- everything else works perfectly]); fi
|
- everything else works perfectly]); fi
|
||||||
AC_CONFIG_FILES([test/makefile])
|
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_DEFUN([AX_BUILD_EXAMPLES], [
|
||||||
AC_CONFIG_FILES([examples/makefile])
|
AC_CONFIG_FILES([examples/makefile])
|
||||||
AX_ADD_MAKEFILE_TARGET_DEP([maintainer-clean-am], [maintainer-clean-example-targets], [examples/makefile.in])
|
AX_ADD_MAKEFILE_TARGET_DEP([maintainer-clean-am], [maintainer-clean-example-targets], [examples/makefile.in])
|
||||||
@@ -170,11 +239,12 @@ maintainer-clean-example-targets:
|
|||||||
EOF
|
EOF
|
||||||
])
|
])
|
||||||
|
|
||||||
|
# use this in configure.ac to support C++ libraries
|
||||||
AC_DEFUN([AX_USE_LIBTOOL], [
|
AC_DEFUN([AX_USE_LIBTOOL], [
|
||||||
# libtool versioning
|
# libtool versioning
|
||||||
LIB_MAJOR=m4_eval(x_major+x_minor)
|
LIB_MAJOR=m4_eval(x_major+x_minor)
|
||||||
LIB_MINOR=x_least
|
LIB_MINOR=x_least
|
||||||
LIB_LEAST=x_minor
|
LIB_LEAST=x_minor_fixed
|
||||||
LIB_VERSION="${LIB_MAJOR}:${LIB_MINOR}:${LIB_LEAST}"
|
LIB_VERSION="${LIB_MAJOR}:${LIB_MINOR}:${LIB_LEAST}"
|
||||||
AM_LDFLAGS="-version-info ${LIB_VERSION}"
|
AM_LDFLAGS="-version-info ${LIB_VERSION}"
|
||||||
AC_SUBST(AM_LDFLAGS)
|
AC_SUBST(AM_LDFLAGS)
|
||||||
@@ -197,6 +267,7 @@ uninstall-data-libtool-pkg:
|
|||||||
EOF
|
EOF
|
||||||
])
|
])
|
||||||
|
|
||||||
|
# use this in configure.ac to support debian packages
|
||||||
AC_DEFUN([AX_USE_DEBIAN_PACKAGING], [
|
AC_DEFUN([AX_USE_DEBIAN_PACKAGING], [
|
||||||
README_DEB=$(tail -n +3 README | sed -e 's/^$/./g' -e 's/^/ /g')
|
README_DEB=$(tail -n +3 README | sed -e 's/^$/./g' -e 's/^/ /g')
|
||||||
AC_SUBST(README_DEB)
|
AC_SUBST(README_DEB)
|
||||||
@@ -217,6 +288,7 @@ distclean-debian-targets:
|
|||||||
EOF
|
EOF
|
||||||
])
|
])
|
||||||
|
|
||||||
|
# use this in configure.ac to support RPM packages
|
||||||
AC_DEFUN([AX_USE_RPM_PACKAGING], [
|
AC_DEFUN([AX_USE_RPM_PACKAGING], [
|
||||||
# m4_include(ax_rpm_rules.m4)
|
# m4_include(ax_rpm_rules.m4)
|
||||||
AC_CONFIG_FILES([${PACKAGE_NAME}.spec])
|
AC_CONFIG_FILES([${PACKAGE_NAME}.spec])
|
||||||
@@ -230,6 +302,12 @@ rpm: dist
|
|||||||
EOF
|
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_DEFUN([AX_USE_DOXYGEN], [
|
||||||
AC_CHECK_PROG(have_doxygen, doxygen, yes, no)
|
AC_CHECK_PROG(have_doxygen, doxygen, yes, no)
|
||||||
AC_CHECK_PROG(have_dot, dot, yes, no)
|
AC_CHECK_PROG(have_dot, dot, yes, no)
|
||||||
@@ -280,19 +358,116 @@ uninstall-documentation:
|
|||||||
EOF
|
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], [
|
AC_DEFUN([AX_PKG_REQUIRE], [
|
||||||
PKG_PROG_PKG_CONFIG
|
PKG_PROG_PKG_CONFIG
|
||||||
PKG_CHECK_MODULES([$1], [$1], [
|
PKG_CHECK_MODULES([$1], [$2], [
|
||||||
|
if test -n "$3"; then
|
||||||
|
$1_found=0;
|
||||||
|
for p in ${$1_CFLAGS}; do
|
||||||
|
if test -e ${p#-I}/$3; then
|
||||||
|
$1_found=1
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
if test ${$1_found} -eq 0; then
|
||||||
|
for p in /usr/include ${$1_CFLAGS}; do
|
||||||
|
$1_file=$(find ${p#-I} -name $3)
|
||||||
|
if test -e "${$1_file}"; then
|
||||||
|
AC_MSG_NOTICE([Header file $3 found in sub path as ${$1_file}])
|
||||||
|
$1_CFLAGS="${$1_CFLAGS} -I${$1_file%/$3}"
|
||||||
|
$1_found=1
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
if test ${$1_found} -eq 0; then
|
||||||
|
AC_MSG_WARN([Header file $3 not found in $1_CFLAGS = ${$1_CFLAGS}])
|
||||||
|
fi
|
||||||
|
fi
|
||||||
AM_CPPFLAGS+=" ${$1_CFLAGS}"
|
AM_CPPFLAGS+=" ${$1_CFLAGS}"
|
||||||
AM_CXXFLAGS+=" ${$1_CFLAGS}"
|
AM_CXXFLAGS+=" ${$1_CFLAGS}"
|
||||||
LIBS+=" ${$1_LIBS}"
|
LIBS+=" ${$1_LIBS}"
|
||||||
|
if test -z "$PKG_REQUIREMENTS"; then
|
||||||
|
PKG_REQUIREMENTS="$2"
|
||||||
|
else
|
||||||
|
PKG_REQUIREMENTS="${PKG_REQUIREMENTS}, $2"
|
||||||
|
fi
|
||||||
], [
|
], [
|
||||||
AC_MSG_ERROR([Required package $1 not found])
|
AC_MSG_WARN([Recommended package $2 for feature $1 not installed])
|
||||||
|
if test -n "$4"; then
|
||||||
|
for pkg in $4; do
|
||||||
|
PKG_CHECK_MODULES([$1], [$pkg], [
|
||||||
|
if test -n "$3"; then
|
||||||
|
$1_found=0;
|
||||||
|
for p in ${$1_CFLAGS}; do
|
||||||
|
if test -e ${p#-I}/$3; then
|
||||||
|
$1_found=1
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
if test ${$1_found} -eq 0; then
|
||||||
|
for p in /usr/include ${$1_CFLAGS}; do
|
||||||
|
$1_file=$(find ${p#-I} -name $3)
|
||||||
|
if test -e ${$1_file}; then
|
||||||
|
AC_MSG_NOTICE([Header file $3 found in sub path as ${$1_file}])
|
||||||
|
$1_CFLAGS="${$1_CFLAGS} -I${$1_file%/$3}"
|
||||||
|
$1_found=1
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
if test ${$1_found} -eq 0; then
|
||||||
|
AC_MSG_WARN([Header file $3 not found in $1_CFLAGS = ${$1_CFLAGS}])
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
AM_CPPFLAGS+=" ${$1_CFLAGS}"
|
||||||
|
AM_CXXFLAGS+=" ${$1_CFLAGS}"
|
||||||
|
LIBS+=" ${$1_LIBS}"
|
||||||
|
if test -z "$PKG_REQUIREMENTS"; then
|
||||||
|
PKG_REQUIREMENTS="$pkg"
|
||||||
|
else
|
||||||
|
PKG_REQUIREMENTS="${PKG_REQUIREMENTS}, $pkg"
|
||||||
|
fi
|
||||||
|
], [
|
||||||
|
AC_MSG_WARN([Recommended package $pkg for feature $1 not installed])
|
||||||
|
])
|
||||||
|
done
|
||||||
|
fi
|
||||||
])
|
])
|
||||||
AC_SUBST(AM_CPPFLAGS)
|
AC_SUBST(AM_CPPFLAGS)
|
||||||
AC_SUBST(AM_CXXFLAGS)
|
AC_SUBST(AM_CXXFLAGS)
|
||||||
|
AC_SUBST(PKG_REQUIREMENTS)
|
||||||
|
if test -n "$3"; then
|
||||||
|
old_CPPFLAGS=${CPPFLAGS}
|
||||||
|
CPPFLAGS=" ${$1_CFLAGS} ${CPPFLAGS}"
|
||||||
|
AC_CHECK_HEADER([$3], [
|
||||||
|
], [
|
||||||
|
AC_MSG_ERROR([Required header $3 for feature $1 not found])
|
||||||
|
])
|
||||||
|
CPPFLAGS=${old_CPPFLAGS}
|
||||||
|
fi
|
||||||
])
|
])
|
||||||
|
|
||||||
|
# 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], [
|
AC_DEFUN([AX_PKG_CHECK], [
|
||||||
PKG_PROG_PKG_CONFIG
|
PKG_PROG_PKG_CONFIG
|
||||||
PKG_CHECK_MODULES([$1], [m4_default([$2], [$1])], [
|
PKG_CHECK_MODULES([$1], [m4_default([$2], [$1])], [
|
||||||
@@ -300,6 +475,11 @@ AC_DEFUN([AX_PKG_CHECK], [
|
|||||||
AM_CPPFLAGS+=" ${$1_CFLAGS}"
|
AM_CPPFLAGS+=" ${$1_CFLAGS}"
|
||||||
AM_CXXFLAGS+=" ${$1_CFLAGS}"
|
AM_CXXFLAGS+=" ${$1_CFLAGS}"
|
||||||
LIBS+=" ${$1_LIBS}"
|
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
|
HAVE_$1=0
|
||||||
])
|
])
|
||||||
@@ -307,4 +487,5 @@ AC_DEFUN([AX_PKG_CHECK], [
|
|||||||
AC_SUBST(HAVE_$1)
|
AC_SUBST(HAVE_$1)
|
||||||
AC_SUBST(AM_CPPFLAGS)
|
AC_SUBST(AM_CPPFLAGS)
|
||||||
AC_SUBST(AM_CXXFLAGS)
|
AC_SUBST(AM_CXXFLAGS)
|
||||||
|
AC_SUBST(PKG_REQUIREMENTS)
|
||||||
])
|
])
|
||||||
|
426
bootstrap.sh
426
bootstrap.sh
@@ -14,23 +14,218 @@
|
|||||||
## added file header
|
## added file header
|
||||||
##
|
##
|
||||||
|
|
||||||
|
MY_NAME=${0##*/}
|
||||||
|
PROJECT_PATH=$(pwd)
|
||||||
|
DEFAULT_PROJECT_NAME=${PROJECT_PATH##*/}
|
||||||
|
|
||||||
configure=0
|
configure=0
|
||||||
|
build=0
|
||||||
|
overwrite=0
|
||||||
|
rebuild=0
|
||||||
|
rebuildfiles=()
|
||||||
while test $# -gt 0; do
|
while test $# -gt 0; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
(--configure|-c) configure=1;;
|
(--configure|-c) configure=1;;
|
||||||
|
(--build|-b) configure=1; build=1;;
|
||||||
|
(--overwrite|-o) overwrite=1;;
|
||||||
|
(--rebuild|-r) rebuild=1;;
|
||||||
|
(--rebuild-file|-f) shift; rebuildfiles+=("$1");;
|
||||||
|
(--version|-v)
|
||||||
|
echo "$Id$";
|
||||||
|
exit;;
|
||||||
|
(--help|-h) less <<EOF
|
||||||
|
SYNOPSIS
|
||||||
|
|
||||||
|
${MY_NAME} [--help|-h] [OPTIOS]
|
||||||
|
|
||||||
|
OPTIONS
|
||||||
|
|
||||||
|
--configure, -c call ./configure after initialization
|
||||||
|
--build, -c build, also call ./configure && make
|
||||||
|
--overwrite, -o overwrite all basic files (bootstrap.sh, m4-macros)
|
||||||
|
--rebuild, -r force rebuild of generated files, even if modified
|
||||||
|
--rebuild-file, -f <file> rebild specific file (can be added multiple times)
|
||||||
|
--help, -h show this help
|
||||||
|
--version, -v show version and date of this file
|
||||||
|
|
||||||
|
DESCRIPTION
|
||||||
|
|
||||||
|
Initializes your build environment, as far as neccessary. Reads your
|
||||||
|
used features from configure.ac, if that file exists, or creates a
|
||||||
|
configure.ac. Automatically copies or creates all required template
|
||||||
|
files.
|
||||||
|
|
||||||
|
From your new and empty project's subversion path, call $0 to
|
||||||
|
initialize your build environment.
|
||||||
|
|
||||||
|
Before you call ${MY_NAME} the very first time, edit ${0#/*}/AUTHORS
|
||||||
|
and replace it with your name (or the authors of your project, one
|
||||||
|
name each line, main developper and copyright holder on the first
|
||||||
|
line).
|
||||||
|
|
||||||
|
The first call to ${MY_NAME} should be something like
|
||||||
|
../bootstrap-build-environment/${MY_NAME} and not
|
||||||
|
./${MY_NAME}. Actually, you called $0.
|
||||||
|
|
||||||
|
In the way you called ${MY_NAME}, it has detected
|
||||||
|
${DEFAULT_PROJECT_NAME} as the project name for your project in
|
||||||
|
${PROJECT_PATH}. In the first run, you should call ${MY_NAME} from a
|
||||||
|
checked out the bootstrap-build-environment from
|
||||||
|
https://dev.marc.waeckerlin.org/, and the path from where you call
|
||||||
|
${MY_NAME} (which is actually ${PROJECT_PATH}) should be the path to
|
||||||
|
your newly created project. Please note that your project must be a
|
||||||
|
checked out subversion repository, since this build environment
|
||||||
|
relies on subversion.
|
||||||
|
|
||||||
|
Example for an initial run, where your new projet is stored in
|
||||||
|
subversion on svn:/path/to/your/new-project:
|
||||||
|
|
||||||
|
cd ~/svn
|
||||||
|
svn co https://dev.marc.waeckerlin.org/svn/bootstrap-build-environment/trunk \\
|
||||||
|
bootstrap-build-environment
|
||||||
|
svn co svn:/path/to/your/new-project/trunk new-project
|
||||||
|
cd new-project
|
||||||
|
../bootstrap-build-environment/bootstrap.sh
|
||||||
|
|
||||||
|
RUNNING
|
||||||
|
|
||||||
|
If you run ${MY_NAME}, it first generates the necessary files (see
|
||||||
|
below), then first runs make distclean if a makefile exists. After
|
||||||
|
this it calles aclocal, libtoolize, automake, autoconf and
|
||||||
|
optionally ./configure.
|
||||||
|
|
||||||
|
GENERATED FILES
|
||||||
|
|
||||||
|
This script copies the following files into your project environment:
|
||||||
|
* ${MY_NAME}
|
||||||
|
* ax_init_standard_project.m4 - auxiliary macro definition file
|
||||||
|
* ax_cxx_compile_stdcxx_11.m4 - auxiliary macro definition file
|
||||||
|
* ax_check_qt.m4 - auxiliary macro definition file
|
||||||
|
* AUTHORS - replace your name in AUTHORS before first run
|
||||||
|
* configure.ac - global configuration file template
|
||||||
|
* makefile.am - global makefile template
|
||||||
|
* src/makefile.am - if you enabled AX_USE_CXX
|
||||||
|
* src/version.hxx - if you enabled AX_USE_CXX
|
||||||
|
* src/version.cxx - if you enabled AX_USE_CXX
|
||||||
|
* scripts/makefile.in - if you enabled AX_USE_SCRIPTS
|
||||||
|
* doc/makefile.am - if you enabled AX_USE_DOXYGEN
|
||||||
|
* doc/doxyfile.in - if you enabled AX_USE_DOXYGEN
|
||||||
|
* test/makefile.am - if you enabled AX_USE_CPPUNIT
|
||||||
|
* examples/makefile.am - if you enabled AX_BUILD_EXAMPLES
|
||||||
|
* debian/changelog.in - if you enabled AX_USE_DEBIAN_PACKAGING
|
||||||
|
* debian/control.in - if you enabled AX_USE_DEBIAN_PACKAGING
|
||||||
|
* debian/docs - if you enabled AX_USE_DEBIAN_PACKAGING
|
||||||
|
* debian/${DEFAULT_PROJECT_NAME}.install - if you enabled AX_USE_DEBIAN_PACKAGING
|
||||||
|
* debian/${DEFAULT_PROJECT_NAME}.dirs - if you enabled AX_USE_DEBIAN_PACKAGING
|
||||||
|
* debian/${DEFAULT_PROJECT_NAME}-dev.install - if you enabled AX_USE_DEBIAN_PACKAGING
|
||||||
|
* debian/${DEFAULT_PROJECT_NAME}-dev.dirs - if you enabled AX_USE_DEBIAN_PACKAGING
|
||||||
|
* debian/rules - if you enabled AX_USE_DEBIAN_PACKAGING
|
||||||
|
* debian/compat - if you enabled AX_USE_DEBIAN_PACKAGING
|
||||||
|
* src/${DEFAULT_PROJECT_NAME}.pc.in - if you enabled AX_USE_LIBTOOL
|
||||||
|
|
||||||
|
REBUILDING FILES
|
||||||
|
|
||||||
|
To rebuild all these files, just run "${MY_NAME} -r".
|
||||||
|
|
||||||
|
To copy only the files provided by this package, that means those
|
||||||
|
files you must never change, that means to update the build system
|
||||||
|
to the latest release, run "${MY_NAME} -o"
|
||||||
|
|
||||||
|
You can also rebuild a list of singleany list of specific file files
|
||||||
|
by adding option "${MY_NAME} -f <file>" to rebuild file
|
||||||
|
"<file>". You can add option "-f" more than once.
|
||||||
|
|
||||||
|
FILES TO EDIT
|
||||||
|
|
||||||
|
After creation of the files, you can edit them according to your
|
||||||
|
needs. Please don't forget to redo your edits after rebuilding a
|
||||||
|
file. Most files don't even need to be edited, they work out of the
|
||||||
|
box.
|
||||||
|
|
||||||
|
The following files normally require editing:
|
||||||
|
* AUTHORS
|
||||||
|
* README
|
||||||
|
* configure.ac
|
||||||
|
* src/makefile.am
|
||||||
|
* test/makefile.am
|
||||||
|
* examples/makefile.am
|
||||||
|
|
||||||
|
FILE DEPENDENCIES
|
||||||
|
|
||||||
|
You should rebuild (see above) the files, whenever you change the
|
||||||
|
configuration a dependent, i.e.:
|
||||||
|
|
||||||
|
* test/makefile.am depends on AX_USE_LIBTOOL
|
||||||
|
* doc/doxyfile.in depends on AX_BUILD_EXAMPLES
|
||||||
|
* debian/control.in depends on AX_USE_DOXYGEN, AX_USE_CPPUNIT,
|
||||||
|
AX_CXX_QT, AX_CXX_CHECK_QT, AX_USE_LIBTOOL
|
||||||
|
* debian/${DEFAULT_PROJECT_NAME}.install depends on AX_USE_LIBTOOL
|
||||||
|
* debian/${DEFAULT_PROJECT_NAME}.dirs depends on AX_USE_LIBTOOL
|
||||||
|
* debian/${DEFAULT_PROJECT_NAME}-dev.install depends on AX_USE_LIBTOOL
|
||||||
|
* debian/${DEFAULT_PROJECT_NAME}-dev.dirs depends on AX_USE_LIBTOOL
|
||||||
|
|
||||||
|
FILES
|
||||||
|
|
||||||
|
* AUTHORS: First line is the main author and used in Debian and RPM
|
||||||
|
packaging, so there must be a GPG key that matches
|
||||||
|
to this line.
|
||||||
|
* README: First line is a short description of your project, then an
|
||||||
|
empty line must follow. All remaining lines are a
|
||||||
|
long description of your project. this information
|
||||||
|
is copied, e.g. in Debian or RPM packages. In C++
|
||||||
|
<ou can access the readme by calling
|
||||||
|
${DEFAULT_PROJECT_NAME}::description().
|
||||||
|
* ChangeLog: Your changelog is automatically maintained from
|
||||||
|
subversion history, using svn2cl. You don't need to
|
||||||
|
care about.
|
||||||
|
* configure.ac: This file becomes very short and simple. You provide
|
||||||
|
the project name, the major and minor version. The
|
||||||
|
least version number is automatically taken from
|
||||||
|
subversion's revision, so every checkin
|
||||||
|
automatically increments the least version
|
||||||
|
number. The following macros are supported:
|
||||||
|
* Enable C++: AX_USE_CXX
|
||||||
|
* Enable LibTool library creation: AX_USE_LIBTOOL
|
||||||
|
* Enable Scripts: AX_USE_SCRIPTS
|
||||||
|
* Enable Doxygen documentation generation: AX_USE_DOXYGEN
|
||||||
|
* Enable Debian packaging by calling "make deb": AX_USE_DEBIAN_PACKAGING
|
||||||
|
* Not yet implemented: AX_USE_RPM_PACKAGING
|
||||||
|
* Enable C++ testing using CppUnit: AX_USE_CPPUNIT
|
||||||
|
* Enable C++ examples, i.e. for libraries: AX_BUILD_EXAMPLES
|
||||||
|
* Check for C++11 support: AX_CXX_COMPILE_STDCXX_11 (see ax_cxx_compile_stdcxx_11.m4)
|
||||||
|
* Require a QT module: AX_REQUIRE_QT (see ax_check_qt.m4)
|
||||||
|
* Optionally use a QT module: AX_CHECK_QT (see ax_check_qt.m4)
|
||||||
|
* Require a module: AX_PKG_REQUIRE (see ax_init_standard_project.m4)
|
||||||
|
* Check for an optional module: AX_PKG_CHECK (see ax_init_standard_project.m4)
|
||||||
|
|
||||||
|
EXAMPLES: src/makefile.am in a QT project
|
||||||
|
|
||||||
|
In this example, you wrote the following files:
|
||||||
|
* ${DEFAULT_PROJECT_NAME}.hxx - Qt Header file, passed to moc
|
||||||
|
* ${DEFAULT_PROJECT_NAME}.cxx - C++ file containing main()
|
||||||
|
* ${DEFAULT_PROJECT_NAME}.ui - UI file
|
||||||
|
|
||||||
|
All rules are implicitely added, all you need to do is to add the
|
||||||
|
following definitions, most lines are generic:
|
||||||
|
|
||||||
|
bin_PROGRAMS = ${DEFAULT_PROJECT_NAME}
|
||||||
|
${DEFAULT_PROJECT_NAME}_MOCFILES = moc_${DEFAULT_PROJECT_NAME}.cxx
|
||||||
|
${DEFAULT_PROJECT_NAME}_UIFILES = ui_${DEFAULT_PROJECT_NAME}.hxx
|
||||||
|
${DEFAULT_PROJECT_NAME}_SOURCES = version.cxx version.hxx ${DEFAULT_PROJECT_NAME}.cxx ${DEFAULT_PROJECT_NAME}_MOCFILES ${DEFAULT_PROJECT_NAME}_UIFILES
|
||||||
|
BUILT_SOURCES = \${${DEFAULT_PROJECT_NAME}_MOCFILES} \${${DEFAULT_PROJECT_NAME}_UIFILES}
|
||||||
|
EXTRA_DIST = \${${DEFAULT_PROJECT_NAME}_MOCFILES:moc_%.cxx=%.hxx} \${${DEFAULT_PROJECT_NAME}_UIFILES:ui_%.hxx=%.ui}
|
||||||
|
MAINTAINERCLEANFILES = makefile.in
|
||||||
|
EOF
|
||||||
|
exit;;
|
||||||
(*) break;;
|
(*) break;;
|
||||||
esac
|
esac
|
||||||
shift;
|
shift;
|
||||||
done
|
done
|
||||||
|
|
||||||
|
|
||||||
MY_NAME=${0##*/}
|
HEADER='## @id '"\$Id\$"'
|
||||||
PROJECT_PATH=$(pwd)
|
|
||||||
DEFAULT_PROJECT_NAME=${PROJECT_PATH##*/}
|
|
||||||
|
|
||||||
HEADER='## @id $Id$
|
|
||||||
#
|
#
|
||||||
# This file has been added by '${MY_NAME}' on '$(date -R)'
|
# This file has been added by '${MY_NAME}' on '$(LANG= date +"%a, %d %B %Y %H:%M:%S %z")'
|
||||||
# Feel free to change it or even remove and rebuild it, up to your needs
|
# Feel free to change it or even remove and rebuild it, up to your needs
|
||||||
#
|
#
|
||||||
## 1 2 3 4 5 6 7 8
|
## 1 2 3 4 5 6 7 8
|
||||||
@@ -70,6 +265,12 @@ testtag() {
|
|||||||
egrep -q '^ *'"$1" configure.ac
|
egrep -q '^ *'"$1" configure.ac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
contains() {
|
||||||
|
local e
|
||||||
|
for e in "${@:2}"; do [[ "$e" == "$1" ]] && return 0; done
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
checkdir() {
|
checkdir() {
|
||||||
if ! test -d "$1"; then # create path
|
if ! test -d "$1"; then # create path
|
||||||
run mkdir -p "$1"
|
run mkdir -p "$1"
|
||||||
@@ -77,19 +278,32 @@ checkdir() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
checkfile() {
|
||||||
|
exists=0
|
||||||
|
if test -f "$1"; then
|
||||||
|
exists=1
|
||||||
|
fi
|
||||||
|
test $exists -eq 1
|
||||||
|
}
|
||||||
|
|
||||||
to() {
|
to() {
|
||||||
while test $# -gt 0; do
|
while test $# -gt 0; do
|
||||||
|
mode="u=rw,g=rw,o=r"
|
||||||
case "$1" in
|
case "$1" in
|
||||||
(--condition) shift # test for a tag, abort if not set
|
(--condition) shift # test for a tag, abort if not set
|
||||||
if ! testtag "$1" configure.ac; then
|
if ! testtag "$1" configure.ac; then
|
||||||
return
|
return
|
||||||
fi;;
|
fi;;
|
||||||
|
(--mode) shift # test for a tag, abort if not set
|
||||||
|
mode="$1";;
|
||||||
(*) break;;
|
(*) break;;
|
||||||
esac
|
esac
|
||||||
shift;
|
shift;
|
||||||
done
|
done
|
||||||
if test -f "$1"; then # file already exists
|
if checkfile "$1" && test $rebuild -eq 0 \
|
||||||
return
|
&& ! contains "$1" "${rebuildfiles[@]}"; then
|
||||||
|
# file already exists and must not be rebuilt
|
||||||
|
return 1
|
||||||
fi
|
fi
|
||||||
checkdir "$(dirname ${1})"
|
checkdir "$(dirname ${1})"
|
||||||
echo -en "\e[1m-> generating:\e[0m $1 ..."
|
echo -en "\e[1m-> generating:\e[0m $1 ..."
|
||||||
@@ -105,13 +319,22 @@ to() {
|
|||||||
else
|
else
|
||||||
echo -e " \e[32msuccess\e[0m"
|
echo -e " \e[32msuccess\e[0m"
|
||||||
fi
|
fi
|
||||||
|
chmod $mode $1
|
||||||
|
if test $exists -eq 0; then
|
||||||
run svn add "$1"
|
run svn add "$1"
|
||||||
run svn propset svn:keywords "Id" "$1"
|
run svn propset svn:keywords "Id" "$1"
|
||||||
|
fi
|
||||||
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
copy() {
|
copy() {
|
||||||
if ! test -f "$1"; then
|
if checkfile "$1" && test $overwrite -eq 0 \
|
||||||
|
&& ! contains "$1" "${rebuildfiles[@]}"; then
|
||||||
|
# file already exists and must not be rebuilt
|
||||||
|
return
|
||||||
|
fi
|
||||||
run cp "${0%/*}/$1" "$1"
|
run cp "${0%/*}/$1" "$1"
|
||||||
|
if test $exists -eq 0; then
|
||||||
run svn add "$1"
|
run svn add "$1"
|
||||||
run svn propset svn:keywords "Id" "$1"
|
run svn propset svn:keywords "Id" "$1"
|
||||||
fi
|
fi
|
||||||
@@ -119,11 +342,22 @@ copy() {
|
|||||||
|
|
||||||
doxyreplace() {
|
doxyreplace() {
|
||||||
echo -en "\e[1m-> doxyfile:\e[0m configure $1 ..."
|
echo -en "\e[1m-> doxyfile:\e[0m configure $1 ..."
|
||||||
if sed -i 's|\(^'"$1"' *=\) *|\1'" $2"'|g' doc/doxyfile.in; then
|
if sed -i 's|\(^'"$1"' *=\) *.*|\1'" $2"'|g' doc/doxyfile.in; then
|
||||||
echo -e " \e[32msuccess\e[0m"
|
echo -e " \e[32msuccess\e[0m"
|
||||||
else
|
else
|
||||||
echo -e " \e[31merror\e[0m"
|
echo -e " \e[31merror\e[0m"
|
||||||
echo -e "\e[1m**** command: sed -i 's|\(^'"$1"' *=\) *|\1'" $2"'|g' doc/doxyfile.in;\e[0m"
|
echo -e "\e[1m**** command: $0 $*\e[0m"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
doxyadd() {
|
||||||
|
echo -en "\e[1m-> doxyfile:\e[0m configure $1 ..."
|
||||||
|
if sed -i '/^'"$1"' *=/a'"$1"' += '"$2" doc/doxyfile.in; then
|
||||||
|
echo -e " \e[32msuccess\e[0m"
|
||||||
|
else
|
||||||
|
echo -e " \e[31merror\e[0m"
|
||||||
|
echo -e "\e[1m**** command: $0 $*\e[0m"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@@ -134,48 +368,136 @@ copy ax_init_standard_project.m4
|
|||||||
copy ax_cxx_compile_stdcxx_11.m4
|
copy ax_cxx_compile_stdcxx_11.m4
|
||||||
copy ax_check_qt.m4
|
copy ax_check_qt.m4
|
||||||
copy AUTHORS
|
copy AUTHORS
|
||||||
if ! test -f configure.ac; then
|
to configure.ac <<EOF && \
|
||||||
to configure.ac <<EOF
|
( echo "please edit configure.ac, then rerun $0"; exit 0 )
|
||||||
${HEADER}m4_define(x_package_name, ${DEFAULT_PROJECT_NAME}) # project's name
|
${HEADER}m4_define(x_package_name, ${DEFAULT_PROJECT_NAME}) # project's name
|
||||||
m4_define(x_major, 0) # project's major version
|
m4_define(x_major, 0) # project's major version
|
||||||
m4_define(x_minor, 0) # project's minor version
|
m4_define(x_minor, 0) # project's minor version
|
||||||
m4_include(ax_init_standard_project.m4)
|
m4_include(ax_init_standard_project.m4)
|
||||||
AC_INIT(x_package_name, x_major.x_minor.x_least, x_bugreport, x_package_name)
|
AC_INIT(x_package_name, x_version, x_package_name)
|
||||||
AM_INIT_AUTOMAKE([1.9 tar-pax])
|
AM_INIT_AUTOMAKE([1.9 tar-pax])
|
||||||
AX_INIT_STANDARD_PROJECT
|
AX_INIT_STANDARD_PROJECT
|
||||||
|
|
||||||
# requirements, uncomment, what you need:
|
# requirements, uncomment, what you need:
|
||||||
#AX_USE_CXX
|
#AX_USE_CXX
|
||||||
#AX_USE_LIBTOOL
|
#AX_USE_LIBTOOL
|
||||||
|
#AX_USE_SCRIPTS
|
||||||
#AX_USE_DOXYGEN
|
#AX_USE_DOXYGEN
|
||||||
#AX_USE_DEBIAN_PACKAGING
|
#AX_USE_DEBIAN_PACKAGING
|
||||||
#AX_USE_RPM_PACKAGING
|
#AX_USE_RPM_PACKAGING
|
||||||
#AX_USE_CPPUNIT
|
#AX_USE_CPPUNIT
|
||||||
#AX_BUILD_EXAMPLES
|
#AX_BUILD_EXAMPLES
|
||||||
|
|
||||||
|
# qt features, uncomment, what you need:
|
||||||
|
#AX_CHECK_QT([QT], [QtCore QtGui QtNetwork], [QtWidgets])
|
||||||
|
#AM_CPPFLAGS="${AM_CPPFLAGS} -DQT_NO_KEYWORDS"
|
||||||
|
|
||||||
# create output
|
# create output
|
||||||
AC_OUTPUT
|
AC_OUTPUT
|
||||||
EOF
|
EOF
|
||||||
echo "please edit configure.ac, then rerun $0"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
PACKAGE_NAME=$(sed -n 's/.*m4_define *( *x_package_name *, *\([^ ]*\) *).*/\1/p' configure.ac)
|
PACKAGE_NAME=$(sed -n 's/.*m4_define *( *x_package_name *, *\([^ ]*\) *).*/\1/p' configure.ac)
|
||||||
echo "${HEADER}" | to --condition AX_USE_CXX src/makefile.am
|
echo "${HEADER}MAINTAINERCLEANFILES = makefile.in" | to --condition AX_USE_CXX src/makefile.am
|
||||||
echo "${HEADER}" | to --condition AX_USE_DOXYGEN doc/makefile.am
|
to --condition AX_USE_CXX src/version.hxx <<EOF
|
||||||
|
/*! @file
|
||||||
|
|
||||||
|
@id \$Id\$
|
||||||
|
*/
|
||||||
|
// 1 2 3 4 5 6 7 8
|
||||||
|
// 45678901234567890123456789012345678901234567890123456789012345678901234567890
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
namespace NAMESPACE {
|
||||||
|
/// get package string which consists of package name and package version
|
||||||
|
std::string package_string();
|
||||||
|
/// get package name
|
||||||
|
std::string package_name();
|
||||||
|
/// get package version
|
||||||
|
std::string version();
|
||||||
|
/// get code build date
|
||||||
|
std::string build_date();
|
||||||
|
/// get author, i.e. copyright holder
|
||||||
|
std::string author();
|
||||||
|
/// get short package description (1st line of README)
|
||||||
|
std::string description();
|
||||||
|
/// get long package description (starting at 3rd line in README)
|
||||||
|
std::string readme();
|
||||||
|
/// get package logo file name
|
||||||
|
std::string logo();
|
||||||
|
/// get package icon file name
|
||||||
|
std::string icon();
|
||||||
|
/// used for <code>what filename</code>
|
||||||
|
extern const std::string WHAT;
|
||||||
|
/// used for <code>ident filename</code>
|
||||||
|
extern const std::string IDENT;
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
to --condition AX_USE_CXX src/version.cxx <<EOF
|
||||||
|
/*! @file
|
||||||
|
|
||||||
|
@id $Id\$
|
||||||
|
*/
|
||||||
|
// 1 2 3 4 5 6 7 8
|
||||||
|
// 45678901234567890123456789012345678901234567890123456789012345678901234567890
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
namespace NAMESPACE {
|
||||||
|
std::string package_string() {
|
||||||
|
return PACKAGE_STRING;
|
||||||
|
}
|
||||||
|
std::string package_name() {
|
||||||
|
return PACKAGE_NAME;
|
||||||
|
}
|
||||||
|
std::string version() {
|
||||||
|
return PACKAGE_VERSION;
|
||||||
|
}
|
||||||
|
std::string build_date() {
|
||||||
|
return BUILD_DATE;
|
||||||
|
}
|
||||||
|
std::string author() {
|
||||||
|
return AUTHOR;
|
||||||
|
}
|
||||||
|
std::string description() {
|
||||||
|
return DESCRIPTION;
|
||||||
|
}
|
||||||
|
std::string readme() {
|
||||||
|
return README;
|
||||||
|
}
|
||||||
|
std::string logo() {
|
||||||
|
return PROJECT_LOGO;
|
||||||
|
}
|
||||||
|
std::string icon() {
|
||||||
|
return PROJECT_ICON;
|
||||||
|
}
|
||||||
|
const std::string WHAT("#(@) " PACKAGE_STRING);
|
||||||
|
const std::string IDENT("\$Id: " PACKAGE_STRING);
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
echo "${HEADER}MAINTAINERCLEANFILES = makefile.in" | to --condition AX_USE_SCRIPTS scripts/makefile.am
|
||||||
|
echo "${HEADER}MAINTAINERCLEANFILES = makefile.in" | to --condition AX_USE_DOXYGEN doc/makefile.am
|
||||||
to --condition AX_USE_CPPUNIT test/makefile.am <<EOF
|
to --condition AX_USE_CPPUNIT test/makefile.am <<EOF
|
||||||
${HEADER}AM_CPPFLAGS = -I${top_srcdir}/src -I${top_builddir}/src
|
${HEADER}AM_CPPFLAGS = -I${top_srcdir}/src -I${top_builddir}/src
|
||||||
AM_LDFLAGS = -L${top_builddir}/src/.libs
|
AM_LDFLAGS = -L${top_builddir}/src/.libs
|
||||||
LDADD = -l${PACKAGE_NAME}
|
LDADD = -l${PACKAGE_NAME}
|
||||||
|
|
||||||
|
MAINTAINERCLEANFILES = makefile.in
|
||||||
EOF
|
EOF
|
||||||
to --condition AX_BUILD_EXAMPLES examples/makefile.am <<EOF
|
to --condition AX_BUILD_EXAMPLES examples/makefile.am <<EOF
|
||||||
${HEADER}AM_CPPFLAGS = -I${top_srcdir}/src -I${top_builddir}/src
|
${HEADER}AM_CPPFLAGS = -I${top_srcdir}/src -I${top_builddir}/src
|
||||||
AM_LDFLAGS = -L${top_builddir}/src/.libs
|
AM_LDFLAGS = -L${top_builddir}/src/.libs
|
||||||
LDADD = -l${PACKAGE_NAME}
|
LDADD = -l${PACKAGE_NAME}
|
||||||
|
|
||||||
|
MAINTAINERCLEANFILES = makefile.in
|
||||||
EOF
|
EOF
|
||||||
if testtag AX_USE_DOXYGEN && ! test -f doc/doxyfile.in; then
|
if testtag AX_USE_DOXYGEN && \
|
||||||
|
( ! checkfile doc/doxyfile.in || \
|
||||||
|
contains doc/doxyfile.in "${rebuildfiles[@]}" ); then
|
||||||
run doxygen -g doc/doxyfile.in
|
run doxygen -g doc/doxyfile.in
|
||||||
|
if test $exists -eq 0; then
|
||||||
run svn add doc/doxyfile.in
|
run svn add doc/doxyfile.in
|
||||||
run svn propset svn:keywords "Id" doc/doxyfile.in
|
run svn propset svn:keywords "Id" doc/doxyfile.in
|
||||||
|
fi
|
||||||
doxyreplace PROJECT_NAME "@PACKAGE_NAME@"
|
doxyreplace PROJECT_NAME "@PACKAGE_NAME@"
|
||||||
doxyreplace PROJECT_NUMBER "@PACKAGE_VERSION@"
|
doxyreplace PROJECT_NUMBER "@PACKAGE_VERSION@"
|
||||||
doxyreplace PROJECT_BRIEF "@DESCRIPTION@"
|
doxyreplace PROJECT_BRIEF "@DESCRIPTION@"
|
||||||
@@ -183,27 +505,47 @@ if testtag AX_USE_DOXYGEN && ! test -f doc/doxyfile.in; then
|
|||||||
doxyreplace INLINE_INHERITED_MEMB YES
|
doxyreplace INLINE_INHERITED_MEMB YES
|
||||||
doxyreplace MULTILINE_CPP_IS_BRIEF YES
|
doxyreplace MULTILINE_CPP_IS_BRIEF YES
|
||||||
doxyreplace TAB_SIZE 2
|
doxyreplace TAB_SIZE 2
|
||||||
doxyreplace ALIASES '"id=\par File-ID\n" "copy=\par Copyright\n" "license=\par License\n" "classmutex=\par Reentrant:\nAccess is locked with class static mutex @c " "instancemutex=\par Reentrant:\nAccess is locked with per instance mutex @c " "mutex=\par Reentrant:\nAccess is locked with mutex @c "'
|
doxyreplace ALIASES '"id=\\par File-ID\\n"'
|
||||||
|
doxyadd ALIASES '"copy=\\par Copyright\\n"'
|
||||||
|
doxyadd ALIASES '"license=\\par License\\n"'
|
||||||
|
doxyadd ALIASES '"classmutex=\\par Reentrant:\\nAccess is locked with class static mutex @c "'
|
||||||
|
doxyadd ALIASES '"instancemutex=\\par Reentrant:\\nAccess is locked with per instance mutex @c "'
|
||||||
|
doxyadd ALIASES '"mutex=\\par Reentrant:\\nAccess is locked with mutex @c "'
|
||||||
|
doxyreplace ENABLE_PREPROCESSING YES
|
||||||
|
doxyreplace MACRO_EXPANSION YES
|
||||||
|
doxyadd PREDEFINED '"NAMESPACE=@PACKAGE_NAME@"'
|
||||||
doxyreplace BUILTIN_STL_SUPPORT YES
|
doxyreplace BUILTIN_STL_SUPPORT YES
|
||||||
doxyreplace DISTRIBUTE_GROUP_DOC YES
|
doxyreplace DISTRIBUTE_GROUP_DOC YES
|
||||||
doxyreplace EXTRACT_ALL YES
|
doxyreplace EXTRACT_ALL YES
|
||||||
|
doxyreplace EXTRACT_PACKAGE YES
|
||||||
doxyreplace EXTRACT_PRIVATE YES
|
doxyreplace EXTRACT_PRIVATE YES
|
||||||
doxyreplace EXTRACT_STATIC YES
|
doxyreplace EXTRACT_STATIC YES
|
||||||
doxyreplace EXTRACT_LOCAL_CLASSES YES
|
doxyreplace EXTRACT_LOCAL_CLASSES YES
|
||||||
doxyreplace EXTRACT_LOCAL_METHODS YES
|
doxyreplace EXTRACT_LOCAL_METHODS YES
|
||||||
doxyreplace EXTRACT_ANON_NSPACES YES
|
doxyreplace EXTRACT_ANON_NSPACES YES
|
||||||
|
doxyreplace SHOW_GROUPED_MEMB_INC YES
|
||||||
doxyreplace SORT_MEMBERS_CTORS_1ST YES
|
doxyreplace SORT_MEMBERS_CTORS_1ST YES
|
||||||
doxyreplace WARN_IF_UNDOCUMENTED NO
|
doxyreplace WARN_IF_UNDOCUMENTED NO
|
||||||
doxyreplace WARN_LOGFILE doxygen.errors
|
doxyreplace WARN_LOGFILE doxygen.errors
|
||||||
doxyreplace INPUT "@top_srcdir@/src"
|
doxyreplace INPUT "@top_srcdir@/src"
|
||||||
|
if testtag AX_USE_SCRIPTS; then
|
||||||
|
doxyadd INPUT "@top_srcdir@/scripts"
|
||||||
|
fi
|
||||||
|
if testtag AX_USE_CPPUNIT; then
|
||||||
|
doxyadd INPUT "@top_srcdir@/test"
|
||||||
|
fi
|
||||||
|
doxyreplace FILE_PATTERNS '*.c *.cc *.cxx *.cpp *.c++ *.java *.ii *.ixx *.ipp *.i++ *.inl *.idl *.ddl *.odl *.h *.hh *.hxx *.hpp *.h++ *.cs *.d *.php *.php4 *.php5 *.phtml *.inc *.m *.markdown *.md *.mm *.dox *.py *.f90 *.f *.for *.tcl *.vhd *.vhdl *.ucf *.qsf *.as *.js'
|
||||||
|
doxyadd FILE_PATTERNS *.wt
|
||||||
doxyreplace RECURSIVE YES
|
doxyreplace RECURSIVE YES
|
||||||
doxyreplace EXCLUDE_PATTERNS "moc_* uic_* qrc_*"
|
doxyreplace EXCLUDE_PATTERNS "moc_* uic_* qrc_*"
|
||||||
if testtag AX_BUILD_EXAMPLES; then
|
if testtag AX_BUILD_EXAMPLES; then
|
||||||
doxyreplace EXAMPLE_PATH @top_srcdir@/examples
|
doxyreplace EXAMPLE_PATH @top_srcdir@/examples
|
||||||
fi
|
fi
|
||||||
doxyreplace EXAMPLE_RECURSIVE YES
|
doxyreplace EXAMPLE_RECURSIVE YES
|
||||||
|
doxyreplace FILTER_PATTERNS '*.wt=doxygen-webtester.sed'
|
||||||
doxyreplace SOURCE_BROWSER YES
|
doxyreplace SOURCE_BROWSER YES
|
||||||
doxyreplace INLINE_SOURCES YES
|
doxyreplace INLINE_SOURCES YES
|
||||||
|
doxyreplace GENERATE_TESTLIST YES
|
||||||
doxyreplace GENERATE_TREEVIEW NO
|
doxyreplace GENERATE_TREEVIEW NO
|
||||||
doxyreplace SEARCHENGINE YES
|
doxyreplace SEARCHENGINE YES
|
||||||
doxyreplace GENERATE_HTML YES
|
doxyreplace GENERATE_HTML YES
|
||||||
@@ -237,8 +579,7 @@ Maintainer: @AUTHOR@
|
|||||||
Build-Depends: debhelper, pkg-config, autotools-dev, lsb-release $(if testtag AX_USE_DOXYGEN; then echo -n ", doxygen, graphviz"; fi; if testtag AX_USE_CPPUNIT; then echo -n ", libcppunit-dev"; fi; if testtag AX_CXX_QT || testtag AX_CXX_CHECK_QT; then echo -n ", qtbase5-dev | libqt4-dev, qtbase5-dev-tools | qt4-dev-tools"; fi)
|
Build-Depends: debhelper, pkg-config, autotools-dev, lsb-release $(if testtag AX_USE_DOXYGEN; then echo -n ", doxygen, graphviz"; fi; if testtag AX_USE_CPPUNIT; then echo -n ", libcppunit-dev"; fi; if testtag AX_CXX_QT || testtag AX_CXX_CHECK_QT; then echo -n ", qtbase5-dev | libqt4-dev, qtbase5-dev-tools | qt4-dev-tools"; fi)
|
||||||
|
|
||||||
Package: @PACKAGE_NAME@
|
Package: @PACKAGE_NAME@
|
||||||
$(if testtag AX_USE_LIBTOOL; then echo "Section: libs"; fi)
|
$(if testtag AX_USE_LIBTOOL; then echo "Section: libs"; fi)Architecture: any
|
||||||
Architecture: any
|
|
||||||
Depends: \${shlibs:Depends}, \${misc:Depends}
|
Depends: \${shlibs:Depends}, \${misc:Depends}
|
||||||
Description: @DESCRIPTION@
|
Description: @DESCRIPTION@
|
||||||
@README_DEB@
|
@README_DEB@
|
||||||
@@ -258,41 +599,32 @@ EOF
|
|||||||
NEWS
|
NEWS
|
||||||
README
|
README
|
||||||
EOF
|
EOF
|
||||||
to debian/${PACKAGE_NAME}.install <<EOF
|
to --condition AX_USE_LIBTOOL debian/${PACKAGE_NAME}.install <<EOF
|
||||||
usr/bin/*
|
|
||||||
usr/lib/lib*.so.*
|
usr/lib/lib*.so.*
|
||||||
$(if ! testtag AX_USE_LIBTOOL; then echo "usr/share/doc/${PACKAGE_NAME}/html"; fi)
|
|
||||||
EOF
|
EOF
|
||||||
to debian/${PACKAGE_NAME}.dirs <<EOF
|
to --condition AX_USE_LIBTOOL debian/${PACKAGE_NAME}-dev.install <<EOF
|
||||||
usr/lib
|
|
||||||
EOF
|
|
||||||
if testtag AX_USE_LIBTOOL; then
|
|
||||||
to debian/${PACKAGE_NAME}-dev.install <<EOF
|
|
||||||
usr/include/*
|
usr/include/*
|
||||||
usr/lib/lib*.a
|
usr/lib/lib*.a
|
||||||
usr/lib/lib*.so
|
usr/lib/lib*.so
|
||||||
usr/lib/pkgconfig/*
|
usr/lib/pkgconfig/*
|
||||||
usr/lib/*.la
|
usr/lib/*.la
|
||||||
$(if testtag AX_USE_LIBTOOL; then echo "usr/share/doc/${PACKAGE_NAME}/html"; fi)
|
usr/share/doc/${PACKAGE_NAME}/html
|
||||||
EOF
|
EOF
|
||||||
to debian/${PACKAGE_NAME}-dev.dirs <<EOF
|
to --mode "u=rwx,g=rwx,o=rx" debian/rules <<EOF
|
||||||
usr/lib
|
|
||||||
usr/include
|
|
||||||
EOF
|
|
||||||
fi
|
|
||||||
to debian/rules <<EOF
|
|
||||||
${HEADER}%:
|
${HEADER}%:
|
||||||
dh \$@
|
dh \$@
|
||||||
EOF
|
EOF
|
||||||
echo 7 | to debian/compat
|
echo 7 | to debian/compat
|
||||||
fi
|
fi
|
||||||
if ! test -f makefile.am; then
|
SUBDIRS=""
|
||||||
SUBDIRS=""
|
for d in src test scripts doc examples; do
|
||||||
for d in src test doc examples; do
|
|
||||||
test -d $d && SUBDIRS="${SUBDIRS} $d"
|
test -d $d && SUBDIRS="${SUBDIRS} $d"
|
||||||
done
|
done
|
||||||
echo "${HEADER}SUBDIRS =${SUBDIRS}" | to makefile.am
|
to makefile.am<<EOF
|
||||||
fi
|
${HEADER}SUBDIRS =${SUBDIRS}
|
||||||
|
|
||||||
|
MAINTAINERCLEANFILES = makefile.in
|
||||||
|
EOF
|
||||||
to --condition AX_USE_LIBTOOL src/${PACKAGE_NAME}.pc.in <<EOF
|
to --condition AX_USE_LIBTOOL src/${PACKAGE_NAME}.pc.in <<EOF
|
||||||
${HEADER}prefix=@prefix@
|
${HEADER}prefix=@prefix@
|
||||||
exec_prefix=@exec_prefix@
|
exec_prefix=@exec_prefix@
|
||||||
@@ -304,6 +636,7 @@ Description: @DESCRIPTION@
|
|||||||
Version: @VERSION@
|
Version: @VERSION@
|
||||||
Libs: -L\${libdir} -l@PACKAGE_NAME@ @LDFLAGS@
|
Libs: -L\${libdir} -l@PACKAGE_NAME@ @LDFLAGS@
|
||||||
Cflags: -I\${includedir} @CPPFLAGS@
|
Cflags: -I\${includedir} @CPPFLAGS@
|
||||||
|
Requires: @PKG_REQUIREMENTS@
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
#### Cleanup If Makefile Exists ####
|
#### Cleanup If Makefile Exists ####
|
||||||
@@ -321,3 +654,8 @@ run autoconf
|
|||||||
if test "$configure" -eq 1; then
|
if test "$configure" -eq 1; then
|
||||||
./configure $*
|
./configure $*
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
#### Run Make If User Requires ####
|
||||||
|
if test "$build" -eq 1; then
|
||||||
|
make
|
||||||
|
fi
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
## @id $Id$
|
## @id $Id$
|
||||||
#
|
#
|
||||||
# This file has been added by bootstrap.sh on Sun, 15 Mar 2015 16:54:22 +0100
|
# This file has been added by bootstrap.sh on Sat, 09 May 2015 10:46:31 +0200
|
||||||
# Feel free to change it or even remove and rebuild it, up to your needs
|
# Feel free to change it or even remove and rebuild it, up to your needs
|
||||||
#
|
#
|
||||||
## 1 2 3 4 5 6 7 8
|
## 1 2 3 4 5 6 7 8
|
||||||
@@ -16,3 +16,4 @@ Description: @DESCRIPTION@
|
|||||||
Version: @VERSION@
|
Version: @VERSION@
|
||||||
Libs: -L${libdir} -l@PACKAGE_NAME@ @LDFLAGS@
|
Libs: -L${libdir} -l@PACKAGE_NAME@ @LDFLAGS@
|
||||||
Cflags: -I${includedir} @CPPFLAGS@
|
Cflags: -I${includedir} @CPPFLAGS@
|
||||||
|
Requires: @PKG_REQUIREMENTS@
|
||||||
|
33
src/version.hxx
Normal file
33
src/version.hxx
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
/*! @file
|
||||||
|
|
||||||
|
@id $Id$
|
||||||
|
*/
|
||||||
|
// 1 2 3 4 5 6 7 8
|
||||||
|
// 45678901234567890123456789012345678901234567890123456789012345678901234567890
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
namespace NAMESPACE {
|
||||||
|
/// get package string which consists of package name and package version
|
||||||
|
std::string package_string();
|
||||||
|
/// get package name
|
||||||
|
std::string package_name();
|
||||||
|
/// get package version
|
||||||
|
std::string version();
|
||||||
|
/// get code build date
|
||||||
|
std::string build_date();
|
||||||
|
/// get author, i.e. copyright holder
|
||||||
|
std::string author();
|
||||||
|
/// get short package description (1st line of README)
|
||||||
|
std::string description();
|
||||||
|
/// get long package description (starting at 3rd line in README)
|
||||||
|
std::string readme();
|
||||||
|
/// get package logo file name
|
||||||
|
std::string logo();
|
||||||
|
/// get package icon file name
|
||||||
|
std::string icon();
|
||||||
|
/// used for <code>what filename</code>
|
||||||
|
extern const std::string WHAT;
|
||||||
|
/// used for <code>ident filename</code>
|
||||||
|
extern const std::string IDENT;
|
||||||
|
}
|
Reference in New Issue
Block a user