diff options
-rw-r--r-- | src/main/javassist/bytecode/SignatureAttribute.java | 5 | ||||
-rw-r--r-- | src/main/javassist/scopedpool/ScopedClassPool.java | 46 |
2 files changed, 37 insertions, 14 deletions
diff --git a/src/main/javassist/bytecode/SignatureAttribute.java b/src/main/javassist/bytecode/SignatureAttribute.java index 41748e7c..808809ed 100644 --- a/src/main/javassist/bytecode/SignatureAttribute.java +++ b/src/main/javassist/bytecode/SignatureAttribute.java @@ -610,10 +610,7 @@ public class SignatureAttribute extends AttributeInfo { ObjectType[] ex = (ObjectType[])exceptions.toArray(new ObjectType[exceptions.size()]); return new MethodSignature(tp, p, ret, ex); } -boolean getB() -{ - return false; -} + private static TypeParameter[] parseTypeParams(String sig, Cursor cur) throws BadBytecode { diff --git a/src/main/javassist/scopedpool/ScopedClassPool.java b/src/main/javassist/scopedpool/ScopedClassPool.java index 46fdd38f..455b6737 100644 --- a/src/main/javassist/scopedpool/ScopedClassPool.java +++ b/src/main/javassist/scopedpool/ScopedClassPool.java @@ -31,7 +31,7 @@ import javassist.NotFoundException; * @author <a href="mailto:bill@jboss.org">Bill Burke</a> * @author <a href="adrian@jboss.com">Adrian Brock</a> * @author <a href="kabir.khan@jboss.com">Kabir Khan</a> - * @version $Revision: 1.6 $ + * @version $Revision: 1.7 $ */ public class ScopedClassPool extends ClassPool { protected ScopedClassPoolRepository repository; @@ -41,6 +41,8 @@ public class ScopedClassPool extends ClassPool { protected LoaderClassPath classPath; protected SoftValueHashMap softcache = new SoftValueHashMap(); + + boolean isBootstrapCl = true; static { ClassPool.doPruning = false; @@ -56,17 +58,39 @@ public class ScopedClassPool extends ClassPool { * the original class pool * @param repository * the repository + *@deprecated */ protected ScopedClassPool(ClassLoader cl, ClassPool src, ScopedClassPoolRepository repository) { - super(src); - this.repository = repository; - this.classLoader = new WeakReference(cl); - if (cl != null) { - classPath = new LoaderClassPath(cl); - this.insertClassPath(classPath); - } - childFirstLookup = true; + this(cl, src, repository, false); + } + + /** + * Create a new ScopedClassPool. + * + * @param cl + * the classloader + * @param src + * the original class pool + * @param repository + * the repository + * @param isTemp + * Whether this is a temporary pool used to resolve references + */ + protected ScopedClassPool(ClassLoader cl, ClassPool src, ScopedClassPoolRepository repository, boolean isTemp) + { + super(src); + this.repository = repository; + this.classLoader = new WeakReference(cl); + if (cl != null) { + classPath = new LoaderClassPath(cl); + this.insertClassPath(classPath); + } + childFirstLookup = true; + if (!isTemp && cl == null) + { + isBootstrapCl = true; + } } /** @@ -76,9 +100,11 @@ public class ScopedClassPool extends ClassPool { */ public ClassLoader getClassLoader() { ClassLoader cl = getClassLoader0(); - if (cl == null) + if (cl == null && !isBootstrapCl) + { throw new IllegalStateException( "ClassLoader has been garbage collected"); + } return cl; } |