class sun.security.jgss.krb5.SubjectComber
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: sun.security.jgss.krb5.SubjectComber
  super_class: java.lang.Object
{
  private static final boolean DEBUG;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 48
            getstatic sun.security.jgss.krb5.Krb5Util.DEBUG:Z
            putstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.jgss.krb5.SubjectComber this
         0: .line 53
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 54
            return
        end local 0 // sun.security.jgss.krb5.SubjectComber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/jgss/krb5/SubjectComber;

  static <T> T find(javax.security.auth.Subject, java.lang.String, java.lang.String, java.lang.Class<T>);
    descriptor: (Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=6, locals=4, args_size=4
        start local 0 // javax.security.auth.Subject subject
        start local 1 // java.lang.String serverPrincipal
        start local 2 // java.lang.String clientPrincipal
        start local 3 // java.lang.Class credClass
         0: .line 60
            aload 3 /* credClass */
            aload 0 /* subject */
            aload 1 /* serverPrincipal */
         1: .line 61
            aload 2 /* clientPrincipal */
            aload 3 /* credClass */
            iconst_1
         2: .line 60
            invokestatic sun.security.jgss.krb5.SubjectComber.findAux:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;Z)Ljava/lang/Object;
            invokevirtual java.lang.Class.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 3 // java.lang.Class credClass
        end local 2 // java.lang.String clientPrincipal
        end local 1 // java.lang.String serverPrincipal
        end local 0 // javax.security.auth.Subject subject
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    3     0          subject  Ljavax/security/auth/Subject;
            0    3     1  serverPrincipal  Ljava/lang/String;
            0    3     2  clientPrincipal  Ljava/lang/String;
            0    3     3        credClass  Ljava/lang/Class<TT;>;
    Signature: <T:Ljava/lang/Object;>(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class<TT;>;)TT;
    MethodParameters:
                 Name  Flags
      subject          
      serverPrincipal  
      clientPrincipal  
      credClass        

  static <T> java.util.List<T> findMany(javax.security.auth.Subject, java.lang.String, java.lang.String, java.lang.Class<T>);
    descriptor: (Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/util/List;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // javax.security.auth.Subject subject
        start local 1 // java.lang.String serverPrincipal
        start local 2 // java.lang.String clientPrincipal
        start local 3 // java.lang.Class credClass
         0: .line 68
            aload 0 /* subject */
            aload 1 /* serverPrincipal */
            aload 2 /* clientPrincipal */
         1: .line 69
            aload 3 /* credClass */
            iconst_0
         2: .line 68
            invokestatic sun.security.jgss.krb5.SubjectComber.findAux:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;Z)Ljava/lang/Object;
            checkcast java.util.List
            areturn
        end local 3 // java.lang.Class credClass
        end local 2 // java.lang.String clientPrincipal
        end local 1 // java.lang.String serverPrincipal
        end local 0 // javax.security.auth.Subject subject
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    3     0          subject  Ljavax/security/auth/Subject;
            0    3     1  serverPrincipal  Ljava/lang/String;
            0    3     2  clientPrincipal  Ljava/lang/String;
            0    3     3        credClass  Ljava/lang/Class<TT;>;
    Signature: <T:Ljava/lang/Object;>(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class<TT;>;)Ljava/util/List<TT;>;
    MethodParameters:
                 Name  Flags
      subject          
      serverPrincipal  
      clientPrincipal  
      credClass        

  private static <T>  findAux(javax.security.auth.Subject, java.lang.String, java.lang.String, java.lang.Class<T>, boolean);
    descriptor: (Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;Z)Ljava/lang/Object;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=12, args_size=5
        start local 0 // javax.security.auth.Subject subject
        start local 1 // java.lang.String serverPrincipal
        start local 2 // java.lang.String clientPrincipal
        start local 3 // java.lang.Class credClass
        start local 4 // boolean oneOnly
         0: .line 82
            aload 0 /* subject */
            ifnonnull 2
         1: .line 83
            aconst_null
            areturn
         2: .line 85
      StackMap locals:
      StackMap stack:
            iload 4 /* oneOnly */
            ifeq 3
            aconst_null
            goto 4
      StackMap locals:
      StackMap stack:
         3: new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
      StackMap locals:
      StackMap stack: java.util.ArrayList
         4: astore 5 /* answer */
        start local 5 // java.util.List answer
         5: .line 87
            aload 3 /* credClass */
            ldc Ljavax/security/auth/kerberos/KeyTab;
            if_acmpne 17
         6: .line 90
            aload 0 /* subject */
            aload 3 /* credClass */
            invokevirtual javax.security.auth.Subject.getPrivateCredentials:(Ljava/lang/Class;)Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
         7: .line 89
            astore 6 /* iterator */
        start local 6 // java.util.Iterator iterator
         8: .line 91
            goto 15
         9: .line 92
      StackMap locals: java.util.List java.util.Iterator
      StackMap stack:
            aload 6 /* iterator */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 7 /* t */
        start local 7 // java.lang.Object t
        10: .line 93
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 12
        11: .line 94
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Found "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* credClass */
            invokevirtual java.lang.Class.getSimpleName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        12: .line 96
      StackMap locals: java.lang.Object
      StackMap stack:
            iload 4 /* oneOnly */
            ifeq 14
        13: .line 97
            aload 7 /* t */
            areturn
        14: .line 99
      StackMap locals:
      StackMap stack:
            aload 5 /* answer */
            aload 7 /* t */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 7 // java.lang.Object t
        15: .line 91
      StackMap locals:
      StackMap stack:
            aload 6 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        end local 6 // java.util.Iterator iterator
        16: .line 102
            goto 88
      StackMap locals:
      StackMap stack:
        17: aload 3 /* credClass */
            ldc Ljavax/security/auth/kerberos/KerberosKey;
            if_acmpne 35
        18: .line 105
            aload 0 /* subject */
            ldc Ljavax/security/auth/kerberos/KerberosKey;
            invokevirtual javax.security.auth.Subject.getPrivateCredentials:(Ljava/lang/Class;)Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
        19: .line 104
            astore 6 /* iterator */
        start local 6 // java.util.Iterator iterator
        20: .line 106
            goto 33
        21: .line 107
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 6 /* iterator */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosKey
            astore 7 /* t */
        start local 7 // javax.security.auth.kerberos.KerberosKey t
        22: .line 108
            aload 7 /* t */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
            astore 8 /* name */
        start local 8 // java.lang.String name
        23: .line 109
            aload 1 /* serverPrincipal */
            ifnull 24
            aload 1 /* serverPrincipal */
            aload 8 /* name */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 33
        24: .line 110
      StackMap locals: javax.security.auth.kerberos.KerberosKey java.lang.String
      StackMap stack:
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 28
        25: .line 111
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Found "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        26: .line 112
            aload 3 /* credClass */
            invokevirtual java.lang.Class.getSimpleName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " for "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 8 /* name */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        27: .line 111
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        28: .line 114
      StackMap locals:
      StackMap stack:
            iload 4 /* oneOnly */
            ifeq 30
        29: .line 115
            aload 7 /* t */
            areturn
        30: .line 117
      StackMap locals:
      StackMap stack:
            aload 1 /* serverPrincipal */
            ifnonnull 32
        31: .line 120
            aload 8 /* name */
            astore 1 /* serverPrincipal */
        32: .line 122
      StackMap locals:
      StackMap stack:
            aload 5 /* answer */
            aload 3 /* credClass */
            aload 7 /* t */
            invokevirtual java.lang.Class.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 8 // java.lang.String name
        end local 7 // javax.security.auth.kerberos.KerberosKey t
        33: .line 106
      StackMap locals:
      StackMap stack:
            aload 6 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 21
        end local 6 // java.util.Iterator iterator
        34: .line 126
            goto 88
      StackMap locals:
      StackMap stack:
        35: aload 3 /* credClass */
            ldc Ljavax/security/auth/kerberos/KerberosTicket;
            if_acmpne 88
        36: .line 129
            aload 0 /* subject */
            invokevirtual javax.security.auth.Subject.getPrivateCredentials:()Ljava/util/Set;
            astore 6 /* pcs */
        start local 6 // java.util.Set pcs
        37: .line 130
            aload 6 /* pcs */
            dup
            astore 7
            monitorenter
        38: .line 131
            aload 6 /* pcs */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 8 /* iterator */
        start local 8 // java.util.Iterator iterator
        39: .line 132
            goto 83
        40: .line 133
      StackMap locals: java.util.Set java.util.Set java.util.Iterator
      StackMap stack:
            aload 8 /* iterator */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 9 /* obj */
        start local 9 // java.lang.Object obj
        41: .line 134
            aload 9 /* obj */
            instanceof javax.security.auth.kerberos.KerberosTicket
            ifeq 83
        42: .line 136
            aload 9 /* obj */
            checkcast javax.security.auth.kerberos.KerberosTicket
            astore 10 /* ticket */
        start local 10 // javax.security.auth.kerberos.KerberosTicket ticket
        43: .line 137
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 51
        44: .line 138
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Found ticket for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        45: .line 139
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getClient:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        46: .line 140
            ldc " to go to "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        47: .line 141
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getServer:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        48: .line 142
            ldc " expiring on "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        49: .line 143
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getEndTime:()Ljava/util/Date;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        50: .line 138
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        51: .line 145
      StackMap locals: java.lang.Object javax.security.auth.kerberos.KerberosTicket
      StackMap stack:
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.isCurrent:()Z
            ifne 66
        52: .line 149
            aload 0 /* subject */
            invokevirtual javax.security.auth.Subject.isReadOnly:()Z
            ifne 83
        53: .line 150
            aload 8 /* iterator */
            invokeinterface java.util.Iterator.remove:()V
        54: .line 152
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.destroy:()V
        55: .line 153
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 83
        56: .line 154
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Removed and destroyed the expired Ticket \n"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        57: .line 156
            aload 10 /* ticket */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        58: .line 154
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        59: .line 159
            goto 83
      StackMap locals:
      StackMap stack: javax.security.auth.DestroyFailedException
        60: astore 11 /* dfe */
        start local 11 // javax.security.auth.DestroyFailedException dfe
        61: .line 160
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 83
        62: .line 161
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Expired ticket not detroyed successfully. "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        63: .line 162
            aload 11 /* dfe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        64: .line 161
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 11 // javax.security.auth.DestroyFailedException dfe
        65: .line 167
            goto 83
        66: .line 168
      StackMap locals:
      StackMap stack:
            aload 1 /* serverPrincipal */
            ifnull 68
        67: .line 169
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getServer:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
            aload 1 /* serverPrincipal */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 83
        68: .line 171
      StackMap locals:
      StackMap stack:
            aload 2 /* clientPrincipal */
            ifnull 73
        69: .line 172
            aload 2 /* clientPrincipal */
        70: .line 173
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getClient:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
        71: .line 172
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        72: .line 173
            ifeq 83
        73: .line 174
      StackMap locals:
      StackMap stack:
            iload 4 /* oneOnly */
            ifeq 76
        74: .line 175
            aload 10 /* ticket */
            aload 7
            monitorexit
        75: areturn
        76: .line 179
      StackMap locals:
      StackMap stack:
            aload 2 /* clientPrincipal */
            ifnonnull 79
        77: .line 181
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getClient:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
        78: .line 180
            astore 2 /* clientPrincipal */
        79: .line 183
      StackMap locals:
      StackMap stack:
            aload 1 /* serverPrincipal */
            ifnonnull 82
        80: .line 185
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getServer:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
        81: .line 184
            astore 1 /* serverPrincipal */
        82: .line 187
      StackMap locals:
      StackMap stack:
            aload 5 /* answer */
            aload 3 /* credClass */
            aload 10 /* ticket */
            invokevirtual java.lang.Class.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 10 // javax.security.auth.kerberos.KerberosTicket ticket
        end local 9 // java.lang.Object obj
        83: .line 132
      StackMap locals:
      StackMap stack:
            aload 8 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 40
        end local 8 // java.util.Iterator iterator
        84: .line 130
            aload 7
            monitorexit
        85: goto 88
      StackMap locals: javax.security.auth.Subject java.lang.String java.lang.String java.lang.Class int java.util.List java.util.Set java.util.Set
      StackMap stack: java.lang.Throwable
        86: aload 7
            monitorexit
        87: athrow
        end local 6 // java.util.Set pcs
        88: .line 196
      StackMap locals:
      StackMap stack:
            aload 5 /* answer */
            areturn
        end local 5 // java.util.List answer
        end local 4 // boolean oneOnly
        end local 3 // java.lang.Class credClass
        end local 2 // java.lang.String clientPrincipal
        end local 1 // java.lang.String serverPrincipal
        end local 0 // javax.security.auth.Subject subject
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   89     0          subject  Ljavax/security/auth/Subject;
            0   89     1  serverPrincipal  Ljava/lang/String;
            0   89     2  clientPrincipal  Ljava/lang/String;
            0   89     3        credClass  Ljava/lang/Class<TT;>;
            0   89     4          oneOnly  Z
            5   89     5           answer  Ljava/util/List<TT;>;
            8   16     6         iterator  Ljava/util/Iterator<TT;>;
           10   15     7                t  TT;
           20   34     6         iterator  Ljava/util/Iterator<Ljavax/security/auth/kerberos/KerberosKey;>;
           22   33     7                t  Ljavax/security/auth/kerberos/KerberosKey;
           23   33     8             name  Ljava/lang/String;
           37   88     6              pcs  Ljava/util/Set<Ljava/lang/Object;>;
           39   84     8         iterator  Ljava/util/Iterator<Ljava/lang/Object;>;
           41   83     9              obj  Ljava/lang/Object;
           43   83    10           ticket  Ljavax/security/auth/kerberos/KerberosTicket;
           61   65    11              dfe  Ljavax/security/auth/DestroyFailedException;
      Exception table:
        from    to  target  type
          54    59      60  Class javax.security.auth.DestroyFailedException
          38    75      86  any
          76    85      86  any
          86    87      86  any
    Signature: <T:Ljava/lang/Object;>(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class<TT;>;Z)Ljava/lang/Object;
    MethodParameters:
                 Name  Flags
      subject          
      serverPrincipal  
      clientPrincipal  
      credClass        
      oneOnly          
}
SourceFile: "SubjectComber.java"