X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/projects.git/blobdiff_plain/d9cf8cb8c48333ccb726cabb189827cf061c73ce..adedfeb0291a60352eaeaa2e2753cfab08189dc6:/tools/make/mconfigure diff --git a/tools/make/mconfigure b/tools/make/mconfigure index 691825d..08f9d44 100755 --- a/tools/make/mconfigure +++ b/tools/make/mconfigure @@ -11,6 +11,35 @@ function echo_usage { echo " -o : support old Debian 7 format" } +function cmake_check { + pushd ../build >/dev/null + # do checks + if [ -e debian/$paket.build ] + then + echo "cmake is not compatible with other builds. Remove $paket.build" + exit 1 + fi + if [ -e debian/$paket.prebuild ] + then + echo "cmake is not compatible with other builds. Remove $paket.prebuild" + exit 2 + fi + + if [ -n "$cross" ] + then + # inject cross toolset + echo "set (CMAKE_MODULE_PATH $cross)" > CMakeLists.txt + echo "include(toolset)" >> CMakeLists.txt + cat debian/$paket.cmake >> CMakeLists.txt + else + cp debian/$paket.cmake CMakeLists.txt + fi + + echo "make" > debian/$paket.build + chmod 755 debian/$paket.build + cmake . + popd >/dev/null +} function check_unversioned { # has to be called in the projects base directory # result: "M" in stdout or nothing @@ -55,8 +84,8 @@ function set_build { fi changes=$(check_unversioned) tag="$tag$changes" - version=${tag%-*} - version=${version##*_} + version=${tag##*_} + version=${version%%-*} build=${tag##*-} else echo "No configuration system found. Cannot determine version." @@ -149,24 +178,36 @@ fi if [ $configure -eq 1 ] then # delete changelog and control - rm debian/changelog debian/control 2>/dev/null || true + rm debian/changelog debian/control debian/README.debian debian/copyright 2>/dev/null || true # mconfigure builds 2 environment files: setenv.sh + rules.pre echo "" > debian/rules.pre if [ -e debian/setenv.sh ]; then rm debian/setenv.sh; fi - if [ -n "$ARCH" ] - then - arch_opt="-a $ARCH" - fi if [ -n "$cross" ] then if [ ${cross:0:1} != "/" ] then cross="/opt/cross/$cross" + #export $cross + fi + if [ -f "$cross/setenv.sh" ] + then + . "$cross/setenv.sh" + cp $cross/setenv.sh debian/setenv.sh + fi + if [ -z "$ARCH" ] + then + # determine architecture + GNU_ARCH=${cross%-*} # assumed format: DEB_HOST_GNU_TYPE-g++version, e.g. arm-linux-gnueabihf-4.9 + GNU_ARCH=${GNU_ARCH##*/} + arch_opt="-t $GNU_ARCH" fi - . "$cross/setenv.sh" - cp $cross/setenv.sh debian/setenv.sh + fi + + if [ -n "$ARCH" ] + then + arch_opt="-a $ARCH" fi dpkg-architecture $arch_opt >> debian/setenv.sh @@ -197,6 +238,7 @@ then fi # check for pre/post installation scripts + echo "TODO: check for conffiles" if [ -f $paket.preinst ] then echo "add_inst_tgt += debian/tmp/DEBIAN/preinst" >> rules.pre @@ -214,6 +256,12 @@ then echo "add_inst_tgt += debian/tmp/DEBIAN/postrm" >> rules.pre fi + # check for README.debian + if [ -f $paket.README.debian ] + then + cp $paket.README.debian README.debian + fi + mkdir -p tmp/DEBIAN # add export to setenv.sh @@ -238,12 +286,8 @@ then . debian/setenv.sh debian/$paket.prepare fi - if [ -e debian/$paket.cmake ] - then - # trigger build - touch debian/$paket.build - fi - if [ -e debian/$paket.build ] + # .build or .cmake + if [ -x debian/$paket.build -o -e debian/$paket.cmake ] then if [ -e ../build ] then @@ -256,9 +300,24 @@ then exit 2 fi # sync build dir -# . debian/setenv.sh -# debian/rules sync - + . debian/setenv.sh + debian/rules sync + fi + # .build + if [ -x debian/$paket.build ] + then + if [ -x debian/$paket.prebuild ] + then + pushd ../build >/dev/null + . debian/setenv.sh + debian/$paket.prebuild + popd >/dev/null + fi + fi + # .cmake + if [ -e debian/$paket.cmake ] + then + cmake_check fi # pack prepare @@ -281,16 +340,16 @@ then fi fi -if [ $compile -eq 1 -a ! -e debian/$paket.build ] -then - echo "no debian/$paket.build: skipping build step" - compile=0 -fi if [ $compile -eq 1 ] then - # build package - . debian/setenv.sh - debian/rules build + if [ -x debian/$paket.build -o -e debian/$paket.cmake ] + then + # build package + . debian/setenv.sh + debian/rules build + else + echo "skipping build step ..." + fi fi if [ $pack -eq 1 ]