#!/usr/bin/env bash # NOTE: if the output of this backend has to change (e.g. we change what gets # included in the archive, or we change the format of the archive (e.g. tar # options, compression ratio or method)), we MUST update the format version # in the variable BR_FTM_VERSION_svn, in package/pkg-download.mk. # We want to catch any unexpected failure, and exit immediately set -e # Download helper for svn, to be called from the download wrapper script # # Options: # -q Be quiet. # -o FILE Generate archive in FILE. # -u URI Checkout from repository at URI. # -c REV Use revision REV. # -n NAME Use basename NAME. # -r Recursive, i.e. use externals # # Environment: # SVN : the svn command to call # shellcheck disable=SC1090 # Only provides mk_tar_gz() . "${0%/*}/helpers" quiet= externals=--ignore-externals while getopts "${BR_BACKEND_DL_GETOPTS}" OPT; do case "${OPT}" in q) quiet=-q;; o) output="${OPTARG}";; u) uri="${OPTARG}";; c) rev="${OPTARG}";; n) basename="${OPTARG}";; r) externals=;; :) 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) _svn() { if [ -z "${quiet}" ]; then printf '%s ' "${SVN}" "${@}"; printf '\n' fi _plain_svn "$@" } # Note: please keep command below aligned with what is printed above _plain_svn() { # shellcheck disable=SC2086 # We want word-splitting for SVN eval ${SVN} "${@}" } # shellcheck disable=SC2086 # externals and quiet may be empty _svn export --ignore-keywords ${quiet} ${externals} "${@}" "'${uri}@${rev}'" "'${basename}'" # For 'svn info', we only need the credentials, if any; other options # would be invalid, as they are intended for 'svn export'. # We can also consume the positional parameters, as we'll no longer # be calling any other remote-reaching svn command. creds= while [ ${#} -gt 0 ]; do case "${1}" in --username=*) creds+=" ${1}"; shift;; --password=*) creds+=" ${1}"; shift;; --username) creds+=" ${1} ${2}"; shift 2;; --password) creds+=" ${1} ${2}"; shift 2;; *) shift;; esac done # Get the date of the revision, to generate reproducible archives. # The output format is YYYY-MM-DDTHH:MM:SS.mmmuuuZ (i.e. always in the # UTC timezone), which we can feed as-is to the --mtime option for tar. # In case there is a redirection (e.g. http -> https), just keep the # last line (svn outputs everything on stdout) # shellcheck disable=SC2086 # creds may be empty date="$( _plain_svn info ${creds} "'${uri}@${rev}'" \ |sed -r -e '/^Last Changed Date: /!d; s///' )" # Generate the archive. # We did a 'svn export' above, so it's not a working copy (there is no .svn # directory or file to ignore). mk_tar_gz "${basename}" "${basename}" "${date}" "${output}"