X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/projects.git/blobdiff_plain/a5167266107ee7a73a48b3758708dc4e0ae274b9..8d00b092ec8d9b993776937f48a5a88de19cacda:/tools/make/mconfigure diff --git a/tools/make/mconfigure b/tools/make/mconfigure index e94ead5..95e0006 100755 --- a/tools/make/mconfigure +++ b/tools/make/mconfigure @@ -2,16 +2,27 @@ set -e function echo_usage { - echo "usage: mconfigure [options]" + echo "usage: mconfigure [options] " echo " -a " echo " -c : configure" echo " -d : compile" echo " -p : pack default: do all" + echo " -o : support old Debian 7 format" } 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##*/} @@ -27,6 +38,7 @@ function check_unversioned { } function set_build { + set -e if [ -e .svn ] then version="0.0" @@ -35,16 +47,11 @@ function set_build { build="$build$(check_unversioned)" elif [ -e .git ] then - tag=$(git describe --tags 2>/dev/null) || true + tag=$(git describe --tags --match "${paket}_*" 2>/dev/null) || true if test -z "$tag" then tag="0.0-0TOP" fi - tag_paket=${tag%_*} - if [ "$tag_paket" != "$paket" ] - then - tag="0.0-0TOP" - fi changes=$(check_unversioned) tag="$tag$changes" version=${tag%-*} @@ -57,9 +64,10 @@ function set_build { } function check_version { + set -e vline=$(head -1 debian/$paket.changelog) - vline=${vline%[-)]*} + vline=${vline%-*} clversion=${vline#*(} if [ $version = "0.0" ] then @@ -79,15 +87,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 @@ -95,13 +94,10 @@ then exit 2 fi -paket=$1 - configure=0 compile=0 pack=0 -shift -while getopts "a:cdp" opt; do +while getopts "a:cdpo" opt; do case $opt in a) ARCH=$OPTARG ;; @@ -111,6 +107,8 @@ while getopts "a:cdp" opt; do ;; p) pack=1 ;; + o) oldpack="-Zgzip" + ;; \?) echo "Invalid option: -$OPTARG" echo_usage exit 1 @@ -121,6 +119,15 @@ while getopts "a:cdp" opt; do ;; esac done +shift $((OPTIND -1)) + +if [ $# -lt 1 ] +then + echo_usage + exit 1 +fi + +paket=$1 # if nothing is selected, select all if [ $configure -eq 0 -a $compile -eq 0 -a $pack -eq 0 ] @@ -145,8 +152,7 @@ then echo "" > debian/rules.pre echo "paket=$paket" >> debian/setenv.sh - - cpp_build=0 + echo "oldpack=\"$oldpack\"" >> debian/setenv.sh set_build check_version @@ -189,18 +195,8 @@ 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 ] - then - cpp_build=1 - . projects/tools/make/c_configure.sh - . $paket.cpp.sh - fi - # add export to setenv.sh sed -i "s/^/export /" setenv.sh @@ -213,23 +209,16 @@ 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 [ -x debian/$paket.prepare ] + then + . debian/setenv.sh + debian/$paket.prepare + fi if [ -e debian/$paket.build ] then if [ -e ../build ] @@ -242,6 +231,17 @@ Maintainer: WagnerTech UG debian/rules sync debian/$paket.build -prepare fi + # sync build dir + . debian/setenv.sh + debian/rules sync + + # executing prebuild + if [ -x debian/$paket.prebuild ] + then + pushd ~/build >/dev/null + debian/$paket.prebuild + popd >/dev/null + fi fi # pack prepare @@ -266,7 +266,7 @@ fi if [ $compile -eq 1 -a ! -e debian/$paket.build ] then - echo "no debian/build.sh: skipping build step" + echo "no debian/$paket.build: skipping build step" compile=0 fi if [ $compile -eq 1 ]