package org.aspectj.weaver.tools;
import org.aspectj.util.LangUtil;
public abstract class TraceFactory {
public final static String DEBUG_PROPERTY = "org.aspectj.tracing.debug";
public final static String FACTORY_PROPERTY = "org.aspectj.tracing.factory";
public final static String DEFAULT_FACTORY_NAME = "default";
protected static boolean debug = getBoolean(DEBUG_PROPERTY,false);
private static TraceFactory instance;
public Trace getTrace (Class clazz) {
return instance.getTrace(clazz);
}
public static TraceFactory getTraceFactory () {
return instance;
}
protected static boolean getBoolean(String name, boolean def) {
String defaultValue = String.valueOf(def);
String value = System.getProperty(name,defaultValue);
return Boolean.valueOf(value).booleanValue();
}
static {
String factoryName = System.getProperty(FACTORY_PROPERTY);
if (factoryName != null) try {
if (factoryName.equals(DEFAULT_FACTORY_NAME)) {
instance = new DefaultTraceFactory();
}
else {
Class factoryClass = Class.forName(factoryName);
instance = (TraceFactory)factoryClass.newInstance();
}
}
catch (Throwable th) {
if (debug) th.printStackTrace();
}
if (instance == null) try {
if (LangUtil.is15VMOrGreater()) {
Class factoryClass = Class.forName("org.aspectj.weaver.tools.Jdk14TraceFactory");
instance = (TraceFactory)factoryClass.newInstance();
} else {
Class factoryClass = Class.forName("org.aspectj.weaver.tools.CommonsTraceFactory");
instance = (TraceFactory)factoryClass.newInstance();
}
}
catch (Throwable th) {
if (debug) th.printStackTrace();
}
if (instance == null) {
instance = new DefaultTraceFactory();
}
if (debug) System.err.println("TraceFactory.instance=" + instance);
}
}