]> wagnertech.de Git - projects.git/blobdiff - tools/make/mconfigure
Merge branch 'master' of http://wagnertech.de/git/projects
[projects.git] / tools / make / mconfigure
index 8ce366eca347332396bd07fab8ab2e269ef37173..c164f10bb6b94a3976b59727a1cda6fcb3c7c257 100755 (executable)
@@ -4,7 +4,9 @@ set -e
 function echo_usage {
        echo "usage: mconfigure <package> [options]"
        echo "  -a <arch>"
-       echo "  -p : prepare build, but not do it"
+       echo "  -c : configure"
+       echo "  -d : compile"
+       echo "  -p : pack default: do all"
 }
 
 function set_build {
@@ -26,7 +28,11 @@ function set_build {
                        tag="${tag}M"
                fi
                version=${tag%%-*}
+               version=${version##*_}
                build=${tag#*-}
+       else
+               echo "No configuration system found. Cannot determine version."
+               exit 1
        fi
 }
 
@@ -57,35 +63,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
 
 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
+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
@@ -97,107 +93,134 @@ 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
+       echo "paket=$paket" > debian/rules.pre
+#      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/rules.pre
+       echo "build=$build" >> debian/rules.pre
 
-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
-               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 <mail@wagnertech.de>
-" > debian/control
-               grep -v "Version:" $control |grep -v "Maintainer:" >> debian/control 
+               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
+
+       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
+               cp debian/$paket.control debian/control
+       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: $pwd
+       Section: main
+       Priority: optional
+       Maintainer: WagnerTech UG <mail@wagnertech.de>
+       " > debian/control
+                       grep -v "Version:" $control |grep -v "Maintainer:" >> debian/control 
+               fi
+       fi
+       
+       # build prepare
+       if [ -e debian/$paket.build ]
+       then
+               if [ -e ../build ]
+               then
+                       rm -rf ../build
+                       mkdir ../build
+               fi
+               debian/$paket.build -prepare
+       fi
+       
+       # pack prepare
+       if [ -f debian/$paket.cp -a -f $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/build.sh ]
 then
-       exit 0
+       echo "no debian/build.sh: skipping build step"
+       compile=0
+fi
+if [ $compile -eq 1 ]
+then
+       # build artefacts
+       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
-## mBuild make.pre script (auto generated)
-#project = $paket
-#COPY = ./$paket.cp
-#MAKE_PRE
-#      if [ -n "$ARCH" ]
-#      then
-#              echo "arch = $ARCH" >>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