class io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock implements io.vertx.core.shareddata.impl.LockInternal
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock
  super_class: java.lang.Object
{
  final java.lang.String lockName;
    descriptor: Ljava/lang/String;
    flags: (0x0010) ACC_FINAL

  final java.util.concurrent.atomic.AtomicBoolean invoked;
    descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
    flags: (0x0010) ACC_FINAL

  final io.vertx.core.shareddata.impl.LocalAsyncLocks this$0;
    descriptor: Lio/vertx/core/shareddata/impl/LocalAsyncLocks;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  void <init>(io.vertx.core.shareddata.impl.LocalAsyncLocks, java.lang.String);
    descriptor: (Lio/vertx/core/shareddata/impl/LocalAsyncLocks;Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock this
        start local 2 // java.lang.String lockName
         0: .line 83
            aload 0 /* this */
            aload 1
            putfield io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock.this$0:Lio/vertx/core/shareddata/impl/LocalAsyncLocks;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 81
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicBoolean
            dup
            invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:()V
            putfield io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock.invoked:Ljava/util/concurrent/atomic/AtomicBoolean;
         2: .line 84
            aload 0 /* this */
            aload 2 /* lockName */
            putfield io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock.lockName:Ljava/lang/String;
         3: .line 85
            return
        end local 2 // java.lang.String lockName
        end local 0 // io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0      this  Lio/vertx/core/shareddata/impl/LocalAsyncLocks$AsyncLock;
            0    4     2  lockName  Ljava/lang/String;
    MethodParameters:
          Name  Flags
      this$0    final
      lockName  

  public void release();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock this
         0: .line 89
            aload 0 /* this */
            getfield io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock.invoked:Ljava/util/concurrent/atomic/AtomicBoolean;
            iconst_0
            iconst_1
            invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
            ifeq 2
         1: .line 90
            aload 0 /* this */
            getfield io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock.this$0:Lio/vertx/core/shareddata/impl/LocalAsyncLocks;
            aload 0 /* this */
            getfield io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock.lockName:Ljava/lang/String;
            invokevirtual io.vertx.core.shareddata.impl.LocalAsyncLocks.nextWaiter:(Ljava/lang/String;)V
         2: .line 92
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/vertx/core/shareddata/impl/LocalAsyncLocks$AsyncLock;

  public int waiters();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock this
         0: .line 96
            aload 0 /* this */
            getfield io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock.this$0:Lio/vertx/core/shareddata/impl/LocalAsyncLocks;
            getfield io.vertx.core.shareddata.impl.LocalAsyncLocks.waitersMap:Ljava/util/concurrent/ConcurrentMap;
            aload 0 /* this */
            getfield io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock.lockName:Ljava/lang/String;
            invokeinterface java.util.concurrent.ConcurrentMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.List
            astore 1 /* waiters */
        start local 1 // java.util.List waiters
         1: .line 97
            aload 1 /* waiters */
            ifnonnull 2
            iconst_0
            goto 3
      StackMap locals: java.util.List
      StackMap stack:
         2: aload 1 /* waiters */
            invokeinterface java.util.List.size:()I
            iconst_1
            isub
      StackMap locals:
      StackMap stack: int
         3: ireturn
        end local 1 // java.util.List waiters
        end local 0 // io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    4     0     this  Lio/vertx/core/shareddata/impl/LocalAsyncLocks$AsyncLock;
            1    4     1  waiters  Ljava/util/List<Lio/vertx/core/shareddata/impl/LocalAsyncLocks$LockWaiter;>;
}
SourceFile: "LocalAsyncLocks.java"
NestHost: io.vertx.core.shareddata.impl.LocalAsyncLocks
InnerClasses:
  private AsyncLock = io.vertx.core.shareddata.impl.LocalAsyncLocks$AsyncLock of io.vertx.core.shareddata.impl.LocalAsyncLocks