public final class org.apache.ibatis.logging.jdbc.ResultSetLogger extends org.apache.ibatis.logging.jdbc.BaseJdbcLogger implements java.lang.reflect.InvocationHandler
{
private static final java.util.Set BLOB_TYPES;
private boolean first;
private int rows;
private final java.sql.ResultSet rs;
private final java.util.Set blobColumns;
private void <init>(java.sql.ResultSet, org.apache.ibatis.logging.Log, int)
{
java.util.HashSet v;
java.sql.ResultSet v;
org.apache.ibatis.logging.jdbc.ResultSetLogger v;
org.apache.ibatis.logging.Log v;
int v;
v := @this: org.apache.ibatis.logging.jdbc.ResultSetLogger;
v := @parameter: java.sql.ResultSet;
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.ResultSetLogger: boolean first> = 1;
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set blobColumns> = v;
v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: java.sql.ResultSet rs> = v;
return;
}
public java.lang.Object invoke(java.lang.Object, java.lang.reflect.Method, java.lang.Object[]) throws java.lang.Throwable
{
java.lang.Throwable v, v;
java.lang.Object[] v;
java.sql.ResultSet v, v;
int v, v, v, v;
java.lang.String v, v, v;
java.lang.reflect.Method v;
boolean v, v, v, v, v;
org.apache.ibatis.logging.jdbc.ResultSetLogger v;
java.lang.Class v, v;
java.lang.Object v, v, v;
java.sql.ResultSetMetaData v;
v := @this: org.apache.ibatis.logging.jdbc.ResultSetLogger;
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 = v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: java.sql.ResultSet rs>;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
v = "next";
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 = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
if v == 0 goto label;
v = v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: int rows>;
v = v + 1;
v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: int rows> = v;
v = virtualinvoke v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: java.sql.ResultSet rs>;
v = interfaceinvoke v.<java.sql.ResultSet: java.sql.ResultSetMetaData getMetaData()>();
v = interfaceinvoke v.<java.sql.ResultSetMetaData: int getColumnCount()>();
v = v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: boolean first>;
if v == 0 goto label;
v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: boolean first> = 0;
specialinvoke v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: void printColumnHeaders(java.sql.ResultSetMetaData,int)>(v, v);
label:
specialinvoke v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: void printColumnValues(int)>(v);
goto label;
label:
v = v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: int rows>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("     Total: \u0001");
virtualinvoke v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: void debug(java.lang.String,boolean)>(v, 0);
label:
virtualinvoke v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: void clearColumnInfo()>();
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;
}
private void printColumnHeaders(java.sql.ResultSetMetaData, int) throws java.sql.SQLException
{
org.apache.ibatis.logging.jdbc.ResultSetLogger v;
java.util.Set v, v;
java.lang.Integer v, v;
java.util.StringJoiner v;
int v, v, v;
java.lang.String v, v;
java.sql.ResultSetMetaData v;
boolean v;
v := @this: org.apache.ibatis.logging.jdbc.ResultSetLogger;
v := @parameter: java.sql.ResultSetMetaData;
v := @parameter: int;
v = new java.util.StringJoiner;
specialinvoke v.<java.util.StringJoiner: void <init>(java.lang.CharSequence,java.lang.CharSequence,java.lang.CharSequence)>(", ", "   Columns: ", "");
v = 1;
label:
if v > v goto label;
v = <org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set BLOB_TYPES>;
v = interfaceinvoke v.<java.sql.ResultSetMetaData: int getColumnType(int)>(v);
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set blobColumns>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
v = interfaceinvoke v.<java.sql.ResultSetMetaData: java.lang.String getColumnLabel(int)>(v);
virtualinvoke v.<java.util.StringJoiner: java.util.StringJoiner add(java.lang.CharSequence)>(v);
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.util.StringJoiner: java.lang.String toString()>();
virtualinvoke v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: void trace(java.lang.String,boolean)>(v, 0);
return;
}
private void printColumnValues(int)
{
org.apache.ibatis.logging.jdbc.ResultSetLogger v;
java.util.Set v;
java.lang.Integer v;
java.sql.SQLException v;
java.sql.ResultSet v;
java.util.StringJoiner v;
int v, v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.ibatis.logging.jdbc.ResultSetLogger;
v := @parameter: int;
v = new java.util.StringJoiner;
specialinvoke v.<java.util.StringJoiner: void <init>(java.lang.CharSequence,java.lang.CharSequence,java.lang.CharSequence)>(", ", "       Row: ", "");
v = 1;
label:
if v > v goto label;
label:
v = v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set blobColumns>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
virtualinvoke v.<java.util.StringJoiner: java.util.StringJoiner add(java.lang.CharSequence)>("<<BLOB>>");
goto label;
label:
v = v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: java.sql.ResultSet rs>;
v = interfaceinvoke v.<java.sql.ResultSet: java.lang.String getString(int)>(v);
virtualinvoke v.<java.util.StringJoiner: java.util.StringJoiner add(java.lang.CharSequence)>(v);
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<java.util.StringJoiner: java.util.StringJoiner add(java.lang.CharSequence)>("<<Cannot Display>>");
label:
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.util.StringJoiner: java.lang.String toString()>();
virtualinvoke v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: void trace(java.lang.String,boolean)>(v, 0);
return;
catch java.sql.SQLException from label to label with label;
}
public static java.sql.ResultSet newInstance(java.sql.ResultSet, org.apache.ibatis.logging.Log, int)
{
org.apache.ibatis.logging.jdbc.ResultSetLogger v;
java.lang.Class[] v;
java.sql.ResultSet 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.ResultSet;
v := @parameter: org.apache.ibatis.logging.Log;
v := @parameter: int;
v = new org.apache.ibatis.logging.jdbc.ResultSetLogger;
specialinvoke v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: void <init>(java.sql.ResultSet,org.apache.ibatis.logging.Log,int)>(v, v, v);
v = class "Ljava/sql/ResultSet;";
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
v = newarray (java.lang.Class)[1];
v[0] = class "Ljava/sql/ResultSet;";
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.ResultSet getRs()
{
java.sql.ResultSet v;
org.apache.ibatis.logging.jdbc.ResultSetLogger v;
v := @this: org.apache.ibatis.logging.jdbc.ResultSetLogger;
v = v.<org.apache.ibatis.logging.jdbc.ResultSetLogger: java.sql.ResultSet rs>;
return v;
}
static void <clinit>()
{
java.lang.Integer v, v, v, v, v, v, v, v;
java.util.HashSet v;
int v, v, v, v, v;
java.util.Set v, v, v, v, v, v, v, v;
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
<org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set BLOB_TYPES> = v;
v = <org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set BLOB_TYPES>;
v = (int) -2;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set BLOB_TYPES>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(2004);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set BLOB_TYPES>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(2005);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set BLOB_TYPES>;
v = (int) -16;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set BLOB_TYPES>;
v = (int) -4;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set BLOB_TYPES>;
v = (int) -1;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set BLOB_TYPES>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(2011);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
v = <org.apache.ibatis.logging.jdbc.ResultSetLogger: java.util.Set BLOB_TYPES>;
v = (int) -3;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
return;
}
}