/*
* Javassist, a Java-bytecode translator toolkit.
* Copyright (C) 1999- Shigeru Chiba. All Rights Reserved.
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. Alternatively, the contents of this file may be used under
* the terms of the GNU Lesser General Public License Version 2.1 or later,
* or the Apache License Version 2.0.
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*/
package javassist.scopedpool;
import java.util.Map;
import javassist.ClassPool;
An interface to ScopedClassPoolRepositoryImpl
.
Author: Kabir Khan Version: $Revision: 1.4 $
/**
* An interface to <code>ScopedClassPoolRepositoryImpl</code>.
*
* @author <a href="kabir.khan@jboss.com">Kabir Khan</a>
* @version $Revision: 1.4 $
*/
public interface ScopedClassPoolRepository {
Records a factory.
/**
* Records a factory.
*/
void setClassPoolFactory(ScopedClassPoolFactory factory);
Obtains the recorded factory.
/**
* Obtains the recorded factory.
*/
ScopedClassPoolFactory getClassPoolFactory();
Returns whether or not the class pool is pruned.
Returns: the prune.
/**
* Returns whether or not the class pool is pruned.
*
* @return the prune.
*/
boolean isPrune();
Sets the prune flag.
Params: - prune – a new value.
/**
* Sets the prune flag.
*
* @param prune a new value.
*/
void setPrune(boolean prune);
Create a scoped classpool.
Params: - cl – the classloader.
- src – the original classpool.
Returns: the classpool.
/**
* Create a scoped classpool.
*
* @param cl the classloader.
* @param src the original classpool.
* @return the classpool.
*/
ScopedClassPool createScopedClassPool(ClassLoader cl, ClassPool src);
Finds a scoped classpool registered under the passed in classloader.
Params: - cl – the classloader.
Returns: the classpool.
/**
* Finds a scoped classpool registered under the passed in classloader.
*
* @param cl the classloader.
* @return the classpool.
*/
ClassPool findClassPool(ClassLoader cl);
Register a classloader.
Params: - ucl – the classloader.
Returns: the classpool.
/**
* Register a classloader.
*
* @param ucl the classloader.
* @return the classpool.
*/
ClassPool registerClassLoader(ClassLoader ucl);
Get the registered classloaders.
Returns: the registered classloaders.
/**
* Get the registered classloaders.
*
* @return the registered classloaders.
*/
Map<ClassLoader,ScopedClassPool> getRegisteredCLs();
This method will check to see if a register classloader has been
undeployed (as in JBoss).
/**
* This method will check to see if a register classloader has been
* undeployed (as in JBoss).
*/
void clearUnregisteredClassLoaders();
Unregisters a classpool and unregisters its classloader.
Params: - cl – the classloader the pool is stored under.
/**
* Unregisters a classpool and unregisters its classloader.
*
* @param cl the classloader the pool is stored under.
*/
void unregisterClassLoader(ClassLoader cl);
}