Package groovy.lang
Class GroovyClassLoader
java.lang.Object
java.lang.ClassLoader
java.security.SecureClassLoader
java.net.URLClassLoader
groovy.lang.GroovyClassLoader
- All Implemented Interfaces:
- Closeable,- AutoCloseable
- Direct Known Subclasses:
- GroovyClassLoader.InnerLoader
A ClassLoader which can load Groovy classes. The loaded classes are cached,
 classes from other classloaders should not be cached. To be able to load a
 script that was asked for earlier but was created later it is essential not
 to keep anything like a "class not found" information for that class name.
 This includes possible parent loaders. Classes that are not cached are always
 reloaded.
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classstatic class
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final EvictableCache<String,Class> this cache contains the loaded classes or PARSING, if the class is currently parsedprotected final StampedCommonCache<String,Class> This cache contains mappings of file name to class.
- 
Constructor SummaryConstructorsConstructorDescriptioncreates a GroovyClassLoader using the current Thread's context Class loader as parent.GroovyClassLoader(GroovyClassLoader parent) creates a GroovyClassLoader using the given GroovyClassLoader as parent.GroovyClassLoader(ClassLoader loader) creates a GroovyClassLoader using the given ClassLoader as parentGroovyClassLoader(ClassLoader loader, CompilerConfiguration config) creates a GroovyClassLoader using the given ClassLoader as parent.GroovyClassLoader(ClassLoader parent, CompilerConfiguration config, boolean useConfigurationClasspath) creates a GroovyClassLoader.
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddClasspath(String path) adds a classpath to this classloader.voidadds a URL to the classloader.voidRemoves all classes from the class cache.voidclose()Closes this GroovyClassLoader and clears any caches it maintains.protected GroovyClassLoader.ClassCollectorcreateCollector(CompilationUnit unit, SourceUnit su) creates a ClassCollector for a new compilation.protected CompilationUnitcreateCompilationUnit(CompilerConfiguration config, CodeSource source) creates a new CompilationUnit.defineClass(String name, byte[] bytes) Converts an array of bytes into an instance ofClass.defineClass(ClassNode classNode, String file, String newCodeBase) Loads the given class node returning the implementation Class.genEncodingString(CharSequence chars) Generates an encoded string based on the specified characters and the defined encoding algorithm.protected ClassgetClassCacheEntry(String name) gets a class from the class cache.protected String[]gets the currently used classpath.Class[]Returns all Groovy classes loaded by this class loader.protected PermissionCollectiongetPermissions(CodeSource codeSource) protected longgetTimeStamp(Class cls) gets the time stamp of a given class.booleanCheck if this class loader has compatibleCompilerConfigurationwith the provided one.protected booleanisRecompilable(Class cls) Indicates if a class is recompilable.gets the currently set recompilation mode.protected booleanisSourceNewer(URL source, Class cls) Decides if the given source is newer than a class.Class<?>protected ClassImplemented here to check package access prior to returning an already loaded class.loads a class from a file or a parent classloader.loads a class from a file or a parent classloader.parseClass(GroovyCodeSource codeSource) parseClass(GroovyCodeSource codeSource, boolean shouldCacheSource) Parses the given code source into a Java class.parseClass(File file) Parses the given file into a Java class capable of being runparseClass(Reader reader, String fileName) parseClass(String text) Parses the given text into a Java class capable of being runparseClass(String text, String fileName) Parses the given text into a Java class capable of being runprotected Class(Re)Compiles the given source.protected voidremoveClassCacheEntry(String name) removes a class from the class cache.protected voidsetClassCacheEntry(Class cls) sets an entry in the class cache.voidsetResourceLoader(GroovyResourceLoader resourceLoader) voidsetShouldRecompile(Boolean mode) sets if the recompilation should be enabled.Methods inherited from class java.net.URLClassLoaderdefinePackage, findClass, findResource, findResources, getResourceAsStream, getURLs, newInstance, newInstanceMethods inherited from class java.security.SecureClassLoaderdefineClass, defineClassMethods inherited from class java.lang.ClassLoaderclearAssertionStatus, defineClass, defineClass, defineClass, defineClass, definePackage, findClass, findLibrary, findLoadedClass, findResource, findSystemClass, getClassLoadingLock, getDefinedPackage, getDefinedPackages, getName, getPackage, getPackages, getParent, getPlatformClassLoader, getResource, getResources, getSystemClassLoader, getSystemResource, getSystemResourceAsStream, getSystemResources, getUnnamedModule, isRegisteredAsParallelCapable, registerAsParallelCapable, resolveClass, resources, setClassAssertionStatus, setDefaultAssertionStatus, setPackageAssertionStatus, setSigners
- 
Field Details- 
classCachethis cache contains the loaded classes or PARSING, if the class is currently parsed
- 
sourceCacheThis cache contains mappings of file name to class. It is used to bypass compilation.
 
- 
- 
Constructor Details- 
GroovyClassLoaderpublic GroovyClassLoader()creates a GroovyClassLoader using the current Thread's context Class loader as parent.
- 
GroovyClassLoadercreates a GroovyClassLoader using the given ClassLoader as parent
- 
GroovyClassLoadercreates a GroovyClassLoader using the given GroovyClassLoader as parent. This loader will get the parent's CompilerConfiguration
- 
GroovyClassLoaderpublic GroovyClassLoader(ClassLoader parent, CompilerConfiguration config, boolean useConfigurationClasspath) creates a GroovyClassLoader.- Parameters:
- parent- the parent class loader
- config- the compiler configuration
- useConfigurationClasspath- determines if the configurations classpath should be added
 
- 
GroovyClassLoadercreates a GroovyClassLoader using the given ClassLoader as parent.
 
- 
- 
Method Details- 
setResourceLoader
- 
getResourceLoader
- 
defineClassLoads the given class node returning the implementation Class.WARNING: this compilation is not synchronized - Parameters:
- classNode-
- Returns:
- a class
 
- 
hasCompatibleConfigurationCheck if this class loader has compatibleCompilerConfigurationwith the provided one.- Parameters:
- config- the compiler configuration to test for compatibility
- Returns:
- trueif the provided config is exactly the same instance of- CompilerConfigurationas this loader has
 
- 
parseClassParses the given file into a Java class capable of being run- Parameters:
- file- the file name to parse
- Returns:
- the main class defined in the given script
- Throws:
- CompilationFailedException
- IOException
 
- 
parseClassParses the given text into a Java class capable of being run- Parameters:
- text- the text of the script/class to parse
- fileName- the file name to use as the name of the class
- Returns:
- the main class defined in the given script
- Throws:
- CompilationFailedException
 
- 
parseClassParses the given text into a Java class capable of being run- Parameters:
- text- the text of the script/class to parse
- Returns:
- the main class defined in the given script
- Throws:
- CompilationFailedException
 
- 
generateScriptName
- 
parseClass- Throws:
- CompilationFailedException
 
- 
parseClass- Throws:
- CompilationFailedException
 
- 
parseClasspublic Class parseClass(GroovyCodeSource codeSource, boolean shouldCacheSource) throws CompilationFailedException Parses the given code source into a Java class. If there is a class file for the given code source, then no parsing is done, instead the cached class is returned.- Parameters:
- shouldCacheSource- if true then the generated class will be stored in the source cache
- Returns:
- the main class defined in the given script
- Throws:
- CompilationFailedException
 
- 
getClassPathgets the currently used classpath.- Returns:
- a String[] containing the file information of the urls
- See Also:
 
- 
getPermissions- Overrides:
- getPermissionsin class- URLClassLoader
 
- 
createCompilationUnitcreates a new CompilationUnit. If you want to add additional phase operations to the CompilationUnit (for example to inject additional methods, variables, fields), then you should overwrite this method.- Parameters:
- config- the compiler configuration, usually the same as for this class loader
- source- the source containing the initial file to compile, more files may follow during compilation
- Returns:
- the CompilationUnit
 
- 
createCollectorcreates a ClassCollector for a new compilation.- Parameters:
- unit- the compilationUnit
- su- the SourceUnit
- Returns:
- the ClassCollector
 
- 
defineClassConverts an array of bytes into an instance ofClass.- Throws:
- ClassFormatError
 
- 
loadClasspublic Class loadClass(String name, boolean lookupScriptFiles, boolean preferClassOverScript) throws ClassNotFoundException, CompilationFailedException loads a class from a file or a parent classloader. This method does call loadClass(String, boolean, boolean, boolean) with the last parameter set to false.- Throws:
- CompilationFailedException- if compilation was not successful
- ClassNotFoundException
 
- 
getClassCacheEntrygets a class from the class cache. This cache contains only classes loaded through this class loader or an InnerLoader instance. If no class is stored for a specific name, then the method should return null.- Parameters:
- name- of the class
- Returns:
- the class stored for the given name
- See Also:
 
- 
setClassCacheEntrysets an entry in the class cache.- Parameters:
- cls- the class
- See Also:
 
- 
removeClassCacheEntryremoves a class from the class cache.- Parameters:
- name- of the class
- See Also:
 
- 
addURLadds a URL to the classloader.- Overrides:
- addURLin class- URLClassLoader
- Parameters:
- url- the new classpath element
 
- 
isRecompilableIndicates if a class is recompilable. Recompilable means, that the classloader will try to locate a groovy source file for this class and then compile it again, adding the resulting class as entry to the cache. Giving null as class is like a recompilation, so the method should always return true here. Only classes that are implementing GroovyObject are compilable and only if the timestamp in the class is lower than Long.MAX_VALUE.NOTE: First the parent loaders will be asked and only if they don't return a class the recompilation will happen. Recompilation also only happen if the source file is newer. - Parameters:
- cls- the class to be tested. If null the method should return true
- Returns:
- true if the class should be compiled again
- See Also:
 
- 
setShouldRecompilesets if the recompilation should be enabled. There are 3 possible values for this. Any value different from null overrides the value from the compiler configuration. true means to recompile if needed false means to never recompile.- Parameters:
- mode- the recompilation mode
- See Also:
 
- 
isShouldRecompilegets the currently set recompilation mode. null means, the compiler configuration is used. False means no recompilation and true means that recompilation will be done if needed.- Returns:
- the recompilation mode
 
- 
loadClasspublic Class loadClass(String name, boolean lookupScriptFiles, boolean preferClassOverScript, boolean resolve) throws ClassNotFoundException, CompilationFailedException loads a class from a file or a parent classloader.- Parameters:
- name- of the class to be loaded
- lookupScriptFiles- if false no lookup at files is done at all
- preferClassOverScript- if true the file lookup is only done if there is no class
- resolve- see- ClassLoader.loadClass(java.lang.String, boolean)
- Returns:
- the class found or the class created from a file lookup
- Throws:
- ClassNotFoundException- if the class could not be found
- CompilationFailedException- if the source file could not be compiled
 
- 
recompileprotected Class recompile(URL source, String className, Class oldClass) throws CompilationFailedException, IOException (Re)Compiles the given source. This method starts the compilation of a given source, if the source has changed since the class was created. For this isSourceNewer is called.- Parameters:
- source- the source pointer for the compilation
- className- the name of the class to be generated
- oldClass- a possible former class
- Returns:
- the old class if the source wasn't new enough, the new class else
- Throws:
- CompilationFailedException- if the compilation failed
- IOException- if the source is not readable
- See Also:
 
- 
loadClass- Overrides:
- loadClassin class- ClassLoader
- Throws:
- ClassNotFoundException
 
- 
loadClassImplemented here to check package access prior to returning an already loaded class.- Overrides:
- loadClassin class- ClassLoader
- Throws:
- CompilationFailedException- if the compilation failed
- ClassNotFoundException- if the class was not found
- See Also:
 
- 
getTimeStampgets the time stamp of a given class. For groovy generated classes this usually means to return the value of the static field __timeStamp. If the parameter doesn't have such a field, then Long.MAX_VALUE is returned- Parameters:
- cls- the class
- Returns:
- the time stamp
 
- 
isSourceNewerDecides if the given source is newer than a class.- Parameters:
- source- the source we may want to compile
- cls- the former class
- Returns:
- true if the source is newer, false else
- Throws:
- IOException- if it is not possible to open a connection for the given source
- See Also:
 
- 
addClasspathadds a classpath to this classloader.- Parameters:
- path- is a jar file or a directory.
- See Also:
 
- 
getLoadedClassesReturns all Groovy classes loaded by this class loader. - Returns:
- all classes loaded by this class loader
 
- 
clearCachepublic void clearCache()Removes all classes from the class cache.In addition to internal caches this method also clears any previously set MetaClass information for the given set of classes being removed. 
- 
closeCloses this GroovyClassLoader and clears any caches it maintains.No use should be made of this instance after this method is invoked. Any classes that are already loaded are still accessible. - Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- Closeable
- Overrides:
- closein class- URLClassLoader
- Throws:
- IOException
- Since:
- 2.5.0
- See Also:
 
- 
genEncodingStringGenerates an encoded string based on the specified characters and the defined encoding algorithm. Supported algorithms currently are "md5" and sha256". An exception is throw for an unknown algorithm or if the JVM doesn't support the algorithm.- Parameters:
- chars- The characters to encode.
- Returns:
- The encoded string.
 
 
-