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 49
            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 54
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 55
            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 61
            aload 3 /* credClass */
            aload 0 /* subject */
            aload 1 /* serverPrincipal */
         1: .line 62
            aload 2 /* clientPrincipal */
            aload 3 /* credClass */
            iconst_1
         2: .line 61
            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 69
            aload 0 /* subject */
            aload 1 /* serverPrincipal */
            aload 2 /* clientPrincipal */
         1: .line 70
            aload 3 /* credClass */
            iconst_0
         2: .line 69
            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 83
            aload 0 /* subject */
            ifnonnull 2
         1: .line 84
            aconst_null
            areturn
         2: .line 86
      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 88
            aload 3 /* credClass */
            ldc Ljavax/security/auth/kerberos/KeyTab;
            if_acmpne 32
         6: .line 90
            aload 0 /* subject */
            ldc Ljavax/security/auth/kerberos/KeyTab;
            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 30
         9: .line 92
      StackMap locals: java.util.List java.util.Iterator
      StackMap stack:
            aload 6 /* iterator */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KeyTab
            astore 7 /* t */
        start local 7 // javax.security.auth.kerberos.KeyTab t
        10: .line 93
            aload 1 /* serverPrincipal */
            ifnull 23
            aload 7 /* t */
            invokevirtual javax.security.auth.kerberos.KeyTab.isBound:()Z
            ifeq 23
        11: .line 94
            aload 7 /* t */
            invokevirtual javax.security.auth.kerberos.KeyTab.getPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            astore 8 /* name */
        start local 8 // javax.security.auth.kerberos.KerberosPrincipal name
        12: .line 95
            aload 8 /* name */
            ifnull 15
        13: .line 96
            aload 1 /* serverPrincipal */
            aload 8 /* name */
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 23
        14: .line 97
            goto 30
        15: .line 102
      StackMap locals: javax.security.auth.kerberos.KeyTab javax.security.auth.kerberos.KerberosPrincipal
      StackMap stack:
            iconst_0
            istore 9 /* found */
        start local 9 // boolean found
        16: .line 104
            aload 0 /* subject */
            ldc Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.Subject.getPrincipals:(Ljava/lang/Class;)Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 11
            goto 21
      StackMap locals: javax.security.auth.Subject java.lang.String java.lang.String java.lang.Class int java.util.List java.util.Iterator javax.security.auth.kerberos.KeyTab javax.security.auth.kerberos.KerberosPrincipal int top java.util.Iterator
      StackMap stack:
        17: aload 11
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosPrincipal
            astore 10 /* princ */
        start local 10 // javax.security.auth.kerberos.KerberosPrincipal princ
        18: .line 105
            aload 10 /* princ */
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
            aload 1 /* serverPrincipal */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 21
        19: .line 106
            iconst_1
            istore 9 /* found */
        20: .line 107
            goto 22
        end local 10 // javax.security.auth.kerberos.KerberosPrincipal princ
        21: .line 103
      StackMap locals:
      StackMap stack:
            aload 11
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 17
        22: .line 110
      StackMap locals: javax.security.auth.Subject java.lang.String java.lang.String java.lang.Class int java.util.List java.util.Iterator javax.security.auth.kerberos.KeyTab javax.security.auth.kerberos.KerberosPrincipal int
      StackMap stack:
            iload 9 /* found */
            ifne 23
            goto 30
        end local 9 // boolean found
        end local 8 // javax.security.auth.kerberos.KerberosPrincipal name
        23: .line 114
      StackMap locals:
      StackMap stack:
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 27
        24: .line 115
            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;
        25: .line 116
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 7 /* t */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        26: .line 115
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        27: .line 118
      StackMap locals:
      StackMap stack:
            iload 4 /* oneOnly */
            ifeq 29
        28: .line 119
            aload 7 /* t */
            areturn
        29: .line 121
      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 7 // javax.security.auth.kerberos.KeyTab t
        30: .line 91
      StackMap locals:
      StackMap stack:
            aload 6 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        end local 6 // java.util.Iterator iterator
        31: .line 124
            goto 101
      StackMap locals:
      StackMap stack:
        32: aload 3 /* credClass */
            ldc Ljavax/security/auth/kerberos/KerberosKey;
            if_acmpne 48
        33: .line 127
            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;
        34: .line 126
            astore 6 /* iterator */
        start local 6 // java.util.Iterator iterator
        35: .line 128
            goto 46
        36: .line 129
      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
        37: .line 130
            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
        38: .line 131
            aload 1 /* serverPrincipal */
            ifnull 39
            aload 1 /* serverPrincipal */
            aload 8 /* name */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 46
        39: .line 132
      StackMap locals: javax.security.auth.kerberos.KerberosKey java.lang.String
      StackMap stack:
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 43
        40: .line 133
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Found "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        41: .line 134
            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;
        42: .line 133
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        43: .line 136
      StackMap locals:
      StackMap stack:
            iload 4 /* oneOnly */
            ifeq 45
        44: .line 137
            aload 7 /* t */
            areturn
        45: .line 139
      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
        46: .line 128
      StackMap locals:
      StackMap stack:
            aload 6 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 36
        end local 6 // java.util.Iterator iterator
        47: .line 143
            goto 101
      StackMap locals:
      StackMap stack:
        48: aload 3 /* credClass */
            ldc Ljavax/security/auth/kerberos/KerberosTicket;
            if_acmpne 101
        49: .line 146
            aload 0 /* subject */
            invokevirtual javax.security.auth.Subject.getPrivateCredentials:()Ljava/util/Set;
            astore 6 /* pcs */
        start local 6 // java.util.Set pcs
        50: .line 147
            aload 6 /* pcs */
            dup
            astore 7
            monitorenter
        51: .line 148
            aload 6 /* pcs */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 8 /* iterator */
        start local 8 // java.util.Iterator iterator
        52: .line 149
            goto 96
        53: .line 150
      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
        54: .line 151
            aload 9 /* obj */
            instanceof javax.security.auth.kerberos.KerberosTicket
            ifeq 96
        55: .line 153
            aload 9 /* obj */
            checkcast javax.security.auth.kerberos.KerberosTicket
            astore 10 /* ticket */
        start local 10 // javax.security.auth.kerberos.KerberosTicket ticket
        56: .line 154
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 64
        57: .line 155
            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
        58: .line 156
            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;
        59: .line 157
            ldc " to go to "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        60: .line 158
            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;
        61: .line 159
            ldc " expiring on "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        62: .line 160
            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;
        63: .line 155
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        64: .line 162
      StackMap locals: java.lang.Object javax.security.auth.kerberos.KerberosTicket
      StackMap stack:
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.isCurrent:()Z
            ifne 79
        65: .line 166
            aload 0 /* subject */
            invokevirtual javax.security.auth.Subject.isReadOnly:()Z
            ifne 96
        66: .line 167
            aload 8 /* iterator */
            invokeinterface java.util.Iterator.remove:()V
        67: .line 169
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.destroy:()V
        68: .line 170
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 96
        69: .line 171
            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
        70: .line 173
            aload 10 /* ticket */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        71: .line 171
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        72: .line 176
            goto 96
      StackMap locals:
      StackMap stack: javax.security.auth.DestroyFailedException
        73: astore 11 /* dfe */
        start local 11 // javax.security.auth.DestroyFailedException dfe
        74: .line 177
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 96
        75: .line 178
            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
        76: .line 179
            aload 11 /* dfe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        77: .line 178
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 11 // javax.security.auth.DestroyFailedException dfe
        78: .line 184
            goto 96
        79: .line 185
      StackMap locals:
      StackMap stack:
            aload 1 /* serverPrincipal */
            ifnull 81
        80: .line 186
            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 96
        81: .line 188
      StackMap locals:
      StackMap stack:
            aload 2 /* clientPrincipal */
            ifnull 86
        82: .line 189
            aload 2 /* clientPrincipal */
        83: .line 190
            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;
        84: .line 189
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        85: .line 190
            ifeq 96
        86: .line 191
      StackMap locals:
      StackMap stack:
            iload 4 /* oneOnly */
            ifeq 89
        87: .line 192
            aload 10 /* ticket */
            aload 7
            monitorexit
        88: areturn
        89: .line 196
      StackMap locals:
      StackMap stack:
            aload 2 /* clientPrincipal */
            ifnonnull 92
        90: .line 198
            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;
        91: .line 197
            astore 2 /* clientPrincipal */
        92: .line 200
      StackMap locals:
      StackMap stack:
            aload 1 /* serverPrincipal */
            ifnonnull 95
        93: .line 202
            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;
        94: .line 201
            astore 1 /* serverPrincipal */
        95: .line 204
      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
        96: .line 149
      StackMap locals:
      StackMap stack:
            aload 8 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 53
        end local 8 // java.util.Iterator iterator
        97: .line 147
            aload 7
            monitorexit
        98: goto 101
      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
        99: aload 7
            monitorexit
       100: athrow
        end local 6 // java.util.Set pcs
       101: .line 213
      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  102     0          subject  Ljavax/security/auth/Subject;
            0  102     1  serverPrincipal  Ljava/lang/String;
            0  102     2  clientPrincipal  Ljava/lang/String;
            0  102     3        credClass  Ljava/lang/Class<TT;>;
            0  102     4          oneOnly  Z
            5  102     5           answer  Ljava/util/List<TT;>;
            8   31     6         iterator  Ljava/util/Iterator<Ljavax/security/auth/kerberos/KeyTab;>;
           10   30     7                t  Ljavax/security/auth/kerberos/KeyTab;
           12   23     8             name  Ljavax/security/auth/kerberos/KerberosPrincipal;
           16   23     9            found  Z
           18   21    10            princ  Ljavax/security/auth/kerberos/KerberosPrincipal;
           35   47     6         iterator  Ljava/util/Iterator<Ljavax/security/auth/kerberos/KerberosKey;>;
           37   46     7                t  Ljavax/security/auth/kerberos/KerberosKey;
           38   46     8             name  Ljava/lang/String;
           50  101     6              pcs  Ljava/util/Set<Ljava/lang/Object;>;
           52   97     8         iterator  Ljava/util/Iterator<Ljava/lang/Object;>;
           54   96     9              obj  Ljava/lang/Object;
           56   96    10           ticket  Ljavax/security/auth/kerberos/KerberosTicket;
           74   78    11              dfe  Ljavax/security/auth/DestroyFailedException;
      Exception table:
        from    to  target  type
          67    72      73  Class javax.security.auth.DestroyFailedException
          51    88      99  any
          89    98      99  any
          99   100      99  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"