mirror of
https://git.yoctoproject.org/poky
synced 2026-02-07 17:26:36 +01:00
python: update to version 2.7.15
Update to the latest stable version License-Update: Copyright year updated to include 2018 Remove the alignment patch that is included upstream (From OE-Core rev: 855020053906478cea164ed254c08bedce48479d) (From OE-Core rev: ab2dd15f72a94cce528276e6e3e38c56677e7ba4) Signed-off-by: Derek Straka <derek@asterius.io> Signed-off-by: Ross Burton <ross.burton@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org> [Bug fix update only, drop patches included in update] Signed-off-by: Armin Kuster <akuster808@gmail.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
28ef114253
commit
62f52fdda0
85
meta/recipes-devtools/python/python-native_2.7.15.bb
Normal file
85
meta/recipes-devtools/python/python-native_2.7.15.bb
Normal file
@@ -0,0 +1,85 @@
|
||||
require python.inc
|
||||
EXTRANATIVEPATH += "bzip2-native"
|
||||
DEPENDS = "openssl-native bzip2-replacement-native zlib-native readline-native sqlite3-native expat-native gdbm-native db-native"
|
||||
PR = "${INC_PR}.1"
|
||||
|
||||
SRC_URI += "\
|
||||
file://05-enable-ctypes-cross-build.patch \
|
||||
file://10-distutils-fix-swig-parameter.patch \
|
||||
file://11-distutils-never-modify-shebang-line.patch \
|
||||
file://0001-distutils-set-the-prefix-to-be-inside-staging-direct.patch \
|
||||
file://debug.patch \
|
||||
file://unixccompiler.patch \
|
||||
file://nohostlibs.patch \
|
||||
file://multilib.patch \
|
||||
file://add-md5module-support.patch \
|
||||
file://builddir.patch \
|
||||
file://parallel-makeinst-create-bindir.patch \
|
||||
file://revert_use_of_sysconfigdata.patch \
|
||||
"
|
||||
|
||||
S = "${WORKDIR}/Python-${PV}"
|
||||
|
||||
FILESEXTRAPATHS =. "${FILE_DIRNAME}/${PN}:"
|
||||
|
||||
inherit native
|
||||
|
||||
EXTRA_OECONF_append = " --bindir=${bindir}/${PN} --with-system-expat=${STAGING_DIR_HOST}"
|
||||
|
||||
EXTRA_OEMAKE = '\
|
||||
LIBC="" \
|
||||
STAGING_LIBDIR=${STAGING_LIBDIR_NATIVE} \
|
||||
STAGING_INCDIR=${STAGING_INCDIR_NATIVE} \
|
||||
'
|
||||
|
||||
do_configure_append() {
|
||||
autoreconf --verbose --install --force --exclude=autopoint ../Python-${PV}/Modules/_ctypes/libffi
|
||||
}
|
||||
|
||||
# Regenerate all of the generated files
|
||||
# This ensures that pgen and friends get created during the compile phase
|
||||
do_compile_prepend() {
|
||||
oe_runmake regen-all
|
||||
}
|
||||
|
||||
do_install() {
|
||||
oe_runmake 'DESTDIR=${D}' install
|
||||
install -d ${D}${bindir}/${PN}
|
||||
install -m 0755 Parser/pgen ${D}${bindir}/${PN}
|
||||
|
||||
# Make sure we use /usr/bin/env python
|
||||
for PYTHSCRIPT in `grep -rIl ${bindir}/${PN}/python ${D}${bindir}/${PN}`; do
|
||||
sed -i -e '1s|^#!.*|#!/usr/bin/env python|' $PYTHSCRIPT
|
||||
done
|
||||
|
||||
# Add a symlink to the native Python so that scripts can just invoke
|
||||
# "nativepython" and get the right one without needing absolute paths
|
||||
# (these often end up too long for the #! parser in the kernel as the
|
||||
# buffer is 128 bytes long).
|
||||
ln -s python-native/python ${D}${bindir}/nativepython
|
||||
|
||||
# We don't want modules in ~/.local being used in preference to those
|
||||
# installed in the native sysroot, so disable user site support.
|
||||
sed -i -e 's,^\(ENABLE_USER_SITE = \).*,\1False,' ${D}${libdir}/python${PYTHON_MAJMIN}/site.py
|
||||
}
|
||||
|
||||
python(){
|
||||
|
||||
# Read JSON manifest
|
||||
import json
|
||||
pythondir = d.getVar('THISDIR',True)
|
||||
with open(pythondir+'/python/python2-manifest.json') as manifest_file:
|
||||
python_manifest=json.load(manifest_file)
|
||||
|
||||
rprovides = d.getVar('RPROVIDES').split()
|
||||
|
||||
# Hardcoded since it cant be python-native-foo, should be python-foo-native
|
||||
pn = 'python'
|
||||
|
||||
for key in python_manifest:
|
||||
pypackage = pn + '-' + key + '-native'
|
||||
if pypackage not in rprovides:
|
||||
rprovides.append(pypackage)
|
||||
|
||||
d.setVar('RPROVIDES', ' '.join(rprovides))
|
||||
}
|
||||
Reference in New Issue
Block a user