public class org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics extends java.lang.Object
{
private final java.util.concurrent.atomic.AtomicInteger builtConnections;
private final java.util.concurrent.atomic.AtomicInteger requestedConnections;
private final java.util.concurrent.atomic.AtomicInteger connectionErrors;
private final java.util.concurrent.atomic.AtomicLong firstConnectionRequest;
private java.util.concurrent.atomic.AtomicLong lastConnectionRequest;
public void <init>()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
long v, v;
java.util.concurrent.atomic.AtomicLong v, v;
java.util.concurrent.atomic.AtomicInteger v, v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.atomic.AtomicLong;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>(long)>(v);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicLong firstConnectionRequest> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(0);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger builtConnections> = v;
v = new java.util.concurrent.atomic.AtomicLong;
v = specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: long getCurrentTimeInInMillis()>();
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>(long)>(v);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicLong lastConnectionRequest> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(0);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger requestedConnections> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(0);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger connectionErrors> = v;
return;
}
private void <init>(int, long, long, int, int)
{
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
long v, v;
java.util.concurrent.atomic.AtomicLong v, v;
java.util.concurrent.atomic.AtomicInteger v, v, v;
int v, v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v := @parameter: int;
v := @parameter: long;
v := @parameter: long;
v := @parameter: int;
v := @parameter: int;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(v);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger builtConnections> = v;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>(long)>(v);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicLong firstConnectionRequest> = v;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>(long)>(v);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicLong lastConnectionRequest> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(v);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger requestedConnections> = v;
v = new java.util.concurrent.atomic.AtomicInteger;
specialinvoke v.<java.util.concurrent.atomic.AtomicInteger: void <init>(int)>(v);
v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger connectionErrors> = v;
return;
}
public static org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics clone(org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics)
{
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v, v;
long v, v;
java.util.concurrent.atomic.AtomicLong v, v;
java.util.concurrent.atomic.AtomicInteger v, v, v;
int v, v, v;
v := @parameter: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = new org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger builtConnections>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicLong firstConnectionRequest>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicLong lastConnectionRequest>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger requestedConnections>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger connectionErrors>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: void <init>(int,long,long,int,int)>(v, v, v, v, v);
return v;
}
public int getRequestedConnections()
{
int v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
java.util.concurrent.atomic.AtomicInteger v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger requestedConnections>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
return v;
}
public int requestConnection()
{
java.util.concurrent.atomic.AtomicLong v;
java.util.concurrent.atomic.AtomicInteger v;
int v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
long v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicLong lastConnectionRequest>;
v = specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: long getCurrentTimeInInMillis()>();
virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: void set(long)>(v);
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger requestedConnections>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
return v;
}
private long getCurrentTimeInInMillis()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager v;
java.time.Clock v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
long v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = staticinvoke <org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager getInstance()>();
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.state.ConnectionStateManager: java.time.Clock getClock()>();
v = virtualinvoke v.<java.time.Clock: long millis()>();
return v;
}
public long getFirstConnectionRequest()
{
java.util.concurrent.atomic.AtomicLong v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
long v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicLong firstConnectionRequest>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
return v;
}
public long getLastConnectionRequest()
{
java.util.concurrent.atomic.AtomicLong v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
long v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicLong lastConnectionRequest>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
return v;
}
public long getDataSourceAge()
{
java.util.concurrent.atomic.AtomicLong v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
long v, v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: long getCurrentTimeInInMillis()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicLong firstConnectionRequest>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v - v;
return v;
}
public long getLastConnectionRequestAge()
{
java.util.concurrent.atomic.AtomicLong v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
long v, v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = specialinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: long getCurrentTimeInInMillis()>();
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicLong lastConnectionRequest>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
v = v - v;
return v;
}
public int buildConnection()
{
int v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
java.util.concurrent.atomic.AtomicInteger v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger builtConnections>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
return v;
}
public int getBuiltConnections()
{
int v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
java.util.concurrent.atomic.AtomicInteger v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger builtConnections>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
return v;
}
public void logConnectionError()
{
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
java.util.concurrent.atomic.AtomicInteger v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger connectionErrors>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
return;
}
public int getTotalConnectionErrors()
{
int v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
java.util.concurrent.atomic.AtomicInteger v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: java.util.concurrent.atomic.AtomicInteger connectionErrors>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
return v;
}
public boolean equals(java.lang.Object)
{
long v, v, v, v;
java.lang.Integer v, v, v, v, v, v;
java.lang.Long v, v, v, v;
int v, v, v, v, v, v;
boolean v, v, v, v, v, v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
java.lang.Class v, v;
java.lang.Object v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v := @parameter: java.lang.Object;
if v != v goto label;
return 1;
label:
if v == null goto label;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
if v == v goto label;
label:
return 0;
label:
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: int getBuiltConnections()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: int getBuiltConnections()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>(v, v);
if v == 0 goto label;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: int getRequestedConnections()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: int getRequestedConnections()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>(v, v);
if v == 0 goto label;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: int getTotalConnectionErrors()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: int getTotalConnectionErrors()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>(v, v);
if v == 0 goto label;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: long getFirstConnectionRequest()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: long getFirstConnectionRequest()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>(v, v);
if v == 0 goto label;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: long getLastConnectionRequest()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: long getLastConnectionRequest()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = staticinvoke <java.util.Objects: boolean equals(java.lang.Object,java.lang.Object)>(v, v);
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public int hashCode()
{
java.lang.Object[] v;
org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics v;
long v, v;
java.lang.Integer v, v, v;
java.lang.Long v, v;
int v, v, v, v;
v := @this: org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics;
v = newarray (java.lang.Object)[5];
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: int getBuiltConnections()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: int getRequestedConnections()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: int getTotalConnectionErrors()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[2] = v;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: long getFirstConnectionRequest()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[3] = v;
v = virtualinvoke v.<org.finos.legend.engine.plan.execution.stores.relational.connection.ds.DataSourceStatistics: long getLastConnectionRequest()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[4] = v;
v = staticinvoke <java.util.Objects: int hash(java.lang.Object[])>(v);
return v;
}
}