diff options
author | rillig <rillig@pkgsrc.org> | 2005-11-06 17:12:55 +0000 |
---|---|---|
committer | rillig <rillig@pkgsrc.org> | 2005-11-06 17:12:55 +0000 |
commit | 84755182d32e0a3b66b7b4888c3d9f6f45076a06 (patch) | |
tree | 943cc4c906836f41cdc3eb6d649fd8ea269faefb | |
parent | de67b21eee9a0b98e2cf4e09f682964a7c820da3 (diff) | |
download | pkgsrc-84755182d32e0a3b66b7b4888c3d9f6f45076a06.tar.gz |
Added basic checks to make sure the values from the configuration file are
somewhat sane. If a check fails, the bulk build is terminated. Removed the
conditional under which MAKECONF is exported, as it is not needed anymore.
-rw-r--r-- | mk/bulk/build | 3 | ||||
-rw-r--r-- | mk/bulk/post-build-conf | 140 |
2 files changed, 126 insertions, 17 deletions
diff --git a/mk/bulk/build b/mk/bulk/build index d82f5517f39..765752fcea3 100644 --- a/mk/bulk/build +++ b/mk/bulk/build @@ -1,5 +1,5 @@ #!/bin/sh -# $NetBSD: build,v 1.69 2005/11/06 10:27:57 seb Exp $ +# $NetBSD: build,v 1.70 2005/11/06 17:12:55 rillig Exp $ # # Copyright (c) 1999, 2000 Hubert Feyrer <hubertf@NetBSD.org> @@ -181,6 +181,7 @@ esac { test -f "${BULK_BUILD_CONF}" \ && . "${BULK_BUILD_CONF}" \ && . "${scriptdir}/post-build-conf" \ + && check_config_vars \ && export_config_vars } || die "Cannot load config file ${BULK_BUILD_CONF}, aborting." diff --git a/mk/bulk/post-build-conf b/mk/bulk/post-build-conf index 7ac575e9fd2..994db5a0268 100644 --- a/mk/bulk/post-build-conf +++ b/mk/bulk/post-build-conf @@ -1,14 +1,17 @@ -# $NetBSD: post-build-conf,v 1.2 2005/11/06 10:32:58 seb Exp $ +# $NetBSD: post-build-conf,v 1.3 2005/11/06 17:12:55 rillig Exp $ # # This file is included after the build.conf file by the "build" and -# "pre-build" scripts. It provides two functions for printing and +# "pre-build" scripts. It provides functions for printing, checking and # exporting the configuration variables. -# usage: show_variable varname -show_variable() { - eval "fnv_isset=\${$1+set}" - case $fnv_isset in +# Note: All function whose name start with "pbc_" are considered private +# to this file. The "pbc" prefix is an abbreviation for "post-build-conf". + +# usage: pbc_showvar varname +pbc_showvar() { + eval "pbc_isset=\${$1+set}" + case $pbc_isset in "set") eval "fnv_val=\${$1-}" printf " %-25s = %s\\n" "$1" "${fnv_val}" ;; @@ -17,27 +20,27 @@ show_variable() { esac } -# usage: section title varname... -section() { +# usage: pbc_section title varname... +pbc_section() { printf "%s\\n" "$1" shift - for i in "$@"; do - show_variable "$i" + for pbc_var in "$@"; do + pbc_showvar "${pbc_var}" done printf "\\n" } # usage: show_config_vars show_config_vars() { - section "System information" \ + pbc_section "System information" \ osrev arch BULK_BUILD_CONF USR_PKGSRC MAKECONF - section "Keeping pkgsrc up-to-date" \ + pbc_section "Keeping pkgsrc up-to-date" \ CVS_USER CVS_FLAGS - section "Getting distfiles" \ + pbc_section "Getting distfiles" \ PRUNEDISTFILES ftp_proxy http_proxy - section "Building packages" \ + pbc_section "Building packages" \ PKGLIST NICE_LEVEL ADMIN ADMINSIG - section "Uploading binary packages" \ + pbc_section "Uploading binary packages" \ UPDATE_VULNERABILITY_LIST PRUNEPACKAGES MKSUMS SIGN_AS \ RSYNC_DST RSYNC_OPTS FTPHOST FTP } @@ -50,5 +53,110 @@ export_config_vars() { export PKGLIST NICE_LEVEL ADMIN ADMINSIG export UPDATE_VULNERABILITY_LIST PRUNEPACKAGES MKSUMS SIGN_AS export RSYNC_DST RSYNC_OPTS FTPHOST FTP - if [ -n "$MAKECONF" ]; then export MAKECONF; fi +} + +# usage: pbc_die error-message +pbc_die() { + exec 1>&2 + printf "error: %s\\n" "$1" + printf " Please check your bulk build configuration file:\\n" + case ${BULK_BUILD_CONF+set} in + "set") printf " %s\\n" "${BULK_BUILD_CONF}" + esac + exit 1 +} + +# usage: pbc_checkyesno varname +pbc_checkyesno() { + eval "pbc_val=\${$1-}" + case $pbc_val in + [Yy][Ee][Ss]|[Nn][Oo]) ;; + *) pbc_die "$1 must be set to one of YES, yes, NO, no.";; + esac +} + +# usage: pbc_checkexistingfile varname +pbc_checkexistingfile() { + eval "pbc_val=\${$1-}" + + case $pbc_val in + /*) ;; + *) pbc_die "$1 must be an absolute pathname.";; + esac + + test -f "${pbc_val}" \ + || pbc_die "$1 must be the name of an existing file." +} + +# usage: pbc_checkexistingdir varname +pbc_checkexistingdir() { + eval "pbc_val=\${$1-}" + + case $pbc_val in + /*) ;; + *) pbc_die "$1 must be an absolute pathname.";; + esac + + test -d "${pbc_val}" \ + || pbc_die "$1 must be the name of an existing directory." +} + +# usage: pbc_checknonempty varname +pbc_checknonempty() { + eval "pbc_isset=\${$1+set}" + eval "pbc_val=\${$1-}" + + case $pbc_isset in + "set") case $pbc_val in + "") pbc_die "$1 must be non-empty.";; + esac;; + *) pbc_die "$1 must be defined and non-empty.";; + esac +} + +# usage: pbc_checkdefined varname +pbc_checkdefined() { + eval "pbc_val=\${$1+set}" + + case $pbc_val in + "set") ;; + *) pbc_die "$1 must be defined.";; + esac +} + +# usage: check_config_vars +check_config_vars() { + # section "System information" + pbc_checknonempty osrev + pbc_checknonempty arch + pbc_checkexistingfile BULK_BUILD_CONF + pbc_checkexistingdir USR_PKGSRC + case ${MAKECONF+set} in set) + pbc_checkexistingfile MAKECONF;; + esac + + # section "Keeping pkgsrc up-to-date" + # no checks for CVS_USER + # no checks for CVS_FLAGS + + # section "Getting distfiles" + pbc_checkyesno PRUNEDISTFILES + # no checks for ftp_proxy + # no checks for http_proxy + + # section "Building packages" + # no checks for PKGLIST + # no checks for NICE_LEVEL + # no checks for ADMIN + # no checks for ADMINSIG + + # section "Uploading binary packages" + pbc_checkyesno UPDATE_VULNERABILITY_LIST + pbc_checkyesno PRUNEPACKAGES + pbc_checkyesno MKSUMS + # no checks for SIGN_AS + # no checks for RSYNC_DST + # no checks for RSYNC_OPTS + # no checks for FTPHOST + # no checks for FTP } |