/*
* 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 scouter.javassist.scopedpool;
import java.util.Map;
import scouter.javassist.ClassPool;
import scouter.javassist.scopedpool.ScopedClassPool;
import scouter.javassist.scopedpool.ScopedClassPoolFactory;
/**
* 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.
*/
void setClassPoolFactory(ScopedClassPoolFactory factory);
/**
* Obtains the recorded factory.
*/
ScopedClassPoolFactory getClassPoolFactory();
/**
* Returns whether or not the class pool is pruned.
*
* @return the prune.
*/
boolean isPrune();
/**
* Sets the prune flag.
*
* @param prune a new value.
*/
void setPrune(boolean prune);
/**
* 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.
*
* @param cl the classloader.
* @return the classpool.
*/
ClassPool findClassPool(ClassLoader cl);
/**
* Register a classloader.
*
* @param ucl the classloader.
* @return the classpool.
*/
ClassPool registerClassLoader(ClassLoader ucl);
/**
* Get the registered classloaders.
*
* @return the registered classloaders.
*/
Map getRegisteredCLs();
/**
* 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.
*
* @param cl the classloader the pool is stored under.
*/
void unregisterClassLoader(ClassLoader cl);
}