diff options
author | Calin Juravle <calin@google.com> | 2014-08-06 20:04:34 +0100 |
---|---|---|
committer | Calin Juravle <calin@google.com> | 2014-08-06 20:04:34 +0100 |
commit | e05ad6f7a1e2e34db62587269a066d479dc8e0ad (patch) | |
tree | e2c7b2646974ba814827e4ebdbf4f48f787fe220 | |
parent | 97aed98beeb2c3831a9fc110aaca8b36fbbb7aee (diff) | |
download | libcore-e05ad6f7a1e2e34db62587269a066d479dc8e0ad.zip libcore-e05ad6f7a1e2e34db62587269a066d479dc8e0ad.tar.gz libcore-e05ad6f7a1e2e34db62587269a066d479dc8e0ad.tar.bz2 |
Use absolute path when opening dex files.
The device always sees absolute paths so this will be no-op but on host
this enables testing with relative paths (which is much more
convenient).
Bug: 16644204
Change-Id: Ife8d231a8127ff97f8fd97c745c64b435cdddf02
-rw-r--r-- | dalvik/src/main/java/dalvik/system/DexFile.java | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/dalvik/src/main/java/dalvik/system/DexFile.java b/dalvik/src/main/java/dalvik/system/DexFile.java index 3965b81..7aeba87 100644 --- a/dalvik/src/main/java/dalvik/system/DexFile.java +++ b/dalvik/src/main/java/dalvik/system/DexFile.java @@ -281,6 +281,18 @@ public final class DexFile { } } + + /* + * Open a DEX file. The value returned is a magic VM cookie. On + * failure, an IOException is thrown. + */ + private static long openDexFile(String sourceName, String outputName, int flags) throws IOException { + // Use absolute paths to enable the use of relative paths when testing on host. + return openDexFileNative(new File(sourceName).getAbsolutePath(), + (outputName == null) ? null : new File(outputName).getAbsolutePath(), + flags); + } + private static native void closeDexFile(long cookie); private static native Class defineClassNative(String name, ClassLoader loader, long cookie) throws ClassNotFoundException, NoClassDefFoundError; @@ -289,7 +301,7 @@ public final class DexFile { * Open a DEX file. The value returned is a magic VM cookie. On * failure, an IOException is thrown. */ - private static native long openDexFile(String sourceName, String outputName, int flags); + private static native long openDexFileNative(String sourceName, String outputName, int flags); /** * Returns true if the VM believes that the apk/jar file is out of date |