You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

94 lines
3.7 KiB

# This tool can be used to install a new package into MicroPython
# library location (for unix port, default behavior), or produce
# complete library snapshot to be deployed on a device for baremetal
# ports (if PIP_MICROPY_DEST environment var is set).
# Note: this tool is deprecated in favor of "upip" native MicroPython
# package manager, which is bundled with MicroPython unix binary
# as a frozen module and can be run as "micropython -u pip" or installed
# from PyPI package "micropython-upip". This utility is left for
# reference, regression testing, debugging, etc.
if [ "$1" != "install" ]; then
echo "Only install command is supported currently"
exit 1
if [ -z "$TMPDIR" ]; then
if [ -n "$PIP_MICROPY_DEST" ]; then
echo "Destination snapshot directory: $dest"
elif [ -n "$MICROPYPATH" ]; then
libdest=$(echo "$MICROPYPATH" | awk -F: ' {print $1}')
echo "Destination library directory: $libdest"
echo "Warning: MICROPYPATH is not set, assuming default value"
echo "Destination library directory: $libdest"
# Due to bugs in pip, installation should happen with active virtualenv
# The issue (at least with pip 1.0 which is still what's shipped with many
# distros) is that even if --ignore-installed is used, package is not
# installed if it's already installed for main python distribution.
if [ ! -d "$TMPVENV" ]; then
virtualenv --no-site-packages "$TMPVENV"
# distutils, setuptools, pip are buggy and allow target packages affect
# their execution environment. For example, if distribution they install
# has, they will import that instead of system re. So, we need
# to remove current dir from sys.path, but that appear to be quite uneasy
# with CPython, so we hook __import__ and exterminate it persistently.
# See also
cat > $(ls -1d "$TMPVENV"/lib/python*/)/ <<EOF
import sys
import __builtin__
old_imp = __import__
def new_imp(*a, **kw):
if not sys.path[0]: sys.path.pop(0)
return old_imp(*a, **kw)
__builtin__.__import__ = new_imp
. "$TMPVENV"/bin/activate
# We need to specify --record to override this switch as passed by pip
# pip will try to parse this file (at the location in specifies), and try to
# access files as specified in it. But paths there will be relative to --root
# we pass, so it won't find files and crash. However, if it won't find the
# file, it will just issue a warning and continue.
if [ -n "$dest" ]; then
pip install "$@" \
--install-option="--install-base=." \
--install-option="--install-purelib=lib" \
--install-option="--install-platlib=lib" \
--install-option="--install-scripts=." \
--install-option="--install-headers=headers" \
--install-option="--install-data=lib" \
--install-option="--record=$TMPDIR/setuptools-record.txt" \
--install-option="--no-compile" \
# Here we assume that base dir is lib dir, and install scripts a level
# higher. For default value of ~/.micropython/lib/ , this should give
# reasonable behavior, though better would make it overridable (or
# go bold and use ~/bin ?)
pip install "$@" \
--install-option="--install-base=." \
--install-option="--install-purelib=." \
--install-option="--install-platlib=." \
--install-option="--install-scripts=.." \
--install-option="--install-headers=../headers" \
--install-option="--install-data=." \
--install-option="--record=$TMPDIR/setuptools-record.txt" \
--install-option="--no-compile" \