summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--dalvik/src/main/java/dalvik/system/BaseDexClassLoader.java17
-rw-r--r--dalvik/src/main/java/dalvik/system/DexPathList.java41
-rw-r--r--luni/src/main/java/java/lang/Runtime.java19
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