hc
2024-07-16 5fbd6e2385615a225453562361c4bdab3b15fda1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#!/usr/bin/env bash
 
# We want to catch any unexpected failure, and exit immediately
set -e
 
# Download helper for cp, to be called from the download wrapper script
#
# Options:
#   -q          Be quiet.
#   -o FILE     Copy to file FILE.
#   -f FILE     Copy from basename file FILE.
#   -u DIR      Copy from FILE in DIR.
#
# Environment:
#   LOCALFILES: the cp command to call
 
# 'cp' usually does not print anything on its stdout, whereas the
# other download backends, even if not verbose, at least print some
# progress information.
# Make 'cp' verbose by default, so it behaves a bit like the others.
verbose=-v
 
while getopts "${BR_BACKEND_DL_GETOPTS}" OPT; do
    case "${OPT}" in
    q)  verbose=;;
    o)  output="${OPTARG}";;
    f)  file="${OPTARG}";;
    u)  dir="${OPTARG}";;
    :)  printf "option '%s' expects a mandatory argument\n" "${OPTARG}"; exit 1;;
    \?) printf "unknown option '%s'\n" "${OPTARG}" >&2; exit 1;;
    esac
done
 
shift $((OPTIND-1)) # Get rid of our options
 
# Caller needs to single-quote its arguments to prevent them from
# being expanded a second time (in case there are spaces in them)
_localfiles() {
    if [ -n "${verbose}" ]; then
        printf '%s ' ${LOCALFILES} "${@}"; printf '\n'
    fi
    _plain_localfiles "$@"
}
# Note: please keep command below aligned with what is printed above
_plain_localfiles() {
    eval ${LOCALFILES} "${@}"
}
 
_localfiles ${verbose} "'${dir##file://}/${file}'" "'${output}'"