Skip to content

Commit

Permalink
Merge pull request #250 from skybber/master
Browse files Browse the repository at this point in the history
Control ctxClassLoader usage per thread
  • Loading branch information
chibash committed Mar 17, 2019
2 parents eff2f4b + f1e1268 commit 50430c1
Showing 1 changed file with 16 additions and 1 deletion.
17 changes: 16 additions & 1 deletion src/main/javassist/runtime/Desc.java
Expand Up @@ -34,10 +34,25 @@ public class Desc {
*/
public static boolean useContextClassLoader = false;

private static final ThreadLocal<Boolean> USE_CONTEXT_CLASS_LOADER_LOCALLY = new ThreadLocal<Boolean>() {
@Override
protected Boolean initialValue() {
return false;
}
};

public static void setUseContextClassLoaderLocally() {
USE_CONTEXT_CLASS_LOADER_LOCALLY.set(true);
}

public static void resetUseContextClassLoaderLocally() {
USE_CONTEXT_CLASS_LOADER_LOCALLY.remove();
}

private static Class<?> getClassObject(String name)
throws ClassNotFoundException
{
if (useContextClassLoader)
if (useContextClassLoader || USE_CONTEXT_CLASS_LOADER_LOCALLY.get())
return Class.forName(name, true, Thread.currentThread().getContextClassLoader());
return Class.forName(name);
}
Expand Down

0 comments on commit 50430c1

Please sign in to comment.