X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/projects.git/blobdiff_plain/f95a6d2cfaffc95c415f799e05e7b02c8040b9be..5e8e2b2380cd6697b8634a765cdfd0b9e07c502c:/tools/make/mconfigure diff --git a/tools/make/mconfigure b/tools/make/mconfigure index 8ce366e..b102ad7 100755 --- a/tools/make/mconfigure +++ b/tools/make/mconfigure @@ -2,202 +2,120 @@ set -e function echo_usage { - echo "usage: mconfigure [options]" - echo " -a " - echo " -p : prepare build, but not do it" + echo "usage: mconfigure [options] " + echo " -c : copy configure/Makefile" + echo " -d : compile" + echo " -p : pack default: do all" + ./configure -I } -function set_build { - if [ -e .svn ] - then - version="0.0" - build=$(svnversion) - build=${build/:/-} - elif [ -e .git ] - then - tag=$(git describe --tags 2>/dev/null) || true - if test -z "$tag" - then - tag="0.0-TOP" - fi - changes=$(git status -s |grep "^ *M") || true - if test -n "$changes" - then - tag="${tag}M" - fi - version=${tag%%-*} - build=${tag#*-} - fi -} +############################################################################## +# Main program +############################################################################## -function check_version { - vline=$(head -1 debian/$paket.changelog) - vline=${vline%-*} - clversion=${vline#*(} - if [ $version = "0.0" ] - then - version=$clversion - return - fi - if [ "$clversion" != $version ] +if [ ! -d debian ] +then + echo "run mconfigure in the project base directory with a debian directory in it!" + exit 2 +fi + +configure=0 +compile=0 +pack=0 +confirure_args="-b ../build" +while [ $OPTIND -le "$#" ] +do + if getopts "cdp" opt then - echo "version mismatch: git: $version, changelog: $clversion" - exit 1 + case $opt in + c) configure=1 + ;; + d) compile=1 + ;; + p) pack=1 + ;; + \?) $confirure_args="$configure_ars -$OPTARG" + if [ $OPTARG="a" -o $OPTARG="C" -o $OPTARG="i" -o $OPTARG="v" ] + then + eval OPTIND=OPTIND+1 + $confirure_args="$configure_ars ${!OPTIND}" + fi + ;; + :) echo "Option -$OPTARG requires an argument." + echo_usage + exit 1 + ;; + esac + else + paket="${!OPTIND}" + eval OPTIND=OPTIND+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 +done -if [ $# -lt 1 ] +if [ -z "$paket" ] then echo_usage exit 1 fi -if [ ! -d debian ] +if [ $configure -eq 1 ] then - echo "run mconfigure in the project base directory!" - exit 2 + # installation of configure file + cp /usr/share/mbuild/configure . +else + if [ ! -e configure ] + then + ln -s /usr/share/mbuild/configure . + fi fi -paket=$1 -echo "export paket=$1" > debian/setenv.sh -shift -ARCH="" -cpp_build=0 - -set_build -check_version -echo "export version=$version" >> debian/setenv.sh -echo "export build=$build" >> debian/setenv.sh - -# get repository name -tmp=$(pwd) -pwd=${tmp##*/} -pwd=${pwd,,*} -echo "export pwd=$pwd" >> debian/setenv.sh - -echo "building $paket with build $version-$build" - -prepare=0 -while getopts ":ap" opt; do - case $opt in - a) ARCH=$OPTARG - ;; - p) prepare=1 - ;; - \?) echo "Invalid option: -$OPTARG" - echo_usage - exit 1 - ;; - :) echo "Option -$OPTARG requires an argument." - echo_usage - exit 1 - ;; - esac -done -# -## clean dirs and check out -#if [ -d build -a $delete_src -eq 1 ] -#then -# rm -rf build -#fi -# - -pushd debian >/dev/null - -ln -sf /usr/share/mbuild/rules . - -#if [ -e tmp ] -#then -# rm -rf tmp -#fi -#rm *.stamp 2>/dev/null || true -#rm make.pre 2>/dev/null || true - -mkdir -p tmp/DEBIAN - -# load util functions for C/C++ - build -if [ -f $paket.cpp.sh ] +configure_args="$configure_args $paket" +if [ -x debian/$paket.preconfigure ] then - cpp_build=1 - . projects/tools/make/c_configure.sh - . $paket.cpp.sh + # if necessary $configure_args can be added to setenv.sh + debian/$paket.preconfigure fi -popd >/dev/null - -# copy package control -if [ ! -f debian/control ] +#-> configure +# .build or .cmake +if [ -x debian/$paket.build -o -e debian/$paket.cmake ] then - control=$(find etc -name $paket.control) - if [ -z "$control" ] + echo "BUILD_DIR=../build" >> debian/setenv.sh + if [ -e ../build ] then - echo "warning: control file not found" - echo " this file is necessary for any package production." - else - echo "Source: $pwd -Section: main -Priority: optional -Maintainer: WagnerTech UG -" > debian/control - grep -v "Version:" $control |grep -v "Maintainer:" >> debian/control + rm -rf ../build + 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 -if [ $prepare = 1 ] +# perform configure +. debian/setenv.sh +./configure $configure_args + +# if nothing is selected, select all +if [ $compile -eq 0 -a $pack -eq 0 ] then - exit 0 + compile=1 + pack=1 fi -# check for copy file -#if [ ! -f debian/$paket.cp ] -#then -# # search for copy file -# copy=$(find . -name $paket.cp) -# if [ -n "$copy" ] -# then -# echo "ln -sf ../$copy debian/" -# ln -sf ../$copy debian/ -# else -# echo "warning: file $paket.cp missing or not executable:" -# echo " this file is necessary for any package production." -# fi -#fi - -# build package -. debian/setenv.sh -debian/rules binary - -# -## check for installation scripts -#files=$(find .. -name $paket.preinst) -#files="$files $(find .. -name $paket.postinst)" -#files="$files $(find .. -name $paket.prerm)" -#files="$files $(find .. -name $paket.postrm)" -#for file in $files -#do -# ln -sf $file . -#done +if [ $compile -eq 1 ] +then + # build + make +fi -# create generic make.pre, if not existing -#if [ ! -f make.pre ] -#then -# cat >>make.pre <>make.pre -# echo "_arch = _${ARCH}" >>make.pre -# fi -# echo "make.pre written." -#fi -# -## append version to make.pre -#echo "version = $version" >> make.pre -#echo "build = $build" >> make.pre +if [ $pack -eq 1 ] +then + # build package + debian/rules pack +fi