Issue 29040: building Android with android-ndk-r14 (original) (raw)
Issue29040
This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.
This issue has been migrated to GitHub: https://github.com/python/cpython/issues/73226
classification
Title: | building Android with android-ndk-r14 | ||
---|---|---|---|
Type: | compile error | Stage: | resolved |
Components: | Cross-Build | Versions: | Python 3.7 |
process
Status: | closed | Resolution: | fixed |
---|---|---|---|
Dependencies: | Superseder: | ||
Assigned To: | Nosy List: | Alex.Willmer, xdegaye, yan12125 | |
Priority: | normal | Keywords: | patch |
Created on 2016-12-21 20:24 by xdegaye, last changed 2022-04-11 14:58 by admin. This issue is now closed.
Files | |||
---|---|---|---|
File name | Uploaded | Description | Edit |
api-level.h | xdegaye,2016-12-21 20:24 |
Pull Requests | |||
---|---|---|---|
URL | Status | Linked | Edit |
PR 4492 | merged | xdegaye,2017-11-21 16:03 |
Messages (4) | ||
---|---|---|
msg283778 - (view) | Author: Xavier de Gaye (xdegaye) * ![]() |
Date: 2016-12-21 20:24 |
android-ndk-r14 introduces "Unified Headers" [1] and is planned to be released late january/early february 2017 [2]. __ANDROID_API__ is not anymore defined in 'android/api-level.h' that is currently included by Include/pyport.h, and is passed instead with -D__ANDROID_API__=$API when compiling. And 'android/api-level.h' is now used to set the API level to 10000 as a Magic version number for a current development build when __ANDROID_API__ is not defined (see attached file). Adoption of android-ndk-r14 should be made with the following changes: * Remove the include of <android/api-level.h> in Include/pyport.h. * Update configure.ac to abort when __ANDROID__ is defined and __ANDROID_API__ is not defined. * Revert the changes made in issues #28538 and #28762, android-ndk-r14 fixes the problems raised in these two issues. [1] https://android.googlesource.com/platform/ndk.git/+/master/docs/UnifiedHeaders.md [2] https://github.com/android-ndk/ndk/wiki | ||
msg283815 - (view) | Author: (yan12125) * | Date: 2016-12-22 06:40 |
Thanks for compiling up necessary changes for NDK r14! Seems that indicates future Python versions will require at least NDK r14 to build? Another headache from unified headers is that it requires different --sysroot in compilation and linking. Currently setup.py/distutils does not cope with it well. See my dirty hack at [1] for an ad-hoc workaround. [1] https://github.com/yan12125/python3-android/blob/master/mk/python/distutils-android-sysroot.patch | ||
msg283822 - (view) | Author: Xavier de Gaye (xdegaye) * ![]() |
Date: 2016-12-22 09:11 |
> Seems that indicates future Python versions will require at least NDK r14 to build? Yes. | ||
msg306799 - (view) | Author: Xavier de Gaye (xdegaye) * ![]() |
Date: 2017-11-23 10:44 |
New changeset c06c22e9a9fb9326e79fcf1551601eacc1fd457d by xdegaye in branch 'master': bpo-29040: Support building Android with Unified Headers (GH-4492) https://github.com/python/cpython/commit/c06c22e9a9fb9326e79fcf1551601eacc1fd457d |
History | |||
---|---|---|---|
Date | User | Action | Args |
2022-04-11 14:58:41 | admin | set | github: 73226 |
2017-11-23 10:46:12 | xdegaye | set | status: open -> closedresolution: fixedstage: patch review -> resolved |
2017-11-23 10:44:40 | xdegaye | set | messages: + |
2017-11-21 16:03:30 | xdegaye | set | keywords: + patchstage: needs patch -> patch reviewpull_requests: + <pull%5Frequest4429> |
2017-11-21 10:11:39 | xdegaye | set | versions: - Python 3.6 |
2016-12-22 09:11:00 | xdegaye | set | messages: + |
2016-12-22 06:40:09 | yan12125 | set | nosy: + yan12125messages: + |
2016-12-21 20:27:49 | xdegaye | link | issue26865 dependencies |
2016-12-21 20:24:25 | xdegaye | create |