From 53722eddb6307ce0183505611f45162c6cd45bff Mon Sep 17 00:00:00 2001 From: Andre Miras Date: Sun, 10 May 2020 17:08:26 +0200 Subject: [PATCH] Share PythonUtil.java between bootstraps Note we're using `addLibraryIfExists()` for libraries that are needed by the `sdl2` bootstrap, but may not be compiled on other bootstraps. This way it should fail gracefully while letting us share 100% of the code. --- .../java/org/kivy/android/PythonUtil.java | 7 +- .../java/org/kivy/android/PythonUtil.java | 78 ------------------- 2 files changed, 6 insertions(+), 79 deletions(-) delete mode 100644 pythonforandroid/bootstraps/sdl2/build/src/main/java/org/kivy/android/PythonUtil.java diff --git a/pythonforandroid/bootstraps/common/build/src/main/java/org/kivy/android/PythonUtil.java b/pythonforandroid/bootstraps/common/build/src/main/java/org/kivy/android/PythonUtil.java index 0ac6f63e90..ebb3286024 100644 --- a/pythonforandroid/bootstraps/common/build/src/main/java/org/kivy/android/PythonUtil.java +++ b/pythonforandroid/bootstraps/common/build/src/main/java/org/kivy/android/PythonUtil.java @@ -33,8 +33,13 @@ protected static ArrayList getLibraries(File libsDir) { ArrayList libsList = new ArrayList(); addLibraryIfExists(libsList, "sqlite3", libsDir); addLibraryIfExists(libsList, "ffi", libsDir); + addLibraryIfExists(libsList, "png16", libsDir); addLibraryIfExists(libsList, "ssl.*", libsDir); addLibraryIfExists(libsList, "crypto.*", libsDir); + addLibraryIfExists(libsList, "SDL2", libsDir); + addLibraryIfExists(libsList, "SDL2_image", libsDir); + addLibraryIfExists(libsList, "SDL2_mixer", libsDir); + addLibraryIfExists(libsList, "SDL2_ttf", libsDir); libsList.add("python3.5m"); libsList.add("python3.6m"); libsList.add("python3.7m"); @@ -70,5 +75,5 @@ public static void loadLibraries(File filesDir, File libsDir) { } Log.v(TAG, "Loaded everything!"); - } + } } diff --git a/pythonforandroid/bootstraps/sdl2/build/src/main/java/org/kivy/android/PythonUtil.java b/pythonforandroid/bootstraps/sdl2/build/src/main/java/org/kivy/android/PythonUtil.java deleted file mode 100644 index d380e03582..0000000000 --- a/pythonforandroid/bootstraps/sdl2/build/src/main/java/org/kivy/android/PythonUtil.java +++ /dev/null @@ -1,78 +0,0 @@ -package org.kivy.android; - -import java.io.File; - -import android.util.Log; -import java.util.ArrayList; -import java.util.regex.Pattern; - -public class PythonUtil { - private static final String TAG = "pythonutil"; - - protected static void addLibraryIfExists(ArrayList libsList, String pattern, File libsDir) { - // pattern should be the name of the lib file, without the - // preceding "lib" or suffix ".so", for instance "ssl.*" will - // match files of the form "libssl.*.so". - File [] files = libsDir.listFiles(); - - pattern = "lib" + pattern + "\\.so"; - Pattern p = Pattern.compile(pattern); - for (int i = 0; i < files.length; ++i) { - File file = files[i]; - String name = file.getName(); - Log.v(TAG, "Checking pattern " + pattern + " against " + name); - if (p.matcher(name).matches()) { - Log.v(TAG, "Pattern " + pattern + " matched file " + name); - libsList.add(name.substring(3, name.length() - 3)); - } - } - } - - protected static ArrayList getLibraries(File libsDir) { - ArrayList libsList = new ArrayList(); - addLibraryIfExists(libsList, "sqlite3", libsDir); - addLibraryIfExists(libsList, "ffi", libsDir); - addLibraryIfExists(libsList, "png16", libsDir); - libsList.add("SDL2"); - libsList.add("SDL2_image"); - libsList.add("SDL2_mixer"); - libsList.add("SDL2_ttf"); - addLibraryIfExists(libsList, "ssl.*", libsDir); - addLibraryIfExists(libsList, "crypto.*", libsDir); - libsList.add("python3.5m"); - libsList.add("python3.6m"); - libsList.add("python3.7m"); - libsList.add("python3.8m"); - libsList.add("main"); - return libsList; - } - - public static void loadLibraries(File filesDir, File libsDir) { - boolean foundPython = false; - - for (String lib : getLibraries(libsDir)) { - Log.v(TAG, "Loading library: " + lib); - try { - System.loadLibrary(lib); - if (lib.startsWith("python")) { - foundPython = true; - } - } catch(UnsatisfiedLinkError e) { - // If this is the last possible libpython - // load, and it has failed, give a more - // general error - Log.v(TAG, "Library loading error: " + e.getMessage()); - if (lib.startsWith("python3.8") && !foundPython) { - throw new RuntimeException("Could not load any libpythonXXX.so"); - } else if (lib.startsWith("python")) { - continue; - } else { - Log.v(TAG, "An UnsatisfiedLinkError occurred loading " + lib); - throw e; - } - } - } - - Log.v(TAG, "Loaded everything!"); - } -}