X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/projects.git/blobdiff_plain/2db0d888c5eefc4a7d7dfd7bc367db3e2679f3a4..0b8ae20fd3339cdb7b02aa37ec295cb0ceca6380:/tools/make/mconfigure?ds=sidebyside diff --git a/tools/make/mconfigure b/tools/make/mconfigure index 9217fa1..dda9b97 100755 --- a/tools/make/mconfigure +++ b/tools/make/mconfigure @@ -2,61 +2,13 @@ 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" + echo "usage: mconfigure [options] " + ./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%%-*} - 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 - -if [ $# -lt 1 ] -then - echo_usage - exit 1 -fi +############################################################################## +# Main program +############################################################################## if [ ! -d debian ] then @@ -64,123 +16,146 @@ then exit 2 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 +configure=0 +configure_args="-i debian/tmp" +while [ $OPTIND -le "$#" ] +do + if getopts "c" opt + then + case $opt in + \?) $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 3 + ;; + esac + else + paket="${!OPTIND}" + eval OPTIND=OPTIND+1 + fi done -if [ $configure -eq 1 ] +if [ -z "$paket" ] then - 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_usage + exit 4 +fi - echo "building $paket with build $version-$build" +if [ ! -f debian/$paket.conf ] +then + echo "$paket.conf missing. We create it ..." + echo "to be implemented ..." + exit 5 +fi - pushd debian >/dev/null +if [ ! -e configure ] +then + ln -s /usr/share/mbuild/configure . +fi - ln -sf /usr/share/mbuild/rules . +# clean build directory +if [ "$compile_type" != "NONE" ] +then + if [ -e ~/build ] + then + rm -rf ~/build + mkdir ~/build + fi +fi - #if [ -e tmp ] - #then - # rm -rf tmp - #fi - #rm *.stamp 2>/dev/null || true - #rm make.pre 2>/dev/null || true +# perform configure +. debian/$paket.conf +if [ -n "$compile_dir" ] +then + configure_args="$configure_args -b $compile_dir" +fi +if [ -z "$compile_type" ] +then + echo "compile_type required in $paket.conf" + exit 51 +fi +if [ "$target_type" == "FILE" ] +then + # no version needed + configure_args="$configure_args -V" +fi +configure_args="$configure_args $paket" +echo "Executing ./configure $configure_args ..." +./configure $configure_args - mkdir -p tmp/DEBIAN +if [ "$compile_type" != "NONE" ] +then + if grep -- "-prepare" debian/$paket.build >/dev/null + then + echo "prepare in .build no longer supported. Use .prebuild" + exit 6 + fi + # sync build dir + . debian/setenv.sh + debian/rules sync + make +fi - # load util functions for C/C++ - build - if [ -f $paket.cpp.sh ] +# pack prepare +if [ "$target_type" == "DEB" ] +then + if [ ! -f debian/$paket.cp ] then - cpp_build=1 - . projects/tools/make/c_configure.sh - . $paket.cpp.sh + echo "debian/$paket.cp missing for target type DEB" + exit 9 fi - - popd >/dev/null - - # copy package control - if [ ! -f debian/control ] + if [ ! -f debian/$paket.control ] then - control=$(find etc -name $paket.control) - if [ -z "$control" ] + echo "debian/$paket.control missing for target type DEB" + exit 10 + fi + + echo "PACK=binary" >> debian/rules.pre + if grep "^Architecture: *all" debian/$paket.control >/dev/null + then + echo "arch = all" >> debian/rules.pre + echo 'BINARY_INDEP = copy ../$(paket)_$(version)-$(build)_all.deb' >> debian/rules.pre + else + echo 'arch = ${DEB_HOST_ARCH}' >> debian/rules.pre + echo "BINARY_ARCH = copy ../${paket}_$version-${build}_"'$(arch).deb' >> debian/rules.pre + fi + if ! [ -f debian/$paket.changelog ] + then + echo "changelog_source = debian/default.changelog" >> debian/rules.pre + if [ -f debian/default.changelog ] 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 debian/default.changelog fi fi -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 - -if [ $compile -eq 1 ] +elif [ "$target_type" == "ZIP" ] then - # build artefacts - . debian/setenv.sh - debian/rules build -fi - -if [ $pack -eq 1 ] + echo "PACK=zip" >> debian/rules.pre + if [ ! -f debian/$paket.cp ] + then + echo "debian/$paket.cp missing for target type ZIP" + exit 11 + fi +elif [ "$target_type" == "FILE" ] then - # build package - . debian/setenv.sh - debian/rules binary + echo "PACK=version" >> debian/rules.pre + if [ -z "$compile_target" ] + then + echo "compile_target is needed for target_type FILE" + exit 12 + fi + echo "TARGET = $compile_target" >> debian/rules.pre + +else + echo "Unknown target type: $target_type" + exit 13 fi +# build package +debian/rules pack +