mirror of
https://git.yoctoproject.org/poky
synced 2026-02-07 17:26:36 +01:00
python: update to 2.7.16
Drop backported patches License-update: copyright years (From OE-Core rev: 0fec1d486a3ef663dc4bbab76e5ec0ed646f23e4) Signed-off-by: Alexander Kanavin <alex.kanavin@gmail.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org> 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
02dc57ea64
commit
2268bf548a
89
meta/recipes-devtools/python/python-native_2.7.16.bb
Normal file
89
meta/recipes-devtools/python/python-native_2.7.16.bb
Normal file
@@ -0,0 +1,89 @@
|
||||
require python.inc
|
||||
EXTRANATIVEPATH += "bzip2-native"
|
||||
DEPENDS = "openssl-native bzip2-replacement-native zlib-native readline-native sqlite3-native expat-native gdbm-native db-native"
|
||||
|
||||
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 \
|
||||
file://0001-python-native-fix-one-do_populate_sysroot-warning.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')
|
||||
with open(pythondir+'/python/python2-manifest.json') as manifest_file:
|
||||
manifest_str = manifest_file.read()
|
||||
json_start = manifest_str.find('# EOC') + 6
|
||||
manifest_file.seek(json_start)
|
||||
manifest_str = manifest_file.read()
|
||||
python_manifest = json.loads(manifest_str)
|
||||
|
||||
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