X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/projects.git/blobdiff_plain/1dd818ead588216487bfcd91c2a7767b1bdabbe8..2db0d888c5eefc4a7d7dfd7bc367db3e2679f3a4:/tools/make/mconfigure diff --git a/tools/make/mconfigure b/tools/make/mconfigure index d329219..9217fa1 100755 --- a/tools/make/mconfigure +++ b/tools/make/mconfigure @@ -4,27 +4,50 @@ set -e function echo_usage { echo "usage: mconfigure [options]" echo " -a " + echo " -c : configure only, no compile, pack" + echo " -d : compile only" + echo " -p : pack only" } function set_build { if [ -e .svn ] then + version="0.0" build=$(svnversion) + build=${build/:/-} elif [ -e .git ] then - build=$(git describe --tags 2>/dev/null) || true - if test -z "$build" + tag=$(git describe --tags 2>/dev/null) || true + if test -z "$tag" then - build="0.0-TOP" + tag="0.0-TOP" fi changes=$(git status -s |grep "^ *M") || true - if test -z "$changes" + if test -n "$changes" then - build="${build}M" + tag="${tag}M" fi + version=${tag%%-*} + version=${version##*_} + build=${tag#*-} fi } +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 ] + then + echo "version mismatch: git: $version, changelog: $clversion" + 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 @@ -37,128 +60,127 @@ 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 -export paket=$1 -shift -ARCH="" -cpp_build=0 - -set_build -export build - -# get repository name -tmp=$(pwd) -export pwd=${tmp##*/} - -echo "building $paket with build $build" - -#while getopts ":a" opt; do -# case $opt in -# a) ARCH=$OPTARG -# ;; -# \?) 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 -# +paket=$1 + +configure=1 +compile=1 +pack=1 +while getopts ":ap" opt; do + case $opt in + a) ARCH=$OPTARG + ;; + c) compile=0 + pack=0 + ;; + d) configure=0 + pack=0 + ;; + p) configure=0 + compile=0 + ;; + \?) echo "Invalid option: -$OPTARG" + echo_usage + exit 1 + ;; + :) echo "Option -$OPTARG requires an argument." + echo_usage + exit 1 + ;; + esac +done + +if [ $configure -eq 1 ] +then + echo "export paket=$1" > debian/setenv.sh + shift + ARCH="" + cpp_build=0 -pushd debian >/dev/null + set_build + check_version + echo "export version=$version" >> debian/setenv.sh + echo "export build=$build" >> debian/setenv.sh -ln -sf /usr/share/mbuild/rules . + # get repository name + tmp=$(pwd) + pwd=${tmp##*/} + pwd=${pwd,,*} + echo "export pwd=$pwd" >> debian/setenv.sh -#if [ -e tmp ] -#then -# rm -rf tmp -#fi -#rm *.stamp 2>/dev/null || true -#rm make.pre 2>/dev/null || true + echo "building $paket with build $version-$build" -mkdir -p tmp/DEBIAN + pushd debian >/dev/null -# 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 + ln -sf /usr/share/mbuild/rules . -# copy package control -#control=$(find .. -name $paket.control) -#build_number=${build#*_} -#if [ -z "$control" ] -#then -# echo "warning: control file not found" -# echo " this file is necessary for any package production." -#else -# sed "s/%BUILD%/$build_number/" $control |sed "s/%ARCH%/$ARCH/" >$paket.control -# echo "$paket.control written." -# -# # extract version -# version=$(grep Version $paket.control |sed "s/Version: //") -#fi + #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 -popd >/dev/null + # 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 -# build package -debian/rules binary + popd >/dev/null -## check for copy file -#if [ ! -f $paket.cp ] + # copy package control + if [ ! -f debian/control ] + then + control=$(find etc -name $paket.control) + if [ -z "$control" ] + 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 + fi + fi +fi + +# check for copy file +#if [ ! -f debian/$paket.cp ] #then # # search for copy file -# copy=$(find .. -name $paket.cp) +# copy=$(find . -name $paket.cp) # if [ -n "$copy" ] # then -# ln -sf $copy . +# 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 -# -## 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 [ $compile -eq 1 ] +then + # build artefacts + . debian/setenv.sh + debian/rules build +fi + +if [ $pack -eq 1 ] +then + # build package + . debian/setenv.sh + debian/rules binary +fi