diff options
author | Tudor Florea <tudor.florea@enea.com> | 2015-10-09 22:59:03 +0200 |
---|---|---|
committer | Tudor Florea <tudor.florea@enea.com> | 2015-10-09 22:59:03 +0200 |
commit | 972dcfcdbfe75dcfeb777150c136576cf1a71e99 (patch) | |
tree | 97a61cd7e293d7ae9d56ef7ed0f81253365bb026 /meta/recipes-devtools/python/python3_3.3.3.bb | |
download | poky-972dcfcdbfe75dcfeb777150c136576cf1a71e99.tar.gz |
initial commit for Enea Linux 5.0 arm
Signed-off-by: Tudor Florea <tudor.florea@enea.com>
Diffstat (limited to 'meta/recipes-devtools/python/python3_3.3.3.bb')
-rw-r--r-- | meta/recipes-devtools/python/python3_3.3.3.bb | 219 |
1 files changed, 219 insertions, 0 deletions
diff --git a/meta/recipes-devtools/python/python3_3.3.3.bb b/meta/recipes-devtools/python/python3_3.3.3.bb new file mode 100644 index 0000000000..2c1f63f5b8 --- /dev/null +++ b/meta/recipes-devtools/python/python3_3.3.3.bb | |||
@@ -0,0 +1,219 @@ | |||
1 | require recipes-devtools/python/python.inc | ||
2 | |||
3 | DEPENDS = "python3-native libffi bzip2 db gdbm openssl readline sqlite3 zlib virtual/libintl xz" | ||
4 | PR = "${INC_PR}.0" | ||
5 | PYTHON_MAJMIN = "3.3" | ||
6 | PYTHON_BINABI= "${PYTHON_MAJMIN}m" | ||
7 | DISTRO_SRC_URI ?= "file://sitecustomize.py" | ||
8 | DISTRO_SRC_URI_linuxstdbase = "" | ||
9 | SRC_URI = "http://www.python.org/ftp/python/${PV}/Python-${PV}.tar.bz2 \ | ||
10 | file://12-distutils-prefix-is-inside-staging-area.patch \ | ||
11 | file://python-config.patch \ | ||
12 | file://000-cross-compile.patch \ | ||
13 | file://020-dont-compile-python-files.patch \ | ||
14 | file://030-fixup-include-dirs.patch \ | ||
15 | file://070-dont-clean-ipkg-install.patch \ | ||
16 | file://080-distutils-dont_adjust_files.patch \ | ||
17 | file://110-enable-zlib.patch \ | ||
18 | file://130-readline-setup.patch \ | ||
19 | file://150-fix-setupterm.patch \ | ||
20 | file://0001-h2py-Fix-issue-13032-where-it-fails-with-UnicodeDeco.patch \ | ||
21 | file://fix-ast.h-dependency.patch \ | ||
22 | file://makerace.patch \ | ||
23 | ${DISTRO_SRC_URI} \ | ||
24 | file://python3-fix-build-error-with-Readline-6.3.patch \ | ||
25 | " | ||
26 | |||
27 | SRC_URI += "\ | ||
28 | file://03-fix-tkinter-detection.patch \ | ||
29 | file://04-default-is-optimized.patch \ | ||
30 | file://avoid_warning_about_tkinter.patch \ | ||
31 | file://06-ctypes-libffi-fix-configure.patch \ | ||
32 | file://remove_sqlite_rpath.patch \ | ||
33 | file://cgi_py.patch \ | ||
34 | file://host_include_contamination.patch \ | ||
35 | file://python-3.3-multilib.patch \ | ||
36 | file://shutil-follow-symlink-fix.patch \ | ||
37 | file://sysroot-include-headers.patch \ | ||
38 | file://unixccompiler.patch \ | ||
39 | file://avoid-ncursesw-include-path.patch \ | ||
40 | file://python3-use-CROSSPYTHONPATH-for-PYTHON_FOR_BUILD.patch \ | ||
41 | file://python3-setup.py-no-host-headers-libs.patch \ | ||
42 | " | ||
43 | SRC_URI[md5sum] = "f3ebe34d4d8695bf889279b54673e10c" | ||
44 | SRC_URI[sha256sum] = "e526e9b612f623888364d30cc9f3dfc34dcef39065c713bdbcddf47df84d8dcb" | ||
45 | |||
46 | LIC_FILES_CHKSUM = "file://LICENSE;md5=4eaea08eaaf6875189b0c49f26fa2005" | ||
47 | |||
48 | S = "${WORKDIR}/Python-${PV}" | ||
49 | |||
50 | inherit autotools multilib_header python3native pkgconfig | ||
51 | |||
52 | CONFIGUREOPTS += " --with-system-ffi " | ||
53 | |||
54 | CACHED_CONFIGUREVARS = "ac_cv_have_chflags=no \ | ||
55 | ac_cv_have_lchflags=no \ | ||
56 | ac_cv_have_long_long_format=yes \ | ||
57 | ac_cv_buggy_getaddrinfo=no \ | ||
58 | ac_cv_file__dev_ptmx=yes \ | ||
59 | ac_cv_file__dev_ptc=no \ | ||
60 | " | ||
61 | # The 3 lines below are copied from the libffi recipe, ctypes ships its own copy of the libffi sources | ||
62 | #Somehow gcc doesn't set __SOFTFP__ when passing -mfloatabi=softp :( | ||
63 | TARGET_CC_ARCH_append_armv6 = " -D__SOFTFP__" | ||
64 | TARGET_CC_ARCH_append_armv7a = " -D__SOFTFP__" | ||
65 | TARGET_CC_ARCH += "-DNDEBUG -fno-inline" | ||
66 | EXTRA_OEMAKE += "CROSS_COMPILE=yes" | ||
67 | EXTRA_OECONF += "CROSSPYTHONPATH=${STAGING_LIBDIR_NATIVE}/python${PYTHON_MAJMIN}/lib-dynload/" | ||
68 | |||
69 | # No ctypes option for python 3 | ||
70 | PYTHONLSBOPTS = "" | ||
71 | |||
72 | do_configure_prepend() { | ||
73 | rm -f ${S}/Makefile.orig | ||
74 | autoreconf -Wcross --verbose --install --force --exclude=autopoint Modules/_ctypes/libffi || bbnote "_ctypes failed to autoreconf" | ||
75 | } | ||
76 | |||
77 | do_compile() { | ||
78 | # regenerate platform specific files, because they depend on system headers | ||
79 | cd Lib/plat-linux* | ||
80 | include=${STAGING_INCDIR} ${STAGING_BINDIR_NATIVE}/python3-native/python3 \ | ||
81 | ${S}/Tools/scripts/h2py.py -i '(u_long)' \ | ||
82 | ${STAGING_INCDIR}/dlfcn.h \ | ||
83 | ${STAGING_INCDIR}/linux/cdrom.h \ | ||
84 | ${STAGING_INCDIR}/netinet/in.h \ | ||
85 | ${STAGING_INCDIR}/sys/types.h | ||
86 | sed -e 's,${STAGING_DIR_HOST},,g' -i *.py | ||
87 | cd - | ||
88 | |||
89 | # remove hardcoded ccache, see http://bugs.openembedded.net/show_bug.cgi?id=4144 | ||
90 | sed -i -e s,ccache\ ,'$(CCACHE) ', Makefile | ||
91 | |||
92 | # remove any bogus LD_LIBRARY_PATH | ||
93 | sed -i -e s,RUNSHARED=.*,RUNSHARED=, Makefile | ||
94 | |||
95 | if [ ! -f Makefile.orig ]; then | ||
96 | install -m 0644 Makefile Makefile.orig | ||
97 | fi | ||
98 | sed -i -e 's,^CONFIGURE_LDFLAGS=.*,CONFIGURE_LDFLAGS=-L. -L${STAGING_LIBDIR},g' \ | ||
99 | -e 's,libdir=${libdir},libdir=${STAGING_LIBDIR},g' \ | ||
100 | -e 's,libexecdir=${libexecdir},libexecdir=${STAGING_DIR_HOST}${libexecdir},g' \ | ||
101 | -e 's,^LIBDIR=.*,LIBDIR=${STAGING_LIBDIR},g' \ | ||
102 | -e 's,includedir=${includedir},includedir=${STAGING_INCDIR},g' \ | ||
103 | -e 's,^INCLUDEDIR=.*,INCLUDE=${STAGING_INCDIR},g' \ | ||
104 | -e 's,^CONFINCLUDEDIR=.*,CONFINCLUDE=${STAGING_INCDIR},g' \ | ||
105 | Makefile | ||
106 | # save copy of it now, because if we do it in do_install and | ||
107 | # then call do_install twice we get Makefile.orig == Makefile.sysroot | ||
108 | install -m 0644 Makefile Makefile.sysroot | ||
109 | |||
110 | export CROSS_COMPILE="${TARGET_PREFIX}" | ||
111 | export PYTHONBUILDDIR="${S}" | ||
112 | oe_runmake HOSTPGEN=${STAGING_BINDIR_NATIVE}/python3-native/pgen \ | ||
113 | HOSTPYTHON=${STAGING_BINDIR_NATIVE}/python3-native/python3 \ | ||
114 | STAGING_LIBDIR=${STAGING_LIBDIR} \ | ||
115 | STAGING_BASELIBDIR=${STAGING_BASELIBDIR} \ | ||
116 | STAGING_INCDIR=${STAGING_INCDIR} \ | ||
117 | BUILD_SYS=${BUILD_SYS} HOST_SYS=${HOST_SYS} \ | ||
118 | LIB=${baselib} \ | ||
119 | ARCH=${TARGET_ARCH} \ | ||
120 | OPT="${CFLAGS}" libpython3.so | ||
121 | |||
122 | oe_runmake HOSTPGEN=${STAGING_BINDIR_NATIVE}/python3-native/pgen \ | ||
123 | HOSTPYTHON=${STAGING_BINDIR_NATIVE}/python3-native/python3 \ | ||
124 | STAGING_LIBDIR=${STAGING_LIBDIR} \ | ||
125 | STAGING_INCDIR=${STAGING_INCDIR} \ | ||
126 | STAGING_BASELIBDIR=${STAGING_BASELIBDIR} \ | ||
127 | BUILD_SYS=${BUILD_SYS} HOST_SYS=${HOST_SYS} \ | ||
128 | LIB=${baselib} \ | ||
129 | ARCH=${TARGET_ARCH} \ | ||
130 | OPT="${CFLAGS}" | ||
131 | } | ||
132 | |||
133 | do_install() { | ||
134 | # make install needs the original Makefile, or otherwise the inclues would | ||
135 | # go to ${D}${STAGING...}/... | ||
136 | install -m 0644 Makefile.orig Makefile | ||
137 | |||
138 | export CROSS_COMPILE="${TARGET_PREFIX}" | ||
139 | export PYTHONBUILDDIR="${S}" | ||
140 | install -d ${D}${libdir}/pkgconfig | ||
141 | install -d ${D}${libdir}/python${PYTHON_MAJMIN}/config | ||
142 | |||
143 | # rerun the build once again with original makefile this time | ||
144 | # run install in a separate step to avoid compile/install race | ||
145 | oe_runmake HOSTPGEN=${STAGING_BINDIR_NATIVE}/python3-native/pgen \ | ||
146 | HOSTPYTHON=${STAGING_BINDIR_NATIVE}/python3-native/python3 \ | ||
147 | STAGING_LIBDIR=${STAGING_LIBDIR} \ | ||
148 | STAGING_INCDIR=${STAGING_INCDIR} \ | ||
149 | STAGING_BASELIBDIR=${STAGING_BASELIBDIR} \ | ||
150 | BUILD_SYS=${BUILD_SYS} HOST_SYS=${HOST_SYS} \ | ||
151 | LIB=${baselib} \ | ||
152 | ARCH=${TARGET_ARCH} \ | ||
153 | DESTDIR=${D} LIBDIR=${libdir} | ||
154 | |||
155 | oe_runmake HOSTPGEN=${STAGING_BINDIR_NATIVE}/python3-native/pgen \ | ||
156 | HOSTPYTHON=${STAGING_BINDIR_NATIVE}/python3-native/python3 \ | ||
157 | STAGING_LIBDIR=${STAGING_LIBDIR} \ | ||
158 | STAGING_INCDIR=${STAGING_INCDIR} \ | ||
159 | STAGING_BASELIBDIR=${STAGING_BASELIBDIR} \ | ||
160 | BUILD_SYS=${BUILD_SYS} HOST_SYS=${HOST_SYS} \ | ||
161 | LIB=${baselib} \ | ||
162 | ARCH=${TARGET_ARCH} \ | ||
163 | DESTDIR=${D} LIBDIR=${libdir} install | ||
164 | |||
165 | install -m 0644 Makefile.sysroot ${D}/${libdir}/python${PYTHON_MAJMIN}/config/Makefile | ||
166 | |||
167 | if [ -e ${WORKDIR}/sitecustomize.py ]; then | ||
168 | install -m 0644 ${WORKDIR}/sitecustomize.py ${D}/${libdir}/python${PYTHON_MAJMIN} | ||
169 | fi | ||
170 | |||
171 | oe_multilib_header python${PYTHON_MAJMIN}/pyconfig.h | ||
172 | } | ||
173 | |||
174 | do_install_append_class-nativesdk () { | ||
175 | create_wrapper ${D}${bindir}/python${PYTHON_MAJMIN} TERMINFO_DIRS='${sysconfdir}/terminfo:/etc/terminfo:/usr/share/terminfo:/usr/share/misc/terminfo:/lib/terminfo' | ||
176 | } | ||
177 | |||
178 | SSTATE_SCAN_FILES += "Makefile" | ||
179 | PACKAGE_PREPROCESS_FUNCS += "py_package_preprocess" | ||
180 | |||
181 | py_package_preprocess () { | ||
182 | # copy back the old Makefile to fix target package | ||
183 | install -m 0644 Makefile.orig ${PKGD}/${libdir}/python${PYTHON_MAJMIN}/config/Makefile | ||
184 | # Remove references to buildmachine paths in target Makefile | ||
185 | sed -i -e 's:--sysroot=${STAGING_DIR_TARGET}::g' -e s:'--with-libtool-sysroot=${STAGING_DIR_TARGET}'::g ${PKGD}/${libdir}/python${PYTHON_MAJMIN}/config/Makefile | ||
186 | } | ||
187 | |||
188 | require python-${PYTHON_MAJMIN}-manifest.inc | ||
189 | |||
190 | # manual dependency additions | ||
191 | RPROVIDES_${PN}-core = "${PN}" | ||
192 | RRECOMMENDS_${PN}-core = "${PN}-readline" | ||
193 | RRECOMMENDS_${PN}-crypt = "openssl" | ||
194 | RRECOMMENDS_${PN}-crypt_class-nativesdk = "nativesdk-openssl" | ||
195 | |||
196 | FILES_${PN}-2to3 += "${bindir}/2to3-${PYTHON_MAJMIN}" | ||
197 | FILES_${PN}-pydoc += "${bindir}/pydoc${PYTHON_MAJMIN} ${bindir}/pydoc3" | ||
198 | FILES_${PN}-idle += "${bindir}/idle3 ${bindir}/idle${PYTHON_MAJMIN}" | ||
199 | |||
200 | PACKAGES =+ "${PN}-pyvenv" | ||
201 | FILES_${PN}-pyvenv += "${bindir}/pyvenv-${PYTHON_MAJMIN} ${bindir}/pyvenv" | ||
202 | |||
203 | # package libpython3 | ||
204 | PACKAGES =+ "libpython3 libpython3-staticdev" | ||
205 | FILES_libpython3 = "${libdir}/libpython*.so.*" | ||
206 | FILES_libpython3-staticdev += "${libdir}/python${PYTHON_MAJMIN}/config-${PYTHON_BINABI}/libpython${PYTHON_BINABI}.a" | ||
207 | |||
208 | # catch debug extensions (isn't that already in python-core-dbg?) | ||
209 | FILES_${PN}-dbg += "${libdir}/python${PYTHON_MAJMIN}/lib-dynload/.debug" | ||
210 | |||
211 | # catch all the rest (unsorted) | ||
212 | PACKAGES += "${PN}-misc" | ||
213 | FILES_${PN}-misc = "${libdir}/python${PYTHON_MAJMIN}" | ||
214 | |||
215 | # catch manpage | ||
216 | PACKAGES += "${PN}-man" | ||
217 | FILES_${PN}-man = "${datadir}/man" | ||
218 | |||
219 | BBCLASSEXTEND = "nativesdk" | ||