diff options
| author | Ned Deily <nad@acm.org> | 2014-11-15 02:53:59 (GMT) |
|---|---|---|
| committer | Ned Deily <nad@acm.org> | 2014-11-15 02:53:59 (GMT) |
| commit | 3010182390565f4fe4cf168071ef6669582d9cd7 (patch) | |
| tree | 960db13ab91194c5e936f8a7020517a3d121f6d5 /Mac/BuildScript/scripts | |
| parent | 05e7c9ea6fe36ecb3a0c3d0083811ccfb461fdf1 (diff) | |
| download | cpython-3010182390565f4fe4cf168071ef6669582d9cd7.zip cpython-3010182390565f4fe4cf168071ef6669582d9cd7.tar.gz cpython-3010182390565f4fe4cf168071ef6669582d9cd7.tar.bz2 | |
Issue #22877: PEP 477 - OS X installer for 2.7.9 now installs pip.
Diffstat (limited to 'Mac/BuildScript/scripts')
| -rwxr-xr-x | Mac/BuildScript/scripts/postflight.ensurepip | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/Mac/BuildScript/scripts/postflight.ensurepip b/Mac/BuildScript/scripts/postflight.ensurepip new file mode 100755 index 0000000..bf893d1 --- /dev/null +++ b/Mac/BuildScript/scripts/postflight.ensurepip @@ -0,0 +1,69 @@ +#!/bin/sh +# +# Install/upgrade pip. +# + +PYVER="@PYVER@" +PYMAJOR="@PYMAJOR@" +FWK="/Library/Frameworks/Python.framework/Versions/${PYVER}" +RELFWKBIN="../../..${FWK}/bin" + +umask 022 + +"${FWK}/bin/python${PYVER}" -m ensurepip --upgrade + +"${FWK}/bin/python${PYVER}" -Wi \ + "${FWK}/lib/python${PYVER}/compileall.py" \ + -f -x badsyntax \ + "${FWK}/lib/python${PYVER}/site-packages" + +"${FWK}/bin/python${PYVER}" -Wi -O \ + "${FWK}/lib/python${PYVER}/compileall.py" \ + -f -x badsyntax \ + "${FWK}/lib/python${PYVER}/site-packages" + +chgrp -R admin "${FWK}/lib/python${PYVER}/site-packages" "${FWK}/bin" +chmod -R g+w "${FWK}/lib/python${PYVER}/site-packages" "${FWK}/bin" + +# We do not know if the user selected the Python command-line tools +# package that installs symlinks to /usr/local/bin. So we assume +# that the command-line tools package has already completed or was +# not selected and we will only install /usr/local/bin symlinks for +# pip et al if there are /usr/local/bin/python* symlinks to our +# framework bin directory. + +if [ -d /usr/local/bin ] ; then + ( + install_links_if_our_fw() { + if [ "$(readlink -n ./$1)" = "${RELFWKBIN}/$1" ] ; then + shift + for fn ; + do + if [ -e "${RELFWKBIN}/${fn}" ] ; then + rm -f ./${fn} + ln -s "${RELFWKBIN}/${fn}" "./${fn}" + chgrp -h admin "./${fn}" + chmod -h g+w "./${fn}" + fi + done + fi + } + + cd /usr/local/bin + + # Create pipx.y and easy_install-x.y links if /usr/local/bin/pythonx.y + # is linked to this framework version + install_links_if_our_fw "python${PYVER}" \ + "pip${PYVER}" "easy_install-${PYVER}" + + # Create pipx link if /usr/local/bin/pythonx is linked to this version + install_links_if_our_fw "python${PYMAJOR}" \ + "pip${PYMAJOR}" + + # Create pip and easy_install link if /usr/local/bin/python + # is linked to this version + install_links_if_our_fw "python" \ + "pip" "easy_install" + ) +fi +exit 0 |
