public class org.apache.ibatis.datasource.pooled.PooledDataSource extends java.lang.Object implements javax.sql.DataSource
{
private static final org.apache.ibatis.logging.Log log;
private final org.apache.ibatis.datasource.pooled.PoolState state;
private final org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource;
protected int poolMaximumActiveConnections;
protected int poolMaximumIdleConnections;
protected int poolMaximumCheckoutTime;
protected int poolTimeToWait;
protected int poolMaximumLocalBadConnectionTolerance;
protected java.lang.String poolPingQuery;
protected boolean poolPingEnabled;
protected int poolPingConnectionsNotUsedFor;
private int expectedConnectionTypeCode;
private final java.util.concurrent.locks.Lock lock;
private final java.util.concurrent.locks.Condition condition;
public void <init>()
{
java.util.concurrent.locks.Condition v;
java.util.concurrent.locks.Lock v;
java.util.concurrent.locks.ReentrantLock v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
org.apache.ibatis.datasource.pooled.PoolState v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new org.apache.ibatis.datasource.pooled.PoolState;
specialinvoke v.<org.apache.ibatis.datasource.pooled.PoolState: void <init>(org.apache.ibatis.datasource.pooled.PooledDataSource)>(v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state> = v;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumActiveConnections> = 10;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumIdleConnections> = 5;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumCheckoutTime> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolTimeToWait> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumLocalBadConnectionTolerance> = 3;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.lang.String poolPingQuery> = "NO PING QUERY SET";
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.Lock: java.util.concurrent.locks.Condition newCondition()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Condition condition> = v;
v = new org.apache.ibatis.datasource.unpooled.UnpooledDataSource;
specialinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void <init>()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource> = v;
return;
}
public void <init>(org.apache.ibatis.datasource.unpooled.UnpooledDataSource)
{
java.util.concurrent.locks.Condition v;
java.util.concurrent.locks.Lock v;
java.util.concurrent.locks.ReentrantLock v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
org.apache.ibatis.datasource.pooled.PoolState v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: org.apache.ibatis.datasource.unpooled.UnpooledDataSource;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new org.apache.ibatis.datasource.pooled.PoolState;
specialinvoke v.<org.apache.ibatis.datasource.pooled.PoolState: void <init>(org.apache.ibatis.datasource.pooled.PooledDataSource)>(v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state> = v;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumActiveConnections> = 10;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumIdleConnections> = 5;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumCheckoutTime> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolTimeToWait> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumLocalBadConnectionTolerance> = 3;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.lang.String poolPingQuery> = "NO PING QUERY SET";
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.Lock: java.util.concurrent.locks.Condition newCondition()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Condition condition> = v;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource> = v;
return;
}
public void <init>(java.lang.String, java.lang.String, java.lang.String, java.lang.String)
{
org.apache.ibatis.datasource.pooled.PooledDataSource v;
int v;
org.apache.ibatis.datasource.pooled.PoolState v;
java.lang.String v, v, v, v, v, v, v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v, v, v, v;
java.util.concurrent.locks.ReentrantLock v;
java.util.concurrent.locks.Condition v;
java.util.concurrent.locks.Lock v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new org.apache.ibatis.datasource.pooled.PoolState;
specialinvoke v.<org.apache.ibatis.datasource.pooled.PoolState: void <init>(org.apache.ibatis.datasource.pooled.PooledDataSource)>(v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state> = v;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumActiveConnections> = 10;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumIdleConnections> = 5;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumCheckoutTime> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolTimeToWait> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumLocalBadConnectionTolerance> = 3;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.lang.String poolPingQuery> = "NO PING QUERY SET";
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.Lock: java.util.concurrent.locks.Condition newCondition()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Condition condition> = v;
v = new org.apache.ibatis.datasource.unpooled.UnpooledDataSource;
specialinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void <init>(java.lang.String,java.lang.String,java.lang.String,java.lang.String)>(v, v, v, v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUrl()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUsername()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getPassword()>();
v = specialinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int assembleConnectionTypeCode(java.lang.String,java.lang.String,java.lang.String)>(v, v, v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int expectedConnectionTypeCode> = v;
return;
}
public void <init>(java.lang.String, java.lang.String, java.util.Properties)
{
org.apache.ibatis.datasource.pooled.PooledDataSource v;
int v;
org.apache.ibatis.datasource.pooled.PoolState v;
java.lang.String v, v, v, v, v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v, v, v, v;
java.util.Properties v;
java.util.concurrent.locks.ReentrantLock v;
java.util.concurrent.locks.Condition v;
java.util.concurrent.locks.Lock v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.util.Properties;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new org.apache.ibatis.datasource.pooled.PoolState;
specialinvoke v.<org.apache.ibatis.datasource.pooled.PoolState: void <init>(org.apache.ibatis.datasource.pooled.PooledDataSource)>(v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state> = v;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumActiveConnections> = 10;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumIdleConnections> = 5;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumCheckoutTime> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolTimeToWait> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumLocalBadConnectionTolerance> = 3;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.lang.String poolPingQuery> = "NO PING QUERY SET";
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.Lock: java.util.concurrent.locks.Condition newCondition()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Condition condition> = v;
v = new org.apache.ibatis.datasource.unpooled.UnpooledDataSource;
specialinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void <init>(java.lang.String,java.lang.String,java.util.Properties)>(v, v, v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUrl()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUsername()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getPassword()>();
v = specialinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int assembleConnectionTypeCode(java.lang.String,java.lang.String,java.lang.String)>(v, v, v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int expectedConnectionTypeCode> = v;
return;
}
public void <init>(java.lang.ClassLoader, java.lang.String, java.lang.String, java.lang.String, java.lang.String)
{
org.apache.ibatis.datasource.pooled.PooledDataSource v;
int v;
org.apache.ibatis.datasource.pooled.PoolState v;
java.lang.String v, v, v, v, v, v, v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v, v, v, v;
java.util.concurrent.locks.ReentrantLock v;
java.util.concurrent.locks.Condition v;
java.util.concurrent.locks.Lock v;
java.lang.ClassLoader v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.ClassLoader;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new org.apache.ibatis.datasource.pooled.PoolState;
specialinvoke v.<org.apache.ibatis.datasource.pooled.PoolState: void <init>(org.apache.ibatis.datasource.pooled.PooledDataSource)>(v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state> = v;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumActiveConnections> = 10;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumIdleConnections> = 5;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumCheckoutTime> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolTimeToWait> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumLocalBadConnectionTolerance> = 3;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.lang.String poolPingQuery> = "NO PING QUERY SET";
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.Lock: java.util.concurrent.locks.Condition newCondition()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Condition condition> = v;
v = new org.apache.ibatis.datasource.unpooled.UnpooledDataSource;
specialinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void <init>(java.lang.ClassLoader,java.lang.String,java.lang.String,java.lang.String,java.lang.String)>(v, v, v, v, v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUrl()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUsername()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getPassword()>();
v = specialinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int assembleConnectionTypeCode(java.lang.String,java.lang.String,java.lang.String)>(v, v, v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int expectedConnectionTypeCode> = v;
return;
}
public void <init>(java.lang.ClassLoader, java.lang.String, java.lang.String, java.util.Properties)
{
org.apache.ibatis.datasource.pooled.PooledDataSource v;
int v;
org.apache.ibatis.datasource.pooled.PoolState v;
java.lang.String v, v, v, v, v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v, v, v, v;
java.util.Properties v;
java.util.concurrent.locks.ReentrantLock v;
java.util.concurrent.locks.Condition v;
java.util.concurrent.locks.Lock v;
java.lang.ClassLoader v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.ClassLoader;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.util.Properties;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new org.apache.ibatis.datasource.pooled.PoolState;
specialinvoke v.<org.apache.ibatis.datasource.pooled.PoolState: void <init>(org.apache.ibatis.datasource.pooled.PooledDataSource)>(v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state> = v;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumActiveConnections> = 10;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumIdleConnections> = 5;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumCheckoutTime> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolTimeToWait> = 20000;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumLocalBadConnectionTolerance> = 3;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.lang.String poolPingQuery> = "NO PING QUERY SET";
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
v = interfaceinvoke v.<java.util.concurrent.locks.Lock: java.util.concurrent.locks.Condition newCondition()>();
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Condition condition> = v;
v = new org.apache.ibatis.datasource.unpooled.UnpooledDataSource;
specialinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void <init>(java.lang.ClassLoader,java.lang.String,java.lang.String,java.util.Properties)>(v, v, v, v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUrl()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUsername()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getPassword()>();
v = specialinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int assembleConnectionTypeCode(java.lang.String,java.lang.String,java.lang.String)>(v, v, v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int expectedConnectionTypeCode> = v;
return;
}
public java.sql.Connection getConnection() throws java.sql.SQLException
{
java.sql.Connection v;
org.apache.ibatis.datasource.pooled.PooledConnection v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
java.lang.String v, v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v, v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUsername()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getPassword()>();
v = specialinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PooledConnection popConnection(java.lang.String,java.lang.String)>(v, v);
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getProxyConnection()>();
return v;
}
public java.sql.Connection getConnection(java.lang.String, java.lang.String) throws java.sql.SQLException
{
java.sql.Connection v;
org.apache.ibatis.datasource.pooled.PooledConnection v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
java.lang.String v, v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = specialinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PooledConnection popConnection(java.lang.String,java.lang.String)>(v, v);
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getProxyConnection()>();
return v;
}
public void setLoginTimeout(int)
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: int;
staticinvoke <java.sql.DriverManager: void setLoginTimeout(int)>(v);
return;
}
public int getLoginTimeout()
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = staticinvoke <java.sql.DriverManager: int getLoginTimeout()>();
return v;
}
public void setLogWriter(java.io.PrintWriter)
{
java.io.PrintWriter v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.io.PrintWriter;
staticinvoke <java.sql.DriverManager: void setLogWriter(java.io.PrintWriter)>(v);
return;
}
public java.io.PrintWriter getLogWriter()
{
java.io.PrintWriter v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = staticinvoke <java.sql.DriverManager: java.io.PrintWriter getLogWriter()>();
return v;
}
public void setDriver(java.lang.String)
{
java.lang.String v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.String;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void setDriver(java.lang.String)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setUrl(java.lang.String)
{
java.lang.String v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.String;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void setUrl(java.lang.String)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setUsername(java.lang.String)
{
java.lang.String v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.String;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void setUsername(java.lang.String)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setPassword(java.lang.String)
{
java.lang.String v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.String;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void setPassword(java.lang.String)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setDefaultAutoCommit(boolean)
{
org.apache.ibatis.datasource.pooled.PooledDataSource v;
java.lang.Boolean v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
boolean v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: boolean;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void setAutoCommit(java.lang.Boolean)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setDefaultTransactionIsolationLevel(java.lang.Integer)
{
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
java.lang.Integer v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.Integer;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void setDefaultTransactionIsolationLevel(java.lang.Integer)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setDriverProperties(java.util.Properties)
{
java.util.Properties v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.util.Properties;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void setDriverProperties(java.util.Properties)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setDefaultNetworkTimeout(java.lang.Integer)
{
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
java.lang.Integer v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.Integer;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: void setDefaultNetworkTimeout(java.lang.Integer)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setPoolMaximumActiveConnections(int)
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: int;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumActiveConnections> = v;
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setPoolMaximumIdleConnections(int)
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: int;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumIdleConnections> = v;
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setPoolMaximumLocalBadConnectionTolerance(int)
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: int;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumLocalBadConnectionTolerance> = v;
return;
}
public void setPoolMaximumCheckoutTime(int)
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: int;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumCheckoutTime> = v;
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setPoolTimeToWait(int)
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: int;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolTimeToWait> = v;
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setPoolPingQuery(java.lang.String)
{
java.lang.String v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.String;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.lang.String poolPingQuery> = v;
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setPoolPingEnabled(boolean)
{
org.apache.ibatis.datasource.pooled.PooledDataSource v;
boolean v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: boolean;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: boolean poolPingEnabled> = v;
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public void setPoolPingConnectionsNotUsedFor(int)
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: int;
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolPingConnectionsNotUsedFor> = v;
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
return;
}
public java.lang.String getDriver()
{
java.lang.String v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getDriver()>();
return v;
}
public java.lang.String getUrl()
{
java.lang.String v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUrl()>();
return v;
}
public java.lang.String getUsername()
{
java.lang.String v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUsername()>();
return v;
}
public java.lang.String getPassword()
{
java.lang.String v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getPassword()>();
return v;
}
public boolean isAutoCommit()
{
org.apache.ibatis.datasource.pooled.PooledDataSource v;
java.lang.Boolean v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
boolean v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.Boolean isAutoCommit()>();
v = virtualinvoke v.<java.lang.Boolean: boolean booleanValue()>();
return v;
}
public java.lang.Integer getDefaultTransactionIsolationLevel()
{
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
java.lang.Integer v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.Integer getDefaultTransactionIsolationLevel()>();
return v;
}
public java.util.Properties getDriverProperties()
{
java.util.Properties v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.util.Properties getDriverProperties()>();
return v;
}
public java.lang.Integer getDefaultNetworkTimeout()
{
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v;
java.lang.Integer v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.Integer getDefaultNetworkTimeout()>();
return v;
}
public int getPoolMaximumActiveConnections()
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumActiveConnections>;
return v;
}
public int getPoolMaximumIdleConnections()
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumIdleConnections>;
return v;
}
public int getPoolMaximumLocalBadConnectionTolerance()
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumLocalBadConnectionTolerance>;
return v;
}
public int getPoolMaximumCheckoutTime()
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumCheckoutTime>;
return v;
}
public int getPoolTimeToWait()
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolTimeToWait>;
return v;
}
public java.lang.String getPoolPingQuery()
{
java.lang.String v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.lang.String poolPingQuery>;
return v;
}
public boolean isPoolPingEnabled()
{
org.apache.ibatis.datasource.pooled.PooledDataSource v;
boolean v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: boolean poolPingEnabled>;
return v;
}
public int getPoolPingConnectionsNotUsedFor()
{
int v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolPingConnectionsNotUsedFor>;
return v;
}
public void forceCloseAll()
{
java.sql.Connection v, v;
boolean v, v, v;
java.lang.Exception v, v;
java.util.List v, v, v, v;
java.lang.Throwable v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
org.apache.ibatis.logging.Log v, v;
int v, v, v, v, v;
org.apache.ibatis.datasource.pooled.PoolState v, v, v, v;
java.lang.String v, v, v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v, v, v;
java.util.concurrent.locks.Lock v, v, v;
java.lang.Object v, v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUrl()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUsername()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getPassword()>();
v = specialinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int assembleConnectionTypeCode(java.lang.String,java.lang.String,java.lang.String)>(v, v, v);
v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int expectedConnectionTypeCode> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List activeConnections>;
v = interfaceinvoke v.<java.util.List: int size()>();
label:
if v <= 0 goto label;
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List activeConnections>;
v = v - 1;
v = interfaceinvoke v.<java.util.List: java.lang.Object remove(int)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void invalidate()>();
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
v = interfaceinvoke v.<java.sql.Connection: boolean getAutoCommit()>();
if v != 0 goto label;
interfaceinvoke v.<java.sql.Connection: void rollback()>();
label:
interfaceinvoke v.<java.sql.Connection: void close()>();
label:
goto label;
label:
v := @caughtexception;
label:
v = v - 1;
goto label;
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List idleConnections>;
v = interfaceinvoke v.<java.util.List: int size()>();
label:
if v <= 0 goto label;
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List idleConnections>;
v = v - 1;
v = interfaceinvoke v.<java.util.List: java.lang.Object remove(int)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void invalidate()>();
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
v = interfaceinvoke v.<java.sql.Connection: boolean getAutoCommit()>();
if v != 0 goto label;
interfaceinvoke v.<java.sql.Connection: void rollback()>();
label:
interfaceinvoke v.<java.sql.Connection: void close()>();
label:
goto label;
label:
v := @caughtexception;
label:
v = v - 1;
goto label;
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
label:
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>("PooledDataSource forcefully closed/removed all connections.");
label:
return;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public org.apache.ibatis.datasource.pooled.PoolState getPoolState()
{
org.apache.ibatis.datasource.pooled.PoolState v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
return v;
}
private int assembleConnectionTypeCode(java.lang.String, java.lang.String, java.lang.String)
{
org.apache.ibatis.datasource.pooled.PooledDataSource v;
int v;
java.lang.String v, v, v, v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
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[])>("\u0001\u0001\u0001");
v = virtualinvoke v.<java.lang.String: int hashCode()>();
return v;
}
protected void pushConnection(org.apache.ibatis.datasource.pooled.PooledConnection) throws java.sql.SQLException
{
java.sql.Connection v, v, v, v, v, v;
boolean v, v, v, v, v, v;
java.util.List v, v, v;
java.lang.Throwable v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
long v, v, v, v, v, v, v, v, v, v;
org.apache.ibatis.logging.Log v, v, v, v, v, v;
int v, v, v, v, v, v, v;
org.apache.ibatis.datasource.pooled.PoolState v, v, v, v, v, v;
java.lang.String v, v, v;
java.util.concurrent.locks.Condition v;
java.util.concurrent.locks.Lock v, v, v;
org.apache.ibatis.datasource.pooled.PooledConnection v, v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: org.apache.ibatis.datasource.pooled.PooledConnection;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List activeConnections>;
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: boolean isValid()>();
if v == 0 goto label;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List idleConnections>;
v = interfaceinvoke v.<java.util.List: int size()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumIdleConnections>;
if v >= v goto label;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getConnectionTypeCode()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int expectedConnectionTypeCode>;
if v != v goto label;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedCheckoutTime>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: long getCheckoutTime()>();
v = v + v;
v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedCheckoutTime> = v;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
v = interfaceinvoke v.<java.sql.Connection: boolean getAutoCommit()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
interfaceinvoke v.<java.sql.Connection: void rollback()>();
label:
v = new org.apache.ibatis.datasource.pooled.PooledConnection;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
specialinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void <init>(java.sql.Connection,org.apache.ibatis.datasource.pooled.PooledDataSource)>(v, v);
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List idleConnections>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: long getCreatedTimestamp()>();
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void setCreatedTimestamp(long)>(v);
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: long getLastUsedTimestamp()>();
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void setLastUsedTimestamp(long)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void invalidate()>();
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getRealHashCode()>();
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[])>("Returned connection \u to pool.");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Condition condition>;
interfaceinvoke v.<java.util.concurrent.locks.Condition: void signal()>();
goto label;
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedCheckoutTime>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: long getCheckoutTime()>();
v = v + v;
v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedCheckoutTime> = v;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
v = interfaceinvoke v.<java.sql.Connection: boolean getAutoCommit()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
interfaceinvoke v.<java.sql.Connection: void rollback()>();
label:
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
interfaceinvoke v.<java.sql.Connection: void close()>();
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getRealHashCode()>();
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[])>("Closed connection \u.");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
label:
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void invalidate()>();
goto label;
label:
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getRealHashCode()>();
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[])>("A bad connection (\u) attempted to return to the pool, discarding connection.");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: long badConnectionCount>;
v = v + 1L;
v.<org.apache.ibatis.datasource.pooled.PoolState: long badConnectionCount> = v;
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private org.apache.ibatis.datasource.pooled.PooledConnection popConnection(java.lang.String, java.lang.String) throws java.sql.SQLException
{
byte v;
java.lang.Thread v;
java.lang.Throwable v;
long v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.sql.SQLException v, v, v;
org.apache.ibatis.logging.Log v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v;
org.apache.ibatis.datasource.unpooled.UnpooledDataSource v, v;
java.util.concurrent.locks.Lock v, v, v, v;
org.apache.ibatis.datasource.pooled.PooledConnection v, v;
java.sql.Connection v, v, v, v, v, v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.List v, v, v, v, v, v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
int v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.ibatis.datasource.pooled.PoolState v, v, v, v, v, v, v, v, v, v, v, v, v, v;
java.util.concurrent.TimeUnit v;
java.util.concurrent.locks.Condition v;
java.lang.InterruptedException v;
java.lang.Object v, v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = 0;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = 0;
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List idleConnections>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List idleConnections>;
v = interfaceinvoke v.<java.util.List: java.lang.Object remove(int)>(0);
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getRealHashCode()>();
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[])>("Checked out connection \u from pool.");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
goto label;
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List activeConnections>;
v = interfaceinvoke v.<java.util.List: int size()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumActiveConnections>;
if v >= v goto label;
v = new org.apache.ibatis.datasource.pooled.PooledConnection;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.sql.Connection getConnection()>();
specialinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void <init>(java.sql.Connection,org.apache.ibatis.datasource.pooled.PooledDataSource)>(v, v);
v = v;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getRealHashCode()>();
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[])>("Created connection \u.");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
goto label;
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List activeConnections>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: long getCheckoutTime()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumCheckoutTime>;
v = v cmp v;
if v <= 0 goto label;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: long claimedOverdueConnectionCount>;
v = v + 1L;
v.<org.apache.ibatis.datasource.pooled.PoolState: long claimedOverdueConnectionCount> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedCheckoutTimeOfOverdueConnections>;
v = v + v;
v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedCheckoutTimeOfOverdueConnections> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedCheckoutTime>;
v = v + v;
v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedCheckoutTime> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List activeConnections>;
interfaceinvoke v.<java.util.List: boolean remove(java.lang.Object)>(v);
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
v = interfaceinvoke v.<java.sql.Connection: boolean getAutoCommit()>();
if v != 0 goto label;
label:
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
interfaceinvoke v.<java.sql.Connection: void rollback()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>("Bad connection. Could not roll back");
label:
v = new org.apache.ibatis.datasource.pooled.PooledConnection;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
specialinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void <init>(java.sql.Connection,org.apache.ibatis.datasource.pooled.PooledDataSource)>(v, v);
v = v;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: long getCreatedTimestamp()>();
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void setCreatedTimestamp(long)>(v);
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: long getLastUsedTimestamp()>();
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void setLastUsedTimestamp(long)>(v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void invalidate()>();
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getRealHashCode()>();
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[])>("Claimed overdue connection \u.");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
goto label;
label:
if v != 0 goto label;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: long hadToWaitCount>;
v = v + 1L;
v.<org.apache.ibatis.datasource.pooled.PoolState: long hadToWaitCount> = v;
v = 1;
label:
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolTimeToWait>;
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[])>("Waiting as long as \u milliseconds for connection.");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
label:
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Condition condition>;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolTimeToWait>;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = interfaceinvoke v.<java.util.concurrent.locks.Condition: boolean await(long,java.util.concurrent.TimeUnit)>(v, v);
if v != 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>("Wait failed...");
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedWaitTime>;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
v = v + v;
v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedWaitTime> = v;
label:
goto label;
label:
v := @caughtexception;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
if v == null goto label;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: boolean isValid()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
v = interfaceinvoke v.<java.sql.Connection: boolean getAutoCommit()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
interfaceinvoke v.<java.sql.Connection: void rollback()>();
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.unpooled.UnpooledDataSource dataSource>;
v = virtualinvoke v.<org.apache.ibatis.datasource.unpooled.UnpooledDataSource: java.lang.String getUrl()>();
v = specialinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int assembleConnectionTypeCode(java.lang.String,java.lang.String,java.lang.String)>(v, v, v);
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void setConnectionTypeCode(int)>(v);
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void setCheckoutTimestamp(long)>(v);
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: void setLastUsedTimestamp(long)>(v);
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: java.util.List activeConnections>;
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: long requestCount>;
v = v + 1L;
v.<org.apache.ibatis.datasource.pooled.PoolState: long requestCount> = v;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedRequestTime>;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = v - v;
v = v + v;
v.<org.apache.ibatis.datasource.pooled.PoolState: long accumulatedRequestTime> = v;
goto label;
label:
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getRealHashCode()>();
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[])>("A bad connection (\u) was returned from the pool, getting another connection.");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.datasource.pooled.PoolState state>;
v = v.<org.apache.ibatis.datasource.pooled.PoolState: long badConnectionCount>;
v = v + 1L;
v.<org.apache.ibatis.datasource.pooled.PoolState: long badConnectionCount> = v;
v = v + 1;
v = null;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumIdleConnections>;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolMaximumLocalBadConnectionTolerance>;
v = v + v;
if v <= v goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>("PooledDataSource: Could not get a good connection to the database.");
label:
v = new java.sql.SQLException;
specialinvoke v.<java.sql.SQLException: void <init>(java.lang.String)>("PooledDataSource: Could not get a good connection to the database.");
throw v;
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.util.concurrent.locks.Lock lock>;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
label:
if v != null goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>("PooledDataSource: Unknown severe error condition.  The connection pool returned a null connection.");
label:
v = new java.sql.SQLException;
specialinvoke v.<java.sql.SQLException: void <init>(java.lang.String)>("PooledDataSource: Unknown severe error condition.  The connection pool returned a null connection.");
throw v;
label:
return v;
catch java.sql.SQLException from label to label with label;
catch java.lang.InterruptedException 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;
}
protected boolean pingConnection(org.apache.ibatis.datasource.pooled.PooledConnection)
{
java.sql.Connection v, v, v;
byte v;
java.sql.ResultSet v;
boolean v, v, v, v, v, v, v, v, v;
java.lang.Exception v, v;
java.lang.Throwable v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
long v;
java.sql.SQLException v;
org.apache.ibatis.logging.Log v, v, v, v, v, v, v, v, v;
int v, v, v, v, v, v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
org.apache.ibatis.datasource.pooled.PooledConnection v;
java.sql.Statement v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: org.apache.ibatis.datasource.pooled.PooledConnection;
label:
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
v = interfaceinvoke v.<java.sql.Connection: boolean isClosed()>();
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
v = v;
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getRealHashCode()>();
v = virtualinvoke v.<java.sql.SQLException: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int,java.lang.String)>(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[])>("Connection \u is BAD: \u0001");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
label:
v = 0;
label:
if v == 0 goto label;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: boolean poolPingEnabled>;
if v == 0 goto label;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolPingConnectionsNotUsedFor>;
if v < 0 goto label;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: long getTimeElapsedSinceLastUse()>();
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: int poolPingConnectionsNotUsedFor>;
v = v cmp v;
if v <= 0 goto label;
label:
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getRealHashCode()>();
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[])>("Testing connection \u ...");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
label:
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
v = interfaceinvoke v.<java.sql.Connection: java.sql.Statement createStatement()>();
label:
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.lang.String poolPingQuery>;
v = interfaceinvoke v.<java.sql.Statement: java.sql.ResultSet executeQuery(java.lang.String)>(v);
interfaceinvoke v.<java.sql.ResultSet: void close()>();
label:
interfaceinvoke v.<java.sql.Statement: void close()>();
goto label;
label:
v := @caughtexception;
throw v;
label:
v = interfaceinvoke v.<java.sql.Connection: boolean getAutoCommit()>();
if v != 0 goto label;
interfaceinvoke v.<java.sql.Connection: void rollback()>();
label:
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getRealHashCode()>();
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[])>("Connection \u is GOOD!");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = v.<org.apache.ibatis.datasource.pooled.PooledDataSource: java.lang.String poolPingQuery>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(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[])>("Execution of ping query \'\u0001\' failed: \u0001");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void warn(java.lang.String)>(v);
label:
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
interfaceinvoke v.<java.sql.Connection: void close()>();
label:
goto label;
label:
v := @caughtexception;
label:
v = 0;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = <org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log>;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: int getRealHashCode()>();
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int,java.lang.String)>(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[])>("Connection \u is BAD: \u0001");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
label:
return v;
catch java.sql.SQLException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
public static java.sql.Connection unwrapConnection(java.sql.Connection)
{
java.sql.Connection v, v;
java.lang.Class v;
java.lang.reflect.InvocationHandler v;
boolean v, v;
v := @parameter: java.sql.Connection;
v = interfaceinvoke v.<java.sql.Connection: java.lang.Class getClass()>();
v = staticinvoke <java.lang.reflect.Proxy: boolean isProxyClass(java.lang.Class)>(v);
if v == 0 goto label;
v = staticinvoke <java.lang.reflect.Proxy: java.lang.reflect.InvocationHandler getInvocationHandler(java.lang.Object)>(v);
v = v instanceof org.apache.ibatis.datasource.pooled.PooledConnection;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledConnection: java.sql.Connection getRealConnection()>();
return v;
label:
return v;
}
protected void finalize() throws java.lang.Throwable
{
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
virtualinvoke v.<org.apache.ibatis.datasource.pooled.PooledDataSource: void forceCloseAll()>();
specialinvoke v.<java.lang.Object: void finalize()>();
return;
}
public java.lang.Object unwrap(java.lang.Class) throws java.sql.SQLException
{
java.sql.SQLException v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
java.lang.Class v, v;
java.lang.String v, v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.Class;
v = new java.sql.SQLException;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
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[])>("\u is not a wrapper.");
specialinvoke v.<java.sql.SQLException: void <init>(java.lang.String)>(v);
throw v;
}
public boolean isWrapperFor(java.lang.Class)
{
java.lang.Class v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v := @parameter: java.lang.Class;
return 0;
}
public java.util.logging.Logger getParentLogger()
{
java.util.logging.Logger v;
org.apache.ibatis.datasource.pooled.PooledDataSource v;
v := @this: org.apache.ibatis.datasource.pooled.PooledDataSource;
v = staticinvoke <java.util.logging.Logger: java.util.logging.Logger getLogger(java.lang.String)>("global");
return v;
}
static void <clinit>()
{
org.apache.ibatis.logging.Log v;
v = staticinvoke <org.apache.ibatis.logging.LogFactory: org.apache.ibatis.logging.Log getLog(java.lang.Class)>(class "Lorg/apache/ibatis/datasource/pooled/PooledDataSource;");
<org.apache.ibatis.datasource.pooled.PooledDataSource: org.apache.ibatis.logging.Log log> = v;
return;
}
}