X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/projects.git/blobdiff_plain/290f9a4e182a7c7a89765e58c9ba477be4fc4732..56b24328934af53e173afa7ffa576f03048db73e:/tools/make/mconfigure diff --git a/tools/make/mconfigure b/tools/make/mconfigure index a1ea508..08f9d44 100755 --- a/tools/make/mconfigure +++ b/tools/make/mconfigure @@ -2,17 +2,57 @@ set -e function echo_usage { - echo "usage: mconfigure [options]" + echo "usage: mconfigure [options] " echo " -a " echo " -c : configure" + echo " -C " echo " -d : compile" echo " -p : pack default: do all" - echo " -o : support old Debian 7 format" + 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 + set -e + + # check if build is running in a sandbox + if ! [ -f .cm.ignore ] + then + # we create one + echo ".cm.ignore" > .cm.ignore + echo "debian.*" >> .cm.ignore + echo "up.*" >> .cm.ignore + fi project=$(pwd) project=${project##*/} @@ -28,6 +68,7 @@ function check_unversioned { } function set_build { + set -e if [ -e .svn ] then version="0.0" @@ -43,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." @@ -53,6 +94,7 @@ function set_build { } function check_version { + set -e vline=$(head -1 debian/$paket.changelog) vline=${vline%-*} @@ -75,15 +117,6 @@ function check_version { exit 1 fi } -# to build a package you need ... -# .cp (optional): copy step for package production -# .cpp.sh (optional): commands to setup the C++ compile environment - -if [ $# -lt 1 ] -then - echo_usage - exit 1 -fi if [ ! -d debian ] then @@ -91,13 +124,10 @@ then exit 2 fi -paket=$1 - configure=0 compile=0 pack=0 -shift -while getopts "a:cdpo" opt; do +while getopts "a:cC:dpo" opt; do case $opt in a) ARCH=$OPTARG ;; @@ -105,6 +135,8 @@ while getopts "a:cdpo" opt; do ;; d) compile=1 ;; + C) cross=$OPTARG + ;; p) pack=1 ;; o) oldpack="-Zgzip" @@ -119,6 +151,21 @@ while getopts "a:cdpo" opt; do ;; esac done +shift $((OPTIND -1)) + +if [ $# -lt 1 ] +then + echo_usage + exit 1 +fi + +paket=$1 + +if [ -n "$ARCH" -a -n "$cross" ] +then + echo "invalid options: supply -a for multiarch or -C for explicit cross compile environment" + exit 1 +fi # if nothing is selected, select all if [ $configure -eq 0 -a $compile -eq 0 -a $pack -eq 0 ] @@ -131,20 +178,41 @@ 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 "$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 + fi + if [ -n "$ARCH" ] then arch_opt="-a $ARCH" fi - dpkg-architecture $arch_opt > debian/setenv.sh - echo "" > debian/rules.pre + dpkg-architecture $arch_opt >> debian/setenv.sh echo "paket=$paket" >> debian/setenv.sh echo "oldpack=\"$oldpack\"" >> debian/setenv.sh - cpp_build=0 set_build check_version @@ -170,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 @@ -187,18 +256,14 @@ then echo "add_inst_tgt += debian/tmp/DEBIAN/postrm" >> rules.pre fi - #cat setenv.sh >> rules.pre - - mkdir -p tmp/DEBIAN - - # load util functions for C/C++ - build - if [ -f $paket.cpp.sh ] + # check for README.debian + if [ -f $paket.README.debian ] then - cpp_build=1 - . projects/tools/make/c_configure.sh - . $paket.cpp.sh + cp $paket.README.debian README.debian fi + mkdir -p tmp/DEBIAN + # add export to setenv.sh sed -i "s/^/export /" setenv.sh @@ -211,24 +276,18 @@ then # proceed echo else - # try old fashoned way - control=$(find etc -name $paket.control) || true - if [ -z "$control" ] - then - echo "warning: control file not found" - echo " this file is necessary for any package production." - else - echo "Source: $paket -Section: main -Priority: optional -Maintainer: WagnerTech UG -" > debian/$paket.control - grep -v "Version:" $control |grep -v "Maintainer:" >> debian/$paket.control - fi + echo "warning: control file not found" + echo " this file is necessary for any package production." fi # build prepare - if [ -e debian/$paket.build ] + if [ -x debian/$paket.prepare ] + then + . debian/setenv.sh + debian/$paket.prepare + fi + # .build or .cmake + if [ -x debian/$paket.build -o -e debian/$paket.cmake ] then if [ -e ../build ] then @@ -236,11 +295,30 @@ Maintainer: WagnerTech UG mkdir ../build fi if grep -- "-prepare" debian/$paket.build >/dev/null + then + echo "prepare in .build no longer supported. Use .prebuild" + exit 2 + fi + # sync build dir + . debian/setenv.sh + debian/rules sync + fi + # .build + if [ -x debian/$paket.build ] + then + if [ -x debian/$paket.prebuild ] then - debian/rules sync - debian/$paket.build -prepare + 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 if [ -f debian/$paket.cp -a -f debian/$paket.control ] @@ -262,16 +340,16 @@ Maintainer: WagnerTech UG fi fi -if [ $compile -eq 1 -a ! -e debian/$paket.build ] -then - echo "no debian/build.sh: skipping build step" - compile=0 -fi if [ $compile -eq 1 ] then - # build artefacts - . 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 ]