diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/main/javassist/ClassPool.java | 2 | ||||
-rw-r--r-- | src/main/javassist/compiler/MemberResolver.java | 7 | ||||
-rw-r--r-- | src/test/javassist/JvstTest4.java | 20 |
3 files changed, 26 insertions, 3 deletions
diff --git a/src/main/javassist/ClassPool.java b/src/main/javassist/ClassPool.java index 2c467fb2..4804b593 100644 --- a/src/main/javassist/ClassPool.java +++ b/src/main/javassist/ClassPool.java @@ -936,7 +936,7 @@ public class ClassPool { /** * Detatches the <code>ClassPath</code> object from the search path. * The detached <code>ClassPath</code> object cannot be added - * to the pathagain. + * to the path again. */ public void removeClassPath(ClassPath cp) { source.removeClassPath(cp); diff --git a/src/main/javassist/compiler/MemberResolver.java b/src/main/javassist/compiler/MemberResolver.java index 4ab304fe..f304b034 100644 --- a/src/main/javassist/compiler/MemberResolver.java +++ b/src/main/javassist/compiler/MemberResolver.java @@ -399,7 +399,10 @@ public class MemberResolver implements TokenId { if (found == INVALID) throw new CompileError("no such class: " + name); else if (found != null) - return (CtClass)found; + try { + return classPool.get((String)found); + } + catch (NotFoundException e) {} CtClass cc = null; try { @@ -409,7 +412,7 @@ public class MemberResolver implements TokenId { cc = searchImports(name); } - cache.put(name, cc); + cache.put(name, cc.getName()); return cc; } diff --git a/src/test/javassist/JvstTest4.java b/src/test/javassist/JvstTest4.java index c7582c34..8bcbf01c 100644 --- a/src/test/javassist/JvstTest4.java +++ b/src/test/javassist/JvstTest4.java @@ -875,4 +875,24 @@ public class JvstTest4 extends JvstTestRoot { Object obj = make(cc.getName()); assertEquals(4, invoke(obj, "run")); } + + public void testJIRA188() throws Exception { + CtClass cc = sloader.makeClass("test4.JIRA188"); + CtField f = new CtField(CtClass.intType, "f", cc); + f.setModifiers(Modifier.PRIVATE); + cc.addField(f); + cc.addMethod(CtNewMethod.make( + "public int getf(test4.JIRA188 p){ return p.f; }", cc)); + cc.detach(); + // System.gc(); + try { + cc = sloader.get("test4.JIRA188"); + fail("test4.JIRA188 found"); + } + catch (NotFoundException e) {} + cc = sloader.makeClass("test4.JIRA188"); + cc.addField(new CtField(CtClass.intType, "g", cc)); + cc.addMethod(CtNewMethod.make( + "public int getf(test4.JIRA188 p){ return p.g; }", cc)); + } } |