public class org.apache.ibatis.jdbc.ScriptRunner extends java.lang.Object
{
private static final java.lang.String LINE_SEPARATOR;
private static final java.lang.String DEFAULT_DELIMITER;
private static final java.util.regex.Pattern DELIMITER_PATTERN;
private final java.sql.Connection connection;
private boolean stopOnError;
private boolean throwWarning;
private boolean autoCommit;
private boolean sendFullScript;
private boolean removeCRs;
private boolean escapeProcessing;
private java.io.PrintWriter logWriter;
private java.io.PrintWriter errorLogWriter;
private java.lang.String delimiter;
private boolean fullLineDelimiter;
public void <init>(java.sql.Connection)
{
java.io.PrintStream v, v;
java.io.PrintWriter v, v;
java.sql.Connection v;
org.apache.ibatis.jdbc.ScriptRunner v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.sql.Connection;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.ibatis.jdbc.ScriptRunner: boolean escapeProcessing> = 1;
v = new java.io.PrintWriter;
v = <java.lang.System: java.io.PrintStream out>;
specialinvoke v.<java.io.PrintWriter: void <init>(java.io.OutputStream)>(v);
v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter logWriter> = v;
v = new java.io.PrintWriter;
v = <java.lang.System: java.io.PrintStream err>;
specialinvoke v.<java.io.PrintWriter: void <init>(java.io.OutputStream)>(v);
v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter errorLogWriter> = v;
v.<org.apache.ibatis.jdbc.ScriptRunner: java.lang.String delimiter> = ";";
v.<org.apache.ibatis.jdbc.ScriptRunner: java.sql.Connection connection> = v;
return;
}
public void setStopOnError(boolean)
{
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: boolean;
v.<org.apache.ibatis.jdbc.ScriptRunner: boolean stopOnError> = v;
return;
}
public void setThrowWarning(boolean)
{
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: boolean;
v.<org.apache.ibatis.jdbc.ScriptRunner: boolean throwWarning> = v;
return;
}
public void setAutoCommit(boolean)
{
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: boolean;
v.<org.apache.ibatis.jdbc.ScriptRunner: boolean autoCommit> = v;
return;
}
public void setSendFullScript(boolean)
{
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: boolean;
v.<org.apache.ibatis.jdbc.ScriptRunner: boolean sendFullScript> = v;
return;
}
public void setRemoveCRs(boolean)
{
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: boolean;
v.<org.apache.ibatis.jdbc.ScriptRunner: boolean removeCRs> = v;
return;
}
public void setEscapeProcessing(boolean)
{
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: boolean;
v.<org.apache.ibatis.jdbc.ScriptRunner: boolean escapeProcessing> = v;
return;
}
public void setLogWriter(java.io.PrintWriter)
{
java.io.PrintWriter v;
org.apache.ibatis.jdbc.ScriptRunner v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.io.PrintWriter;
v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter logWriter> = v;
return;
}
public void setErrorLogWriter(java.io.PrintWriter)
{
java.io.PrintWriter v;
org.apache.ibatis.jdbc.ScriptRunner v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.io.PrintWriter;
v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter errorLogWriter> = v;
return;
}
public void setDelimiter(java.lang.String)
{
java.lang.String v;
org.apache.ibatis.jdbc.ScriptRunner v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.lang.String;
v.<org.apache.ibatis.jdbc.ScriptRunner: java.lang.String delimiter> = v;
return;
}
public void setFullLineDelimiter(boolean)
{
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: boolean;
v.<org.apache.ibatis.jdbc.ScriptRunner: boolean fullLineDelimiter> = v;
return;
}
public void runScript(java.io.Reader)
{
java.lang.Throwable v;
java.io.Reader v;
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.io.Reader;
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void setAutoCommit()>();
label:
v = v.<org.apache.ibatis.jdbc.ScriptRunner: boolean sendFullScript>;
if v == 0 goto label;
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void executeFullScript(java.io.Reader)>(v);
goto label;
label:
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void executeLineByLine(java.io.Reader)>(v);
label:
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void rollbackConnection()>();
goto label;
label:
v := @caughtexception;
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void rollbackConnection()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void executeFullScript(java.io.Reader)
{
org.apache.ibatis.jdbc.RuntimeSqlException v;
java.io.Reader v;
org.apache.ibatis.jdbc.ScriptRunner v;
java.lang.Exception v;
java.lang.StringBuilder v;
java.io.BufferedReader v;
java.lang.String v, v, v, v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.io.Reader;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
label:
v = new java.io.BufferedReader;
specialinvoke v.<java.io.BufferedReader: void <init>(java.io.Reader)>(v);
label:
v = virtualinvoke v.<java.io.BufferedReader: java.lang.String readLine()>();
if v == null goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = <org.apache.ibatis.jdbc.ScriptRunner: java.lang.String LINE_SEPARATOR>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
goto label;
label:
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void println(java.lang.Object)>(v);
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void executeStatement(java.lang.String)>(v);
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void commitConnection()>();
label:
goto label;
label:
v := @caughtexception;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.StringBuilder,java.lang.Exception)>(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[])>("Error executing: \u.  Cause: \u0001");
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void printlnError(java.lang.Object)>(v);
v = new org.apache.ibatis.jdbc.RuntimeSqlException;
specialinvoke v.<org.apache.ibatis.jdbc.RuntimeSqlException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
}
private void executeLineByLine(java.io.Reader)
{
org.apache.ibatis.jdbc.RuntimeSqlException v;
java.io.Reader v;
org.apache.ibatis.jdbc.ScriptRunner v;
java.lang.Exception v;
java.lang.StringBuilder v;
java.io.BufferedReader v;
java.lang.String v, v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.io.Reader;
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
label:
v = new java.io.BufferedReader;
specialinvoke v.<java.io.BufferedReader: void <init>(java.io.Reader)>(v);
label:
v = virtualinvoke v.<java.io.BufferedReader: java.lang.String readLine()>();
if v == null goto label;
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void handleLine(java.lang.StringBuilder,java.lang.String)>(v, v);
goto label;
label:
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void commitConnection()>();
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void checkForMissingLineTerminator(java.lang.StringBuilder)>(v);
label:
goto label;
label:
v := @caughtexception;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.StringBuilder,java.lang.Exception)>(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[])>("Error executing: \u.  Cause: \u0001");
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void printlnError(java.lang.Object)>(v);
v = new org.apache.ibatis.jdbc.RuntimeSqlException;
specialinvoke v.<org.apache.ibatis.jdbc.RuntimeSqlException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
}
public void closeConnection()
{
java.sql.Connection v;
org.apache.ibatis.jdbc.ScriptRunner v;
java.lang.Exception v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
label:
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.sql.Connection connection>;
interfaceinvoke v.<java.sql.Connection: void close()>();
label:
goto label;
label:
v := @caughtexception;
label:
return;
catch java.lang.Exception from label to label with label;
}
private void setAutoCommit()
{
java.lang.Throwable v;
java.sql.Connection v, v;
org.apache.ibatis.jdbc.RuntimeSqlException v;
org.apache.ibatis.jdbc.ScriptRunner v;
java.lang.String v;
boolean v, v, v, v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
label:
v = v.<org.apache.ibatis.jdbc.ScriptRunner: boolean autoCommit>;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.sql.Connection connection>;
v = interfaceinvoke v.<java.sql.Connection: boolean getAutoCommit()>();
if v == v goto label;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.sql.Connection connection>;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: boolean autoCommit>;
interfaceinvoke v.<java.sql.Connection: void setAutoCommit(boolean)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.ibatis.jdbc.RuntimeSqlException;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: boolean autoCommit>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (boolean,java.lang.Throwable)>(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[])>("Could not set AutoCommit to \u. Cause: \u0001");
specialinvoke v.<org.apache.ibatis.jdbc.RuntimeSqlException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void commitConnection()
{
java.lang.Throwable v;
java.sql.Connection v, v;
org.apache.ibatis.jdbc.RuntimeSqlException v;
java.lang.String v;
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
label:
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.sql.Connection connection>;
v = interfaceinvoke v.<java.sql.Connection: boolean getAutoCommit()>();
if v != 0 goto label;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.sql.Connection connection>;
interfaceinvoke v.<java.sql.Connection: void commit()>();
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.ibatis.jdbc.RuntimeSqlException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Throwable)>(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[])>("Could not commit transaction. Cause: \u0001");
specialinvoke v.<org.apache.ibatis.jdbc.RuntimeSqlException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void rollbackConnection()
{
java.lang.Throwable v;
java.sql.Connection v, v;
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
label:
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.sql.Connection connection>;
v = interfaceinvoke v.<java.sql.Connection: boolean getAutoCommit()>();
if v != 0 goto label;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.sql.Connection connection>;
interfaceinvoke v.<java.sql.Connection: void rollback()>();
label:
goto label;
label:
v := @caughtexception;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private void checkForMissingLineTerminator(java.lang.StringBuilder)
{
org.apache.ibatis.jdbc.RuntimeSqlException v;
org.apache.ibatis.jdbc.ScriptRunner v;
int v;
java.lang.StringBuilder v;
java.lang.String v, v, v, v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.lang.StringBuilder;
if v == null goto label;
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
v = new org.apache.ibatis.jdbc.RuntimeSqlException;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.lang.String delimiter>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.StringBuilder)>(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[])>("Line missing end-of-line terminator (\u) => \u0001");
specialinvoke v.<org.apache.ibatis.jdbc.RuntimeSqlException: void <init>(java.lang.String)>(v);
throw v;
label:
return;
}
private void handleLine(java.lang.StringBuilder, java.lang.String) throws java.sql.SQLException
{
org.apache.ibatis.jdbc.ScriptRunner v;
java.util.regex.Matcher v;
int v, v;
java.lang.String v, v, v, v, v, v, v;
boolean v, v, v;
java.lang.StringBuilder v;
java.util.regex.Pattern v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.lang.StringBuilder;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: java.lang.String trim()>();
v = specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: boolean lineIsComment(java.lang.String)>(v);
if v == 0 goto label;
v = <org.apache.ibatis.jdbc.ScriptRunner: java.util.regex.Pattern DELIMITER_PATTERN>;
v = virtualinvoke v.<java.util.regex.Pattern: java.util.regex.Matcher matcher(java.lang.CharSequence)>(v);
v = virtualinvoke v.<java.util.regex.Matcher: boolean find()>();
if v == 0 goto label;
v = virtualinvoke v.<java.util.regex.Matcher: java.lang.String group(int)>(5);
v.<org.apache.ibatis.jdbc.ScriptRunner: java.lang.String delimiter> = v;
label:
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void println(java.lang.Object)>(v);
goto label;
label:
v = specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: boolean commandReadyToExecute(java.lang.String)>(v);
if v == 0 goto label;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.lang.String delimiter>;
v = virtualinvoke v.<java.lang.String: int lastIndexOf(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.CharSequence,int,int)>(v, 0, v);
v = <org.apache.ibatis.jdbc.ScriptRunner: java.lang.String LINE_SEPARATOR>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void println(java.lang.Object)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void executeStatement(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: void setLength(int)>(0);
goto label;
label:
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= 0 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = <org.apache.ibatis.jdbc.ScriptRunner: java.lang.String LINE_SEPARATOR>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
label:
return;
}
private boolean lineIsComment(java.lang.String)
{
java.lang.String v;
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v, v, v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.lang.String;
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("//");
if v != 0 goto label;
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("--");
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private boolean commandReadyToExecute(java.lang.String)
{
org.apache.ibatis.jdbc.ScriptRunner v;
java.lang.String v, v, v;
boolean v, v, v, v, v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.lang.String;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: boolean fullLineDelimiter>;
if v != 0 goto label;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.lang.String delimiter>;
v = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>(v);
if v != 0 goto label;
label:
v = v.<org.apache.ibatis.jdbc.ScriptRunner: boolean fullLineDelimiter>;
if v == 0 goto label;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.lang.String delimiter>;
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private void executeStatement(java.lang.String) throws java.sql.SQLException
{
java.lang.Throwable v;
java.sql.Connection v;
org.apache.ibatis.jdbc.ScriptRunner v;
java.sql.SQLException v;
int v, v;
java.sql.Statement v;
java.lang.String v, v, v;
java.sql.SQLWarning v;
boolean v, v, v, v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.lang.String;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.sql.Connection connection>;
v = interfaceinvoke v.<java.sql.Connection: java.sql.Statement createStatement()>();
label:
v = v.<org.apache.ibatis.jdbc.ScriptRunner: boolean escapeProcessing>;
interfaceinvoke v.<java.sql.Statement: void setEscapeProcessing(boolean)>(v);
v = v;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: boolean removeCRs>;
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: java.lang.String replace(java.lang.CharSequence,java.lang.CharSequence)>("\r\n", "\n");
label:
v = interfaceinvoke v.<java.sql.Statement: boolean execute(java.lang.String)>(v);
label:
if v != 0 goto label;
v = interfaceinvoke v.<java.sql.Statement: int getUpdateCount()>();
v = (int) -1;
if v == v goto label;
label:
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void checkWarnings(java.sql.Statement)>(v);
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void printResults(java.sql.Statement,boolean)>(v, v);
v = interfaceinvoke v.<java.sql.Statement: boolean getMoreResults()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: boolean stopOnError>;
if v == 0 goto label;
throw v;
label:
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.sql.SQLException)>(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[])>("Error executing: \u.  Cause: \u0001");
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void printlnError(java.lang.Object)>(v);
label:
interfaceinvoke v.<java.sql.Statement: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
return;
catch java.sql.SQLWarning from label to label with label;
catch java.sql.SQLException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void checkWarnings(java.sql.Statement) throws java.sql.SQLException
{
java.sql.Statement v;
java.sql.SQLWarning v;
org.apache.ibatis.jdbc.ScriptRunner v;
boolean v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.sql.Statement;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: boolean throwWarning>;
if v != 0 goto label;
return;
label:
v = interfaceinvoke v.<java.sql.Statement: java.sql.SQLWarning getWarnings()>();
if v == null goto label;
throw v;
label:
return;
}
private void printResults(java.sql.Statement, boolean)
{
java.lang.Throwable v;
org.apache.ibatis.jdbc.ScriptRunner v;
java.sql.SQLException v;
java.sql.ResultSet v;
int v, v, v, v, v;
java.lang.String v, v, v, v, v, v;
boolean v, v;
java.sql.Statement v;
java.sql.ResultSetMetaData v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.sql.Statement;
v := @parameter: boolean;
if v != 0 goto label;
return;
label:
v = interfaceinvoke v.<java.sql.Statement: java.sql.ResultSet getResultSet()>();
label:
v = interfaceinvoke v.<java.sql.ResultSet: java.sql.ResultSetMetaData getMetaData()>();
v = interfaceinvoke v.<java.sql.ResultSetMetaData: int getColumnCount()>();
v = 0;
label:
if v >= v goto label;
v = v + 1;
v = interfaceinvoke v.<java.sql.ResultSetMetaData: java.lang.String getColumnLabel(int)>(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[])>("\u0001\t");
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void print(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void println(java.lang.Object)>("");
label:
v = interfaceinvoke v.<java.sql.ResultSet: boolean next()>();
if v == 0 goto label;
v = 0;
label:
if v >= v goto label;
v = v + 1;
v = interfaceinvoke v.<java.sql.ResultSet: java.lang.String getString(int)>(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[])>("\u0001\t");
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void print(java.lang.Object)>(v);
v = v + 1;
goto label;
label:
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void println(java.lang.Object)>("");
goto label;
label:
interfaceinvoke v.<java.sql.ResultSet: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = virtualinvoke v.<java.sql.SQLException: java.lang.String getMessage()>();
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[])>("Error printing results: \u0001");
specialinvoke v.<org.apache.ibatis.jdbc.ScriptRunner: void printlnError(java.lang.Object)>(v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.sql.SQLException from label to label with label;
}
private void print(java.lang.Object)
{
java.io.PrintWriter v, v, v;
java.lang.Object v;
org.apache.ibatis.jdbc.ScriptRunner v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.lang.Object;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter logWriter>;
if v == null goto label;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter logWriter>;
virtualinvoke v.<java.io.PrintWriter: void print(java.lang.Object)>(v);
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter logWriter>;
virtualinvoke v.<java.io.PrintWriter: void flush()>();
label:
return;
}
private void println(java.lang.Object)
{
java.io.PrintWriter v, v, v;
java.lang.Object v;
org.apache.ibatis.jdbc.ScriptRunner v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.lang.Object;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter logWriter>;
if v == null goto label;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter logWriter>;
virtualinvoke v.<java.io.PrintWriter: void println(java.lang.Object)>(v);
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter logWriter>;
virtualinvoke v.<java.io.PrintWriter: void flush()>();
label:
return;
}
private void printlnError(java.lang.Object)
{
java.io.PrintWriter v, v, v;
java.lang.Object v;
org.apache.ibatis.jdbc.ScriptRunner v;
v := @this: org.apache.ibatis.jdbc.ScriptRunner;
v := @parameter: java.lang.Object;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter errorLogWriter>;
if v == null goto label;
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter errorLogWriter>;
virtualinvoke v.<java.io.PrintWriter: void println(java.lang.Object)>(v);
v = v.<org.apache.ibatis.jdbc.ScriptRunner: java.io.PrintWriter errorLogWriter>;
virtualinvoke v.<java.io.PrintWriter: void flush()>();
label:
return;
}
static void <clinit>()
{
java.lang.String v;
java.util.regex.Pattern v;
v = staticinvoke <java.lang.System: java.lang.String lineSeparator()>();
<org.apache.ibatis.jdbc.ScriptRunner: java.lang.String LINE_SEPARATOR> = v;
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String,int)>("^\\s*((--)|(//))?\\s*(//)?\\s*@DELIMITER\\s+([^\\s]+)", 2);
<org.apache.ibatis.jdbc.ScriptRunner: java.util.regex.Pattern DELIMITER_PATTERN> = v;
return;
}
}