public class org.apache.zookeeper.server.util.MessageTracker extends java.lang.Object
{
private static final org.slf4j.Logger LOG;
private final org.apache.zookeeper.server.util.CircularBuffer sentBuffer;
private final org.apache.zookeeper.server.util.CircularBuffer receivedBuffer;
public static final java.lang.String MESSAGE_TRACKER_BUFFER_SIZE;
public static final java.lang.String MESSAGE_TRACKER_ENABLED;
public static final int BUFFERED_MESSAGE_SIZE;
private static final boolean enabled;
public void <init>(int)
{
org.apache.zookeeper.server.util.CircularBuffer v, v;
int v;
org.apache.zookeeper.server.util.MessageTracker v;
v := @this: org.apache.zookeeper.server.util.MessageTracker;
v := @parameter: int;
specialinvoke v.<java.lang.Object: void <init>()>();
v = new org.apache.zookeeper.server.util.CircularBuffer;
specialinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: void <init>(java.lang.Class,int)>(class "Lorg/apache/zookeeper/server/util/MessageTracker$BufferedMessage;", v);
v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer sentBuffer> = v;
v = new org.apache.zookeeper.server.util.CircularBuffer;
specialinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: void <init>(java.lang.Class,int)>(class "Lorg/apache/zookeeper/server/util/MessageTracker$BufferedMessage;", v);
v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer receivedBuffer> = v;
return;
}
public void trackSent(long)
{
org.apache.zookeeper.server.util.CircularBuffer v;
long v;
org.apache.zookeeper.server.util.MessageTracker v;
org.apache.zookeeper.server.util.MessageTracker$BufferedMessage v;
boolean v;
v := @this: org.apache.zookeeper.server.util.MessageTracker;
v := @parameter: long;
v = <org.apache.zookeeper.server.util.MessageTracker: boolean enabled>;
if v == 0 goto label;
v = v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer sentBuffer>;
v = new org.apache.zookeeper.server.util.MessageTracker$BufferedMessage;
specialinvoke v.<org.apache.zookeeper.server.util.MessageTracker$BufferedMessage: void <init>(long)>(v);
virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: void write(java.lang.Object)>(v);
label:
return;
}
public void trackSent(int)
{
org.apache.zookeeper.server.util.CircularBuffer v;
int v;
org.apache.zookeeper.server.util.MessageTracker v;
org.apache.zookeeper.server.util.MessageTracker$BufferedMessage v;
boolean v;
v := @this: org.apache.zookeeper.server.util.MessageTracker;
v := @parameter: int;
v = <org.apache.zookeeper.server.util.MessageTracker: boolean enabled>;
if v == 0 goto label;
v = v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer sentBuffer>;
v = new org.apache.zookeeper.server.util.MessageTracker$BufferedMessage;
specialinvoke v.<org.apache.zookeeper.server.util.MessageTracker$BufferedMessage: void <init>(int)>(v);
virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: void write(java.lang.Object)>(v);
label:
return;
}
public void trackReceived(long)
{
org.apache.zookeeper.server.util.CircularBuffer v;
long v;
org.apache.zookeeper.server.util.MessageTracker v;
org.apache.zookeeper.server.util.MessageTracker$BufferedMessage v;
boolean v;
v := @this: org.apache.zookeeper.server.util.MessageTracker;
v := @parameter: long;
v = <org.apache.zookeeper.server.util.MessageTracker: boolean enabled>;
if v == 0 goto label;
v = v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer receivedBuffer>;
v = new org.apache.zookeeper.server.util.MessageTracker$BufferedMessage;
specialinvoke v.<org.apache.zookeeper.server.util.MessageTracker$BufferedMessage: void <init>(long)>(v);
virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: void write(java.lang.Object)>(v);
label:
return;
}
public void trackReceived(int)
{
org.apache.zookeeper.server.util.CircularBuffer v;
int v;
org.apache.zookeeper.server.util.MessageTracker v;
org.apache.zookeeper.server.util.MessageTracker$BufferedMessage v;
boolean v;
v := @this: org.apache.zookeeper.server.util.MessageTracker;
v := @parameter: int;
v = <org.apache.zookeeper.server.util.MessageTracker: boolean enabled>;
if v == 0 goto label;
v = v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer receivedBuffer>;
v = new org.apache.zookeeper.server.util.MessageTracker$BufferedMessage;
specialinvoke v.<org.apache.zookeeper.server.util.MessageTracker$BufferedMessage: void <init>(int)>(v);
virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: void write(java.lang.Object)>(v);
label:
return;
}
public final org.apache.zookeeper.server.util.MessageTracker$BufferedMessage peekSent()
{
org.apache.zookeeper.server.util.CircularBuffer v;
java.lang.Object v;
org.apache.zookeeper.server.util.MessageTracker v;
v := @this: org.apache.zookeeper.server.util.MessageTracker;
v = v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer sentBuffer>;
v = virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: java.lang.Object peek()>();
return v;
}
public final org.apache.zookeeper.server.util.MessageTracker$BufferedMessage peekReceived()
{
org.apache.zookeeper.server.util.CircularBuffer v;
java.lang.Object v;
org.apache.zookeeper.server.util.MessageTracker v;
v := @this: org.apache.zookeeper.server.util.MessageTracker;
v = v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer receivedBuffer>;
v = virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: java.lang.Object peek()>();
return v;
}
public final long peekSentTimestamp()
{
org.apache.zookeeper.server.util.CircularBuffer v;
java.lang.Object v;
long v;
org.apache.zookeeper.server.util.MessageTracker v;
boolean v;
v := @this: org.apache.zookeeper.server.util.MessageTracker;
v = <org.apache.zookeeper.server.util.MessageTracker: boolean enabled>;
if v == 0 goto label;
v = v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer sentBuffer>;
v = virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: java.lang.Object peek()>();
v = specialinvoke v.<org.apache.zookeeper.server.util.MessageTracker$BufferedMessage: long getTimestamp()>();
goto label;
label:
v = 0L;
label:
return v;
}
public final long peekReceivedTimestamp()
{
org.apache.zookeeper.server.util.CircularBuffer v;
java.lang.Object v;
long v;
org.apache.zookeeper.server.util.MessageTracker v;
boolean v;
v := @this: org.apache.zookeeper.server.util.MessageTracker;
v = <org.apache.zookeeper.server.util.MessageTracker: boolean enabled>;
if v == 0 goto label;
v = v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer receivedBuffer>;
v = virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: java.lang.Object peek()>();
v = specialinvoke v.<org.apache.zookeeper.server.util.MessageTracker$BufferedMessage: long getTimestamp()>();
goto label;
label:
v = 0L;
label:
return v;
}
public void dumpToLog(java.lang.String)
{
org.apache.zookeeper.server.util.CircularBuffer v, v;
org.apache.zookeeper.server.util.MessageTracker$Direction v, v;
java.lang.String v;
org.apache.zookeeper.server.util.MessageTracker v;
boolean v;
v := @this: org.apache.zookeeper.server.util.MessageTracker;
v := @parameter: java.lang.String;
v = <org.apache.zookeeper.server.util.MessageTracker: boolean enabled>;
if v != 0 goto label;
return;
label:
v = v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer receivedBuffer>;
v = <org.apache.zookeeper.server.util.MessageTracker$Direction: org.apache.zookeeper.server.util.MessageTracker$Direction RECEIVED>;
staticinvoke <org.apache.zookeeper.server.util.MessageTracker: void logMessages(java.lang.String,org.apache.zookeeper.server.util.CircularBuffer,org.apache.zookeeper.server.util.MessageTracker$Direction)>(v, v, v);
v = v.<org.apache.zookeeper.server.util.MessageTracker: org.apache.zookeeper.server.util.CircularBuffer sentBuffer>;
v = <org.apache.zookeeper.server.util.MessageTracker$Direction: org.apache.zookeeper.server.util.MessageTracker$Direction SENT>;
staticinvoke <org.apache.zookeeper.server.util.MessageTracker: void logMessages(java.lang.String,org.apache.zookeeper.server.util.CircularBuffer,org.apache.zookeeper.server.util.MessageTracker$Direction)>(v, v, v);
return;
}
private static void logMessages(java.lang.String, org.apache.zookeeper.server.util.CircularBuffer, org.apache.zookeeper.server.util.MessageTracker$Direction)
{
java.lang.Object[] v, v;
java.lang.Integer v;
int v;
java.lang.String v, v, v, v;
boolean v, v;
org.slf4j.Logger v, v, v;
org.apache.zookeeper.server.util.CircularBuffer v;
org.apache.zookeeper.server.util.MessageTracker$Direction v, v;
java.lang.Object v;
v := @parameter: java.lang.String;
v := @parameter: org.apache.zookeeper.server.util.CircularBuffer;
v := @parameter: org.apache.zookeeper.server.util.MessageTracker$Direction;
v = <org.apache.zookeeper.server.util.MessageTracker$Direction: org.apache.zookeeper.server.util.MessageTracker$Direction SENT>;
if v != v goto label;
v = "sentBuffer to";
goto label;
label:
v = "receivedBuffer from";
label:
v = v;
v = virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: boolean isEmpty()>();
if v == 0 goto label;
v = <org.apache.zookeeper.server.util.MessageTracker: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("No buffered timestamps for messages {} {}", v, v);
goto label;
label:
v = <org.apache.zookeeper.server.util.MessageTracker: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[3];
v = virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v[1] = v;
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object[])>("Last {} timestamps for messages {} {}:", v);
label:
v = virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: boolean isEmpty()>();
if v != 0 goto label;
v = <org.apache.zookeeper.server.util.MessageTracker: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[3];
v[0] = v;
v[1] = v;
v = virtualinvoke v.<org.apache.zookeeper.server.util.CircularBuffer: java.lang.Object take()>();
v = virtualinvoke v.<org.apache.zookeeper.server.util.MessageTracker$BufferedMessage: java.lang.String toString()>();
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object[])>("{} {}  {}", v);
goto label;
label:
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
int v;
java.lang.Integer v;
boolean v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/zookeeper/server/util/MessageTracker;");
<org.apache.zookeeper.server.util.MessageTracker: org.slf4j.Logger LOG> = v;
v = staticinvoke <java.lang.Integer: java.lang.Integer getInteger(java.lang.String,int)>("zookeeper.messageTracker.BufferSize", 10);
v = virtualinvoke v.<java.lang.Integer: int intValue()>();
<org.apache.zookeeper.server.util.MessageTracker: int BUFFERED_MESSAGE_SIZE> = v;
v = staticinvoke <java.lang.Boolean: boolean getBoolean(java.lang.String)>("zookeeper.messageTracker.Enabled");
<org.apache.zookeeper.server.util.MessageTracker: boolean enabled> = v;
return;
}
}