diff options
-rw-r--r-- | dalvik/src/main/java/dalvik/system/BaseDexClassLoader.java | 17 | ||||
-rw-r--r-- | dalvik/src/main/java/dalvik/system/DexPathList.java | 41 | ||||
-rw-r--r-- | luni/src/main/java/java/lang/Runtime.java | 19 |
3 files changed, 54 insertions, 23 deletions
diff --git a/dalvik/src/main/java/dalvik/system/BaseDexClassLoader.java b/dalvik/src/main/java/dalvik/system/BaseDexClassLoader.java index 6a1a493..4124ffa 100644 --- a/dalvik/src/main/java/dalvik/system/BaseDexClassLoader.java +++ b/dalvik/src/main/java/dalvik/system/BaseDexClassLoader.java @@ -133,6 +133,23 @@ public class BaseDexClassLoader extends ClassLoader { return result.toString(); } + /** + * Returns the list of jar/apk files containing classes and + * resources, delimited by {@code File.pathSeparator}. + * + * @hide + */ + public String getDexPath() { + StringBuilder builder = new StringBuilder(); + for (File file : pathList.getDexFiles()) { + if (builder.length() > 0) { + builder.append(':'); + } + builder.append(file); + } + return builder.toString(); + } + @Override public String toString() { return getClass().getName() + "[" + pathList + "]"; } diff --git a/dalvik/src/main/java/dalvik/system/DexPathList.java b/dalvik/src/main/java/dalvik/system/DexPathList.java index e364e40..b1ff1c8 100644 --- a/dalvik/src/main/java/dalvik/system/DexPathList.java +++ b/dalvik/src/main/java/dalvik/system/DexPathList.java @@ -51,6 +51,9 @@ import static android.system.OsConstants.*; /** class definition context */ private final ClassLoader definingContext; + /** List of dexfiles. */ + private final List<File> dexFiles; + /** * List of dex/resource (class path) elements. * Should be called pathElements, but the Facebook app uses reflection @@ -59,7 +62,7 @@ import static android.system.OsConstants.*; private final Element[] dexElements; /** List of native library directories. */ - private final File[] nativeLibraryDirectories; + private final List<File> nativeLibraryDirectories; /** * Exceptions thrown during creation of the dexElements list. @@ -106,7 +109,9 @@ import static android.system.OsConstants.*; this.definingContext = definingContext; ArrayList<IOException> suppressedExceptions = new ArrayList<IOException>(); - this.dexElements = makeDexElements(splitDexPath(dexPath), optimizedDirectory, + // save dexPath for BaseDexClassLoader + this.dexFiles = splitDexPath(dexPath); + this.dexElements = makeDexElements(dexFiles, optimizedDirectory, suppressedExceptions); if (suppressedExceptions.size() > 0) { this.dexElementsSuppressedExceptions = @@ -118,24 +123,34 @@ import static android.system.OsConstants.*; } @Override public String toString() { + File[] nativeLibraryDirectoriesArray = + nativeLibraryDirectories.toArray(new File[nativeLibraryDirectories.size()]); + return "DexPathList[" + Arrays.toString(dexElements) + - ",nativeLibraryDirectories=" + Arrays.toString(nativeLibraryDirectories) + "]"; + ",nativeLibraryDirectories=" + Arrays.toString(nativeLibraryDirectoriesArray) + "]"; } /** * For BaseDexClassLoader.getLdLibraryPath. */ - public File[] getNativeLibraryDirectories() { + public List<File> getNativeLibraryDirectories() { return nativeLibraryDirectories; } /** + * For BaseDexClassLoader.getDexPath. + */ + public List<File> getDexFiles() { + return dexFiles; + } + + /** * Splits the given dex path string into elements using the path * separator, pruning out any elements that do not refer to existing * and readable files. (That is, directories are not included in the * result.) */ - private static ArrayList<File> splitDexPath(String path) { + private static List<File> splitDexPath(String path) { return splitPaths(path, null, false); } @@ -146,7 +161,7 @@ import static android.system.OsConstants.*; * from the system library path, and pruning out any elements that * do not refer to existing and readable directories. */ - private static File[] splitLibraryPath(String path) { + private static List<File> splitLibraryPath(String path) { // Native libraries may exist in both the system and // application library paths, and we use this search order: // @@ -154,8 +169,7 @@ import static android.system.OsConstants.*; // 2. the VM's library path from the system property for system libraries // // This order was reversed prior to Gingerbread; see http://b/2933456. - ArrayList<File> result = splitPaths(path, System.getProperty("java.library.path"), true); - return result.toArray(new File[result.size()]); + return splitPaths(path, System.getProperty("java.library.path"), true); } /** @@ -167,9 +181,8 @@ import static android.system.OsConstants.*; * are empty or {@code null}, or all elements get pruned out, then * this returns a zero-element list. */ - private static ArrayList<File> splitPaths(String path1, String path2, - boolean wantDirectories) { - ArrayList<File> result = new ArrayList<File>(); + private static List<File> splitPaths(String path1, String path2, boolean wantDirectories) { + List<File> result = new ArrayList<File>(); splitAndAdd(path1, wantDirectories, result); splitAndAdd(path2, wantDirectories, result); @@ -181,7 +194,7 @@ import static android.system.OsConstants.*; * and filtering and adding to a result. */ private static void splitAndAdd(String searchPath, boolean directoriesOnly, - ArrayList<File> resultList) { + List<File> resultList) { if (searchPath == null) { return; } @@ -200,8 +213,8 @@ import static android.system.OsConstants.*; * Makes an array of dex/resource path elements, one per element of * the given array. */ - private static Element[] makeDexElements(ArrayList<File> files, File optimizedDirectory, - ArrayList<IOException> suppressedExceptions) { + private static Element[] makeDexElements(List<File> files, File optimizedDirectory, + List<IOException> suppressedExceptions) { ArrayList<Element> elements = new ArrayList<Element>(); /* * Open all files and load the (direct or contained) dex files diff --git a/luni/src/main/java/java/lang/Runtime.java b/luni/src/main/java/java/lang/Runtime.java index a3cb83e..73820dc 100644 --- a/luni/src/main/java/java/lang/Runtime.java +++ b/luni/src/main/java/java/lang/Runtime.java @@ -357,14 +357,11 @@ public class Runtime { */ void loadLibrary(String libraryName, ClassLoader loader) { if (loader != null) { + // TODO: We shouldn't assume that we know default linker search logic. String filename = loader.findLibrary(libraryName); if (filename == null) { - // It's not necessarily true that the ClassLoader used - // System.mapLibraryName, but the default setup does, and it's - // misleading to say we didn't find "libMyLibrary.so" when we - // actually searched for "liblibMyLibrary.so.so". - throw new UnsatisfiedLinkError(loader + " couldn't find \"" + - System.mapLibraryName(libraryName) + "\""); + // The dynamic linker might still find the library by name. + filename = System.mapLibraryName(libraryName); } String error = doLoad(filename, loader); if (error != null) { @@ -418,19 +415,23 @@ public class Runtime { // So, find out what the native library search path is for the ClassLoader in question... String ldLibraryPath = null; + String dexPath = null; if (loader != null && loader instanceof BaseDexClassLoader) { - ldLibraryPath = ((BaseDexClassLoader) loader).getLdLibraryPath(); + BaseDexClassLoader dexClassLoader = (BaseDexClassLoader) loader; + ldLibraryPath = dexClassLoader.getLdLibraryPath(); + dexPath = dexClassLoader.getDexPath(); } // nativeLoad should be synchronized so there's only one LD_LIBRARY_PATH in use regardless // of how many ClassLoaders are in the system, but dalvik doesn't support synchronized // internal natives. synchronized (this) { - return nativeLoad(name, loader, ldLibraryPath); + return nativeLoad(name, loader, ldLibraryPath, dexPath); } } // TODO: should be synchronized, but dalvik doesn't support synchronized internal natives. - private static native String nativeLoad(String filename, ClassLoader loader, String ldLibraryPath); + private static native String nativeLoad(String filename, ClassLoader loader, + String ldLibraryPath, String dexPath); /** * Provides a hint to the VM that it would be useful to attempt |