From: chiba Date: Wed, 8 Mar 2006 07:19:35 +0000 (+0000) Subject: fixed a minor problem of CtClassType X-Git-Tag: rel_3_17_1_ga~371 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=003dce367a611ae6ddc516519e56f39281b3c953;p=javassist.git fixed a minor problem of CtClassType git-svn-id: http://anonsvn.jboss.org/repos/javassist/trunk@257 30ef5769-5b8d-40dd-aea6-55b5d6557bb3 --- diff --git a/src/main/javassist/CtClass.java b/src/main/javassist/CtClass.java index aee49094..fe6597a1 100644 --- a/src/main/javassist/CtClass.java +++ b/src/main/javassist/CtClass.java @@ -1137,7 +1137,7 @@ public abstract class CtClass { * @param directoryName it must end without a directory separator. */ public void writeFile(String directoryName) - throws NotFoundException, CannotCompileException, IOException + throws CannotCompileException, IOException { String classname = getName(); String filename = directoryName + File.separatorChar diff --git a/src/main/javassist/CtClassType.java b/src/main/javassist/CtClassType.java index 770d5724..86dbf3b2 100644 --- a/src/main/javassist/CtClassType.java +++ b/src/main/javassist/CtClassType.java @@ -437,12 +437,11 @@ class CtClassType extends CtClass { } Object[] result = new Object[size1 + size2]; - ClassLoader cl = ClassPool.getContextClassLoader(); for (int i = 0; i < size1; i++) - result[i] = anno1[i].toAnnotationType(cl, cp); + result[i] = toAnnoType(anno1[i], cp); for (int j = 0; j < size2; j++) - result[j + size1] = anno2[j].toAnnotationType(cl, cp); + result[j + size1] = toAnnoType(anno2[j], cp); return result; } @@ -460,7 +459,6 @@ class CtClassType extends CtClass { return new Object[0][]; Object[][] result = new Object[numParameters][]; - ClassLoader cl = ClassPool.getContextClassLoader(); for (int i = 0; i < numParameters; i++) { Annotation[] anno1, anno2; int size1, size2; @@ -485,15 +483,28 @@ class CtClassType extends CtClass { result[i] = new Object[size1 + size2]; for (int j = 0; j < size1; ++j) - result[i][j] = anno1[j].toAnnotationType(cl, cp); + result[i][j] = toAnnoType(anno1[j], cp); for (int j = 0; j < size2; ++j) - result[i][j + size1] = anno2[j].toAnnotationType(cl, cp); + result[i][j + size1] = toAnnoType(anno2[j], cp); } return result; } + private static Object toAnnoType(Annotation anno, ClassPool cp) + throws ClassNotFoundException + { + try { + ClassLoader cl = ClassPool.getContextClassLoader(); + return anno.toAnnotationType(cl, cp); + } + catch (ClassNotFoundException e) { + ClassLoader cl2 = cp.getClass().getClassLoader(); + return anno.toAnnotationType(cl2, cp); + } + } + public boolean subclassOf(CtClass superclass) { if (superclass == null) return false;