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 51
            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 56
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 57
            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 63
            aload 3 /* credClass */
            aload 0 /* subject */
            aload 1 /* serverPrincipal */
         1: .line 64
            aload 2 /* clientPrincipal */
            aload 3 /* credClass */
            iconst_1
         2: .line 63
            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 71
            aload 0 /* subject */
            aload 1 /* serverPrincipal */
            aload 2 /* clientPrincipal */
         1: .line 72
            aload 3 /* credClass */
            iconst_0
         2: .line 71
            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=13, 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 85
            aload 0 /* subject */
            ifnonnull 2
         1: .line 86
            aconst_null
            areturn
         2: .line 88
      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 90
            aload 3 /* credClass */
            ldc Ljavax/security/auth/kerberos/KeyTab;
            if_acmpne 32
         6: .line 92
            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 91
            astore 6 /* iterator */
        start local 6 // java.util.Iterator iterator
         8: .line 93
            goto 30
         9: .line 94
      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 95
            aload 1 /* serverPrincipal */
            ifnull 23
            aload 7 /* t */
            invokevirtual javax.security.auth.kerberos.KeyTab.isBound:()Z
            ifeq 23
        11: .line 96
            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 97
            aload 8 /* name */
            ifnull 15
        13: .line 98
            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 99
            goto 30
        15: .line 104
      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 106
            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 107
            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 108
            iconst_1
            istore 9 /* found */
        20: .line 109
            goto 22
        end local 10 // javax.security.auth.kerberos.KerberosPrincipal princ
        21: .line 105
      StackMap locals:
      StackMap stack:
            aload 11
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 17
        22: .line 112
      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 116
      StackMap locals:
      StackMap stack:
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 27
        24: .line 117
            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 118
            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 117
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        27: .line 120
      StackMap locals:
      StackMap stack:
            iload 4 /* oneOnly */
            ifeq 29
        28: .line 121
            aload 7 /* t */
            areturn
        29: .line 123
      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 93
      StackMap locals:
      StackMap stack:
            aload 6 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        end local 6 // java.util.Iterator iterator
        31: .line 126
            goto 125
      StackMap locals:
      StackMap stack:
        32: aload 3 /* credClass */
            ldc Ljavax/security/auth/kerberos/KerberosKey;
            if_acmpne 48
        33: .line 129
            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 128
            astore 6 /* iterator */
        start local 6 // java.util.Iterator iterator
        35: .line 130
            goto 46
        36: .line 131
      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 132
            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 133
            aload 1 /* serverPrincipal */
            ifnull 39
            aload 1 /* serverPrincipal */
            aload 8 /* name */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 46
        39: .line 134
      StackMap locals: javax.security.auth.kerberos.KerberosKey java.lang.String
      StackMap stack:
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 43
        40: .line 135
            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 136
            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 135
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        43: .line 138
      StackMap locals:
      StackMap stack:
            iload 4 /* oneOnly */
            ifeq 45
        44: .line 139
            aload 7 /* t */
            areturn
        45: .line 141
      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 130
      StackMap locals:
      StackMap stack:
            aload 6 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 36
        end local 6 // java.util.Iterator iterator
        47: .line 145
            goto 125
      StackMap locals:
      StackMap stack:
        48: aload 3 /* credClass */
            ldc Ljavax/security/auth/kerberos/KerberosTicket;
            if_acmpne 125
        49: .line 148
            aload 0 /* subject */
            invokevirtual javax.security.auth.Subject.getPrivateCredentials:()Ljava/util/Set;
            astore 6 /* pcs */
        start local 6 // java.util.Set pcs
        50: .line 149
            aload 6 /* pcs */
            dup
            astore 7
            monitorenter
        51: .line 150
            aload 6 /* pcs */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 8 /* iterator */
        start local 8 // java.util.Iterator iterator
        52: .line 151
            goto 120
        53: .line 152
      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 153
            aload 9 /* obj */
            instanceof javax.security.auth.kerberos.KerberosTicket
            ifeq 120
        55: .line 155
            aload 9 /* obj */
            checkcast javax.security.auth.kerberos.KerberosTicket
            astore 10 /* ticket */
        start local 10 // javax.security.auth.kerberos.KerberosTicket ticket
        56: .line 156
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 64
        57: .line 157
            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 158
            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 159
            ldc " to go to "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        60: .line 160
            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 161
            ldc " expiring on "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        62: .line 162
            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 157
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        64: .line 164
      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 168
            aload 0 /* subject */
            invokevirtual javax.security.auth.Subject.isReadOnly:()Z
            ifne 120
        66: .line 169
            aload 8 /* iterator */
            invokeinterface java.util.Iterator.remove:()V
        67: .line 171
            aload 10 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.destroy:()V
        68: .line 172
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 120
        69: .line 173
            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 175
            aload 10 /* ticket */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        71: .line 173
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        72: .line 178
            goto 120
      StackMap locals:
      StackMap stack: javax.security.auth.DestroyFailedException
        73: astore 11 /* dfe */
        start local 11 // javax.security.auth.DestroyFailedException dfe
        74: .line 179
            getstatic sun.security.jgss.krb5.SubjectComber.DEBUG:Z
            ifeq 120
        75: .line 180
            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 181
            aload 11 /* dfe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        77: .line 180
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 11 // javax.security.auth.DestroyFailedException dfe
        78: .line 186
            goto 120
        79: .line 188
      StackMap locals:
      StackMap stack:
            invokestatic sun.security.krb5.KerberosSecrets.getJavaxSecurityAuthKerberosAccess:()Lsun/security/krb5/JavaxSecurityAuthKerberosAccess;
        80: .line 189
            aload 10 /* ticket */
            invokeinterface sun.security.krb5.JavaxSecurityAuthKerberosAccess.kerberosTicketGetServerAlias:(Ljavax/security/auth/kerberos/KerberosTicket;)Ljavax/security/auth/kerberos/KerberosPrincipal;
        81: .line 187
            astore 11 /* serverAlias */
        start local 11 // javax.security.auth.kerberos.KerberosPrincipal serverAlias
        82: .line 190
            aload 1 /* serverPrincipal */
            ifnull 89
        83: .line 191
            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
            ifne 89
        84: .line 192
            aload 11 /* serverAlias */
            ifnull 120
        85: .line 193
            aload 1 /* serverPrincipal */
        86: .line 194
            aload 11 /* serverAlias */
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
        87: .line 193
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        88: .line 194
            ifeq 120
        89: .line 196
      StackMap locals: javax.security.auth.kerberos.KerberosPrincipal
      StackMap stack:
            invokestatic sun.security.krb5.KerberosSecrets.getJavaxSecurityAuthKerberosAccess:()Lsun/security/krb5/JavaxSecurityAuthKerberosAccess;
        90: .line 197
            aload 10 /* ticket */
            invokeinterface sun.security.krb5.JavaxSecurityAuthKerberosAccess.kerberosTicketGetClientAlias:(Ljavax/security/auth/kerberos/KerberosTicket;)Ljavax/security/auth/kerberos/KerberosPrincipal;
        91: .line 195
            astore 12 /* clientAlias */
        start local 12 // javax.security.auth.kerberos.KerberosPrincipal clientAlias
        92: .line 198
            aload 2 /* clientPrincipal */
            ifnull 102
        93: .line 199
            aload 2 /* clientPrincipal */
        94: .line 200
            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;
        95: .line 199
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        96: .line 200
            ifne 102
        97: .line 201
            aload 12 /* clientAlias */
            ifnull 120
        98: .line 202
            aload 2 /* clientPrincipal */
        99: .line 203
            aload 12 /* clientAlias */
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
       100: .line 202
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
       101: .line 203
            ifeq 120
       102: .line 204
      StackMap locals: javax.security.auth.kerberos.KerberosPrincipal
      StackMap stack:
            iload 4 /* oneOnly */
            ifeq 105
       103: .line 205
            aload 10 /* ticket */
            aload 7
            monitorexit
       104: areturn
       105: .line 209
      StackMap locals:
      StackMap stack:
            aload 2 /* clientPrincipal */
            ifnonnull 112
       106: .line 210
            aload 12 /* clientAlias */
            ifnonnull 110
       107: .line 212
            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;
       108: .line 211
            astore 2 /* clientPrincipal */
       109: .line 213
            goto 112
       110: .line 215
      StackMap locals:
      StackMap stack:
            aload 12 /* clientAlias */
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
       111: .line 214
            astore 2 /* clientPrincipal */
       112: .line 218
      StackMap locals:
      StackMap stack:
            aload 1 /* serverPrincipal */
            ifnonnull 119
       113: .line 219
            aload 11 /* serverAlias */
            ifnonnull 117
       114: .line 221
            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;
       115: .line 220
            astore 1 /* serverPrincipal */
       116: .line 222
            goto 119
       117: .line 224
      StackMap locals:
      StackMap stack:
            aload 11 /* serverAlias */
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
       118: .line 223
            astore 1 /* serverPrincipal */
       119: .line 227
      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 12 // javax.security.auth.kerberos.KerberosPrincipal clientAlias
        end local 11 // javax.security.auth.kerberos.KerberosPrincipal serverAlias
        end local 10 // javax.security.auth.kerberos.KerberosTicket ticket
        end local 9 // java.lang.Object obj
       120: .line 151
      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 java.util.Iterator
      StackMap stack:
            aload 8 /* iterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 53
        end local 8 // java.util.Iterator iterator
       121: .line 149
            aload 7
            monitorexit
       122: goto 125
      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
       123: aload 7
            monitorexit
       124: athrow
        end local 6 // java.util.Set pcs
       125: .line 236
      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  126     0          subject  Ljavax/security/auth/Subject;
            0  126     1  serverPrincipal  Ljava/lang/String;
            0  126     2  clientPrincipal  Ljava/lang/String;
            0  126     3        credClass  Ljava/lang/Class<TT;>;
            0  126     4          oneOnly  Z
            5  126     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  125     6              pcs  Ljava/util/Set<Ljava/lang/Object;>;
           52  121     8         iterator  Ljava/util/Iterator<Ljava/lang/Object;>;
           54  120     9              obj  Ljava/lang/Object;
           56  120    10           ticket  Ljavax/security/auth/kerberos/KerberosTicket;
           74   78    11              dfe  Ljavax/security/auth/DestroyFailedException;
           82  120    11      serverAlias  Ljavax/security/auth/kerberos/KerberosPrincipal;
           92  120    12      clientAlias  Ljavax/security/auth/kerberos/KerberosPrincipal;
      Exception table:
        from    to  target  type
          67    72      73  Class javax.security.auth.DestroyFailedException
          51   104     123  any
         105   122     123  any
         123   124     123  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"