mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-19 19:52:48 +00:00
Merge "Fix downloader not working with curl"
This commit is contained in:
@@ -5,7 +5,24 @@ if [[ ( ${BASH_VERSINFO[0]} == 4 && ${BASH_VERSINFO[1]} > 1 ) || ${BASH_VERSINFO
|
||||
fi
|
||||
set -e
|
||||
|
||||
|
||||
ASTTOPDIR=${ASTTOPDIR:-.}
|
||||
export make=`sed -n -r -e "s/^MAKE\s*=\s*//gp" ${ASTTOPDIR}/makeopts`
|
||||
|
||||
getvar() {
|
||||
$make --quiet --no-print-directory -f- <<EOF
|
||||
include ${ASTTOPDIR}/makeopts
|
||||
all:
|
||||
@echo "\$($1)"
|
||||
EOF
|
||||
}
|
||||
|
||||
XMLSTARLET=`getvar XMLSTARLET`
|
||||
ASTMODDIR=`getvar ASTMODDIR`
|
||||
cache_dir=`getvar EXTERNALS_CACHE_DIR`
|
||||
DOWNLOAD_TO_STDOUT=`getvar DOWNLOAD_TO_STDOUT`
|
||||
HOST_CPU=`getvar HOST_CPU`
|
||||
INSTALL=`getvar INSTALL`
|
||||
|
||||
module_name=${1%%-*}
|
||||
variant=${1##*-}
|
||||
@@ -26,24 +43,16 @@ if [[ -z "${tmpdir}" ]] ; then
|
||||
fi
|
||||
trap "rm -rf ${tmpdir}" EXIT
|
||||
|
||||
# We have to pre-process the makeopts file so it will be parsable by bash
|
||||
# Surround values with double quotes
|
||||
# Convert make $(or) functions to bash ${name:-value}
|
||||
sed -r -e "s/^([^ =]+)\s*=\s*(.*)$/\1=\"\2\"/g" \
|
||||
-e 's/^([^ =]+)="\$\(or ([^,]*),([^)]+)\)"/_tmp="\2"\n\1="${_tmp:-\3}"/g' ${ASTTOPDIR}/makeopts >${tmpdir}/makeopts
|
||||
source ${tmpdir}/makeopts
|
||||
if [[ -z "${ASTMODDIR}" ]] ; then
|
||||
echo "${module_name}: Unable to parse ${ASTTOPDIR}/makeopts."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
XMLSTARLET=${XMLSTARLET:-xmlstarlet}
|
||||
if [[ "${XMLSTARLET}" = ":" ]] ; then
|
||||
echo "${module_name}: The externals downloader requires xmlstarlet to be installed."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
cache_dir="${EXTERNALS_CACHE_DIR}"
|
||||
if [[ -z ${cache_dir} ]] ; then
|
||||
cache_dir=${tmpdir}
|
||||
fi
|
||||
@@ -191,7 +200,7 @@ if [[ -f ${cache_dir}/${full_name}.manifest.xml ]] ; then
|
||||
fi
|
||||
|
||||
if [[ ${need_download} = 1 ]] ; then
|
||||
echo "${full_name}: Downloading ${remote_url}/${tarball}"
|
||||
echo "${full_name}: Downloading ${remote_url}/${tarball} to ${cache_dir}/${tarball}"
|
||||
${DOWNLOAD_TO_STDOUT} ${remote_url}/${tarball} > ${cache_dir}/${tarball} || {
|
||||
echo "${full_name}: Unable to fetch ${remote_url}/${tarball}"
|
||||
exit 1
|
||||
|
@@ -6,6 +6,23 @@ fi
|
||||
set -e
|
||||
|
||||
ASTTOPDIR=${ASTTOPDIR:-.}
|
||||
export make=`sed -n -r -e "s/^MAKE\s*=\s*//gp" ${ASTTOPDIR}/makeopts`
|
||||
|
||||
getvar() {
|
||||
$make --quiet --no-print-directory -f- <<EOF
|
||||
include ${ASTTOPDIR}/makeopts
|
||||
all:
|
||||
@echo "\$($1)"
|
||||
EOF
|
||||
}
|
||||
|
||||
|
||||
XMLSTARLET=`getvar XMLSTARLET`
|
||||
ASTMODDIR=`getvar ASTMODDIR`
|
||||
cache_dir=`getvar EXTERNALS_CACHE_DIR`
|
||||
DOWNLOAD_TO_STDOUT=`getvar DOWNLOAD_TO_STDOUT`
|
||||
HOST_CPU=`getvar HOST_CPU`
|
||||
INSTALL=`getvar INSTALL`
|
||||
|
||||
tmpdir=$(mktemp -d)
|
||||
if [[ -z "${tmpdir}" ]] ; then
|
||||
@@ -14,18 +31,11 @@ if [[ -z "${tmpdir}" ]] ; then
|
||||
fi
|
||||
trap "rm -rf ${tmpdir}" EXIT
|
||||
|
||||
# We have to pre-process the makeopts file so it will be parsable by bash
|
||||
# Surround values with double quotes
|
||||
# Convert make $(or) functions to bash ${name:-value}
|
||||
sed -r -e "s/^([^ =]+)\s*=\s*(.*)$/\1=\"\2\"/g" \
|
||||
-e 's/^([^ =]+)="\$\(or ([^,]*),([^)]+)\)"/_tmp="\2"\n\1="${_tmp:-\3}"/g' ${ASTTOPDIR}/makeopts >${tmpdir}/makeopts
|
||||
source ${tmpdir}/makeopts
|
||||
if [[ -z "${ASTMODDIR}" ]] ; then
|
||||
echo "${module_name}: Unable to parse ${ASTTOPDIR}/makeopts."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
XMLSTARLET=${XMLSTARLET:-xmlstarlet}
|
||||
if [[ "${XMLSTARLET}" = ":" ]] ; then
|
||||
echo "${module_name}: The externals downloader requires xmlstarlet to be installed."
|
||||
exit 1
|
||||
|
Reference in New Issue
Block a user