public class oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex extends java.lang.Object implements oadd.org.apache.curator.framework.recipes.locks.InterProcessLock, oadd.org.apache.curator.framework.recipes.locks.Revocable
{
private final oadd.org.apache.curator.framework.recipes.locks.LockInternals internals;
private final java.lang.String basePath;
private final java.util.concurrent.ConcurrentMap threadData;
private static final java.lang.String LOCK_NAME;
public void <init>(oadd.org.apache.curator.framework.CuratorFramework, java.lang.String)
{
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
oadd.org.apache.curator.framework.recipes.locks.StandardLockInternalsDriver v;
java.lang.String v;
oadd.org.apache.curator.framework.CuratorFramework v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v := @parameter: oadd.org.apache.curator.framework.CuratorFramework;
v := @parameter: java.lang.String;
v = new oadd.org.apache.curator.framework.recipes.locks.StandardLockInternalsDriver;
specialinvoke v.<oadd.org.apache.curator.framework.recipes.locks.StandardLockInternalsDriver: void <init>()>();
specialinvoke v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: void <init>(oadd.org.apache.curator.framework.CuratorFramework,java.lang.String,oadd.org.apache.curator.framework.recipes.locks.LockInternalsDriver)>(v, v, v);
return;
}
public void <init>(oadd.org.apache.curator.framework.CuratorFramework, java.lang.String, oadd.org.apache.curator.framework.recipes.locks.LockInternalsDriver)
{
oadd.org.apache.curator.framework.recipes.locks.LockInternalsDriver v;
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
java.lang.String v;
oadd.org.apache.curator.framework.CuratorFramework v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v := @parameter: oadd.org.apache.curator.framework.CuratorFramework;
v := @parameter: java.lang.String;
v := @parameter: oadd.org.apache.curator.framework.recipes.locks.LockInternalsDriver;
specialinvoke v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: void <init>(oadd.org.apache.curator.framework.CuratorFramework,java.lang.String,java.lang.String,int,oadd.org.apache.curator.framework.recipes.locks.LockInternalsDriver)>(v, v, "lock-", 1, v);
return;
}
public void acquire() throws java.lang.Exception
{
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
java.io.IOException v;
java.lang.String v, v;
boolean v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v = specialinvoke v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: boolean internalLock(long,java.util.concurrent.TimeUnit)>(-1L, null);
if v != 0 goto label;
v = new java.io.IOException;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.lang.String basePath>;
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[])>("Lost connection while trying to acquire lock: \u0001");
specialinvoke v.<java.io.IOException: void <init>(java.lang.String)>(v);
throw v;
label:
return;
}
public boolean acquire(long, java.util.concurrent.TimeUnit) throws java.lang.Exception
{
java.util.concurrent.TimeUnit v;
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
long v;
boolean v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v := @parameter: long;
v := @parameter: java.util.concurrent.TimeUnit;
v = specialinvoke v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: boolean internalLock(long,java.util.concurrent.TimeUnit)>(v, v);
return v;
}
public boolean isAcquiredInThisProcess()
{
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
int v;
boolean v;
java.util.concurrent.ConcurrentMap v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.util.concurrent.ConcurrentMap threadData>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: int size()>();
if v <= 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public void release() throws java.lang.Exception
{
java.lang.Throwable v;
oadd.org.apache.curator.framework.recipes.locks.LockInternals v;
java.util.concurrent.ConcurrentMap v, v, v;
java.lang.IllegalMonitorStateException v, v;
java.util.concurrent.atomic.AtomicInteger v;
java.lang.Thread v;
int v;
java.lang.String v, v, v, v, v;
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
java.lang.Object v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.util.concurrent.ConcurrentMap threadData>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = new java.lang.IllegalMonitorStateException;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.lang.String basePath>;
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[])>("You do not own the lock: \u0001");
specialinvoke v.<java.lang.IllegalMonitorStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex$LockData: java.util.concurrent.atomic.AtomicInteger lockCount>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int decrementAndGet()>();
if v <= 0 goto label;
return;
label:
if v >= 0 goto label;
v = new java.lang.IllegalMonitorStateException;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.lang.String basePath>;
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[])>("Lock count has gone negative for lock: \u0001");
specialinvoke v.<java.lang.IllegalMonitorStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: oadd.org.apache.curator.framework.recipes.locks.LockInternals internals>;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex$LockData: java.lang.String lockPath>;
virtualinvoke v.<oadd.org.apache.curator.framework.recipes.locks.LockInternals: void releaseLock(java.lang.String)>(v);
label:
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.util.concurrent.ConcurrentMap threadData>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
goto label;
label:
v := @caughtexception;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.util.concurrent.ConcurrentMap threadData>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
public java.util.Collection getParticipantNodes() throws java.lang.Exception
{
oadd.org.apache.curator.framework.recipes.locks.LockInternalsDriver v;
java.util.Collection v;
oadd.org.apache.curator.framework.recipes.locks.LockInternals v, v, v;
oadd.org.apache.curator.framework.CuratorFramework v;
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
java.lang.String v, v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: oadd.org.apache.curator.framework.recipes.locks.LockInternals internals>;
v = virtualinvoke v.<oadd.org.apache.curator.framework.recipes.locks.LockInternals: oadd.org.apache.curator.framework.CuratorFramework getClient()>();
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.lang.String basePath>;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: oadd.org.apache.curator.framework.recipes.locks.LockInternals internals>;
v = virtualinvoke v.<oadd.org.apache.curator.framework.recipes.locks.LockInternals: java.lang.String getLockName()>();
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: oadd.org.apache.curator.framework.recipes.locks.LockInternals internals>;
v = virtualinvoke v.<oadd.org.apache.curator.framework.recipes.locks.LockInternals: oadd.org.apache.curator.framework.recipes.locks.LockInternalsDriver getDriver()>();
v = staticinvoke <oadd.org.apache.curator.framework.recipes.locks.LockInternals: java.util.Collection getParticipantNodes(oadd.org.apache.curator.framework.CuratorFramework,java.lang.String,java.lang.String,oadd.org.apache.curator.framework.recipes.locks.LockInternalsSorter)>(v, v, v, v);
return v;
}
public void makeRevocable(oadd.org.apache.curator.framework.recipes.locks.RevocationListener)
{
java.util.concurrent.Executor v;
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
oadd.org.apache.curator.framework.recipes.locks.RevocationListener v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v := @parameter: oadd.org.apache.curator.framework.recipes.locks.RevocationListener;
v = staticinvoke <oadd.org.apache.curator.shaded.com.google.common.util.concurrent.MoreExecutors: java.util.concurrent.Executor directExecutor()>();
virtualinvoke v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: void makeRevocable(oadd.org.apache.curator.framework.recipes.locks.RevocationListener,java.util.concurrent.Executor)>(v, v);
return;
}
public void makeRevocable(oadd.org.apache.curator.framework.recipes.locks.RevocationListener, java.util.concurrent.Executor)
{
java.util.concurrent.Executor v;
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
oadd.org.apache.curator.framework.recipes.locks.RevocationListener v;
oadd.org.apache.curator.framework.recipes.locks.LockInternals v;
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex$1 v;
oadd.org.apache.curator.framework.recipes.locks.RevocationSpec v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v := @parameter: oadd.org.apache.curator.framework.recipes.locks.RevocationListener;
v := @parameter: java.util.concurrent.Executor;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: oadd.org.apache.curator.framework.recipes.locks.LockInternals internals>;
v = new oadd.org.apache.curator.framework.recipes.locks.RevocationSpec;
v = new oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex$1;
specialinvoke v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex$1: void <init>(oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex,oadd.org.apache.curator.framework.recipes.locks.RevocationListener)>(v, v);
specialinvoke v.<oadd.org.apache.curator.framework.recipes.locks.RevocationSpec: void <init>(java.util.concurrent.Executor,java.lang.Runnable)>(v, v);
virtualinvoke v.<oadd.org.apache.curator.framework.recipes.locks.LockInternals: void makeRevocable(oadd.org.apache.curator.framework.recipes.locks.RevocationSpec)>(v);
return;
}
void <init>(oadd.org.apache.curator.framework.CuratorFramework, java.lang.String, java.lang.String, int, oadd.org.apache.curator.framework.recipes.locks.LockInternalsDriver)
{
oadd.org.apache.curator.framework.recipes.locks.LockInternalsDriver v;
oadd.org.apache.curator.framework.recipes.locks.LockInternals v;
oadd.org.apache.curator.framework.CuratorFramework v;
java.util.concurrent.ConcurrentMap v;
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
int v;
java.lang.String v, v, v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v := @parameter: oadd.org.apache.curator.framework.CuratorFramework;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: int;
v := @parameter: oadd.org.apache.curator.framework.recipes.locks.LockInternalsDriver;
specialinvoke v.<java.lang.Object: void <init>()>();
v = staticinvoke <oadd.org.apache.curator.shaded.com.google.common.collect.Maps: java.util.concurrent.ConcurrentMap newConcurrentMap()>();
v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.util.concurrent.ConcurrentMap threadData> = v;
v = staticinvoke <oadd.org.apache.curator.utils.PathUtils: java.lang.String validatePath(java.lang.String)>(v);
v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.lang.String basePath> = v;
v = new oadd.org.apache.curator.framework.recipes.locks.LockInternals;
specialinvoke v.<oadd.org.apache.curator.framework.recipes.locks.LockInternals: void <init>(oadd.org.apache.curator.framework.CuratorFramework,oadd.org.apache.curator.framework.recipes.locks.LockInternalsDriver,java.lang.String,java.lang.String,int)>(v, v, v, v, v);
v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: oadd.org.apache.curator.framework.recipes.locks.LockInternals internals> = v;
return;
}
public boolean isOwnedByCurrentThread()
{
java.util.concurrent.atomic.AtomicInteger v;
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
java.lang.Thread v;
int v;
java.lang.Object v;
boolean v;
java.util.concurrent.ConcurrentMap v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.util.concurrent.ConcurrentMap threadData>;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex$LockData: java.util.concurrent.atomic.AtomicInteger lockCount>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int get()>();
if v <= 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
protected byte[] getLockNodeBytes()
{
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
return null;
}
protected java.lang.String getLockPath()
{
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
java.lang.Thread v;
java.lang.Object v;
java.lang.String v;
java.util.concurrent.ConcurrentMap v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.util.concurrent.ConcurrentMap threadData>;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex$LockData: java.lang.String lockPath>;
goto label;
label:
v = null;
label:
return v;
}
private boolean internalLock(long, java.util.concurrent.TimeUnit) throws java.lang.Exception
{
byte[] v;
long v;
oadd.org.apache.curator.framework.recipes.locks.LockInternals v;
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex$LockData v;
java.util.concurrent.ConcurrentMap v, v;
java.util.concurrent.TimeUnit v;
java.util.concurrent.atomic.AtomicInteger v;
oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex v;
java.lang.Thread v;
java.lang.Object v;
java.lang.String v;
v := @this: oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex;
v := @parameter: long;
v := @parameter: java.util.concurrent.TimeUnit;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.util.concurrent.ConcurrentMap threadData>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v == null goto label;
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex$LockData: java.util.concurrent.atomic.AtomicInteger lockCount>;
virtualinvoke v.<java.util.concurrent.atomic.AtomicInteger: int incrementAndGet()>();
return 1;
label:
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: oadd.org.apache.curator.framework.recipes.locks.LockInternals internals>;
v = virtualinvoke v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: byte[] getLockNodeBytes()>();
v = virtualinvoke v.<oadd.org.apache.curator.framework.recipes.locks.LockInternals: java.lang.String attemptLock(long,java.util.concurrent.TimeUnit,byte[])>(v, v, v);
if v == null goto label;
v = new oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex$LockData;
specialinvoke v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex$LockData: void <init>(java.lang.Thread,java.lang.String)>(v, v);
v = v.<oadd.org.apache.curator.framework.recipes.locks.InterProcessMutex: java.util.concurrent.ConcurrentMap threadData>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
return 1;
label:
return 0;
}
}