]> wagnertech.de Git - projects.git/blobdiff - tools/make/mconfigure
posaune
[projects.git] / tools / make / mconfigure
index f37f6a3d5ccd772e8bba050b2cea5bf1cfaeee32..b102ad77d447b87836306058c1dd1cc8821552b7 100755 (executable)
@@ -3,81 +3,15 @@ set -e
 
 function echo_usage {
        echo "usage: mconfigure [options] <package>"
-       echo "  -a <arch>"
-       echo "  -c : configure"
+       echo "  -c : copy configure/Makefile"
        echo "  -d : compile"
        echo "  -p : pack default: do all"
-       echo "  -o : support old Debian 7 format"
+       ./configure -I
 }
 
-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 {
-       if [ -e .svn ]
-       then
-               version="0.0"
-               build=$(svnversion)
-               build=${build/:/-}
-               build="$build$(check_unversioned)"
-       elif [ -e .git ]
-       then
-               tag=$(git describe --tags --match "${paket}_*" 2>/dev/null) || true
-               if test -z "$tag"
-               then
-                       tag="0.0-0TOP"
-               fi
-               changes=$(check_unversioned)
-               tag="$tag$changes"
-               version=${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
-
-       # 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"
-               exit 1
-       fi
-}
-# to build a package you need ...
-# <package>.cp (optional): copy step for package production
-# <package>.cpp.sh (optional): commands to setup the C++ compile environment
+##############################################################################
+# Main program
+##############################################################################
 
 if [ ! -d debian ]
 then
@@ -88,196 +22,100 @@ fi
 configure=0
 compile=0
 pack=0
-while getopts "a:cdpo" opt; do
-       case $opt in
-               a) ARCH=$OPTARG
-                       ;;
-               c) configure=1
-                       ;;
-               d)      compile=1
-                       ;;
-               p)      pack=1
-                       ;;
-               o)      oldpack="-Zgzip"
-                       ;;
-               \?) echo "Invalid option: -$OPTARG"
-                       echo_usage
-                       exit 1
-                       ;;
-               :) echo "Option -$OPTARG requires an argument."
-                       echo_usage
-                       exit 1
-                       ;;
-       esac
+confirure_args="-b ../build"
+while [ $OPTIND -le "$#" ]
+do
+       if getopts "cdp" opt
+       then
+               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
 done
-shift $((OPTIND -1))
 
-if [ $# -lt 1 ]
+if [ -z "$paket" ]
 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 ]
-then
-       configure=1
-       compile=1
-       pack=1
-fi
-
 if [ $configure -eq 1 ]
 then
-       # delete changelog and control
-       rm debian/changelog debian/control 2>/dev/null || true
-       
-       # mconfigure builds 2 environment files: setenv.sh + rules.pre
-       
-       if [ -n "$ARCH" ]
+       # installation of configure file
+       cp /usr/share/mbuild/configure .
+else
+       if [ ! -e configure ]
        then
-               arch_opt="-a $ARCH"
+               ln -s /usr/share/mbuild/configure .
        fi
-       dpkg-architecture $arch_opt > debian/setenv.sh
-       echo "" > debian/rules.pre
-       
-       echo "paket=$paket" >> debian/setenv.sh
-       echo "oldpack=\"$oldpack\"" >> debian/setenv.sh
-       cpp_build=0
-
-       set_build
-       check_version
-       echo "version=$version" >> debian/setenv.sh
-       echo "build=$build" >> debian/setenv.sh
-
-       # get repository name
-#      tmp=$(pwd)
-#      pwd=${tmp##*/}
-#      pwd=${pwd,,*}
-#      echo "pwd=$pwd" >> debian/rules.pre
-
-       echo "building $paket with build $version-$build"
-
-       pushd debian >/dev/null
-       # ./debian -------------------------------------
-
-       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 "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
+fi
 
-       popd >/dev/null
-       # ./. ---------------------------------------------
+configure_args="$configure_args $paket"
+if [ -x debian/$paket.preconfigure ]
+then
+       # if necessary $configure_args can be added to setenv.sh
+       debian/$paket.preconfigure
+fi
 
-       # 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 <mail@wagnertech.de>
-" > debian/$paket.control
-                       grep -v "Version:" $control |grep -v "Maintainer:" >> debian/$paket.control 
-               fi
-       fi
-       
-       # build prepare
-       if [ -e debian/$paket.build ]
+#-> configure
+# .build or .cmake
+if [ -x debian/$paket.build -o -e debian/$paket.cmake ]
+then
+       echo "BUILD_DIR=../build" >> debian/setenv.sh
+       if [ -e ../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
+               rm -rf ../build
+               mkdir ../build
        fi
-       
-       # pack prepare
-       if [ -f debian/$paket.cp -a -f debian/$paket.control ]
-       then
-               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
-       elif [ -f debian/$paket.cp ]
-       then
-               echo "PACK=zip" >> debian/rules.pre
-       else
-               echo "PACK=version" >> debian/rules.pre
+       if grep -- "-prepare" debian/$paket.build >/dev/null
+       then                    
+               echo "prepare in <paket>.build no longer supported. Use <paket>.prebuild"
+               exit 2
        fi
+       # sync build dir
+       . debian/setenv.sh
+       debian/rules sync
 fi
 
-if [ $compile -eq 1 -a ! -e debian/$paket.build ]
+# perform configure
+. debian/setenv.sh
+./configure $configure_args
+
+# if nothing is selected, select all
+if [ $compile -eq 0 -a $pack -eq 0 ]
 then
-       echo "no debian/build.sh: skipping build step"
-       compile=0
+       compile=1
+       pack=1
 fi
+
 if [ $compile -eq 1 ]
 then
-       # build artefacts
-       . debian/setenv.sh
-       debian/rules build
+       # build
+       make
 fi
 
 if [ $pack -eq 1 ]
 then
        # build package
-       . debian/setenv.sh
        debian/rules pack
 fi