From 780ac8182fedbcfc1fb540e1480321abe3401ff5 Mon Sep 17 00:00:00 2001 From: "Felix C. Stegerman" Date: Fri, 1 Jan 2021 23:22:04 +0100 Subject: [PATCH] fix ndk version check & download link --- buildozer/targets/android.py | 31 +++++++++++++------------------ 1 file changed, 13 insertions(+), 18 deletions(-) diff --git a/buildozer/targets/android.py b/buildozer/targets/android.py index d8337e4e2..e92075742 100644 --- a/buildozer/targets/android.py +++ b/buildozer/targets/android.py @@ -412,7 +412,7 @@ def _install_android_ndk(self): return ndk_dir import re - _version = re.search('(.+?)[a-z]', self.android_ndk_version).group(1) + _version = int(re.search('(\d+)', self.android_ndk_version).group(1)) self.buildozer.info('Android NDK is missing, downloading') # Welcome to the NDK URL hell! @@ -422,28 +422,23 @@ def _install_android_ndk(self): # from 10e on the URLs can be looked up at # https://developer.android.com/ndk/downloads/older_releases + is_darwin = platform in ('darwin', ) + is_linux = platform.startswith('linux') + if platform in ('win32', 'cygwin'): # Checking of 32/64 bits at Windows from: http://stackoverflow.com/a/1405971/798575 import struct archive = 'android-ndk-r{0}-windows-{1}.zip' is_64 = (8 * struct.calcsize("P") == 64) - - elif platform in ('darwin', ): - if _version >= '10e': - archive = 'android-ndk-r{0}-darwin-{1}.zip' - elif _version >= '10c': - archive = 'android-ndk-r{0}-darwin-{1}.bin' - else: - archive = 'android-ndk-r{0}-darwin-{1}.tar.bz2' - is_64 = (os.uname()[4] == 'x86_64') - - elif platform.startswith('linux'): - if _version >= '10e': - archive = 'android-ndk-r{0}-linux-{1}.zip' - elif _version >= '10c': - archive = 'android-ndk-r{0}-linux-{1}.bin' + elif is_darwin or is_linux: + _platform = 'linux' if is_linux else 'darwin' + if self.android_ndk_version in ['10c', '10d', '10e']: + ext = 'bin' + elif _version <= 10: + ext = 'tar.bz2' else: - archive = 'android-ndk-r{0}-linux-{1}.tar.bz2' + ext = 'zip' + archive = 'android-ndk-r{0}-' + _platform + '-{1}.' + ext is_64 = (os.uname()[4] == 'x86_64') else: raise SystemError('Unsupported platform: {}'.format(platform)) @@ -453,7 +448,7 @@ def _install_android_ndk(self): archive = archive.format(self.android_ndk_version, architecture) unpacked = unpacked.format(self.android_ndk_version) - if _version >= '10e': + if _version >= 11: url = 'https://dl.google.com/android/repository/' else: url = 'http://dl.google.com/android/ndk/'