summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchiba <chiba@30ef5769-5b8d-40dd-aea6-55b5d6557bb3>2006-03-08 07:19:35 +0000
committerchiba <chiba@30ef5769-5b8d-40dd-aea6-55b5d6557bb3>2006-03-08 07:19:35 +0000
commit003dce367a611ae6ddc516519e56f39281b3c953 (patch)
tree64232939bb6b320355da5ec634a856dc670d8285
parent51c2a8c834d40b1ec2fd0ae71deb3fdfaaba7562 (diff)
downloadjavassist-003dce367a611ae6ddc516519e56f39281b3c953.tar.gz
javassist-003dce367a611ae6ddc516519e56f39281b3c953.zip
fixed a minor problem of CtClassType
git-svn-id: http://anonsvn.jboss.org/repos/javassist/trunk@257 30ef5769-5b8d-40dd-aea6-55b5d6557bb3
-rw-r--r--src/main/javassist/CtClass.java2
-rw-r--r--src/main/javassist/CtClassType.java23
2 files changed, 18 insertions, 7 deletions
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;