support/download: support -q in all download backends

Add an option flag to all backends, as well as the check-hash script, so
as to silence download helpers when the user wants a silent build.

Additionaly, make the default be verbose.

Inspired by Fabio's patch on git/svn.

[Thomas: fix a typo "Environemnt" -> "Environment"

Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
Cc: Fabio Porcedda <fabio.porcedda@gmail.com>
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
This commit is contained in:
Yann E. MORIN 2015-01-02 16:53:39 +01:00 committed by Thomas Petazzoni
parent a61b747686
commit 50c8b7e947
9 changed files with 131 additions and 53 deletions

View File

@ -4,17 +4,26 @@
set -e
# Download helper for bzr, to be called from the download wrapper script
# Expected arguments:
# $1: output file
# $2: bzr repo
# $3: bzr revision
# $4: basename
# And this environment:
#
# Call it as:
# .../bzr [-q] OUT_FILE REPO_URL REV BASENAME
#
# Environment:
# BZR : the bzr command to call
verbose=-v
while getopts :q OPT; do
case "${OPT}" in
q) verbose=-q;;
\?) printf "unknown option '%s'\n" "${OPTARG}" >&2; exit 1;;
esac
done
shift $((OPTIND-1))
output="${1}"
repo="${2}"
rev="${3}"
basename="${4}"
${BZR} export --root="${basename}/" --format=tgz "${output}" "${repo}" -r "${rev}"
${BZR} export ${verbose} --root="${basename}/" --format=tgz "${output}" "${repo}" -r "${rev}"

View File

@ -10,6 +10,14 @@ set -e
# saved as, to be able to match it to the corresponding hashes
# in the .hash file
while getopts :q OPT; do
case "${OPT}" in
q) exec >/dev/null;;
\?) exit 1;;
esac
done
shift $((OPTIND-1))
h_file="${1}"
file="${2}"
base="${3}"

View File

@ -4,13 +4,23 @@
set -e
# Download helper for cp, to be called from the download wrapper script
# Expected arguments:
# $1: output file
# $2: source file
# And this environment:
#
# Call it as:
# .../cp [-q] OUT_FILE SRC_FILE
#
# Environment:
# LOCALFILES: the cp command to call
verbose=-v
while getopts :q OPT; do
case "${OPT}" in
q) verbose=;;
\?) printf "unknown option '%s'\n" "${OPTARG}" >&2; exit 1;;
esac
done
shift $((OPTIND-1))
output="${1}"
source="${2}"
${LOCALFILES} "${source}" "${output}"
${LOCALFILES} ${verbose} "${source}" "${output}"

View File

@ -4,22 +4,29 @@
set -e
# Download helper for cvs, to be called from the download wrapper script
# Expected arguments:
# $1: output file
# $2: cvs repo
# $3: cvs revision
# $4: package's name (eg. foobar)
# $5: package's basename (eg. foobar-1.2.3)
# And this environment:
#
# Call it as:
# .../cvs [-q] OUT_FILE CVS_URL REV PKG_NAME BASENAME
#
# Environment:
# CVS : the cvs command to call
verbose=
while getopts :q OPT; do
case "${OPT}" in
q) verbose=-Q;;
\?) printf "unknown option '%s'\n" "${OPTARG}" >&2; exit 1;;
esac
done
shift $((OPTIND-1))
output="${1}"
repo="${2}"
rev="${3}"
rawname="${4}"
basename="${5}"
${CVS} -z3 -d":pserver:anonymous@${repo}" \
${CVS} ${verbose} -z3 -d":pserver:anonymous@${repo}" \
co -d "${basename}" -r ":${rev}" -P "${rawname}"
tar czf "${output}" "${basename}"

View File

@ -4,14 +4,22 @@
set -e
# Download helper for git, to be called from the download wrapper script
# Expected arguments:
# $1: output file
# $2: git repo
# $3: git cset
# $4: package's basename (eg. foobar-1.2.3)
# And this environment:
#
# Call it as:
# .../git [-q] OUT_FILE REPO_URL CSET BASENAME
#
# Environment:
# GIT : the git command to call
verbose=-v
while getopts :q OPT; do
case "${OPT}" in
q) verbose=-q;;
\?) printf "unknown option '%s'\n" "${OPTARG}" >&2; exit 1;;
esac
done
shift $((OPTIND-1))
output="${1}"
repo="${2}"
cset="${3}"
@ -22,7 +30,7 @@ basename="${4}"
git_done=0
if [ -n "$(${GIT} ls-remote "${repo}" "${cset}" 2>&1)" ]; then
printf "Doing shallow clone\n"
if ${GIT} clone --depth 1 -b "${cset}" --bare "${repo}" "${basename}"; then
if ${GIT} clone ${verbose} --depth 1 -b "${cset}" --bare "${repo}" "${basename}"; then
git_done=1
else
printf "Shallow clone failed, falling back to doing a full clone\n"
@ -30,7 +38,7 @@ if [ -n "$(${GIT} ls-remote "${repo}" "${cset}" 2>&1)" ]; then
fi
if [ ${git_done} -eq 0 ]; then
printf "Doing full clone\n"
${GIT} clone --bare "${repo}" "${basename}"
${GIT} clone ${verbose} --bare "${repo}" "${basename}"
fi
GIT_DIR="${basename}" \

View File

@ -4,21 +4,29 @@
set -e
# Download helper for hg, to be called from the download wrapper script
# Expected arguments:
# $1: output file
# $2: hg repo
# $3: hg cset
# $4: package's basename (eg. foobar-1.2.3)
# And this environment:
#
# Call it as:
# .../hg [-q] OUT_FILE REPO_URL CSET BASENAME
#
# Environment:
# HG : the hg command to call
verbose=-v
while getopts :q OPT; do
case "${OPT}" in
q) verbose=-q;;
\?) printf "unknown option '%s'\n" "${OPTARG}" >&2; exit 1;;
esac
done
shift $((OPTIND-1))
output="${1}"
repo="${2}"
cset="${3}"
basename="${4}"
${HG} clone --noupdate --rev "${cset}" "${repo}" "${basename}"
${HG} clone ${verbose} --noupdate --rev "${cset}" "${repo}" "${basename}"
${HG} archive --repository "${basename}" --type tgz \
${HG} archive ${verbose} --repository "${basename}" --type tgz \
--prefix "${basename}" --rev "${cset}" \
"${output}"

View File

@ -4,13 +4,23 @@
set -e
# Download helper for scp, to be called from the download wrapper script
# Expected arguments:
# $1: output file
# $2: URL
# And this environment:
#
# Call it as:
# .../scp [-q] OUT_FILE SRC_URL
#
# Environment:
# SCP : the scp command to call
verbose=-v
while getopts :q OPT; do
case "${OPT}" in
q) verbose=-q;;
\?) printf "unknown option '%s'\n" "${OPTARG}" >&2; exit 1;;
esac
done
shift $((OPTIND-1))
output="${1}"
url="${2}"
${SCP} "${url}" "${output}"
${SCP} ${verbose} "${url}" "${output}"

View File

@ -4,19 +4,27 @@
set -e
# Download helper for svn, to be called from the download wrapper script
# Expected arguments:
# $1: output file
# $2: svn repo
# $3: svn revision
# $4: package's basename (eg. foobar-1.2.3)
# And this environment:
#
# Call it as:
# .../svn [-q] OUT_FILE REPO_URL REV BASNAME
#
# Environment:
# SVN : the svn command to call
verbose=
while getopts :q OPT; do
case "${OPT}" in
q) verbose=-q;;
\?) printf "unknown option '%s'\n" "${OPTARG}" >&2; exit 1;;
esac
done
shift $((OPTIND-1))
output="${1}"
repo="${2}"
rev="${3}"
basename="${4}"
${SVN} export "${repo}@${rev}" "${basename}"
${SVN} export ${verbose} "${repo}@${rev}" "${basename}"
tar czf "${output}" "${basename}"

View File

@ -4,13 +4,23 @@
set -e
# Download helper for wget, to be called from the download wrapper script
# Expected arguments:
# $1: output file
# $2: URL
# And this environment:
#
# Call it as:
# .../wget [-q] OUT_FILE URL
#
# Environment:
# WGET : the wget command to call
verbose=-v
while getopts :q OPT; do
case "${OPT}" in
q) verbose=-q;;
\?) printf "unknown option '%s'\n" "${OPTARG}" >&2; exit 1;;
esac
done
shift $((OPTIND-1))
output="${1}"
url="${2}"
${WGET} -O "${output}" "${url}"
${WGET} ${verbose} -O "${output}" "${url}"