X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/projects.git/blobdiff_plain/152748262107973df2ea6d018324a75289a5d367..34d5bcbab5f361fa83c207abe3b177e1f408b6db:/tools/make/mconfigure diff --git a/tools/make/mconfigure b/tools/make/mconfigure index be5f3ba..2cb0096 100755 --- a/tools/make/mconfigure +++ b/tools/make/mconfigure @@ -4,7 +4,26 @@ set -e function echo_usage { echo "usage: mconfigure [options]" echo " -a " - echo " -p : prepare build, but not do it" + echo " -c : configure" + echo " -d : compile" + echo " -p : pack default: do all" +} + +function check_unversioned { + # has to be called in the projects base directory + # result: "M" in stdout or nothing + + project=$(pwd) + project=${project##*/} + pushd .. >/dev/null + mCM $project -b -an > /dev/null + wc=$(wc $project.batch) + rm $project.batch + if [ "${wc:0:5}" != "0 0 0" ] + then + echo "M" + fi + popd >/dev/null } function set_build { @@ -13,31 +32,49 @@ function set_build { version="0.0" build=$(svnversion) build=${build/:/-} + pushd .. >/dev/null + build="$build$(check_unversioned)" + popd >/dev/null elif [ -e .git ] then tag=$(git describe --tags 2>/dev/null) || true if test -z "$tag" then - tag="0.0-TOP" + tag="0.0-0TOP" fi - changes=$(git status -s |grep "^ *M") || true - if test -n "$changes" + tag_paket=${tag%_*} + if [ "$tag_paket" != "$paket" ] then - tag="${tag}M" + tag="0.0-0TOP" fi + changes=$(check_unversioned) + tag="$tag$changes" version=${tag%-*} - build=${tag#*-} + version=${version##*_} + build=${tag##*-} + else + echo "No configuration system found. Cannot determine version." + exit 1 fi } function check_version { + + vline=$(head -1 debian/$paket.changelog) + vline=${vline%-*} + clversion=${vline#*(} if [ $version = "0.0" ] then + version=$clversion return fi - vline=$(head -1 debian/$paket.changelog) - vline=${vline%-*} - clversion=${vline#*(} + + # do no check on a modified git repos + if [ "${build: -1}" == "M" ] + then + return + fi + if [ "$clversion" != $version ] then echo "version mismatch: git: $version, changelog: $clversion" @@ -56,34 +93,25 @@ fi if [ ! -d debian ] then - echo "run mconfigure in the project base directory!" + echo "run mconfigure in the project base directory with a debian directory in it!" exit 2 fi -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" +paket=$1 -prepare=0 -while getopts ":ap" opt; do +configure=0 +compile=0 +pack=0 +shift +while getopts ":acdp" opt; do case $opt in a) ARCH=$OPTARG ;; - p) prepare=1 + c) configure=1 + ;; + d) compile=1 + ;; + p) pack=1 ;; \?) echo "Invalid option: -$OPTARG" echo_usage @@ -95,107 +123,152 @@ while getopts ":ap" opt; do ;; esac done -# -## clean dirs and check out -#if [ -d build -a $delete_src -eq 1 ] -#then -# rm -rf build -#fi -# -pushd debian >/dev/null +# if nothing is selected, select all +if [ $configure -eq 0 -a $compile -eq 0 -a $pack -eq 0 ] +then + configure=1 + compile=1 + pack=1 +fi -ln -sf /usr/share/mbuild/rules . +if [ $configure -eq 1 ] +then + # delete changelog and control + rm debian/changelog debian/control || true + + # mconfigure builds 2 environment files: setenv.sh + rules.pre + # setenv.sh is finally appended to rules.pre + + dpkg-architecture > debian/setenv.sh + echo "" > debian/rules.pre + + echo "paket=$paket" >> debian/setenv.sh +# shift + ARCH="" + cpp_build=0 -#if [ -e tmp ] -#then -# rm -rf tmp -#fi -#rm *.stamp 2>/dev/null || true -#rm make.pre 2>/dev/null || true + set_build + check_version + echo "version=$version" >> debian/setenv.sh + echo "build=$build" >> debian/setenv.sh -mkdir -p tmp/DEBIAN + # get repository name +# tmp=$(pwd) +# pwd=${tmp##*/} +# pwd=${pwd,,*} +# echo "pwd=$pwd" >> debian/rules.pre -# 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 + echo "building $paket with build $version-$build" -popd >/dev/null + pushd debian >/dev/null + # ./debian ------------------------------------- -# copy package control -if [ ! -f debian/control ] -then - control=$(find etc -name $paket.control) - if [ -z "$control" ] + ln -sf /usr/share/mbuild/rules . + + if [ -e tmp ] + then + rm -rf tmp + fi + + # check for pre/post installation scripts + if [ -f $paket.preinst ] + then + echo "add_inst_tgt += debian/tmp/DEBIAN/preinst" >> rules.pre + fi + if [ -f $paket.postinst ] + then + echo "add_inst_tgt += debian/tmp/DEBIAN/postinst" >> rules.pre + fi + if [ -f $paket.prerm ] + then + echo "add_inst_tgt += debian/tmp/DEBIAN/prerm" >> rules.pre + fi + if [ -f $paket.postrm ] 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 + 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 + + popd >/dev/null + # ./. --------------------------------------------- + + # copy package control + if [ -f debian/$paket.control ] + 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 + fi + + # build prepare + if [ -e debian/$paket.build ] + then + if [ -e ../build ] + then + rm -rf ../build + mkdir ../build + fi + if grep -- "-prepare" debian/$paket.build >/dev/null + then + debian/rules sync + debian/$paket.build -prepare + fi + fi + + # pack prepare + if [ -f debian/$paket.cp -a -f debian/$paket.control ] + then + echo "PACK=binary" >> debian/rules.pre + elif [ -f debian/$paket.cp ] + then + echo "PACK=zip" >> debian/rules.pre + else + echo "PACK=version" >> debian/rules.pre fi fi -if [ $prepare = 1 ] +if [ $compile -eq 1 -a ! -e debian/$paket.build ] then - exit 0 + echo "no debian/build.sh: skipping build step" + compile=0 +fi +if [ $compile -eq 1 ] +then + # build artefacts + . debian/setenv.sh + debian/rules build 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 - -# 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/setenv.sh + debian/rules pack +fi