public final class org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource extends org.apache.logging.log4j.core.appender.db.jdbc.AbstractConnectionSource
{
private static final org.apache.logging.log4j.Logger LOGGER;
private final javax.sql.DataSource dataSource;
private final java.lang.String description;
private void <init>(javax.sql.DataSource, java.lang.String, java.lang.String, java.lang.String)
{
org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource v;
javax.sql.DataSource v;
java.lang.String v, v, v, v;
v := @this: org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource;
v := @parameter: javax.sql.DataSource;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
specialinvoke v.<org.apache.logging.log4j.core.appender.db.jdbc.AbstractConnectionSource: void <init>()>();
v.<org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource: javax.sql.DataSource dataSource> = v;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,java.lang.String)>(v, v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("factory{ public static \u \u.\u0001() }");
v.<org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource: java.lang.String description> = v;
return;
}
public java.sql.Connection getConnection() throws java.sql.SQLException
{
javax.sql.DataSource v;
org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource v;
java.sql.Connection v;
v := @this: org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource;
v = v.<org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource: javax.sql.DataSource dataSource>;
v = interfaceinvoke v.<javax.sql.DataSource: java.sql.Connection getConnection()>();
return v;
}
public java.lang.String toString()
{
org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource v;
java.lang.String v;
v := @this: org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource;
v = v.<org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource: java.lang.String description>;
return v;
}
public static org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource createConnectionSource(java.lang.String, java.lang.String)
{
java.lang.Object[] v;
org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource v;
org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource$1 v;
java.lang.String v, v, v, v, v, v;
java.lang.reflect.Method v;
boolean v, v;
java.lang.Class[] v;
java.lang.Exception v, v;
org.apache.logging.log4j.Logger v, v, v, v;
java.lang.Class v, v;
java.lang.Object v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = staticinvoke <org.apache.logging.log4j.util.Strings: boolean isEmpty(java.lang.CharSequence)>(v);
if v != 0 goto label;
v = staticinvoke <org.apache.logging.log4j.util.Strings: boolean isEmpty(java.lang.CharSequence)>(v);
if v == 0 goto label;
label:
v = <org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String)>("No class name or method name specified for the connection factory method.");
return null;
label:
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: java.lang.Class loadClass(java.lang.String)>(v);
v = newarray (java.lang.Class)[0];
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String toString()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
return null;
label:
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Class getReturnType()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
if v != class "Ljavax/sql/DataSource;" goto label;
label:
v = newarray (java.lang.Object)[0];
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(null, v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.Object)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u[\u]");
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String toString()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String,java.lang.Throwable)>(v, v);
return null;
label:
if v != class "Ljava/sql/Connection;" goto label;
v = new org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource$1;
specialinvoke v.<org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource$1: void <init>(java.lang.reflect.Method)>(v);
goto label;
label:
v = <org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object,java.lang.Object)>("Method [{}.{}()] returns unsupported type [{}].", v, v, v);
return null;
label:
v = new org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource;
specialinvoke v.<org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource: void <init>(javax.sql.DataSource,java.lang.String,java.lang.String,java.lang.String)>(v, v, v, v);
return v;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
static void <clinit>()
{
org.apache.logging.log4j.status.StatusLogger v;
v = staticinvoke <org.apache.logging.log4j.status.StatusLogger: org.apache.logging.log4j.status.StatusLogger getLogger()>();
<org.apache.logging.log4j.core.appender.db.jdbc.FactoryMethodConnectionSource: org.apache.logging.log4j.Logger LOGGER> = v;
return;
}
}