X-Git-Url: https://git.distorted.org.uk/~mdw/profile/blobdiff_plain/d43de82b21911b0713c8950aa1d9e83774a8c7cb..ad305d7eb64395c1a2f9de06d3f67a0903f31df1:/bin/mdw-build diff --git a/bin/mdw-build b/bin/mdw-build index 5ea9e12..bd1b457 100755 --- a/bin/mdw-build +++ b/bin/mdw-build @@ -21,6 +21,36 @@ ### along with this program; if not, write to the Free Software Foundation, ### Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +###-------------------------------------------------------------------------- +### Conventions for build systems. +### +### This script is designed to work with a variety of `make'-based build +### systems, but there are a number of conventions which must be followed if +### this is going to work properly. +### +### * There must be a `configure.ac', `configure.in', or `.links' file, or +### a `.git' directory in the project top-level, so that we can find it. +### +### * The following `make' variables must be assigned in the top-level +### Makefile, after `mdw-build' has constructed it. +### +### distdir The name of the top-level project directory in the +### source distribution, and the base name for +### distribution archives; should be of the form +### `PROJECT-VERSION'. +### +### The following `make' targets must be available in the top-level +### Makefile. +### +### dist Write to $(distdir).tar.gz a source distribution of +### the package. +### +### distcheck As for `dist', but also build and test the project. +### +### * The source distribution constructed by `make dist' must contain a file +### $(distdir)/RELEASE containing the release name. This isn't currently +### tested, but it might be later. + set -e ###-------------------------------------------------------------------------- @@ -39,6 +69,7 @@ Build options: [no]debian [no]upload [no]clean + [no]vpath EOF } @@ -62,6 +93,7 @@ distcheck=yes debian=yes upload=yes clean=yes +vpath=yes for opt; do case "$opt" in checkout) checkout=yes checkoutrev=HEAD ;; @@ -70,10 +102,10 @@ for opt; do release) build=release ;; norelease) build=test ;; - setup | distcheck | debian | upload | clean) + setup | distcheck | debian | upload | clean | vpath) eval "$opt=yes" ;; - nosetup | nodistcheck | nodebian | noupload | noclean) + nosetup | nodistcheck | nodebian | noupload | noclean | novpath) eval "${opt#no}=no" ;; *) @@ -83,6 +115,18 @@ for opt; do esac done +## Parse DEB_BUILD_OPTIONS. +jobs=1 +set -- $DEB_BUILD_OPTIONS +for opt; do + case "$opt" in + parallel=*) jobs=${opt#*=} ;; + esac +done + +makeopts="" +case $jobs in 1) ;; *) makeopts="$makeopts -j$jobs" ;; esac + ###-------------------------------------------------------------------------- ### Utility functions. @@ -197,7 +241,7 @@ case "$gitver,$debver" in ;; esac -## Maybe check ot a copy of the source. +## Maybe check out a copy of the source. case "$checkout" in yes) cd $releasepath @@ -216,16 +260,26 @@ case "$setup" in esac ## Initialize the build directory. -if [ -e $srcpath/configure ]; then - assign buildpath $releasepath/_build - mkdir $buildpath - cd $buildpath - run $srcpath/configure -else - info "no configure script" - assign buildpath $srcpath - cd $srcpath -fi +case "$vpath,$(yesno [ -e $srcpath/configure ])" in + yes,yes) + assign buildpath $releasepath/_build + mkdir $buildpath + cd $buildpath + run $srcpath/configure + ;; + no,yes) + info "VPATH build disabled" + assign buildpath $srcpath + distcheck=no + cd $srcpath + run ./configure + ;; + *,no) + info "no configure script" + assign buildpath $srcpath + cd $srcpath + ;; +esac ## Discover the release name. cat >find-distdir.mk <<'EOF' @@ -238,10 +292,10 @@ assign distdir $(make -f find-distdir.mk print-distdir) ## Get a tarball distribution. case "$distcheck" in yes) - run make distcheck + run make $makeopts distcheck ;; no) - run make dist + run make $makeopts dist ;; esac