mirror of
https://github.com/kennethreitz/heroku-buildpack-python.git
synced 2026-06-05 23:10:16 +00:00
e15f68944a
This is useful if you'd like to customize python binaries without forking the entire buildpack. Similar functionality was implemented in https://github.com/heroku/heroku-buildpack-ruby/pull/238
39 lines
1.3 KiB
Bash
Executable File
39 lines
1.3 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
# This script serves as the cffi build step of the
|
|
# [**Python Buildpack**](https://github.com/heroku/heroku-buildpack-python)
|
|
# compiler.
|
|
#
|
|
# A [buildpack](https://devcenter.heroku.com/articles/buildpacks) is an
|
|
# adapter between a Python application and Heroku's runtime.
|
|
#
|
|
# This script is invoked by [`bin/compile`](/).
|
|
|
|
if [[ "$STACK" == "heroku-16" ]]; then
|
|
# libffi is pre-installed in the stack image so there is no need to vendor it.
|
|
return 0
|
|
fi
|
|
|
|
# The location of the pre-compiled libffi binary.
|
|
VENDORED_LIBFFI="${VENDOR_URL}/libraries/vendor/libffi.tar.gz"
|
|
|
|
PKG_CONFIG_PATH="/app/.heroku/vendor/lib/pkgconfig:$PKG_CONFIG_PATH"
|
|
|
|
# Syntax sugar.
|
|
# shellcheck source=bin/utils
|
|
source "$BIN_DIR/utils"
|
|
|
|
# If a package using cffi exists within requirements, use vendored libffi.
|
|
if (pip-grep -s requirements.txt argon2-cffi bcrypt cffi cryptography django[argon2] Django[argon2] django[bcrypt] Django[bcrypt] PyNaCl pyOpenSSL PyOpenSSL requests[security] misaka &> /dev/null) then
|
|
|
|
if [ ! -d ".heroku/vendor/lib/libffi-3.1" ]; then
|
|
echo "-----> Noticed cffi. Bootstrapping libffi."
|
|
mkdir -p .heroku/vendor
|
|
# Download and extract libffi into target vendor directory.
|
|
curl "$VENDORED_LIBFFI" -s | tar zxv -C .heroku/vendor &> /dev/null
|
|
fi
|
|
|
|
LIBFFI=$(pwd)/vendor
|
|
export LIBFFI
|
|
fi
|