class javax.security.auth.Subject$SecureSet<E> implements java.util.Set<E>, java.io.Serializable
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: javax.security.auth.Subject$SecureSet
  super_class: java.lang.Object
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 7911754171111800359

  private static final java.io.ObjectStreamField[] serialPersistentFields;
    descriptor: [Ljava/io/ObjectStreamField;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  javax.security.auth.Subject subject;
    descriptor: Ljavax/security/auth/Subject;
    flags: (0x0000) 

  java.util.LinkedList<E> elements;
    descriptor: Ljava/util/LinkedList;
    flags: (0x0000) 
    Signature: Ljava/util/LinkedList<TE;>;

  private int which;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=7, locals=0, args_size=0
         0: .line 1036
            iconst_3
            anewarray java.io.ObjectStreamField
            dup
            iconst_0
         1: .line 1037
            new java.io.ObjectStreamField
            dup
            ldc "this$0"
            ldc Ljavax/security/auth/Subject;
            invokespecial java.io.ObjectStreamField.<init>:(Ljava/lang/String;Ljava/lang/Class;)V
            aastore
            dup
            iconst_1
         2: .line 1038
            new java.io.ObjectStreamField
            dup
            ldc "elements"
            ldc Ljava/util/LinkedList;
            invokespecial java.io.ObjectStreamField.<init>:(Ljava/lang/String;Ljava/lang/Class;)V
            aastore
            dup
            iconst_2
         3: .line 1039
            new java.io.ObjectStreamField
            dup
            ldc "which"
            getstatic java.lang.Integer.TYPE:Ljava/lang/Class;
            invokespecial java.io.ObjectStreamField.<init>:(Ljava/lang/String;Ljava/lang/Class;)V
            aastore
         4: .line 1036
            putstatic javax.security.auth.Subject$SecureSet.serialPersistentFields:[Ljava/io/ObjectStreamField;
         5: .line 1040
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(javax.security.auth.Subject, int);
    descriptor: (Ljavax/security/auth/Subject;I)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // javax.security.auth.Subject subject
        start local 2 // int which
         0: .line 1057
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 1058
            aload 0 /* this */
            aload 1 /* subject */
            putfield javax.security.auth.Subject$SecureSet.subject:Ljavax/security/auth/Subject;
         2: .line 1059
            aload 0 /* this */
            iload 2 /* which */
            putfield javax.security.auth.Subject$SecureSet.which:I
         3: .line 1060
            aload 0 /* this */
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            putfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
         4: .line 1061
            return
        end local 2 // int which
        end local 1 // javax.security.auth.Subject subject
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0    5     1  subject  Ljavax/security/auth/Subject;
            0    5     2    which  I
    MethodParameters:
         Name  Flags
      subject  
      which    

  void <init>(javax.security.auth.Subject, int, java.util.Set<? extends E>);
    descriptor: (Ljavax/security/auth/Subject;ILjava/util/Set;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // javax.security.auth.Subject subject
        start local 2 // int which
        start local 3 // java.util.Set set
         0: .line 1063
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 1064
            aload 0 /* this */
            aload 1 /* subject */
            putfield javax.security.auth.Subject$SecureSet.subject:Ljavax/security/auth/Subject;
         2: .line 1065
            aload 0 /* this */
            iload 2 /* which */
            putfield javax.security.auth.Subject$SecureSet.which:I
         3: .line 1066
            aload 0 /* this */
            new java.util.LinkedList
            dup
            aload 3 /* set */
            invokespecial java.util.LinkedList.<init>:(Ljava/util/Collection;)V
            putfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
         4: .line 1067
            return
        end local 3 // java.util.Set set
        end local 2 // int which
        end local 1 // javax.security.auth.Subject subject
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0    5     1  subject  Ljavax/security/auth/Subject;
            0    5     2    which  I
            0    5     3      set  Ljava/util/Set<+TE;>;
    Signature: (Ljavax/security/auth/Subject;ILjava/util/Set<+TE;>;)V
    MethodParameters:
         Name  Flags
      subject  
      which    
      set      

  public int size();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.security.auth.Subject$SecureSet this
         0: .line 1070
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
            invokevirtual java.util.LinkedList.size:()I
            ireturn
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;

  public java.util.Iterator<E> iterator();
    descriptor: ()Ljava/util/Iterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // javax.security.auth.Subject$SecureSet this
         0: .line 1074
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
            astore 1 /* list */
        start local 1 // java.util.LinkedList list
         1: .line 1075
            new javax.security.auth.Subject$SecureSet$1
            dup
            aload 0 /* this */
            aload 1 /* list */
            invokespecial javax.security.auth.Subject$SecureSet$1.<init>:(Ljavax/security/auth/Subject$SecureSet;Ljava/util/LinkedList;)V
            areturn
        end local 1 // java.util.LinkedList list
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            1    2     1  list  Ljava/util/LinkedList<TE;>;
    Signature: ()Ljava/util/Iterator<TE;>;

  public boolean add();
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // java.lang.Object o
         0: .line 1127
            aload 1 /* o */
         1: .line 1128
            ldc "invalid.null.input.s."
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         2: .line 1127
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         3: .line 1130
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.subject:Ljavax/security/auth/Subject;
            invokevirtual javax.security.auth.Subject.isReadOnly:()Z
            ifeq 7
         4: .line 1131
            new java.lang.IllegalStateException
            dup
         5: .line 1132
            ldc "Subject.is.read.only"
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         6: .line 1131
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 1135
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 2 /* sm */
        start local 2 // java.lang.SecurityManager sm
         8: .line 1136
            aload 2 /* sm */
            ifnull 15
         9: .line 1137
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.which:I
            tableswitch { // 1 - 2
                    1: 10
                    2: 12
              default: 14
          }
        10: .line 1139
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            aload 2 /* sm */
            getstatic javax.security.auth.Subject$AuthPermissionHolder.MODIFY_PRINCIPALS_PERMISSION:Ljavax/security/auth/AuthPermission;
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
        11: .line 1140
            goto 15
        12: .line 1142
      StackMap locals:
      StackMap stack:
            aload 2 /* sm */
            getstatic javax.security.auth.Subject$AuthPermissionHolder.MODIFY_PUBLIC_CREDENTIALS_PERMISSION:Ljavax/security/auth/AuthPermission;
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
        13: .line 1143
            goto 15
        14: .line 1145
      StackMap locals:
      StackMap stack:
            aload 2 /* sm */
            getstatic javax.security.auth.Subject$AuthPermissionHolder.MODIFY_PRIVATE_CREDENTIALS_PERMISSION:Ljavax/security/auth/AuthPermission;
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
        15: .line 1150
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.which:I
            tableswitch { // 1 - 1
                    1: 16
              default: 20
          }
        16: .line 1152
      StackMap locals:
      StackMap stack:
            aload 1 /* o */
            instanceof java.security.Principal
            ifne 20
        17: .line 1153
            new java.lang.SecurityException
            dup
        18: .line 1154
            ldc "attempting.to.add.an.object.which.is.not.an.instance.of.java.security.Principal.to.a.Subject.s.Principal.Set"
        19: .line 1153
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokespecial java.lang.SecurityException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 1163
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
            aload 1 /* o */
            invokevirtual java.util.LinkedList.contains:(Ljava/lang/Object;)Z
            ifne 22
        21: .line 1164
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
            aload 1 /* o */
            invokevirtual java.util.LinkedList.add:(Ljava/lang/Object;)Z
            ireturn
        22: .line 1166
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // java.lang.SecurityManager sm
        end local 1 // java.lang.Object o
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   23     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0   23     1     o  TE;
            8   23     2    sm  Ljava/lang/SecurityManager;
    Signature: (TE;)Z
    MethodParameters:
      Name  Flags
      o     

  public boolean remove(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // java.lang.Object o
         0: .line 1172
            aload 1 /* o */
         1: .line 1173
            ldc "invalid.null.input.s."
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         2: .line 1172
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         3: .line 1175
            aload 0 /* this */
            invokevirtual javax.security.auth.Subject$SecureSet.iterator:()Ljava/util/Iterator;
            astore 2 /* e */
        start local 2 // java.util.Iterator e
         4: .line 1176
            goto 13
         5: .line 1178
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.which:I
            iconst_3
            if_icmpeq 8
         6: .line 1179
            aload 2 /* e */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 3 /* next */
        start local 3 // java.lang.Object next
         7: .line 1180
            goto 10
        end local 3 // java.lang.Object next
         8: .line 1182
      StackMap locals:
      StackMap stack:
            new javax.security.auth.Subject$SecureSet$2
            dup
            aload 0 /* this */
            aload 2 /* e */
            invokespecial javax.security.auth.Subject$SecureSet$2.<init>:(Ljavax/security/auth/Subject$SecureSet;Ljava/util/Iterator;)V
         9: .line 1181
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            astore 3 /* next */
        start local 3 // java.lang.Object next
        10: .line 1189
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 3 /* next */
            aload 1 /* o */
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 13
        11: .line 1190
            aload 2 /* e */
            invokeinterface java.util.Iterator.remove:()V
        12: .line 1191
            iconst_1
            ireturn
        end local 3 // java.lang.Object next
        13: .line 1176
      StackMap locals:
      StackMap stack:
            aload 2 /* e */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        14: .line 1194
            iconst_0
            ireturn
        end local 2 // java.util.Iterator e
        end local 1 // java.lang.Object o
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   15     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0   15     1     o  Ljava/lang/Object;
            4   15     2     e  Ljava/util/Iterator<TE;>;
            7    8     3  next  TE;
           10   13     3  next  TE;
    MethodParameters:
      Name  Flags
      o     

  public boolean contains(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // java.lang.Object o
         0: .line 1199
            aload 1 /* o */
         1: .line 1200
            ldc "invalid.null.input.s."
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         2: .line 1199
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         3: .line 1202
            aload 0 /* this */
            invokevirtual javax.security.auth.Subject$SecureSet.iterator:()Ljava/util/Iterator;
            astore 2 /* e */
        start local 2 // java.util.Iterator e
         4: .line 1203
            goto 18
         5: .line 1205
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.which:I
            iconst_3
            if_icmpeq 8
         6: .line 1206
            aload 2 /* e */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 3 /* next */
        start local 3 // java.lang.Object next
         7: .line 1207
            goto 16
        end local 3 // java.lang.Object next
         8: .line 1215
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 4 /* sm */
        start local 4 // java.lang.SecurityManager sm
         9: .line 1216
            aload 4 /* sm */
            ifnull 14
        10: .line 1217
            aload 4 /* sm */
            new javax.security.auth.PrivateCredentialPermission
            dup
        11: .line 1218
            aload 1 /* o */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
        12: .line 1219
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.subject:Ljavax/security/auth/Subject;
            invokevirtual javax.security.auth.Subject.getPrincipals:()Ljava/util/Set;
            invokespecial javax.security.auth.PrivateCredentialPermission.<init>:(Ljava/lang/String;Ljava/util/Set;)V
        13: .line 1217
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
        14: .line 1222
      StackMap locals: javax.security.auth.Subject$SecureSet java.lang.Object java.util.Iterator top java.lang.SecurityManager
      StackMap stack:
            new javax.security.auth.Subject$SecureSet$3
            dup
            aload 0 /* this */
            aload 2 /* e */
            invokespecial javax.security.auth.Subject$SecureSet$3.<init>:(Ljavax/security/auth/Subject$SecureSet;Ljava/util/Iterator;)V
        15: .line 1221
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            astore 3 /* next */
        end local 4 // java.lang.SecurityManager sm
        start local 3 // java.lang.Object next
        16: .line 1229
      StackMap locals: javax.security.auth.Subject$SecureSet java.lang.Object java.util.Iterator java.lang.Object
      StackMap stack:
            aload 3 /* next */
            aload 1 /* o */
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 18
        17: .line 1230
            iconst_1
            ireturn
        end local 3 // java.lang.Object next
        18: .line 1203
      StackMap locals:
      StackMap stack:
            aload 2 /* e */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        19: .line 1233
            iconst_0
            ireturn
        end local 2 // java.util.Iterator e
        end local 1 // java.lang.Object o
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   20     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0   20     1     o  Ljava/lang/Object;
            4   20     2     e  Ljava/util/Iterator<TE;>;
            7    8     3  next  TE;
           16   18     3  next  TE;
            9   16     4    sm  Ljava/lang/SecurityManager;
    MethodParameters:
      Name  Flags
      o     

  public boolean addAll(java.util.Collection<? extends E>);
    descriptor: (Ljava/util/Collection;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // java.util.Collection c
         0: .line 1237
            iconst_0
            istore 2 /* result */
        start local 2 // boolean result
         1: .line 1239
            aload 1 /* c */
            invokestatic javax.security.auth.Subject.collectionNullClean:(Ljava/util/Collection;)V
         2: .line 1241
            aload 1 /* c */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 5
      StackMap locals: javax.security.auth.Subject$SecureSet java.util.Collection int top java.util.Iterator
      StackMap stack:
         3: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Object
            astore 3 /* item */
        start local 3 // java.lang.Object item
         4: .line 1242
            iload 2 /* result */
            aload 0 /* this */
            aload 3 /* item */
            invokevirtual javax.security.auth.Subject$SecureSet.add:(Ljava/lang/Object;)Z
            ior
            istore 2 /* result */
        end local 3 // java.lang.Object item
         5: .line 1241
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 1245
            iload 2 /* result */
            ireturn
        end local 2 // boolean result
        end local 1 // java.util.Collection c
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    7     0    this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0    7     1       c  Ljava/util/Collection<+TE;>;
            1    7     2  result  Z
            4    5     3    item  TE;
    Signature: (Ljava/util/Collection<+TE;>;)Z
    MethodParameters:
      Name  Flags
      c     

  public boolean removeAll(java.util.Collection<?>);
    descriptor: (Ljava/util/Collection;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=2
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // java.util.Collection c
         0: .line 1249
            aload 1 /* c */
            invokestatic javax.security.auth.Subject.collectionNullClean:(Ljava/util/Collection;)V
         1: .line 1251
            iconst_0
            istore 2 /* modified */
        start local 2 // boolean modified
         2: .line 1252
            aload 0 /* this */
            invokevirtual javax.security.auth.Subject$SecureSet.iterator:()Ljava/util/Iterator;
            astore 3 /* e */
        start local 3 // java.util.Iterator e
         3: .line 1253
            goto 16
         4: .line 1255
      StackMap locals: int java.util.Iterator
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.which:I
            iconst_3
            if_icmpeq 7
         5: .line 1256
            aload 3 /* e */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 4 /* next */
        start local 4 // java.lang.Object next
         6: .line 1257
            goto 9
        end local 4 // java.lang.Object next
         7: .line 1259
      StackMap locals:
      StackMap stack:
            new javax.security.auth.Subject$SecureSet$4
            dup
            aload 0 /* this */
            aload 3 /* e */
            invokespecial javax.security.auth.Subject$SecureSet$4.<init>:(Ljavax/security/auth/Subject$SecureSet;Ljava/util/Iterator;)V
         8: .line 1258
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            astore 4 /* next */
        start local 4 // java.lang.Object next
         9: .line 1266
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 1 /* c */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 5 /* ce */
        start local 5 // java.util.Iterator ce
        10: .line 1267
            goto 15
        11: .line 1268
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 4 /* next */
            aload 5 /* ce */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 15
        12: .line 1269
            aload 3 /* e */
            invokeinterface java.util.Iterator.remove:()V
        13: .line 1270
            iconst_1
            istore 2 /* modified */
        14: .line 1271
            goto 16
        15: .line 1267
      StackMap locals:
      StackMap stack:
            aload 5 /* ce */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 11
        end local 5 // java.util.Iterator ce
        end local 4 // java.lang.Object next
        16: .line 1253
      StackMap locals:
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        17: .line 1275
            iload 2 /* modified */
            ireturn
        end local 3 // java.util.Iterator e
        end local 2 // boolean modified
        end local 1 // java.util.Collection c
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   18     0      this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0   18     1         c  Ljava/util/Collection<*>;
            2   18     2  modified  Z
            3   18     3         e  Ljava/util/Iterator<TE;>;
            6    7     4      next  TE;
            9   16     4      next  TE;
           10   16     5        ce  Ljava/util/Iterator<*>;
    Signature: (Ljava/util/Collection<*>;)Z
    MethodParameters:
      Name  Flags
      c     

  public boolean containsAll(java.util.Collection<?>);
    descriptor: (Ljava/util/Collection;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // java.util.Collection c
         0: .line 1279
            aload 1 /* c */
            invokestatic javax.security.auth.Subject.collectionNullClean:(Ljava/util/Collection;)V
         1: .line 1281
            aload 1 /* c */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 5
      StackMap locals: javax.security.auth.Subject$SecureSet java.util.Collection top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 2 /* item */
        start local 2 // java.lang.Object item
         3: .line 1282
            aload 0 /* this */
            aload 2 /* item */
            invokevirtual javax.security.auth.Subject$SecureSet.contains:(Ljava/lang/Object;)Z
            ifne 5
         4: .line 1283
            iconst_0
            ireturn
        end local 2 // java.lang.Object item
         5: .line 1281
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         6: .line 1287
            iconst_1
            ireturn
        end local 1 // java.util.Collection c
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0    7     1     c  Ljava/util/Collection<*>;
            3    5     2  item  Ljava/lang/Object;
    Signature: (Ljava/util/Collection<*>;)Z
    MethodParameters:
      Name  Flags
      c     

  public boolean retainAll(java.util.Collection<?>);
    descriptor: (Ljava/util/Collection;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=2
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // java.util.Collection c
         0: .line 1291
            aload 1 /* c */
            invokestatic javax.security.auth.Subject.collectionNullClean:(Ljava/util/Collection;)V
         1: .line 1293
            iconst_0
            istore 2 /* modified */
        start local 2 // boolean modified
         2: .line 1294
            aload 0 /* this */
            invokevirtual javax.security.auth.Subject$SecureSet.iterator:()Ljava/util/Iterator;
            astore 3 /* e */
        start local 3 // java.util.Iterator e
         3: .line 1295
            goto 12
         4: .line 1297
      StackMap locals: int java.util.Iterator
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.which:I
            iconst_3
            if_icmpeq 7
         5: .line 1298
            aload 3 /* e */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 4 /* next */
        start local 4 // java.lang.Object next
         6: .line 1299
            goto 9
        end local 4 // java.lang.Object next
         7: .line 1301
      StackMap locals:
      StackMap stack:
            new javax.security.auth.Subject$SecureSet$5
            dup
            aload 0 /* this */
            aload 3 /* e */
            invokespecial javax.security.auth.Subject$SecureSet$5.<init>:(Ljavax/security/auth/Subject$SecureSet;Ljava/util/Iterator;)V
         8: .line 1300
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            astore 4 /* next */
        start local 4 // java.lang.Object next
         9: .line 1308
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 1 /* c */
            aload 4 /* next */
            invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
            ifne 12
        10: .line 1309
            aload 3 /* e */
            invokeinterface java.util.Iterator.remove:()V
        11: .line 1310
            iconst_1
            istore 2 /* modified */
        end local 4 // java.lang.Object next
        12: .line 1295
      StackMap locals:
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        13: .line 1314
            iload 2 /* modified */
            ireturn
        end local 3 // java.util.Iterator e
        end local 2 // boolean modified
        end local 1 // java.util.Collection c
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   14     0      this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0   14     1         c  Ljava/util/Collection<*>;
            2   14     2  modified  Z
            3   14     3         e  Ljava/util/Iterator<TE;>;
            6    7     4      next  TE;
            9   12     4      next  TE;
    Signature: (Ljava/util/Collection<*>;)Z
    MethodParameters:
      Name  Flags
      c     

  public void clear();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // javax.security.auth.Subject$SecureSet this
         0: .line 1318
            aload 0 /* this */
            invokevirtual javax.security.auth.Subject$SecureSet.iterator:()Ljava/util/Iterator;
            astore 1 /* e */
        start local 1 // java.util.Iterator e
         1: .line 1319
            goto 8
         2: .line 1321
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.which:I
            iconst_3
            if_icmpeq 5
         3: .line 1322
            aload 1 /* e */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            pop
         4: .line 1323
            goto 7
         5: .line 1325
      StackMap locals:
      StackMap stack:
            new javax.security.auth.Subject$SecureSet$6
            dup
            aload 0 /* this */
            aload 1 /* e */
            invokespecial javax.security.auth.Subject$SecureSet$6.<init>:(Ljavax/security/auth/Subject$SecureSet;Ljava/util/Iterator;)V
         6: .line 1324
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            pop
         7: .line 1331
      StackMap locals:
      StackMap stack:
            aload 1 /* e */
            invokeinterface java.util.Iterator.remove:()V
         8: .line 1319
      StackMap locals:
      StackMap stack:
            aload 1 /* e */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         9: .line 1333
            return
        end local 1 // java.util.Iterator e
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            1   10     1     e  Ljava/util/Iterator<TE;>;

  public boolean isEmpty();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.security.auth.Subject$SecureSet this
         0: .line 1336
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
            invokevirtual java.util.LinkedList.isEmpty:()Z
            ireturn
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;

  public java.lang.Object[] toArray();
    descriptor: ()[Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=1
        start local 0 // javax.security.auth.Subject$SecureSet this
         0: .line 1340
            aload 0 /* this */
            invokevirtual javax.security.auth.Subject$SecureSet.iterator:()Ljava/util/Iterator;
            astore 1 /* e */
        start local 1 // java.util.Iterator e
         1: .line 1341
            goto 3
         2: .line 1347
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 1 /* e */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            pop
         3: .line 1341
      StackMap locals:
      StackMap stack:
            aload 1 /* e */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         4: .line 1350
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
            invokevirtual java.util.LinkedList.toArray:()[Ljava/lang/Object;
            areturn
        end local 1 // java.util.Iterator e
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            1    5     1     e  Ljava/util/Iterator<TE;>;

  public <T> T[] toArray();
    descriptor: ([Ljava/lang/Object;)[Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // java.lang.Object[] a
         0: .line 1354
            aload 0 /* this */
            invokevirtual javax.security.auth.Subject$SecureSet.iterator:()Ljava/util/Iterator;
            astore 2 /* e */
        start local 2 // java.util.Iterator e
         1: .line 1355
            goto 3
         2: .line 1361
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 2 /* e */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            pop
         3: .line 1355
      StackMap locals:
      StackMap stack:
            aload 2 /* e */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         4: .line 1364
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
            aload 1 /* a */
            invokevirtual java.util.LinkedList.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            areturn
        end local 2 // java.util.Iterator e
        end local 1 // java.lang.Object[] a
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0    5     1     a  [Ljava/lang/Object;
            1    5     2     e  Ljava/util/Iterator<TE;>;
    Signature: <T:Ljava/lang/Object;>([TT;)[TT;
    MethodParameters:
      Name  Flags
      a     

  public boolean equals(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // java.lang.Object o
         0: .line 1368
            aload 1 /* o */
            aload 0 /* this */
            if_acmpne 2
         1: .line 1369
            iconst_1
            ireturn
         2: .line 1372
      StackMap locals:
      StackMap stack:
            aload 1 /* o */
            instanceof java.util.Set
            ifne 4
         3: .line 1373
            iconst_0
            ireturn
         4: .line 1376
      StackMap locals:
      StackMap stack:
            aload 1 /* o */
            checkcast java.util.Collection
            astore 2 /* c */
        start local 2 // java.util.Collection c
         5: .line 1377
            aload 2 /* c */
            invokeinterface java.util.Collection.size:()I
            aload 0 /* this */
            invokevirtual javax.security.auth.Subject$SecureSet.size:()I
            if_icmpeq 7
         6: .line 1378
            iconst_0
            ireturn
         7: .line 1382
      StackMap locals: java.util.Collection
      StackMap stack:
            aload 0 /* this */
            aload 2 /* c */
            invokevirtual javax.security.auth.Subject$SecureSet.containsAll:(Ljava/util/Collection;)Z
         8: ireturn
         9: .line 1383
      StackMap locals:
      StackMap stack: java.lang.ClassCastException
            pop
        10: .line 1384
            iconst_0
            ireturn
        11: .line 1385
      StackMap locals:
      StackMap stack: java.lang.NullPointerException
            pop
        12: .line 1386
            iconst_0
            ireturn
        end local 2 // java.util.Collection c
        end local 1 // java.lang.Object o
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0   13     1     o  Ljava/lang/Object;
            5   13     2     c  Ljava/util/Collection<*>;
      Exception table:
        from    to  target  type
           7     8       9  Class java.lang.ClassCastException
           7     8      11  Class java.lang.NullPointerException
    MethodParameters:
      Name  Flags
      o     

  public int hashCode();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // javax.security.auth.Subject$SecureSet this
         0: .line 1391
            iconst_0
            istore 1 /* h */
        start local 1 // int h
         1: .line 1392
            aload 0 /* this */
            invokevirtual javax.security.auth.Subject$SecureSet.iterator:()Ljava/util/Iterator;
            astore 2 /* i */
        start local 2 // java.util.Iterator i
         2: .line 1393
            goto 6
         3: .line 1394
      StackMap locals: int java.util.Iterator
      StackMap stack:
            aload 2 /* i */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 3 /* obj */
        start local 3 // java.lang.Object obj
         4: .line 1395
            aload 3 /* obj */
            ifnull 6
         5: .line 1396
            iload 1 /* h */
            aload 3 /* obj */
            invokevirtual java.lang.Object.hashCode:()I
            iadd
            istore 1 /* h */
        end local 3 // java.lang.Object obj
         6: .line 1393
      StackMap locals:
      StackMap stack:
            aload 2 /* i */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         7: .line 1399
            iload 1 /* h */
            ireturn
        end local 2 // java.util.Iterator i
        end local 1 // int h
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            1    8     1     h  I
            2    8     2     i  Ljava/util/Iterator<TE;>;
            4    6     3   obj  TE;

  private void writeObject(java.io.ObjectOutputStream);
    descriptor: (Ljava/io/ObjectOutputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // java.io.ObjectOutputStream oos
         0: .line 1414
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.which:I
            iconst_3
            if_icmpne 5
         1: .line 1416
            aload 0 /* this */
            invokevirtual javax.security.auth.Subject$SecureSet.iterator:()Ljava/util/Iterator;
            astore 2 /* i */
        start local 2 // java.util.Iterator i
         2: .line 1417
            goto 4
         3: .line 1418
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 2 /* i */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            pop
         4: .line 1417
      StackMap locals:
      StackMap stack:
            aload 2 /* i */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
        end local 2 // java.util.Iterator i
         5: .line 1421
      StackMap locals:
      StackMap stack:
            aload 1 /* oos */
            invokevirtual java.io.ObjectOutputStream.putFields:()Ljava/io/ObjectOutputStream$PutField;
            astore 2 /* fields */
        start local 2 // java.io.ObjectOutputStream$PutField fields
         6: .line 1422
            aload 2 /* fields */
            ldc "this$0"
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.subject:Ljavax/security/auth/Subject;
            invokevirtual java.io.ObjectOutputStream$PutField.put:(Ljava/lang/String;Ljava/lang/Object;)V
         7: .line 1423
            aload 2 /* fields */
            ldc "elements"
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
            invokevirtual java.io.ObjectOutputStream$PutField.put:(Ljava/lang/String;Ljava/lang/Object;)V
         8: .line 1424
            aload 2 /* fields */
            ldc "which"
            aload 0 /* this */
            getfield javax.security.auth.Subject$SecureSet.which:I
            invokevirtual java.io.ObjectOutputStream$PutField.put:(Ljava/lang/String;I)V
         9: .line 1425
            aload 1 /* oos */
            invokevirtual java.io.ObjectOutputStream.writeFields:()V
        10: .line 1426
            return
        end local 2 // java.io.ObjectOutputStream$PutField fields
        end local 1 // java.io.ObjectOutputStream oos
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   11     0    this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0   11     1     oos  Ljava/io/ObjectOutputStream;
            2    5     2       i  Ljava/util/Iterator<TE;>;
            6   11     2  fields  Ljava/io/ObjectOutputStream$PutField;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      oos   

  private void readObject(java.io.ObjectInputStream);
    descriptor: (Ljava/io/ObjectInputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // javax.security.auth.Subject$SecureSet this
        start local 1 // java.io.ObjectInputStream ois
         0: .line 1432
            aload 1 /* ois */
            invokevirtual java.io.ObjectInputStream.readFields:()Ljava/io/ObjectInputStream$GetField;
            astore 2 /* fields */
        start local 2 // java.io.ObjectInputStream$GetField fields
         1: .line 1433
            aload 0 /* this */
            aload 2 /* fields */
            ldc "this$0"
            aconst_null
            invokevirtual java.io.ObjectInputStream$GetField.get:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast javax.security.auth.Subject
            putfield javax.security.auth.Subject$SecureSet.subject:Ljavax/security/auth/Subject;
         2: .line 1434
            aload 0 /* this */
            aload 2 /* fields */
            ldc "which"
            iconst_0
            invokevirtual java.io.ObjectInputStream$GetField.get:(Ljava/lang/String;I)I
            putfield javax.security.auth.Subject$SecureSet.which:I
         3: .line 1436
            aload 2 /* fields */
            ldc "elements"
            aconst_null
            invokevirtual java.io.ObjectInputStream$GetField.get:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.LinkedList
            astore 3 /* tmp */
        start local 3 // java.util.LinkedList tmp
         4: .line 1438
            aload 3 /* tmp */
            invokestatic javax.security.auth.Subject.collectionNullClean:(Ljava/util/Collection;)V
         5: .line 1440
            aload 3 /* tmp */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            ldc Ljava/util/LinkedList;
            if_acmpeq 8
         6: .line 1441
            aload 0 /* this */
            new java.util.LinkedList
            dup
            aload 3 /* tmp */
            invokespecial java.util.LinkedList.<init>:(Ljava/util/Collection;)V
            putfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
         7: .line 1442
            goto 9
         8: .line 1443
      StackMap locals: java.io.ObjectInputStream$GetField java.util.LinkedList
      StackMap stack:
            aload 0 /* this */
            aload 3 /* tmp */
            putfield javax.security.auth.Subject$SecureSet.elements:Ljava/util/LinkedList;
         9: .line 1445
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.util.LinkedList tmp
        end local 2 // java.io.ObjectInputStream$GetField fields
        end local 1 // java.io.ObjectInputStream ois
        end local 0 // javax.security.auth.Subject$SecureSet this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    this  Ljavax/security/auth/Subject$SecureSet<TE;>;
            0   10     1     ois  Ljava/io/ObjectInputStream;
            1   10     2  fields  Ljava/io/ObjectInputStream$GetField;
            4   10     3     tmp  Ljava/util/LinkedList<TE;>;
    Exceptions:
      throws java.io.IOException, java.lang.ClassNotFoundException
    MethodParameters:
      Name  Flags
      ois   
}
Signature: <E:Ljava/lang/Object;>Ljava/lang/Object;Ljava/util/Set<TE;>;Ljava/io/Serializable;
SourceFile: "Subject.java"
NestHost: javax.security.auth.Subject
InnerClasses:
  public abstract GetField = java.io.ObjectInputStream$GetField of java.io.ObjectInputStream
  public abstract PutField = java.io.ObjectOutputStream$PutField of java.io.ObjectOutputStream
  final AuthPermissionHolder = javax.security.auth.Subject$AuthPermissionHolder of javax.security.auth.Subject
  private SecureSet = javax.security.auth.Subject$SecureSet of javax.security.auth.Subject
  javax.security.auth.Subject$SecureSet$1
  javax.security.auth.Subject$SecureSet$2
  javax.security.auth.Subject$SecureSet$3
  javax.security.auth.Subject$SecureSet$4
  javax.security.auth.Subject$SecureSet$5
  javax.security.auth.Subject$SecureSet$6