Package org.apache.bcel.util
Class ClassPathRepository
java.lang.Object
org.apache.bcel.util.ClassPathRepository
- All Implemented Interfaces:
Repository
This repository is used in situations where a Class is created outside the realm of a ClassLoader. Classes are loaded
from the file systems using the paths specified in the given class path. By default, this is the value returned by
ClassPath.getClassPath().
- See Also:
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidclear()Clears all entries from cache.Finds an already defined (cached) JavaClass object by name.Gets the ClassPath associated with this RepositoryFinds the JavaClass object for a runtime Class object.Finds a JavaClass object by name.voidremoveClass(JavaClass javaClass) Removes class from repository.voidstoreClass(JavaClass javaClass) Stores a new JavaClass instance into this Repository.
-
Constructor Details
-
ClassPathRepository
-
-
Method Details
-
clear
Clears all entries from cache.- Specified by:
clearin interfaceRepository
-
findClass
Finds an already defined (cached) JavaClass object by name.- Specified by:
findClassin interfaceRepository
-
removeClass
Removes class from repository.- Specified by:
removeClassin interfaceRepository
-
storeClass
Stores a new JavaClass instance into this Repository.- Specified by:
storeClassin interfaceRepository
-
getClassPath
Description copied from interface:RepositoryGets the ClassPath associated with this Repository- Specified by:
getClassPathin interfaceRepository
-
loadClass
Finds the JavaClass object for a runtime Class object. If a class with the same name is already in this Repository, the Repository version is returned. Otherwise, getResourceAsStream() is called on the Class object to find the class's representation. If the representation is found, it is added to the Repository.- Specified by:
loadClassin interfaceRepository- Parameters:
clazz- the runtime Class object- Returns:
- JavaClass object for given runtime class
- Throws:
ClassNotFoundException- if the class is not in the Repository, and its representation could not be found- See Also:
-
loadClass
Finds a JavaClass object by name. If it is already in this Repository, the Repository version is returned. Otherwise, the Repository's classpath is searched for the class (and it is added to the Repository if found).- Specified by:
loadClassin interfaceRepository- Parameters:
className- the name of the class- Returns:
- the JavaClass object
- Throws:
ClassNotFoundException- if the class is not in the Repository, and could not be found on the classpath
-