Merge pull request #262 from zcutlip/fix-lldb-1100.0.28.19

Fix lldb 1100.0.28.19
This commit is contained in:
zcutlip 2019-11-08 09:49:02 -08:00 committed by GitHub
commit 988a8a32f7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 74 additions and 9 deletions

View File

@ -34,6 +34,11 @@ YUM_DNF=$(command -v dnf)
USER_MODE='--user'
SUDO=''
#Old versions of pip default to pypi.python.org and fail to install anything
PYPI_URL="https://pypi.org/simple"
PIP_MIN_VER="10.0"
PIP_BOOTSTRAP_URL="https://bootstrap.pypa.io/get-pip.py"
[[ -z "${GDB}" ]]
BACKEND_GDB=$?
[[ -z "${LLDB}" ]]
@ -87,6 +92,15 @@ if [ "${BACKEND_LLDB}" -eq 1 ] && [ -z "${LLDB}" ]; then
exit 1
fi
function quit {
if [ $# -gt 1 ];
then
echo "$1"
shift
fi
exit $1
}
set -ex
function install_apt {
@ -131,6 +145,59 @@ function install_packages {
install_yum
}
function curl_get_pip {
echo "Attempting to curl pip bootstrapt script from $PIP_BOOTSTRAP_URL"
curl "$PIP_BOOTSTRAP_URL" | ${SUDO} ${LLDB_PYTHON} - --upgrade "$USER_MODE" || return $?
}
function ensure_pip {
# Check if pip is installed already
${LLDB_PYTHON} -m pip --version >/dev/null 2>&1
if [ $? -ne 0 ];
then
# If not, attempt to install it using ensurepip
echo "Attempting to install pip using 'ensurepip'."
${SUDO} ${LLDB_PYTHON} -m ensurepip $USER_MODE || return $?
fi
# Some really old pip installations default to the old pypi.python.org, which no longer works.
echo "Attempting to upgrade pip."
${SUDO} ${LLDB_PYTHON} -m pip install "pip>=$PIP_MIN_VER" $USER_MODE -U --index-url "$PYPI_URL"
if [ $? != 0 ];
then
# We may still fail here due to TLS incompatibility
# TLS 1.x got turned off 2018-04-11
# https://status.python.org/incidents/hdx7w97m5hr8
# Curl may be new enough to support TLS 1.2, so try to curl the pip installer from pypa.io
# It's able to download and install pip without TLS errors somehow
echo "Failed to upgrade pip."
echo "Attempting to fall back to installation via curl."
curl_get_pip || return $?
fi
}
function get_lldb_python_exe {
# Find the Python version used by LLDB
local lldb_pyver=$(${LLDB} -Q -x -b --one-line 'script import platform; print(".".join(platform.python_version_tuple()[:2]))'|tail -1)
local lldb_python=$(${LLDB} -Q -x -b --one-line 'script import sys; print(sys.executable)'|tail -1)
lldb_python=$(${LLDB} -Q -x -b --one-line 'script import sys; print(sys.executable)'|tail -1)
local lldb_python_basename=$(basename "${lldb_python}")
if [ "python" = "$lldb_python_basename" ];
then
lldb_python="${lldb_python/%$lldb_pyver/}${lldb_pyver}"
elif [ "lldb" = "$lldb_python_basename" ];
then
# newer lldb versions report sys.path as /path/to/lldb instead of python
# sys.exec_path still appears to be the parent path of bin/python though
local lldb_python_exec_prefix=$(${LLDB} -Q -x -b --one-line 'script import sys; print(sys.exec_prefix)'|tail -1)
lldb_python="$lldb_python_exec_prefix/bin/python"
lldb_python="${lldb_python/%$lldb_pyver/}${lldb_pyver}"
fi
echo "$lldb_python"
}
if [ "${BACKEND_GDB}" -eq 1 ]; then
# Find the Python version used by GDB
GDB_PYVER=$(${GDB} -batch -q --nx -ex 'pi import platform; print(".".join(platform.python_version_tuple()[:2]))')
@ -163,12 +230,10 @@ if [ "${BACKEND_GDB}" -eq 1 ]; then
fi
if [ "${BACKEND_LLDB}" -eq 1 ]; then
# Find the Python version used by LLDB
LLDB_PYVER=$(${LLDB} -Qxb --one-line 'script import platform; print(".".join(platform.python_version_tuple()[:2]))'|tail -1)
LLDB_PYTHON=$(${LLDB} -Qxb --one-line 'script import sys; print(sys.executable)'|tail -1)
LLDB_PYTHON="${LLDB_PYTHON/%$LLDB_PYVER/}${LLDB_PYVER}"
${LLDB_PYTHON} -m pip install --user --upgrade six
LLDB_PYTHON=$(get_lldb_python_exe) || quit "Failed to locate python interpreter." 1
ensure_pip || quit "Failed to install pip." 1
${LLDB_PYTHON} -m pip install --user --upgrade six || quit "Failed to install or upgrade 'six' python package." 1
if [ -n "${VENV}" ]; then
echo "Creating virtualenv..."
@ -177,18 +242,18 @@ if [ "${BACKEND_LLDB}" -eq 1 ]; then
LLDB_PYTHON="${VENV}/bin/python"
LLDB_SITE_PACKAGES=$(find "${VENV}" -name site-packages)
elif [ -z "${USER_MODE}" ]; then
LLDB_SITE_PACKAGES=$(${LLDB} -Qxb --one-line 'script import site; print(site.getsitepackages()[0])'|tail -1)
LLDB_SITE_PACKAGES=$(${LLDB} -Q -x -b --one-line 'script import site; print(site.getsitepackages()[0])'|tail -1) || quit "Failed to locate site-packages." 1
else
LLDB_SITE_PACKAGES=$(${LLDB} -Qxb --one-line 'script import site; print(site.getusersitepackages())'|tail -1)
LLDB_SITE_PACKAGES=$(${LLDB} -Q -x -b --one-line 'script import site; print(site.getusersitepackages())'|tail -1) || quit "Failed to locate site-packages." 1
fi
install_packages
install_packages || quit "Failed to install packages." 1
if [ "$LLDB_SITE_PACKAGES" == "$GDB_SITE_PACKAGES" ]; then
echo "Skipping installation for LLDB - same site-packages directory"
else
# Install Voltron and dependencies
${SUDO} ${LLDB_PYTHON} -m pip install -U $USER_MODE $DEV_MODE .
${SUDO} ${LLDB_PYTHON} -m pip install -U $USER_MODE $DEV_MODE . || quit "Failed to install voltron." 1
fi
# Add Voltron to lldbinit