kivy / python-for-android

Turn your Python application into an Android APK
https://python-for-android.readthedocs.io
MIT License
8.32k stars 1.84k forks source link

The mpl_android_fixes.patch didn't work #1989

Closed cocpy closed 5 years ago

cocpy commented 5 years ago

Versions

Description

I am trying to package an apk with buildozer.

buildozer.spec

Command:

buildozer -v android debug

Spec file:

[app]

# (str) Title of your application
title = My Application

# (str) Package name
package.name = myapp

# (str) Package domain (needed for android/ios packaging)
package.domain = org.test

# (str) Source code where the main.py live
source.dir = .

# (list) Source files to include (let empty to include all the files)
source.include_exts = py,png,jpg,kv,mp3,atlas

# (list) List of inclusions using pattern matching
#source.include_patterns = assets/*,images/*.png

# (list) Source files to exclude (let empty to not exclude anything)
#source.exclude_exts = spec

# (list) List of directory to exclude (let empty to not exclude anything)
#source.exclude_dirs = tests, bin

# (list) List of exclusions using pattern matching
#source.exclude_patterns = license,images/*/*.jpg

# (str) Application versioning (method 1)
version = 1.0

# (str) Application versioning (method 2)
# version.regex = __version__ = ['"](.*)['"]
# version.filename = %(source.dir)s/main.py

# (list) Application requirements
# comma separated e.g. requirements = sqlite3,kivy
requirements = python3,kivy,kivy==1.11.1,pdfminer3k,xlrd,python_docx,beautifulsoup4,matplotlib==2.2.2

# (str) Custom source folders for requirements
# Sets custom source for any requirements with recipes
# requirements.source.kivy = ../../kivy

# (list) Garden requirements
garden_requirements = navigationdrawer,matplotlib

# (str) Presplash of the application
#presplash.filename = %(source.dir)s/data/presplash.png

# (str) Icon of the application
#icon.filename = %(source.dir)s/data/icon.png

# (str) Supported orientation (one of landscape, sensorLandscape, portrait or all)
orientation = portrait

# (list) List of service to declare
#services = NAME:ENTRYPOINT_TO_PY,NAME2:ENTRYPOINT2_TO_PY

#
# OSX Specific
#

#
# author = © Copyright Info

# change the major version of python used by the app
osx.python_version = 3

# Kivy version to use
osx.kivy_version = 1.9.1

#
# Android specific
#

# (bool) Indicate if the application should be fullscreen or not
fullscreen = 0

# (string) Presplash background color (for new android toolchain)
# Supported formats are: #RRGGBB #AARRGGBB or one of the following names:
# red, blue, green, black, white, gray, cyan, magenta, yellow, lightgray,
# darkgray, grey, lightgrey, darkgrey, aqua, fuchsia, lime, maroon, navy,
# olive, purple, silver, teal.
#android.presplash_color = #FFFFFF

# (list) Permissions
#android.permissions = INTERNET

# (int) Target Android API, should be as high as possible.
#android.api = 27

# (int) Minimum API your APK will support.
#android.minapi = 21

# (int) Android SDK version to use
#android.sdk = 20

# (str) Android NDK version to use
#android.ndk = 17c

# (int) Android NDK API to use. This is the minimum API your app will support, it should usually match android.minapi.
#android.ndk_api = 21

# (bool) Use --private data storage (True) or --dir public storage (False)
#android.private_storage = True

# (str) Android NDK directory (if empty, it will be automatically downloaded.)
#android.ndk_path =

# (str) Android SDK directory (if empty, it will be automatically downloaded.)
#android.sdk_path =

# (str) ANT directory (if empty, it will be automatically downloaded.)
#android.ant_path =

# (bool) If True, then skip trying to update the Android sdk
# This can be useful to avoid excess Internet downloads or save time
# when an update is due and you just want to test/build your package
# android.skip_update = False

# (bool) If True, then automatically accept SDK license
# agreements. This is intended for automation only. If set to False,
# the default, you will be shown the license when first running
# buildozer.
# android.accept_sdk_license = False

# (str) Android entry point, default is ok for Kivy-based app
#android.entrypoint = org.renpy.android.PythonActivity

# (list) Pattern to whitelist for the whole project
#android.whitelist =

# (str) Path to a custom whitelist file
#android.whitelist_src =

# (str) Path to a custom blacklist file
#android.blacklist_src =

# (list) List of Java .jar files to add to the libs so that pyjnius can access
# their classes. Don't add jars that you do not need, since extra jars can slow
# down the build process. Allows wildcards matching, for example:
# OUYA-ODK/libs/*.jar
#android.add_jars = foo.jar,bar.jar,path/to/more/*.jar

# (list) List of Java files to add to the android project (can be java or a
# directory containing the files)
#android.add_src =

# (list) Android AAR archives to add (currently works only with sdl2_gradle
# bootstrap)
#android.add_aars =

# (list) Gradle dependencies to add (currently works only with sdl2_gradle
# bootstrap)
#android.gradle_dependencies =

# (list) Java classes to add as activities to the manifest.
#android.add_activites = com.example.ExampleActivity

# (str) python-for-android branch to use, defaults to master
# p4a.branch = master

# (str) OUYA Console category. Should be one of GAME or APP
# If you leave this blank, OUYA support will not be enabled
#android.ouya.category = GAME

# (str) Filename of OUYA Console icon. It must be a 732x412 png image.
#android.ouya.icon.filename = %(source.dir)s/data/ouya_icon.png

# (str) XML file to include as an intent filters in <activity> tag
#android.manifest.intent_filters =

# (str) launchMode to set for the main activity
#android.manifest.launch_mode = standard

# (list) Android additional libraries to copy into libs/armeabi
#android.add_libs_armeabi = libs/android/*.so
#android.add_libs_armeabi_v7a = libs/android-v7/*.so
#android.add_libs_x86 = libs/android-x86/*.so
#android.add_libs_mips = libs/android-mips/*.so

# (bool) Indicate whether the screen should stay on
# Don't forget to add the WAKE_LOCK permission if you set this to True
#android.wakelock = False

# (list) Android application meta-data to set (key=value format)
#android.meta_data =

# (list) Android library project to add (will be added in the
# project.properties automatically.)
#android.library_references =

# (str) Android logcat filters to use
#android.logcat_filters = *:S python:D

# (bool) Copy library instead of making a libpymodules.so
#android.copy_libs = 1

# (str) The Android arch to build for, choices: armeabi-v7a, arm64-v8a, x86
android.arch = armeabi-v7a

#
# Python for android (p4a) specific
#

# (str) python-for-android git clone directory (if empty, it will be automatically cloned from github)
#p4a.source_dir =

# (str) The directory in which python-for-android should look for your own build recipes (if any)
#p4a.local_recipes =

# (str) Filename to the hook for p4a
#p4a.hook =

# (str) Bootstrap to use for android builds
# p4a.bootstrap = sdl2

# (int) port number to specify an explicit --port= p4a argument (eg for bootstrap flask)
#p4a.port =

#
# iOS specific
#

# (str) Path to a custom kivy-ios folder
#ios.kivy_ios_dir = ../kivy-ios
# Alternately, specify the URL and branch of a git checkout:
ios.kivy_ios_url = https://github.com/kivy/kivy-ios
ios.kivy_ios_branch = master

# Another platform dependency: ios-deploy
# Uncomment to use a custom checkout
#ios.ios_deploy_dir = ../ios_deploy
# Or specify URL and branch
ios.ios_deploy_url = https://github.com/phonegap/ios-deploy
ios.ios_deploy_branch = 1.7.0

# (str) Name of the certificate to use for signing the debug version
# Get a list of available identities: buildozer ios list_identities
#ios.codesign.debug = "iPhone Developer: <lastname> <firstname> (<hexstring>)"

# (str) Name of the certificate to use for signing the release version
#ios.codesign.release = %(ios.codesign.debug)s

[buildozer]

# (int) Log level (0 = error only, 1 = info, 2 = debug (with command output))
log_level = 2

# (int) Display warning if buildozer is run as root (0 = False, 1 = True)
warn_on_root = 1

# (str) Path to build artifact storage, absolute or relative to spec file
# build_dir = ./.buildozer

# (str) Path to build output (i.e. .apk, .ipa) storage
# bin_dir = ./bin

#    -----------------------------------------------------------------------------
#    List as sections
#
#    You can define all the "list" as [section:key].
#    Each line will be considered as a option to the list.
#    Let's take [app] / source.exclude_patterns.
#    Instead of doing:
#
#[app]
#source.exclude_patterns = license,data/audio/*.wav,data/images/original/*
#
#    This can be translated into:
#
#[app:source.exclude_patterns]
#license
#data/audio/*.wav
#data/images/original/*
#

#    -----------------------------------------------------------------------------
#    Profiles
#
#    You can extend section / key with a profile
#    For example, you want to deploy a demo version of your application without
#    HD content. You could first change the title to add "(demo)" in the name
#    and extend the excluded directories to remove the HD content.
#
#[app@demo]
#title = My Application (demo)
#
#[app:source.exclude_patterns@demo]
#images/hd/*
#
#    Then, invoke the command line with the "demo" profile:
#
#buildozer --profile demo android debug

Logs

<--

root@VM-0-4-ubuntu:/home/ubuntu/word# buildozer -v android debug
# Check configuration tokens
Buildozer is running as root!
This is not recommended, and may lead to problems later.
Are you sure you want to continue [y/n]? y
# Ensure build layout
# Check configuration tokens
# Preparing build
# Check requirements for android
# Run 'dpkg --version'
# Cwd None
Debian 'dpkg' package management program version 1.19.0.5 (amd64).
This is free software; see the GNU General Public License version 2 or
later for copying conditions. There is NO warranty.
# Search for Git (git)
#  -> found at /usr/bin/git
# Search for Cython (cython)
#  -> found at /usr/bin/cython
# Search for Java compiler (javac)
#  -> found at /usr/lib/jvm/java-8-openjdk-amd64/bin/javac
# Search for Java keytool (keytool)
#  -> found at /usr/lib/jvm/java-8-openjdk-amd64/jre/bin/keytool
# Install platform
# Run '/usr/bin/python -m pip install -q --user \'appdirs\' \'colorama>=0.3.3\' \'jinja2\' \'six\' \'enum34; python_version<"3.4"\' \'sh>=1.10; sys_platform!="nt"\' \'pep517\' \'pytoml\' \'virtualenv\''
# Cwd None
# Apache ANT found at /root/.buildozer/android/platform/apache-ant-1.9.4
# Android SDK found at /root/.buildozer/android/platform/android-sdk
# Android NDK found at /root/.buildozer/android/platform/android-ndk-r17c
# Check application requirements
# Check garden requirements
# Garden requirements already installed, pass
# Compile platform
# Run '/usr/bin/python -m pythonforandroid.toolchain create --dist_name=myapp --bootstrap=sdl2 --requirements=python3,kivy,kivy==1.11.1,pdfminer3k,xlrd,python_docx,beautifulsoup4,matplotlib==2.2.2 --arch armeabi-v7a --copy-libs --color=always --storage-dir="/home/ubuntu/word/.buildozer/android/platform/build" --ndk-api=21'
# Cwd /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Recipe kivy: version "1.11.1" requested
[INFO]:    Recipe matplotlib: version "2.2.2" requested
[INFO]:    Will compile for the following archs: armeabi-v7a
[INFO]:    Found Android API target in $ANDROIDAPI: 27
[INFO]:    Available Android APIs are (27)
[INFO]:    Requested API target 27 is available, continuing.
[INFO]:    Found NDK dir in $ANDROIDNDK: /root/.buildozer/android/platform/android-ndk-r17c
[INFO]:    Found NDK version 17c
[INFO]:    Getting NDK API version (i.e. minimum supported API) from user argument
[INFO]:    Found virtualenv at /usr/local/bin/virtualenv
[INFO]:    ccache is missing, the build will not be optimized in the future.
[INFO]:    Found the following toolchain versions: ['4.9']
[INFO]:    Picking the latest gcc toolchain, here 4.9
[INFO]:    No existing dists meet the given requirements!
[INFO]:    No dist exists that meets your requirements, so one will be built.
[INFO]:    Found a single valid recipe set: ['beautifulsoup4', 'freetype', 'hostpython3', 'libffi', 'openssl', 'pdfminer3k', 'png', 'python_docx', 'sdl2_image', 'sdl2_mixer', 'sdl2_ttf', 'sqlite3', 'xlrd', 'python3', 'sdl2', 'numpy', 'setuptools', 'kiwisolver', 'six', 'matplotlib', 'pyjnius', 'android', 'kivy']
[INFO]:    The selected bootstrap is sdl2
[INFO]:    # Creating dist with sdl2 bootstrap
[INFO]:    Dist will have name myapp and requirements (python3, kivy, kivy, pdfminer3k, xlrd, python_docx, beautifulsoup4, matplotlib)
[INFO]:    Dist contains the following requirements as recipes: ['freetype', 'hostpython3', 'libffi', 'openssl', 'png', 'sdl2_image', 'sdl2_mixer', 'sdl2_ttf', 'sqlite3', 'python3', 'sdl2', 'numpy', 'setuptools', 'kiwisolver', 'six', 'matplotlib', 'pyjnius', 'android', 'kivy']
[INFO]:    Dist will also contain modules (beautifulsoup4, python_docx, pyparsing, cycler, python-dateutil, pdfminer3k, xlrd) installed from pip
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/bootstrap_builds/sdl2-python3
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Recipe build order is ['freetype', 'hostpython3', 'libffi', 'openssl', 'png', 'sdl2_image', 'sdl2_mixer', 'sdl2_ttf', 'sqlite3', 'python3', 'sdl2', 'numpy', 'setuptools', 'kiwisolver', 'six', 'matplotlib', 'pyjnius', 'android', 'kivy']
[INFO]:    The requirements (beautifulsoup4, cycler, pdfminer3k, pyparsing, python-dateutil, python_docx, xlrd) were not found as recipes, they will be installed with pip.
[INFO]:    # Downloading recipes 
[INFO]:    Downloading freetype
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bui...(and 20 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/freetype
[INFO]:    -> running basename http://download.savannah.gnu.org/releases/freety...(and 24 more)
[INFO]:    freetype download already cached, skipping                                                     
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading hostpython3
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bu...(and 24 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/hostpython3
[INFO]:    -> running basename https://www.python.org/ftp/python/3.7.1/Python-3.7.1.tgz
[INFO]:    hostpython3 download already cached, skipping                                                  
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading libffi
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bui...(and 18 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/libffi
[INFO]:    -> running basename https://github.com/libffi/libffi/archive/v3.2.1.tar.gz
[INFO]:    libffi download already cached, skipping                                                       
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading openssl
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bui...(and 19 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/openssl
[INFO]:    -> running basename https://www.openssl.org/source/openssl-1.1.1.tar.gz
[INFO]:    openssl download already cached, skipping                                                      
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading png
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/build/packages/png
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/png
[INFO]:    -> running basename https://github.com/glennrp/libpng/archive/v1.6.37.zip
[INFO]:    png download already cached, skipping                                                          
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading sdl2_image
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bu...(and 23 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/sdl2_image
[INFO]:    -> running basename https://www.libsdl.org/projects/SDL_image/releas...(and 25 more)
[INFO]:    sdl2_image download already cached, skipping                                                   
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading sdl2_mixer
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bu...(and 23 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/sdl2_mixer
[INFO]:    -> running basename https://www.libsdl.org/projects/SDL_mixer/releas...(and 25 more)
[INFO]:    sdl2_mixer download already cached, skipping                                                   
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading sdl2_ttf
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bui...(and 20 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/sdl2_ttf
[INFO]:    -> running basename https://www.libsdl.org/projects/SDL_ttf/release/S...(and 21 more)
[INFO]:    sdl2_ttf download already cached, skipping                                                     
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading sqlite3
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bui...(and 19 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/sqlite3
[INFO]:    -> running basename https://www.sqlite.org/2016/sqlite-amalgamation-3150100.zip
[INFO]:    sqlite3 download already cached, skipping                                                      
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading python3
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bui...(and 19 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/python3
[INFO]:    -> running basename https://www.python.org/ftp/python/3.7.1/Python-3.7.1.tgz
[INFO]:    python3 download already cached, skipping                                                      
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading sdl2
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/build/packages/sdl2
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/sdl2
[INFO]:    -> running basename https://www.libsdl.org/release/SDL2-2.0.9.tar.gz
[INFO]:    sdl2 download already cached, skipping                                                         
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading numpy
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/build/packages/numpy
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/numpy
[INFO]:    -> running basename https://pypi.python.org/packages/source/n/numpy/numpy-1.16.4.zip
[INFO]:    numpy download already cached, skipping                                                        
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading setuptools
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bu...(and 23 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/setuptools
[INFO]:    -> running basename https://pypi.python.org/packages/source/s/setupt...(and 26 more)
[INFO]:    setuptools download already cached, skipping                                                   
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading kiwisolver
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bu...(and 23 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/kiwisolver
[INFO]:    -> running basename https://github.com/nucleic/kiwi/archive/master.zip
[INFO]:    kiwisolver download already cached, skipping                                                   
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading six
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/build/packages/six
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/six
[INFO]:    -> running basename https://pypi.python.org/packages/source/s/six/six-1.10.0.tar.gz
[INFO]:    six download already cached, skipping                                                          
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading matplotlib
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bu...(and 23 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/matplotlib
[INFO]:    -> running basename https://github.com/matplotlib/matplotlib/archive/v2.2.2.zip
[INFO]:    matplotlib download already cached, skipping                                                   
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading pyjnius
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/bui...(and 19 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/pyjnius
[INFO]:    -> running basename https://github.com/kivy/pyjnius/archive/6553ad4.zip
[INFO]:    pyjnius download already cached, skipping                                                      
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Downloading android
[INFO]:    Skipping android download as no URL is set
[INFO]:    Downloading kivy
[INFO]:    -> running mkdir -p /home/ubuntu/word/.buildozer/android/platform/build/packages/kivy
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/packages/kivy
[INFO]:    -> running basename https://github.com/kivy/kivy/archive/1.11.1.zip
[INFO]:    kivy download already cached, skipping                                                         
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    # Building all recipes for arch armeabi-v7a
[INFO]:    # Unpacking recipes
[INFO]:    Unpacking freetype for armeabi-v7a
[INFO]:    -> running basename http://download.savannah.gnu.org/releases/freety...(and 24 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/freetype/armeabi-v7a__ndk_target_21
[INFO]:    freetype is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking hostpython3 for armeabi-v7a
[INFO]:    -> running basename https://www.python.org/ftp/python/3.7.1/Python-3.7.1.tgz
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/hostpython3/desktop
[INFO]:    hostpython3 is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking libffi for armeabi-v7a
[INFO]:    -> running basename https://github.com/libffi/libffi/archive/v3.2.1.tar.gz
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/libffi/armeabi-v7a__ndk_target_21
[INFO]:    libffi is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking openssl for armeabi-v7a
[INFO]:    -> running basename https://www.openssl.org/source/openssl-1.1.1.tar.gz
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/openssl/armeabi-v7a__ndk_target_21
[INFO]:    openssl is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking png for armeabi-v7a
[INFO]:    -> running basename https://github.com/glennrp/libpng/archive/v1.6.37.zip
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/png/armeabi-v7a__ndk_target_21
[INFO]:    png is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking sdl2_image for armeabi-v7a
[INFO]:    -> running basename https://www.libsdl.org/projects/SDL_image/releas...(and 25 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/bootstrap_builds/sdl2-python3/jni
[INFO]:    sdl2_image is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking sdl2_mixer for armeabi-v7a
[INFO]:    -> running basename https://www.libsdl.org/projects/SDL_mixer/releas...(and 25 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/bootstrap_builds/sdl2-python3/jni
[INFO]:    sdl2_mixer is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking sdl2_ttf for armeabi-v7a
[INFO]:    -> running basename https://www.libsdl.org/projects/SDL_ttf/release/S...(and 21 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/bootstrap_builds/sdl2-python3/jni
[INFO]:    sdl2_ttf is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking sqlite3 for armeabi-v7a
[INFO]:    -> running basename https://www.sqlite.org/2016/sqlite-amalgamation-3150100.zip
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/sqlite3/armeabi-v7a__ndk_target_21
[INFO]:    sqlite3 is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking python3 for armeabi-v7a
[INFO]:    -> running basename https://www.python.org/ftp/python/3.7.1/Python-3.7.1.tgz
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/python3-libffi-openssl-sqlite3/armeabi-v7a__ndk_target_21
[INFO]:    python3 is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking sdl2 for armeabi-v7a
[INFO]:    -> running basename https://www.libsdl.org/release/SDL2-2.0.9.tar.gz
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/bootstrap_builds/sdl2-python3/jni
[INFO]:    sdl2 is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking numpy for armeabi-v7a
[INFO]:    -> running basename https://pypi.python.org/packages/source/n/numpy/numpy-1.16.4.zip
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/numpy-python3/armeabi-v7a__ndk_target_21
[INFO]:    numpy is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking setuptools for armeabi-v7a
[INFO]:    -> running basename https://pypi.python.org/packages/source/s/setupt...(and 26 more)
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/setuptools-python3/armeabi-v7a__ndk_target_21
[INFO]:    setuptools is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking kiwisolver for armeabi-v7a
[INFO]:    -> running basename https://github.com/nucleic/kiwi/archive/master.zip
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/kiwisolver-python3/armeabi-v7a__ndk_target_21
[INFO]:    kiwisolver is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking six for armeabi-v7a
[INFO]:    -> running basename https://pypi.python.org/packages/source/s/six/six-1.10.0.tar.gz
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/six-python3/armeabi-v7a__ndk_target_21
[INFO]:    six is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking matplotlib for armeabi-v7a
[INFO]:    -> running basename https://github.com/matplotlib/matplotlib/archive/v2.2.2.zip
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/matplotlib-python3/armeabi-v7a__ndk_target_21
[INFO]:    matplotlib is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    Unpacking pyjnius for armeabi-v7a
[INFO]:    -> running basename https://github.com/kivy/pyjnius/archive/6553ad4.zip
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/pyjnius-python3-sdl2/armeabi-v7a__ndk_target_21
[INFO]:    pyjnius is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    -> running rm -rf /home/ubuntu/word/.buildozer/android/platform/buil...(and 76 more)
[INFO]:    -> running cp -a /home/ubuntu/word/.buildozer/android/platform/pytho...(and 177 more)
[INFO]:    Unpacking kivy for armeabi-v7a
[INFO]:    -> running basename https://github.com/kivy/kivy/archive/1.11.1.zip
[INFO]:    -> directory context /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/kivy-python3/armeabi-v7a__ndk_target_21
[INFO]:    kivy is already unpacked, skipping
[INFO]:    <- directory context /home/ubuntu/word/.buildozer/android/platform/python-for-android
[INFO]:    # Prebuilding recipes
[INFO]:    Prebuilding freetype for armeabi-v7a
[INFO]:    freetype has no prebuild_armeabi_v7a, skipping
[INFO]:    Prebuilding hostpython3 for armeabi-v7a
[INFO]:    hostpython3 has no prebuild_armeabi_v7a, skipping
[INFO]:    Prebuilding libffi for armeabi-v7a
[INFO]:    libffi has no prebuild_armeabi_v7a, skipping
[INFO]:    Applying patches for libffi[armeabi-v7a]
[INFO]:    libffi already patched, skipping
[INFO]:    Prebuilding openssl for armeabi-v7a
[INFO]:    openssl has no prebuild_armeabi_v7a, skipping
[INFO]:    Prebuilding png for armeabi-v7a
[INFO]:    png has no prebuild_armeabi_v7a, skipping
[INFO]:    Prebuilding sdl2_image for armeabi-v7a
[INFO]:    sdl2_image has no prebuild_armeabi_v7a, skipping
[INFO]:    Applying patches for sdl2_image[armeabi-v7a]
[INFO]:    sdl2_image already patched, skipping
[INFO]:    Prebuilding sdl2_mixer for armeabi-v7a
[INFO]:    sdl2_mixer has no prebuild_armeabi_v7a, skipping
[INFO]:    Applying patches for sdl2_mixer[armeabi-v7a]
[INFO]:    sdl2_mixer already patched, skipping
[INFO]:    Prebuilding sdl2_ttf for armeabi-v7a
[INFO]:    sdl2_ttf has no prebuild_armeabi_v7a, skipping
[INFO]:    Prebuilding sqlite3 for armeabi-v7a
[INFO]:    sqlite3 has no prebuild_armeabi_v7a, skipping
[INFO]:    Prebuilding python3 for armeabi-v7a
[INFO]:    python3 has no prebuild_armeabi_v7a, skipping
[INFO]:    Applying patches for python3[armeabi-v7a]
[INFO]:    python3 already patched, skipping
[INFO]:    Prebuilding sdl2 for armeabi-v7a
[INFO]:    sdl2 has no prebuild_armeabi_v7a, skipping
[INFO]:    Prebuilding numpy for armeabi-v7a
[INFO]:    numpy has no prebuild_armeabi_v7a, skipping
[INFO]:    Applying patches for numpy[armeabi-v7a]
[INFO]:    numpy already patched, skipping
[INFO]:    Prebuilding setuptools for armeabi-v7a
[INFO]:    setuptools has no prebuild_armeabi_v7a, skipping
[INFO]:    Prebuilding kiwisolver for armeabi-v7a
[INFO]:    kiwisolver has no prebuild_armeabi_v7a, skipping
[INFO]:    Prebuilding six for armeabi-v7a
[INFO]:    six has no prebuild_armeabi_v7a, skipping
[INFO]:    Prebuilding matplotlib for armeabi-v7a
[INFO]:    Applying patches for matplotlib[armeabi-v7a]
[INFO]:    Applying patch mpl_android_fixes.patch
[INFO]:    -> running patch -t -d /home/ubuntu/word/.buildozer/android/platform...(and 214 more)
Exception in thread background thread for pid 29887:                                                      
Traceback (most recent call last):
  File "/usr/lib/python3.6/threading.py", line 916, in _bootstrap_inner
    self.run()
  File "/usr/lib/python3.6/threading.py", line 864, in run
    self._target(*self._args, **self._kwargs)
  File "/usr/local/lib/python3.6/dist-packages/sh.py", line 1540, in wrap
    fn(*args, **kwargs)
  File "/usr/local/lib/python3.6/dist-packages/sh.py", line 2459, in background_thread
    handle_exit_code(exit_code)
  File "/usr/local/lib/python3.6/dist-packages/sh.py", line 2157, in fn
    return self.command.handle_command_exit_code(exit_code)
  File "/usr/local/lib/python3.6/dist-packages/sh.py", line 815, in handle_command_exit_code
    raise exc
sh.ErrorReturnCode_1: 

  RAN: /usr/bin/patch -t -d /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/matplotlib-python3/armeabi-v7a__ndk_target_21/matplotlib -p1 -i /home/ubuntu/word/.buildozer/android/platform/python-for-android/pythonforandroid/recipes/matplotlib/mpl_android_fixes.patch

  STDOUT:
patching file setupext.py
Hunk #1 FAILED at 1004.
Hunk #2 FAILED at 1443.
2 out of 2 hunks FAILED -- saving rejects to file setupext.py.rej

  STDERR:

[INFO]:    STDOUT:
    patching file setupext.py   
Hunk #1 FAILED at 1004. 
Hunk #2 FAILED at 1443. 
2 out of 2 hunks FAILED -- saving rejects to file setupext.py.rej
[INFO]:    STDERR:

Traceback (most recent call last):
  File "/usr/lib/python3.6/runpy.py", line 193, in _run_module_as_main
    "__main__", mod_spec)
  File "/usr/lib/python3.6/runpy.py", line 85, in _run_code
    exec(code, run_globals)
  File "/home/ubuntu/word/.buildozer/android/platform/python-for-android/pythonforandroid/toolchain.py", line 1192, in <module>
    main()
  File "/home/ubuntu/word/.buildozer/android/platform/python-for-android/pythonforandroid/entrypoints.py", line 18, in main
    ToolchainCL()
  File "/home/ubuntu/word/.buildozer/android/platform/python-for-android/pythonforandroid/toolchain.py", line 668, in __init__
    getattr(self, args.subparser_name.replace('-', '_'))(args)
  File "/home/ubuntu/word/.buildozer/android/platform/python-for-android/pythonforandroid/toolchain.py", line 153, in wrapper_func
    build_dist_from_args(ctx, dist, args)
  File "/home/ubuntu/word/.buildozer/android/platform/python-for-android/pythonforandroid/toolchain.py", line 206, in build_dist_from_args
    args, "ignore_setup_py", False
  File "/home/ubuntu/word/.buildozer/android/platform/python-for-android/pythonforandroid/build.py", line 570, in build_recipes
    recipe.apply_patches(arch)
  File "/home/ubuntu/word/.buildozer/android/platform/python-for-android/pythonforandroid/recipe.py", line 476, in apply_patches
    arch.arch, build_dir=build_dir)
  File "/home/ubuntu/word/.buildozer/android/platform/python-for-android/pythonforandroid/recipe.py", line 199, in apply_patch
    "-i", filename, _tail=10)
  File "/home/ubuntu/word/.buildozer/android/platform/python-for-android/pythonforandroid/logger.py", line 180, in shprint
    for line in output:
  File "/usr/local/lib/python3.6/dist-packages/sh.py", line 863, in next
    self.wait()
  File "/usr/local/lib/python3.6/dist-packages/sh.py", line 792, in wait
    self.handle_command_exit_code(exit_code)
  File "/usr/local/lib/python3.6/dist-packages/sh.py", line 815, in handle_command_exit_code
    raise exc
sh.ErrorReturnCode_1: 

  RAN: /usr/bin/patch -t -d /home/ubuntu/word/.buildozer/android/platform/build/build/other_builds/matplotlib-python3/armeabi-v7a__ndk_target_21/matplotlib -p1 -i /home/ubuntu/word/.buildozer/android/platform/python-for-android/pythonforandroid/recipes/matplotlib/mpl_android_fixes.patch

  STDOUT:
patching file setupext.py
Hunk #1 FAILED at 1004.
Hunk #2 FAILED at 1443.
2 out of 2 hunks FAILED -- saving rejects to file setupext.py.rej

  STDERR:

# Command failed: /usr/bin/python -m pythonforandroid.toolchain create --dist_name=myapp --bootstrap=sdl2 --requirements=python3,kivy,kivy==1.11.1,pdfminer3k,xlrd,python_docx,beautifulsoup4,matplotlib==2.2.2 --arch armeabi-v7a --copy-libs --color=always --storage-dir="/home/ubuntu/word/.buildozer/android/platform/build" --ndk-api=21
# 
# Buildozer failed to execute the last command
# The error might be hidden in the log above this error
# Please read the full log, and search for it before
# raising an issue with buildozer itself.
# In case of a bug report, please add a full log with log_level = 2
root@VM-0-4-ubuntu:/home/ubuntu/word# 

-->

cocpy commented 5 years ago

This is my mpl_android_fixes.patch

diff --git a/setupext.py b/setupext.py index fc82d5d..2067db0 100644 --- a/setupext.py +++ b/setupext.py @@ -1004,10 +1004,10 @@ class Numpy(SetupPackage): ext.define_macros.append(('__STDC_FORMAT_MACROS', 1))

 def get_setup_requires(self):
cocpy commented 5 years ago

oh ,I change the file /root/word/.buildozer/android/platform/build/build/other_builds/matplotlib-python3/armeabi-v7a__ndk_target_21/matplotlib/setupext.py as the patch expected,it worked!!! I hope the python-for-android developer will pay attention to it as quickly as possible.

cocpy commented 5 years ago

Sorry,The error won't happen when I don't specify version number of matplotlib.

themockingjester commented 4 years ago

@cocpy which lines in setupext.py you have channged?? plz let me know because i am also getting this issue

edwit1971 commented 3 years ago

I agree. It's in English and yet it's not English. It's confusing as anything. I wonder if I just never learned to speak English properly. He said, "Oh I change the file...", and he listed the path for setupext.py and said, "...as the patch expected." Okay could you give us some details PLEASE! Like What exactly did the Patch expect? and What exactly did you change from what to what that suddenly worked? It sure would be helpful if some of these "solutions" were a little more detailed and helpful.