class io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl implements io.vertx.core.shareddata.Lock
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl
  super_class: java.lang.Object
{
  private final org.apache.ignite.IgniteSemaphore semaphore;
    descriptor: Lorg/apache/ignite/IgniteSemaphore;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.Executor lockReleaseExec;
    descriptor: Ljava/util/concurrent/Executor;
    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

  private void <init>(org.apache.ignite.IgniteSemaphore, java.util.concurrent.Executor);
    descriptor: (Lorg/apache/ignite/IgniteSemaphore;Ljava/util/concurrent/Executor;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl this
        start local 1 // org.apache.ignite.IgniteSemaphore semaphore
        start local 2 // java.util.concurrent.Executor lockReleaseExec
         0: .line 448
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 446
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicBoolean
            dup
            invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:()V
            putfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.released:Ljava/util/concurrent/atomic/AtomicBoolean;
         2: .line 449
            aload 0 /* this */
            aload 1 /* semaphore */
            putfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.semaphore:Lorg/apache/ignite/IgniteSemaphore;
         3: .line 450
            aload 0 /* this */
            aload 2 /* lockReleaseExec */
            putfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.lockReleaseExec:Ljava/util/concurrent/Executor;
         4: .line 451
            return
        end local 2 // java.util.concurrent.Executor lockReleaseExec
        end local 1 // org.apache.ignite.IgniteSemaphore semaphore
        end local 0 // io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    5     0             this  Lio/vertx/spi/cluster/ignite/IgniteClusterManager$LockImpl;
            0    5     1        semaphore  Lorg/apache/ignite/IgniteSemaphore;
            0    5     2  lockReleaseExec  Ljava/util/concurrent/Executor;
    MethodParameters:
                 Name  Flags
      semaphore        
      lockReleaseExec  

  public void release();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl this
         0: .line 455
            aload 0 /* this */
            getfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.released:Ljava/util/concurrent/atomic/AtomicBoolean;
            iconst_0
            iconst_1
            invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
            ifeq 2
         1: .line 456
            aload 0 /* this */
            getfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.lockReleaseExec:Ljava/util/concurrent/Executor;
            aload 0 /* this */
            getfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.semaphore:Lorg/apache/ignite/IgniteSemaphore;
            dup
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            pop
            invokedynamic run(Lorg/apache/ignite/IgniteSemaphore;)Ljava/lang/Runnable;
              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:
                  ()V
                  org/apache/ignite/IgniteSemaphore.release()V (9 itf)
                  ()V
            invokeinterface java.util.concurrent.Executor.execute:(Ljava/lang/Runnable;)V
         2: .line 458
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/vertx/spi/cluster/ignite/IgniteClusterManager$LockImpl;
}
SourceFile: "IgniteClusterManager.java"
NestHost: io.vertx.spi.cluster.ignite.IgniteClusterManager
InnerClasses:
  private LockImpl = io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl of io.vertx.spi.cluster.ignite.IgniteClusterManager
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles