diff options
author | chibash <chiba@javassist.org> | 2013-05-26 23:26:16 +0900 |
---|---|---|
committer | chibash <chiba@javassist.org> | 2013-05-26 23:26:16 +0900 |
commit | 3358dc269352383eb5e9c186d24ff4a292eeb637 (patch) | |
tree | 73b5fbdfc5f3c20844baedcb8c55c7f73b9442a8 /src/main/javassist/util/proxy | |
parent | e54a07d44fbe41cb8634fd1f1514c0696e1b6f0a (diff) | |
download | javassist-3358dc269352383eb5e9c186d24ff4a292eeb637.tar.gz javassist-3358dc269352383eb5e9c186d24ff4a292eeb637.zip |
fixed JASSIST-199
Diffstat (limited to 'src/main/javassist/util/proxy')
-rw-r--r-- | src/main/javassist/util/proxy/ProxyFactory.java | 49 |
1 files changed, 36 insertions, 13 deletions
diff --git a/src/main/javassist/util/proxy/ProxyFactory.java b/src/main/javassist/util/proxy/ProxyFactory.java index 88636c01..34d67179 100644 --- a/src/main/javassist/util/proxy/ProxyFactory.java +++ b/src/main/javassist/util/proxy/ProxyFactory.java @@ -700,10 +700,38 @@ public class ProxyFactory { setField(DEFAULT_INTERCEPTOR, handler); } - private static int counter = 0; + /** + * A unique class name generator. + */ + public static interface UniqueName { + /** + * Returns a unique class name. + * + * @param classname the super class name of the proxy class. + */ + String get(String classname); + } + + /** + * A unique class name generator. + * Replacing this generator changes the algorithm to generate a + * unique name. The <code>get</code> method does not have to be + * a <code>synchronized</code> method since the access to this field + * is mutually exclusive and thus thread safe. + */ + public static UniqueName nameGenerator = new UniqueName() { + private final String sep = "_$$_jvst" + Integer.toHexString(this.hashCode() & 0xfff) + "_"; + private int counter = 0; - private static synchronized String makeProxyName(String classname) { - return classname + "_$$_javassist_" + counter++; + public String get(String classname) { + return classname + sep + Integer.toHexString(counter++); + } + }; + + private static String makeProxyName(String classname) { + synchronized (nameGenerator) { + return nameGenerator.get(classname); + } } private ClassFile make() throws CannotCompileException { @@ -758,8 +786,7 @@ public class ProxyFactory { return cf; } - private void checkClassAndSuperName() - { + private void checkClassAndSuperName() { if (interfaces == null) interfaces = new Class[0]; @@ -780,8 +807,7 @@ public class ProxyFactory { basename = "org.javassist.tmp." + basename; } - private void allocateClassName() - { + private void allocateClassName() { classname = makeProxyName(basename); } @@ -796,8 +822,7 @@ public class ProxyFactory { } }; - private void makeSortedMethodList() - { + private void makeSortedMethodList() { checkClassAndSuperName(); hasGetHandler = false; // getMethods() may set this to true. @@ -838,8 +863,7 @@ public class ProxyFactory { this.signature = signature; } - private boolean testBit(byte[] signature, int idx) - { + private boolean testBit(byte[] signature, int idx) { int byteIdx = idx >> 3; if (byteIdx > signature.length) { return false; @@ -851,8 +875,7 @@ public class ProxyFactory { } } - private void setBit(byte[] signature, int idx) - { + private void setBit(byte[] signature, int idx) { int byteIdx = idx >> 3; if (byteIdx < signature.length) { int bitIdx = idx & 0x7; |