public final class org.apache.ibatis.logging.jdbc.ConnectionLogger extends org.apache.ibatis.logging.jdbc.BaseJdbcLogger implements java.lang.reflect.InvocationHandler
{
private final java.sql.Connection connection;
private void <init>(java.sql.Connection, org.apache.ibatis.logging.Log, int)
{
java.sql.Connection v;
org.apache.ibatis.logging.jdbc.ConnectionLogger v;
org.apache.ibatis.logging.Log v;
int v;
v := @this: org.apache.ibatis.logging.jdbc.ConnectionLogger;
v := @parameter: java.sql.Connection;
v := @parameter: org.apache.ibatis.logging.Log;
v := @parameter: int;
specialinvoke v.<org.apache.ibatis.logging.jdbc.BaseJdbcLogger: void <init>(org.apache.ibatis.logging.Log,int)>(v, v);
v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: java.sql.Connection connection> = v;
return;
}
public java.lang.Object invoke(java.lang.Object, java.lang.reflect.Method, java.lang.Object[]) throws java.lang.Throwable
{
java.sql.Connection v, v, v;
org.apache.ibatis.logging.jdbc.ConnectionLogger v;
java.lang.reflect.Method v;
boolean v, v, v, v, v;
java.sql.PreparedStatement v;
java.lang.Throwable v, v;
java.lang.Object[] v;
org.apache.ibatis.logging.Log v, v;
int v, v;
java.lang.String v, v, v, v, v, v, v, v;
java.sql.Statement v;
java.lang.Class v, v;
java.lang.Object v, v, v, v, v, v;
v := @this: org.apache.ibatis.logging.jdbc.ConnectionLogger;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.reflect.Method;
v := @parameter: java.lang.Object[];
label:
v = class "Ljava/lang/Object;";
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Class getDeclaringClass()>();
v = virtualinvoke v.<java.lang.Object: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
return v;
label:
v = "prepareStatement";
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
v = "prepareCall";
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
label:
v = virtualinvoke v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: boolean isDebugEnabled()>();
if v == 0 goto label;
v = v[0];
v = virtualinvoke v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: java.lang.String removeExtraWhitespace(java.lang.String)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(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[])>(" Preparing: \u0001");
virtualinvoke v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: void debug(java.lang.String,boolean)>(v, 1);
label:
v = v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: java.sql.Connection connection>;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: org.apache.ibatis.logging.Log statementLog>;
v = v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: int queryStack>;
v = staticinvoke <org.apache.ibatis.logging.jdbc.PreparedStatementLogger: java.sql.PreparedStatement newInstance(java.sql.PreparedStatement,org.apache.ibatis.logging.Log,int)>(v, v, v);
label:
return v;
label:
v = "createStatement";
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: java.sql.Connection connection>;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: org.apache.ibatis.logging.Log statementLog>;
v = v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: int queryStack>;
v = staticinvoke <org.apache.ibatis.logging.jdbc.StatementLogger: java.sql.Statement newInstance(java.sql.Statement,org.apache.ibatis.logging.Log,int)>(v, v, v);
label:
return v;
label:
v = v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: java.sql.Connection connection>;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
return v;
label:
v := @caughtexception;
v = staticinvoke <org.apache.ibatis.reflection.ExceptionUtil: java.lang.Throwable unwrapThrowable(java.lang.Throwable)>(v);
throw v;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public static java.sql.Connection newInstance(java.sql.Connection, org.apache.ibatis.logging.Log, int)
{
java.sql.Connection v;
org.apache.ibatis.logging.jdbc.ConnectionLogger v;
java.lang.Class[] v;
org.apache.ibatis.logging.Log v;
int v;
java.lang.Class v;
java.lang.Object v;
java.lang.ClassLoader v;
v := @parameter: java.sql.Connection;
v := @parameter: org.apache.ibatis.logging.Log;
v := @parameter: int;
v = new org.apache.ibatis.logging.jdbc.ConnectionLogger;
specialinvoke v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: void <init>(java.sql.Connection,org.apache.ibatis.logging.Log,int)>(v, v, v);
v = class "Ljava/sql/Connection;";
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
v = newarray (java.lang.Class)[1];
v[0] = class "Ljava/sql/Connection;";
v = staticinvoke <java.lang.reflect.Proxy: java.lang.Object newProxyInstance(java.lang.ClassLoader,java.lang.Class[],java.lang.reflect.InvocationHandler)>(v, v, v);
return v;
}
public java.sql.Connection getConnection()
{
java.sql.Connection v;
org.apache.ibatis.logging.jdbc.ConnectionLogger v;
v := @this: org.apache.ibatis.logging.jdbc.ConnectionLogger;
v = v.<org.apache.ibatis.logging.jdbc.ConnectionLogger: java.sql.Connection connection>;
return v;
}
}