class io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock implements io.vertx.core.shareddata.Lock
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock
  super_class: java.lang.Object
{
  private final com.hazelcast.core.ISemaphore semaphore;
    descriptor: Lcom/hazelcast/core/ISemaphore;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.atomic.AtomicBoolean released;
    descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  final io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this$0;
    descriptor: Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  private void <init>(io.vertx.spi.cluster.hazelcast.HazelcastClusterManager, com.hazelcast.core.ISemaphore);
    descriptor: (Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;Lcom/hazelcast/core/ISemaphore;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock this
        start local 2 // com.hazelcast.core.ISemaphore semaphore
         0: .line 450
            aload 0 /* this */
            aload 1
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock.this$0:Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 448
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicBoolean
            dup
            invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:()V
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock.released:Ljava/util/concurrent/atomic/AtomicBoolean;
         2: .line 451
            aload 0 /* this */
            aload 2 /* semaphore */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock.semaphore:Lcom/hazelcast/core/ISemaphore;
         3: .line 452
            return
        end local 2 // com.hazelcast.core.ISemaphore semaphore
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0       this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager$HazelcastLock;
            0    4     2  semaphore  Lcom/hazelcast/core/ISemaphore;
    MethodParameters:
           Name  Flags
      this$0     final
      semaphore  

  public void release();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock this
         0: .line 456
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock.released:Ljava/util/concurrent/atomic/AtomicBoolean;
            iconst_0
            iconst_1
            invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
            ifeq 4
         1: .line 457
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock.this$0:Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
            aload 0 /* this */
            invokedynamic handle(Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager$HazelcastLock;)Lio/vertx/core/Handler;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)V
                  io/vertx/spi/cluster/hazelcast/HazelcastClusterManager$HazelcastLock.lambda$0(Lio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         2: .line 460
            iconst_0
            aconst_null
         3: .line 457
            invokeinterface io.vertx.core.Vertx.executeBlocking:(Lio/vertx/core/Handler;ZLio/vertx/core/Handler;)V
         4: .line 462
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager$HazelcastLock;

  private void lambda$0(io.vertx.core.Promise);
    descriptor: (Lio/vertx/core/Promise;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock this
        start local 1 // io.vertx.core.Promise future
         0: .line 458
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock.semaphore:Lcom/hazelcast/core/ISemaphore;
            invokeinterface com.hazelcast.core.ISemaphore.release:()V
         1: .line 459
            aload 1 /* future */
            invokeinterface io.vertx.core.Promise.complete:()V
         2: .line 460
            return
        end local 1 // io.vertx.core.Promise future
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager$HazelcastLock;
            0    3     1  future  Lio/vertx/core/Promise<Ljava/lang/Object;>;
}
SourceFile: "HazelcastClusterManager.java"
NestHost: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager
InnerClasses:
  private HazelcastLock = io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock of io.vertx.spi.cluster.hazelcast.HazelcastClusterManager
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles