public class org.apache.zookeeper.server.persistence.FileTxnSnapLog extends java.lang.Object
{
final java.io.File dataDir;
final java.io.File snapDir;
org.apache.zookeeper.server.persistence.TxnLog txnLog;
org.apache.zookeeper.server.persistence.SnapShot snapLog;
private final boolean autoCreateDB;
private final boolean trustEmptySnapshot;
public static final int VERSION;
public static final java.lang.String version;
private static final org.slf4j.Logger LOG;
public static final java.lang.String ZOOKEEPER_DATADIR_AUTOCREATE;
public static final java.lang.String ZOOKEEPER_DATADIR_AUTOCREATE_DEFAULT;
static final java.lang.String ZOOKEEPER_DB_AUTOCREATE;
private static final java.lang.String ZOOKEEPER_DB_AUTOCREATE_DEFAULT;
public static final java.lang.String ZOOKEEPER_SNAPSHOT_TRUST_EMPTY;
private static final java.lang.String EMPTY_SNAPSHOT_WARNING;
public void <init>(java.io.File, java.io.File) throws java.io.IOException
{
org.apache.zookeeper.server.persistence.FileTxnLog v;
boolean v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.zookeeper.server.persistence.FileSnap v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException v, v, v, v, v, v;
java.lang.Object[] v, v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
java.lang.Boolean v;
java.lang.String v, v, v, v, v, v, v, v, v, v;
org.slf4j.Logger v, v;
java.io.File v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: java.io.File;
v := @parameter: java.io.File;
specialinvoke v.<java.lang.Object: void <init>()>();
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Opening datadir:{} snapDir:{}", v, v);
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, "version-2");
v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir> = v;
v = new java.io.File;
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, "version-2");
v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir> = v;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String,java.lang.String)>("zookeeper.datadir.autocreate", "true");
v = staticinvoke <java.lang.Boolean: boolean parseBoolean(java.lang.String)>(v);
v = staticinvoke <java.lang.Boolean: boolean getBoolean(java.lang.String)>("zookeeper.snapshot.trust.empty");
v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: boolean trustEmptySnapshot> = v;
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: boolean trustEmptySnapshot>;
v = staticinvoke <java.lang.Boolean: java.lang.Boolean valueOf(boolean)>(v);
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("{} : {}", "zookeeper.snapshot.trust.empty", v);
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
if v != 0 goto label;
v = new org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException;
v = newarray (java.lang.Object)[2];
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
v[0] = v;
v[1] = "zookeeper.datadir.autocreate";
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Missing data directory %s, automatic data directory creation is disabled (%s is false). Please create this directory manually.", v);
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
v = virtualinvoke v.<java.io.File: boolean mkdirs()>();
if v != 0 goto label;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
v = new org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("Unable to create data directory \u0001");
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
v = virtualinvoke v.<java.io.File: boolean canWrite()>();
if v != 0 goto label;
v = new org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("Cannot write to data directory \u0001");
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
if v != 0 goto label;
v = new org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException;
v = newarray (java.lang.Object)[2];
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
v[0] = v;
v[1] = "zookeeper.datadir.autocreate";
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Missing snap directory %s, automatic data directory creation is disabled (%s is false).Please create this directory manually.", v);
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
v = virtualinvoke v.<java.io.File: boolean mkdirs()>();
if v != 0 goto label;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
v = virtualinvoke v.<java.io.File: boolean exists()>();
if v != 0 goto label;
v = new org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("Unable to create snap directory \u0001");
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
v = virtualinvoke v.<java.io.File: boolean canWrite()>();
if v != 0 goto label;
v = new org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.File)>(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[])>("Cannot write to snap directory \u0001");
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$DatadirException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
v = virtualinvoke v.<java.io.File: java.lang.String getPath()>();
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
v = virtualinvoke v.<java.io.File: java.lang.String getPath()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: void checkLogDir()>();
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: void checkSnapDir()>();
label:
v = new org.apache.zookeeper.server.persistence.FileTxnLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnLog: void <init>(java.io.File)>(v);
v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog> = v;
v = new org.apache.zookeeper.server.persistence.FileSnap;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileSnap: void <init>(java.io.File)>(v);
v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.SnapShot snapLog> = v;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String,java.lang.String)>("zookeeper.db.autocreate", "true");
v = staticinvoke <java.lang.Boolean: boolean parseBoolean(java.lang.String)>(v);
v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: boolean autoCreateDB> = v;
return;
}
public void setServerStats(org.apache.zookeeper.server.ServerStats)
{
org.apache.zookeeper.server.ServerStats v;
org.apache.zookeeper.server.persistence.TxnLog v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: org.apache.zookeeper.server.ServerStats;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog>;
interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog: void setServerStats(org.apache.zookeeper.server.ServerStats)>(v);
return;
}
private void checkLogDir() throws org.apache.zookeeper.server.persistence.FileTxnSnapLog$LogDirContentCheckException
{
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog$1 v;
int v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog$LogDirContentCheckException v;
java.io.File[] v;
java.io.File v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
v = new org.apache.zookeeper.server.persistence.FileTxnSnapLog$1;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$1: void <init>(org.apache.zookeeper.server.persistence.FileTxnSnapLog)>(v);
v = virtualinvoke v.<java.io.File: java.io.File[] listFiles(java.io.FilenameFilter)>(v);
if v == null goto label;
v = lengthof v;
if v <= 0 goto label;
v = new org.apache.zookeeper.server.persistence.FileTxnSnapLog$LogDirContentCheckException;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$LogDirContentCheckException: void <init>(java.lang.String)>("Log directory has snapshot files. Check if dataLogDir and dataDir configuration is correct.");
throw v;
label:
return;
}
private void checkSnapDir() throws org.apache.zookeeper.server.persistence.FileTxnSnapLog$SnapDirContentCheckException
{
org.apache.zookeeper.server.persistence.FileTxnSnapLog$SnapDirContentCheckException v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog$2 v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
int v;
java.io.File[] v;
java.io.File v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
v = new org.apache.zookeeper.server.persistence.FileTxnSnapLog$2;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$2: void <init>(org.apache.zookeeper.server.persistence.FileTxnSnapLog)>(v);
v = virtualinvoke v.<java.io.File: java.io.File[] listFiles(java.io.FilenameFilter)>(v);
if v == null goto label;
v = lengthof v;
if v <= 0 goto label;
v = new org.apache.zookeeper.server.persistence.FileTxnSnapLog$SnapDirContentCheckException;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$SnapDirContentCheckException: void <init>(java.lang.String)>("Snapshot directory has log files. Check if dataLogDir and dataDir configuration is correct.");
throw v;
label:
return;
}
public java.io.File getDataDir()
{
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
java.io.File v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
return v;
}
public java.io.File getSnapDir()
{
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
java.io.File v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
return v;
}
public org.apache.zookeeper.server.persistence.SnapshotInfo getLastSnapshotInfo()
{
org.apache.zookeeper.server.persistence.SnapShot v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
org.apache.zookeeper.server.persistence.SnapshotInfo v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.SnapShot snapLog>;
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.SnapShot: org.apache.zookeeper.server.persistence.SnapshotInfo getLastSnapshotInfo()>();
return v;
}
public boolean shouldForceWriteInitialSnapshotAfterLeaderElection()
{
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
org.apache.zookeeper.server.persistence.SnapshotInfo v;
boolean v, v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: boolean trustEmptySnapshot>;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.SnapshotInfo getLastSnapshotInfo()>();
if v != null goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public long restore(org.apache.zookeeper.server.DataTree, java.util.Map, org.apache.zookeeper.server.persistence.FileTxnSnapLog$PlayBackListener) throws java.io.IOException
{
org.apache.zookeeper.server.persistence.FileTxnLog v;
long v, v, v, v, v, v, v;
org.apache.zookeeper.metrics.Summary v;
byte v, v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
org.apache.zookeeper.server.ServerMetrics v;
java.util.Map v;
java.lang.String v;
java.nio.file.Path v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog$PlayBackListener v;
boolean v, v, v;
org.slf4j.Logger v, v, v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog$RestoreFinalizer v;
java.io.IOException v;
java.io.File v, v, v;
org.apache.zookeeper.server.persistence.SnapShot v;
org.apache.zookeeper.server.DataTree v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: org.apache.zookeeper.server.DataTree;
v := @parameter: java.util.Map;
v := @parameter: org.apache.zookeeper.server.persistence.FileTxnSnapLog$PlayBackListener;
v = staticinvoke <org.apache.zookeeper.common.Time: long currentElapsedTime()>();
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.SnapShot snapLog>;
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.SnapShot: long deserialize(org.apache.zookeeper.server.DataTree,java.util.Map)>(v, v);
v = staticinvoke <org.apache.zookeeper.server.ServerMetrics: org.apache.zookeeper.server.ServerMetrics getMetrics()>();
v = v.<org.apache.zookeeper.server.ServerMetrics: org.apache.zookeeper.metrics.Summary STARTUP_SNAP_LOAD_TIME>;
v = staticinvoke <org.apache.zookeeper.common.Time: long currentElapsedTime()>();
v = v - v;
interfaceinvoke v.<org.apache.zookeeper.metrics.Summary: void add(long)>(v);
v = new org.apache.zookeeper.server.persistence.FileTxnLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnLog: void <init>(java.io.File)>(v);
v = new java.io.File;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
v = virtualinvoke v.<java.io.File: java.lang.String getParent()>();
specialinvoke v.<java.io.File: void <init>(java.lang.String,java.lang.String)>(v, "initialize");
v = virtualinvoke v.<java.io.File: java.nio.file.Path toPath()>();
v = staticinvoke <java.nio.file.Files: boolean deleteIfExists(java.nio.file.Path)>(v);
if v == 0 goto label;
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>("Initialize file found, an empty database will not block voting participation");
v = 1;
goto label;
label:
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: boolean autoCreateDB>;
label:
v = staticinvoke <org.apache.zookeeper.server.persistence.FileTxnSnapLog$lambda_restore_0__155: org.apache.zookeeper.server.persistence.FileTxnSnapLog$RestoreFinalizer bootstrap$(org.apache.zookeeper.server.persistence.FileTxnSnapLog,org.apache.zookeeper.server.DataTree,java.util.Map,org.apache.zookeeper.server.persistence.FileTxnSnapLog$PlayBackListener)>(v, v, v, v);
v = -1L cmp v;
if v != 0 goto label;
v = virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnLog: long getLastLoggedZxid()>();
v = v cmp -1L;
if v == 0 goto label;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: boolean trustEmptySnapshot>;
if v != 0 goto label;
v = new java.io.IOException;
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>("No snapshot found, but there are log entries. Something is broken!");
throw v;
label:
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object)>("{}This should only be allowed during upgrading.", "No snapshot found, but there are log entries. ");
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$RestoreFinalizer: long run()>();
return v;
label:
if v == 0 goto label;
virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File save(org.apache.zookeeper.server.DataTree,java.util.concurrent.ConcurrentHashMap,boolean)>(v, v, 0);
return 0L;
label:
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String)>("Unexpected empty data tree, setting zxid to -1");
v.<org.apache.zookeeper.server.DataTree: long lastProcessedZxid> = -1L;
return -1L;
label:
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$RestoreFinalizer: long run()>();
return v;
}
public long fastForwardFromEdits(org.apache.zookeeper.server.DataTree, java.util.Map, org.apache.zookeeper.server.persistence.FileTxnSnapLog$PlayBackListener) throws java.io.IOException
{
java.lang.Integer v, v;
org.apache.zookeeper.KeeperException$NoNodeException v;
org.apache.zookeeper.metrics.Summary v, v;
byte v, v;
java.lang.Long v, v, v;
java.util.Map v;
boolean v;
org.apache.jute.Record v, v, v;
java.lang.Throwable v;
java.lang.Object[] v;
org.apache.zookeeper.server.persistence.TxnLog$TxnIterator v;
long v, v, v, v, v, v, v, v, v;
org.apache.zookeeper.txn.TxnDigest v, v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
org.apache.zookeeper.server.ServerMetrics v, v;
int v, v, v;
java.lang.String v, v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog$PlayBackListener v;
org.apache.zookeeper.server.persistence.TxnLog v;
org.slf4j.Logger v, v;
java.io.IOException v;
org.apache.zookeeper.txn.TxnHeader v;
org.apache.zookeeper.server.DataTree v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: org.apache.zookeeper.server.DataTree;
v := @parameter: java.util.Map;
v := @parameter: org.apache.zookeeper.server.persistence.FileTxnSnapLog$PlayBackListener;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog>;
v = v.<org.apache.zookeeper.server.DataTree: long lastProcessedZxid>;
v = v + 1L;
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog: org.apache.zookeeper.server.persistence.TxnLog$TxnIterator read(long)>(v);
v = v.<org.apache.zookeeper.server.DataTree: long lastProcessedZxid>;
v = 0;
v = staticinvoke <org.apache.zookeeper.common.Time: long currentElapsedTime()>();
label:
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog$TxnIterator: org.apache.zookeeper.txn.TxnHeader getHeader()>();
if v != null goto label;
v = v.<org.apache.zookeeper.server.DataTree: long lastProcessedZxid>;
label:
interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog$TxnIterator: void close()>();
return v;
label:
v = virtualinvoke v.<org.apache.zookeeper.txn.TxnHeader: long getZxid()>();
v = v cmp v;
if v >= 0 goto label;
v = v cmp 0L;
if v == 0 goto label;
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[3];
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[0] = v;
v = virtualinvoke v.<org.apache.zookeeper.txn.TxnHeader: long getZxid()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v[1] = v;
v = virtualinvoke v.<org.apache.zookeeper.txn.TxnHeader: int getType()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object[])>("{}(highestZxid) > {}(next log) for type {}", v);
goto label;
label:
v = virtualinvoke v.<org.apache.zookeeper.txn.TxnHeader: long getZxid()>();
label:
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog$TxnIterator: org.apache.jute.Record getTxn()>();
virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: void processTransaction(org.apache.zookeeper.txn.TxnHeader,org.apache.zookeeper.server.DataTree,java.util.Map,org.apache.jute.Record)>(v, v, v, v);
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog$TxnIterator: org.apache.jute.Record getTxn()>();
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog$TxnIterator: org.apache.zookeeper.txn.TxnDigest getDigest()>();
virtualinvoke v.<org.apache.zookeeper.server.DataTree: boolean compareDigest(org.apache.zookeeper.txn.TxnHeader,org.apache.jute.Record,org.apache.zookeeper.txn.TxnDigest)>(v, v, v);
v = v + 1;
label:
goto label;
label:
v := @caughtexception;
v = new java.io.IOException;
v = virtualinvoke v.<org.apache.zookeeper.txn.TxnHeader: int getType()>();
v = virtualinvoke v.<org.apache.zookeeper.KeeperException$NoNodeException: 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[])>("Failed to process transaction type: \u error: \u0001");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog$TxnIterator: org.apache.jute.Record getTxn()>();
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog$TxnIterator: org.apache.zookeeper.txn.TxnDigest getDigest()>();
interfaceinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog$PlayBackListener: void onTxnLoaded(org.apache.zookeeper.txn.TxnHeader,org.apache.jute.Record,org.apache.zookeeper.txn.TxnDigest)>(v, v, v);
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog$TxnIterator: boolean next()>();
if v != 0 goto label;
label:
interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog$TxnIterator: void close()>();
goto label;
label:
v := @caughtexception;
if v == null goto label;
interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog$TxnIterator: void close()>();
label:
throw v;
label:
v = staticinvoke <org.apache.zookeeper.common.Time: long currentElapsedTime()>();
v = v - v;
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("{} txns loaded in {} ms", v, v);
v = staticinvoke <org.apache.zookeeper.server.ServerMetrics: org.apache.zookeeper.server.ServerMetrics getMetrics()>();
v = v.<org.apache.zookeeper.server.ServerMetrics: org.apache.zookeeper.metrics.Summary STARTUP_TXNS_LOADED>;
interfaceinvoke v.<org.apache.zookeeper.metrics.Summary: void add(long)>(v);
v = staticinvoke <org.apache.zookeeper.server.ServerMetrics: org.apache.zookeeper.server.ServerMetrics getMetrics()>();
v = v.<org.apache.zookeeper.server.ServerMetrics: org.apache.zookeeper.metrics.Summary STARTUP_TXNS_LOAD_TIME>;
interfaceinvoke v.<org.apache.zookeeper.metrics.Summary: void add(long)>(v);
return v;
catch org.apache.zookeeper.KeeperException$NoNodeException 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;
}
public org.apache.zookeeper.server.persistence.TxnLog$TxnIterator readTxnLog(long) throws java.io.IOException
{
org.apache.zookeeper.server.persistence.TxnLog$TxnIterator v;
long v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: long;
v = virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog$TxnIterator readTxnLog(long,boolean)>(v, 1);
return v;
}
public org.apache.zookeeper.server.persistence.TxnLog$TxnIterator readTxnLog(long, boolean) throws java.io.IOException
{
org.apache.zookeeper.server.persistence.FileTxnLog v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
org.apache.zookeeper.server.persistence.TxnLog$TxnIterator v;
long v;
java.io.File v;
boolean v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: long;
v := @parameter: boolean;
v = new org.apache.zookeeper.server.persistence.FileTxnLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnLog: void <init>(java.io.File)>(v);
v = virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnLog: org.apache.zookeeper.server.persistence.TxnLog$TxnIterator read(long,boolean)>(v, v);
return v;
}
public void processTransaction(org.apache.zookeeper.txn.TxnHeader, org.apache.zookeeper.server.DataTree, java.util.Map, org.apache.jute.Record) throws org.apache.zookeeper.KeeperException$NoNodeException
{
java.lang.Integer v, v, v;
java.lang.Long v, v;
java.util.Map v;
boolean v, v;
org.apache.zookeeper.server.DataTree$ProcessTxnResult v;
org.apache.jute.Record v;
java.lang.Object[] v;
long v, v, v, v;
org.apache.zookeeper.KeeperException$Code v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
int v, v, v, v, v, v, v;
java.lang.String v, v, v, v, v;
org.slf4j.Logger v, v, v, v, v;
org.apache.zookeeper.txn.TxnHeader v;
org.apache.zookeeper.server.DataTree v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: org.apache.zookeeper.txn.TxnHeader;
v := @parameter: org.apache.zookeeper.server.DataTree;
v := @parameter: java.util.Map;
v := @parameter: org.apache.jute.Record;
v = virtualinvoke v.<org.apache.zookeeper.txn.TxnHeader: int getType()>();
lookupswitch(v)
{
case -11: goto label;
case -10: goto label;
default: goto label;
};
label:
v = virtualinvoke v.<org.apache.zookeeper.txn.TxnHeader: long getClientId()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
v = virtualinvoke v.<org.apache.zookeeper.txn.CreateSessionTxn: int getTimeOut()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.zookeeper.txn.TxnHeader: long getClientId()>();
v = staticinvoke <java.lang.Long: java.lang.String toHexString(long)>(v);
v = virtualinvoke v.<org.apache.zookeeper.txn.CreateSessionTxn: int getTimeOut()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,int)>(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[])>("playLog --- create session in log: 0x\u with timeout: \u0001");
staticinvoke <org.apache.zookeeper.server.ZooTrace: void logTraceMessage(org.slf4j.Logger,long,java.lang.String)>(v, 32L, v);
label:
v = virtualinvoke v.<org.apache.zookeeper.server.DataTree: org.apache.zookeeper.server.DataTree$ProcessTxnResult processTxn(org.apache.zookeeper.txn.TxnHeader,org.apache.jute.Record)>(v, v);
goto label;
label:
v = virtualinvoke v.<org.apache.zookeeper.txn.TxnHeader: long getClientId()>();
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
interfaceinvoke v.<java.util.Map: java.lang.Object remove(java.lang.Object)>(v);
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.zookeeper.txn.TxnHeader: long getClientId()>();
v = staticinvoke <java.lang.Long: java.lang.String toHexString(long)>(v);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("playLog --- close session in log: 0x\u0001");
staticinvoke <org.apache.zookeeper.server.ZooTrace: void logTraceMessage(org.slf4j.Logger,long,java.lang.String)>(v, 32L, v);
label:
v = virtualinvoke v.<org.apache.zookeeper.server.DataTree: org.apache.zookeeper.server.DataTree$ProcessTxnResult processTxn(org.apache.zookeeper.txn.TxnHeader,org.apache.jute.Record)>(v, v);
goto label;
label:
v = virtualinvoke v.<org.apache.zookeeper.server.DataTree: org.apache.zookeeper.server.DataTree$ProcessTxnResult processTxn(org.apache.zookeeper.txn.TxnHeader,org.apache.jute.Record)>(v, v);
label:
v = v.<org.apache.zookeeper.server.DataTree$ProcessTxnResult: int err>;
v = <org.apache.zookeeper.KeeperException$Code: org.apache.zookeeper.KeeperException$Code OK>;
v = virtualinvoke v.<org.apache.zookeeper.KeeperException$Code: int intValue()>();
if v == v goto label;
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
v = newarray (java.lang.Object)[3];
v = virtualinvoke v.<org.apache.zookeeper.txn.TxnHeader: int getType()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
v = v.<org.apache.zookeeper.server.DataTree$ProcessTxnResult: int err>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[1] = v;
v = v.<org.apache.zookeeper.server.DataTree$ProcessTxnResult: java.lang.String path>;
v[2] = v;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object[])>("Ignoring processTxn failure hdr: {}, error: {}, path: {}", v);
label:
return;
}
public long getLastLoggedZxid()
{
org.apache.zookeeper.server.persistence.FileTxnLog v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
long v;
java.io.File v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = new org.apache.zookeeper.server.persistence.FileTxnLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnLog: void <init>(java.io.File)>(v);
v = virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnLog: long getLastLoggedZxid()>();
return v;
}
public java.io.File save(org.apache.zookeeper.server.DataTree, java.util.concurrent.ConcurrentHashMap, boolean) throws java.io.IOException
{
long v, v;
byte v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
java.lang.String v, v, v, v;
boolean v, v;
org.slf4j.Logger v, v, v;
java.util.concurrent.ConcurrentHashMap v;
java.io.IOException v;
java.io.File v, v;
org.apache.zookeeper.server.persistence.SnapShot v;
org.apache.zookeeper.server.DataTree v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: org.apache.zookeeper.server.DataTree;
v := @parameter: java.util.concurrent.ConcurrentHashMap;
v := @parameter: boolean;
v = v.<org.apache.zookeeper.server.DataTree: long lastProcessedZxid>;
v = new java.io.File;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
v = staticinvoke <org.apache.zookeeper.server.persistence.Util: java.lang.String makeSnapshotName(long)>(v);
specialinvoke v.<java.io.File: void <init>(java.io.File,java.lang.String)>(v, v);
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
v = staticinvoke <java.lang.Long: java.lang.String toHexString(long)>(v);
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("Snapshotting: 0x{} to {}", v, v);
label:
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.SnapShot snapLog>;
interfaceinvoke v.<org.apache.zookeeper.server.persistence.SnapShot: void serialize(org.apache.zookeeper.server.DataTree,java.util.Map,java.io.File,boolean)>(v, v, v, v);
label:
return v;
label:
v := @caughtexception;
v = virtualinvoke v.<java.io.File: long length()>();
v = v cmp 0L;
if v != 0 goto label;
v = virtualinvoke v.<java.io.File: boolean delete()>();
if v == 0 goto label;
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("Deleted empty snapshot file: {}", v);
goto label;
label:
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
v = virtualinvoke v.<java.io.File: java.lang.String getAbsolutePath()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object)>("Could not delete empty snapshot file: {}", v);
label:
throw v;
catch java.io.IOException from label to label with label;
}
public boolean truncateLog(long)
{
java.lang.Throwable v;
org.apache.zookeeper.server.persistence.FileTxnLog v, v;
org.slf4j.Logger v;
java.io.IOException v;
long v;
java.io.File v, v, v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
org.apache.zookeeper.server.persistence.FileSnap v;
boolean v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: long;
label:
virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: void close()>();
v = new org.apache.zookeeper.server.persistence.FileTxnLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnLog: void <init>(java.io.File)>(v);
label:
v = virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnLog: boolean truncate(long)>(v);
v = new org.apache.zookeeper.server.persistence.FileTxnLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileTxnLog: void <init>(java.io.File)>(v);
v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog> = v;
v = new org.apache.zookeeper.server.persistence.FileSnap;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileSnap: void <init>(java.io.File)>(v);
v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.SnapShot snapLog> = v;
label:
virtualinvoke v.<org.apache.zookeeper.server.persistence.FileTxnLog: void close()>();
label:
return v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = <org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Unable to truncate Txn log", v);
return 0;
catch java.lang.Throwable from label to label with label;
catch java.io.IOException from label to label with label;
}
public java.io.File findMostRecentSnapshot() throws java.io.IOException
{
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
org.apache.zookeeper.server.persistence.FileSnap v;
java.io.File v, v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = new org.apache.zookeeper.server.persistence.FileSnap;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileSnap: void <init>(java.io.File)>(v);
v = virtualinvoke v.<org.apache.zookeeper.server.persistence.FileSnap: java.io.File findMostRecentSnapshot()>();
return v;
}
public java.util.List findNRecentSnapshots(int) throws java.io.IOException
{
java.util.List v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
int v;
org.apache.zookeeper.server.persistence.FileSnap v;
java.io.File v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: int;
v = new org.apache.zookeeper.server.persistence.FileSnap;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileSnap: void <init>(java.io.File)>(v);
v = virtualinvoke v.<org.apache.zookeeper.server.persistence.FileSnap: java.util.List findNRecentSnapshots(int)>(v);
return v;
}
public java.util.List findNValidSnapshots(int)
{
java.util.List v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
int v;
org.apache.zookeeper.server.persistence.FileSnap v;
java.io.File v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: int;
v = new org.apache.zookeeper.server.persistence.FileSnap;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File snapDir>;
specialinvoke v.<org.apache.zookeeper.server.persistence.FileSnap: void <init>(java.io.File)>(v);
v = virtualinvoke v.<org.apache.zookeeper.server.persistence.FileSnap: java.util.List findNValidSnapshots(int)>(v);
return v;
}
public java.io.File[] getSnapshotLogs(long)
{
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
long v;
java.io.File[] v, v;
java.io.File v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: long;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: java.io.File dataDir>;
v = virtualinvoke v.<java.io.File: java.io.File[] listFiles()>();
v = staticinvoke <org.apache.zookeeper.server.persistence.FileTxnLog: java.io.File[] getLogFiles(java.io.File[],long)>(v, v);
return v;
}
public boolean append(org.apache.zookeeper.server.Request) throws java.io.IOException
{
org.apache.zookeeper.server.Request v;
org.apache.zookeeper.server.persistence.TxnLog v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
boolean v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: org.apache.zookeeper.server.Request;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog>;
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog: boolean append(org.apache.zookeeper.server.Request)>(v);
return v;
}
public void commit() throws java.io.IOException
{
org.apache.zookeeper.server.persistence.TxnLog v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog>;
interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog: void commit()>();
return;
}
public long getTxnLogElapsedSyncTime()
{
long v;
org.apache.zookeeper.server.persistence.TxnLog v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog>;
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog: long getTxnLogSyncElapsedTime()>();
return v;
}
public void rollLog() throws java.io.IOException
{
org.apache.zookeeper.server.persistence.TxnLog v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog>;
interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog: void rollLog()>();
return;
}
public void close() throws java.io.IOException
{
org.apache.zookeeper.server.persistence.SnapShot v;
org.apache.zookeeper.server.persistence.TxnLog v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog>;
if v == null goto label;
interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog: void close()>();
label:
v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog> = null;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.SnapShot snapLog>;
if v == null goto label;
interfaceinvoke v.<org.apache.zookeeper.server.persistence.SnapShot: void close()>();
label:
v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.SnapShot snapLog> = null;
return;
}
public void setTotalLogSize(long)
{
long v;
org.apache.zookeeper.server.persistence.TxnLog v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v := @parameter: long;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog>;
interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog: void setTotalLogSize(long)>(v);
return;
}
public long getTotalLogSize()
{
long v;
org.apache.zookeeper.server.persistence.TxnLog v;
org.apache.zookeeper.server.persistence.FileTxnSnapLog v;
v := @this: org.apache.zookeeper.server.persistence.FileTxnSnapLog;
v = v.<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.apache.zookeeper.server.persistence.TxnLog txnLog>;
v = interfaceinvoke v.<org.apache.zookeeper.server.persistence.TxnLog: long getTotalLogSize()>();
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/zookeeper/server/persistence/FileTxnSnapLog;");
<org.apache.zookeeper.server.persistence.FileTxnSnapLog: org.slf4j.Logger LOG> = v;
return;
}
}