1 /* 2 * Copyright (C) 2007 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package dalvik.system; 18 19 import static android.annotation.SystemApi.Client.MODULE_LIBRARIES; 20 21 import android.annotation.SystemApi; 22 23 import libcore.util.NonNull; 24 import libcore.util.Nullable; 25 26 /** 27 * Provides a simple {@link ClassLoader} implementation that operates on a list 28 * of files and directories in the local file system, but does not attempt to 29 * load classes from the network. Android uses this class for its system class 30 * loader and for its application class loader(s). 31 */ 32 public class PathClassLoader extends BaseDexClassLoader { 33 /** 34 * Creates a {@code PathClassLoader} that operates on a given list of files 35 * and directories. This method is equivalent to calling 36 * {@link #PathClassLoader(String, String, ClassLoader)} with a 37 * {@code null} value for the second argument (see description there). 38 * 39 * @param dexPath the list of jar/apk files containing classes and 40 * resources, delimited by {@code File.pathSeparator}, which 41 * defaults to {@code ":"} on Android 42 * @param parent the parent class loader 43 */ PathClassLoader(String dexPath, ClassLoader parent)44 public PathClassLoader(String dexPath, ClassLoader parent) { 45 super(dexPath, null, null, parent); 46 } 47 48 /** 49 * Creates a {@code PathClassLoader} that operates on two given 50 * lists of files and directories. The entries of the first list 51 * should be one of the following: 52 * 53 * <ul> 54 * <li>JAR/ZIP/APK files, possibly containing a "classes.dex" file as 55 * well as arbitrary resources. 56 * <li>Raw ".dex" files (not inside a zip file). 57 * </ul> 58 * 59 * The entries of the second list should be directories containing 60 * native library files. 61 * 62 * @param dexPath the list of jar/apk files containing classes and 63 * resources, delimited by {@code File.pathSeparator}, which 64 * defaults to {@code ":"} on Android 65 * @param librarySearchPath the list of directories containing native 66 * libraries, delimited by {@code File.pathSeparator}; may be 67 * {@code null} 68 * @param parent the parent class loader 69 */ PathClassLoader(String dexPath, String librarySearchPath, ClassLoader parent)70 public PathClassLoader(String dexPath, String librarySearchPath, ClassLoader parent) { 71 super(dexPath, null, librarySearchPath, parent); 72 } 73 74 /** 75 * Creates a {@code PathClassLoader} that operates on two given 76 * lists of files and directories. The entries of the first list 77 * should be one of the following: 78 * 79 * <ul> 80 * <li>JAR/ZIP/APK files, possibly containing a "classes.dex" file as 81 * well as arbitrary resources. 82 * <li>Raw ".dex" files (not inside a zip file). 83 * </ul> 84 * 85 * The entries of the second list should be directories containing 86 * native library files. 87 * 88 * @param dexPath the list of jar/apk files containing classes and 89 * resources, delimited by {@code File.pathSeparator}, which 90 * defaults to {@code ":"} on Android 91 * @param librarySearchPath the list of directories containing native 92 * libraries, delimited by {@code File.pathSeparator}; may be 93 * {@code null} 94 * @param parent the parent class loader 95 * @param sharedLibraryLoaders class loaders of Java shared libraries 96 * used by this new class loader. The shared library loaders are always 97 * checked before the {@code dexPath} when looking 98 * up classes and resources. 99 * 100 * @hide 101 */ 102 @SystemApi(client = MODULE_LIBRARIES) PathClassLoader( @onNull String dexPath, @Nullable String librarySearchPath, @Nullable ClassLoader parent, @Nullable ClassLoader[] sharedLibraryLoaders)103 public PathClassLoader( 104 @NonNull String dexPath, @Nullable String librarySearchPath, @Nullable ClassLoader parent, 105 @Nullable ClassLoader[] sharedLibraryLoaders) { 106 this(dexPath, librarySearchPath, parent, sharedLibraryLoaders, null); 107 } 108 109 /** 110 * Creates a {@code PathClassLoader} that operates on two given 111 * lists of files and directories. The entries of the first list 112 * should be one of the following: 113 * 114 * <ul> 115 * <li>JAR/ZIP/APK files, possibly containing a "classes.dex" file as 116 * well as arbitrary resources. 117 * <li>Raw ".dex" files (not inside a zip file). 118 * </ul> 119 * 120 * The entries of the second list should be directories containing 121 * native library files. 122 * 123 * @param dexPath the list of jar/apk files containing classes and 124 * resources, delimited by {@code File.pathSeparator}, which 125 * defaults to {@code ":"} on Android 126 * @param librarySearchPath the list of directories containing native 127 * libraries, delimited by {@code File.pathSeparator}; may be 128 * {@code null} 129 * @param parent the parent class loader 130 * @param sharedLibraryLoaders class loaders of Java shared libraries 131 * used by this new class loader. The shared library loaders are always 132 * checked before the {@code dexPath} when looking 133 * up classes and resources. 134 * @param sharedLibraryLoadersAfter class loaders of Java shared libraries 135 * used by this new class loader. These shared library loaders are always 136 * checked <b>after</b> the {@code dexPath} when looking 137 * up classes and resources. 138 * 139 * @hide 140 */ 141 @SystemApi(client = MODULE_LIBRARIES) PathClassLoader( @onNull String dexPath, @Nullable String librarySearchPath, @Nullable ClassLoader parent, @Nullable ClassLoader[] sharedLibraryLoaders, @Nullable ClassLoader[] sharedLibraryLoadersAfter)142 public PathClassLoader( 143 @NonNull String dexPath, @Nullable String librarySearchPath, 144 @Nullable ClassLoader parent, @Nullable ClassLoader[] sharedLibraryLoaders, 145 @Nullable ClassLoader[] sharedLibraryLoadersAfter) { 146 super(dexPath, librarySearchPath, parent, sharedLibraryLoaders, sharedLibraryLoadersAfter); 147 } 148 } 149