public abstract class org.apache.cassandra.utils.concurrent.SharedCloseableImpl implements org.apache.cassandra.utils.concurrent.SharedCloseable
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: org.apache.cassandra.utils.concurrent.SharedCloseableImpl
  super_class: java.lang.Object
{
  final org.apache.cassandra.utils.concurrent.Ref<?> ref;
    descriptor: Lorg/apache/cassandra/utils/concurrent/Ref;
    flags: (0x0010) ACC_FINAL
    Signature: Lorg/apache/cassandra/utils/concurrent/Ref<*>;

  public void <init>(org.apache.cassandra.utils.concurrent.RefCounted$Tidy);
    descriptor: (Lorg/apache/cassandra/utils/concurrent/RefCounted$Tidy;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
        start local 1 // org.apache.cassandra.utils.concurrent.RefCounted$Tidy tidy
         0: .line 28
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 30
            aload 0 /* this */
            new org.apache.cassandra.utils.concurrent.Ref
            dup
            aconst_null
            aload 1 /* tidy */
            invokespecial org.apache.cassandra.utils.concurrent.Ref.<init>:(Ljava/lang/Object;Lorg/apache/cassandra/utils/concurrent/RefCounted$Tidy;)V
            putfield org.apache.cassandra.utils.concurrent.SharedCloseableImpl.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
         2: .line 31
            return
        end local 1 // org.apache.cassandra.utils.concurrent.RefCounted$Tidy tidy
        end local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/utils/concurrent/SharedCloseableImpl;
            0    3     1  tidy  Lorg/apache/cassandra/utils/concurrent/RefCounted$Tidy;
    MethodParameters:
      Name  Flags
      tidy  

  protected void <init>(org.apache.cassandra.utils.concurrent.SharedCloseableImpl);
    descriptor: (Lorg/apache/cassandra/utils/concurrent/SharedCloseableImpl;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
        start local 1 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl copy
         0: .line 33
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 35
            aload 0 /* this */
            aload 1 /* copy */
            getfield org.apache.cassandra.utils.concurrent.SharedCloseableImpl.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
            invokevirtual org.apache.cassandra.utils.concurrent.Ref.ref:()Lorg/apache/cassandra/utils/concurrent/Ref;
            putfield org.apache.cassandra.utils.concurrent.SharedCloseableImpl.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
         2: .line 36
            return
        end local 1 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl copy
        end local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/utils/concurrent/SharedCloseableImpl;
            0    3     1  copy  Lorg/apache/cassandra/utils/concurrent/SharedCloseableImpl;
    MethodParameters:
      Name  Flags
      copy  

  public boolean isCleanedUp();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
         0: .line 40
            aload 0 /* this */
            getfield org.apache.cassandra.utils.concurrent.SharedCloseableImpl.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
            invokevirtual org.apache.cassandra.utils.concurrent.Ref.globalCount:()I
            ifne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/utils/concurrent/SharedCloseableImpl;

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
         0: .line 45
            aload 0 /* this */
            getfield org.apache.cassandra.utils.concurrent.SharedCloseableImpl.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
            invokevirtual org.apache.cassandra.utils.concurrent.Ref.ensureReleased:()V
         1: .line 46
            return
        end local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/utils/concurrent/SharedCloseableImpl;

  public java.lang.Throwable close(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)Ljava/lang/Throwable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
        start local 1 // java.lang.Throwable accumulate
         0: .line 50
            aload 0 /* this */
            getfield org.apache.cassandra.utils.concurrent.SharedCloseableImpl.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
            aload 1 /* accumulate */
            invokevirtual org.apache.cassandra.utils.concurrent.Ref.ensureReleased:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            areturn
        end local 1 // java.lang.Throwable accumulate
        end local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lorg/apache/cassandra/utils/concurrent/SharedCloseableImpl;
            0    1     1  accumulate  Ljava/lang/Throwable;
    MethodParameters:
            Name  Flags
      accumulate  

  public void addTo(org.apache.cassandra.utils.concurrent.Ref$IdentityCollection);
    descriptor: (Lorg/apache/cassandra/utils/concurrent/Ref$IdentityCollection;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
        start local 1 // org.apache.cassandra.utils.concurrent.Ref$IdentityCollection identities
         0: .line 55
            aload 1 /* identities */
            aload 0 /* this */
            getfield org.apache.cassandra.utils.concurrent.SharedCloseableImpl.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
            invokevirtual org.apache.cassandra.utils.concurrent.Ref$IdentityCollection.add:(Lorg/apache/cassandra/utils/concurrent/Ref;)V
         1: .line 56
            return
        end local 1 // org.apache.cassandra.utils.concurrent.Ref$IdentityCollection identities
        end local 0 // org.apache.cassandra.utils.concurrent.SharedCloseableImpl this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lorg/apache/cassandra/utils/concurrent/SharedCloseableImpl;
            0    2     1  identities  Lorg/apache/cassandra/utils/concurrent/Ref$IdentityCollection;
    MethodParameters:
            Name  Flags
      identities  
}
SourceFile: "SharedCloseableImpl.java"
InnerClasses:
  public IdentityCollection = org.apache.cassandra.utils.concurrent.Ref$IdentityCollection of org.apache.cassandra.utils.concurrent.Ref
  public abstract Tidy = org.apache.cassandra.utils.concurrent.RefCounted$Tidy of org.apache.cassandra.utils.concurrent.RefCounted