Sfoglia il codice sorgente

Merge pull request #250 from skybber/master

Control ctxClassLoader usage per thread
tags/rel_3_25_0_ga
Shigeru Chiba 5 anni fa
parent
commit
50430c10be
Nessun account collegato all'indirizzo email del committer
1 ha cambiato i file con 16 aggiunte e 1 eliminazioni
  1. 16
    1
      src/main/javassist/runtime/Desc.java

+ 16
- 1
src/main/javassist/runtime/Desc.java Vedi File

@@ -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);
}

Loading…
Annulla
Salva