public final class sun.security.jgss.krb5.ServiceCreds
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: sun.security.jgss.krb5.ServiceCreds
  super_class: java.lang.Object
{
  private javax.security.auth.kerberos.KerberosPrincipal kp;
    descriptor: Ljavax/security/auth/kerberos/KerberosPrincipal;
    flags: (0x0002) ACC_PRIVATE

  private java.util.Set<javax.security.auth.kerberos.KerberosPrincipal> allPrincs;
    descriptor: Ljava/util/Set;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Set<Ljavax/security/auth/kerberos/KerberosPrincipal;>;

  private java.util.List<javax.security.auth.kerberos.KeyTab> ktabs;
    descriptor: Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/List<Ljavax/security/auth/kerberos/KeyTab;>;

  private java.util.List<javax.security.auth.kerberos.KerberosKey> kk;
    descriptor: Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/List<Ljavax/security/auth/kerberos/KerberosKey;>;

  private javax.security.auth.kerberos.KerberosTicket tgt;
    descriptor: Ljavax/security/auth/kerberos/KerberosTicket;
    flags: (0x0002) ACC_PRIVATE

  private boolean destroyed;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

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

  public static sun.security.jgss.krb5.ServiceCreds getInstance(javax.security.auth.Subject, java.lang.String);
    descriptor: (Ljavax/security/auth/Subject;Ljava/lang/String;)Lsun/security/jgss/krb5/ServiceCreds;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=6, args_size=2
        start local 0 // javax.security.auth.Subject subj
        start local 1 // java.lang.String serverPrincipal
         0: .line 90
            new sun.security.jgss.krb5.ServiceCreds
            dup
            invokespecial sun.security.jgss.krb5.ServiceCreds.<init>:()V
            astore 2 /* sc */
        start local 2 // sun.security.jgss.krb5.ServiceCreds sc
         1: .line 92
            aload 2 /* sc */
         2: .line 93
            aload 0 /* subj */
            ldc Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.Subject.getPrincipals:(Ljava/lang/Class;)Ljava/util/Set;
         3: .line 92
            putfield sun.security.jgss.krb5.ServiceCreds.allPrincs:Ljava/util/Set;
         4: .line 97
            aload 0 /* subj */
            aload 1 /* serverPrincipal */
            aconst_null
            ldc Ljavax/security/auth/kerberos/KerberosKey;
         5: .line 96
            invokestatic sun.security.jgss.krb5.SubjectComber.findMany:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 8
      StackMap locals: javax.security.auth.Subject java.lang.String sun.security.jgss.krb5.ServiceCreds top java.util.Iterator
      StackMap stack:
         6: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosKey
            astore 3 /* key */
        start local 3 // javax.security.auth.kerberos.KerberosKey key
         7: .line 98
            aload 2 /* sc */
            getfield sun.security.jgss.krb5.ServiceCreds.allPrincs:Ljava/util/Set;
            aload 3 /* key */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // javax.security.auth.kerberos.KerberosKey key
         8: .line 96
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
         9: .line 101
            aload 1 /* serverPrincipal */
            ifnull 12
        10: .line 102
            aload 2 /* sc */
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
            aload 1 /* serverPrincipal */
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;)V
            putfield sun.security.jgss.krb5.ServiceCreds.kp:Ljavax/security/auth/kerberos/KerberosPrincipal;
        11: .line 103
            goto 24
        12: .line 107
      StackMap locals: javax.security.auth.Subject java.lang.String sun.security.jgss.krb5.ServiceCreds
      StackMap stack:
            aload 2 /* sc */
            getfield sun.security.jgss.krb5.ServiceCreds.allPrincs:Ljava/util/Set;
            invokeinterface java.util.Set.size:()I
            iconst_1
            if_icmpne 24
        13: .line 108
            iconst_0
            istore 3 /* hasUnbound */
        start local 3 // boolean hasUnbound
        14: .line 110
            aload 0 /* subj */
            aconst_null
            aconst_null
            ldc Ljavax/security/auth/kerberos/KeyTab;
        15: .line 109
            invokestatic sun.security.jgss.krb5.SubjectComber.findMany:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 20
      StackMap locals: javax.security.auth.Subject java.lang.String sun.security.jgss.krb5.ServiceCreds int top java.util.Iterator
      StackMap stack:
        16: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KeyTab
            astore 4 /* ktab */
        start local 4 // javax.security.auth.kerberos.KeyTab ktab
        17: .line 111
            aload 4 /* ktab */
            invokevirtual javax.security.auth.kerberos.KeyTab.isBound:()Z
            ifne 20
        18: .line 112
            iconst_1
            istore 3 /* hasUnbound */
        19: .line 113
            goto 21
        end local 4 // javax.security.auth.kerberos.KeyTab ktab
        20: .line 109
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 16
        21: .line 116
      StackMap locals: javax.security.auth.Subject java.lang.String sun.security.jgss.krb5.ServiceCreds int
      StackMap stack:
            iload 3 /* hasUnbound */
            ifne 24
        22: .line 117
            aload 2 /* sc */
            aload 2 /* sc */
            getfield sun.security.jgss.krb5.ServiceCreds.allPrincs:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosPrincipal
            putfield sun.security.jgss.krb5.ServiceCreds.kp:Ljavax/security/auth/kerberos/KerberosPrincipal;
        23: .line 118
            aload 2 /* sc */
            getfield sun.security.jgss.krb5.ServiceCreds.kp:Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
            astore 1 /* serverPrincipal */
        end local 3 // boolean hasUnbound
        24: .line 123
      StackMap locals:
      StackMap stack:
            aload 2 /* sc */
        25: .line 124
            aload 0 /* subj */
            aload 1 /* serverPrincipal */
            aconst_null
            ldc Ljavax/security/auth/kerberos/KeyTab;
        26: .line 123
            invokestatic sun.security.jgss.krb5.SubjectComber.findMany:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/util/List;
            putfield sun.security.jgss.krb5.ServiceCreds.ktabs:Ljava/util/List;
        27: .line 125
            aload 2 /* sc */
        28: .line 126
            aload 0 /* subj */
            aload 1 /* serverPrincipal */
            aconst_null
            ldc Ljavax/security/auth/kerberos/KerberosKey;
        29: .line 125
            invokestatic sun.security.jgss.krb5.SubjectComber.findMany:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/util/List;
            putfield sun.security.jgss.krb5.ServiceCreds.kk:Ljava/util/List;
        30: .line 127
            aload 2 /* sc */
        31: .line 128
            aload 0 /* subj */
            aconst_null
            aload 1 /* serverPrincipal */
            ldc Ljavax/security/auth/kerberos/KerberosTicket;
        32: .line 127
            invokestatic sun.security.jgss.krb5.SubjectComber.find:(Ljavax/security/auth/Subject;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosTicket
            putfield sun.security.jgss.krb5.ServiceCreds.tgt:Ljavax/security/auth/kerberos/KerberosTicket;
        33: .line 129
            aload 2 /* sc */
            getfield sun.security.jgss.krb5.ServiceCreds.ktabs:Ljava/util/List;
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 35
            aload 2 /* sc */
            getfield sun.security.jgss.krb5.ServiceCreds.kk:Ljava/util/List;
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 35
            aload 2 /* sc */
            getfield sun.security.jgss.krb5.ServiceCreds.tgt:Ljavax/security/auth/kerberos/KerberosTicket;
            ifnonnull 35
        34: .line 130
            aconst_null
            areturn
        35: .line 133
      StackMap locals:
      StackMap stack:
            aload 2 /* sc */
            iconst_0
            putfield sun.security.jgss.krb5.ServiceCreds.destroyed:Z
        36: .line 135
            aload 2 /* sc */
            areturn
        end local 2 // sun.security.jgss.krb5.ServiceCreds sc
        end local 1 // java.lang.String serverPrincipal
        end local 0 // javax.security.auth.Subject subj
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   37     0             subj  Ljavax/security/auth/Subject;
            0   37     1  serverPrincipal  Ljava/lang/String;
            1   37     2               sc  Lsun/security/jgss/krb5/ServiceCreds;
            7    8     3              key  Ljavax/security/auth/kerberos/KerberosKey;
           14   24     3       hasUnbound  Z
           17   20     4             ktab  Ljavax/security/auth/kerberos/KeyTab;
    MethodParameters:
                 Name  Flags
      subj             
      serverPrincipal  

  public java.lang.String getName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.jgss.krb5.ServiceCreds this
         0: .line 140
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.destroyed:Z
            ifeq 2
         1: .line 141
            new java.lang.IllegalStateException
            dup
            ldc "This object is destroyed"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 143
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.kp:Ljavax/security/auth/kerberos/KerberosPrincipal;
            ifnonnull 3
            aconst_null
            goto 4
      StackMap locals:
      StackMap stack:
         3: aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.kp:Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
      StackMap locals:
      StackMap stack: java.lang.String
         4: areturn
        end local 0 // sun.security.jgss.krb5.ServiceCreds this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/jgss/krb5/ServiceCreds;

  public javax.security.auth.kerberos.KerberosKey[] getKKeys();
    descriptor: ()[Ljavax/security/auth/kerberos/KerberosKey;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=1
        start local 0 // sun.security.jgss.krb5.ServiceCreds this
         0: .line 153
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.destroyed:Z
            ifeq 2
         1: .line 154
            new java.lang.IllegalStateException
            dup
            ldc "This object is destroyed"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 156
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.kp:Ljavax/security/auth/kerberos/KerberosPrincipal;
            astore 1 /* one */
        start local 1 // javax.security.auth.kerberos.KerberosPrincipal one
         3: .line 157
            aload 1 /* one */
            ifnonnull 5
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.allPrincs:Ljava/util/Set;
            invokeinterface java.util.Set.isEmpty:()Z
            ifne 5
         4: .line 158
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.allPrincs:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosPrincipal
            astore 1 /* one */
         5: .line 160
      StackMap locals: javax.security.auth.kerberos.KerberosPrincipal
      StackMap stack:
            aload 1 /* one */
            ifnonnull 14
         6: .line 161
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.ktabs:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 13
      StackMap locals: sun.security.jgss.krb5.ServiceCreds javax.security.auth.kerberos.KerberosPrincipal top java.util.Iterator
      StackMap stack:
         7: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KeyTab
            astore 2 /* ktab */
        start local 2 // javax.security.auth.kerberos.KeyTab ktab
         8: .line 164
            aload 2 /* ktab */
            invokestatic sun.security.jgss.krb5.Krb5Util.snapshotFromJavaxKeyTab:(Ljavax/security/auth/kerberos/KeyTab;)Lsun/security/krb5/internal/ktab/KeyTab;
            invokevirtual sun.security.krb5.internal.ktab.KeyTab.getOneName:()Lsun/security/krb5/PrincipalName;
         9: .line 163
            astore 4 /* pn */
        start local 4 // sun.security.krb5.PrincipalName pn
        10: .line 165
            aload 4 /* pn */
            ifnull 13
        11: .line 166
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
            aload 4 /* pn */
            invokevirtual sun.security.krb5.PrincipalName.getName:()Ljava/lang/String;
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;)V
            astore 1 /* one */
        12: .line 167
            goto 14
        end local 4 // sun.security.krb5.PrincipalName pn
        end local 2 // javax.security.auth.kerberos.KeyTab ktab
        13: .line 161
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        14: .line 171
      StackMap locals: sun.security.jgss.krb5.ServiceCreds javax.security.auth.kerberos.KerberosPrincipal
      StackMap stack:
            aload 1 /* one */
            ifnull 16
        15: .line 172
            aload 0 /* this */
            aload 1 /* one */
            invokevirtual sun.security.jgss.krb5.ServiceCreds.getKKeys:(Ljavax/security/auth/kerberos/KerberosPrincipal;)[Ljavax/security/auth/kerberos/KerberosKey;
            areturn
        16: .line 174
      StackMap locals:
      StackMap stack:
            iconst_0
            anewarray javax.security.auth.kerberos.KerberosKey
            areturn
        end local 1 // javax.security.auth.kerberos.KerberosPrincipal one
        end local 0 // sun.security.jgss.krb5.ServiceCreds this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   17     0  this  Lsun/security/jgss/krb5/ServiceCreds;
            3   17     1   one  Ljavax/security/auth/kerberos/KerberosPrincipal;
            8   13     2  ktab  Ljavax/security/auth/kerberos/KeyTab;
           10   13     4    pn  Lsun/security/krb5/PrincipalName;

  public javax.security.auth.kerberos.KerberosKey[] getKKeys(javax.security.auth.kerberos.KerberosPrincipal);
    descriptor: (Ljavax/security/auth/kerberos/KerberosPrincipal;)[Ljavax/security/auth/kerberos/KerberosKey;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=9, args_size=2
        start local 0 // sun.security.jgss.krb5.ServiceCreds this
        start local 1 // javax.security.auth.kerberos.KerberosPrincipal princ
         0: .line 184
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.destroyed:Z
            ifeq 2
         1: .line 185
            new java.lang.IllegalStateException
            dup
            ldc "This object is destroyed"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 187
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 2 /* keys */
        start local 2 // java.util.ArrayList keys
         3: .line 188
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.kp:Ljavax/security/auth/kerberos/KerberosPrincipal;
            ifnull 5
            aload 1 /* princ */
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.kp:Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.equals:(Ljava/lang/Object;)Z
            ifne 5
         4: .line 189
            iconst_0
            anewarray javax.security.auth.kerberos.KerberosKey
            areturn
         5: .line 191
      StackMap locals: java.util.ArrayList
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.kk:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 9
      StackMap locals: sun.security.jgss.krb5.ServiceCreds javax.security.auth.kerberos.KerberosPrincipal java.util.ArrayList top java.util.Iterator
      StackMap stack:
         6: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosKey
            astore 3 /* k */
        start local 3 // javax.security.auth.kerberos.KerberosKey k
         7: .line 192
            aload 3 /* k */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            aload 1 /* princ */
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.equals:(Ljava/lang/Object;)Z
            ifeq 9
         8: .line 193
            aload 2 /* keys */
            aload 3 /* k */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // javax.security.auth.kerberos.KerberosKey k
         9: .line 191
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        10: .line 196
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.ktabs:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 20
      StackMap locals:
      StackMap stack:
        11: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KeyTab
            astore 3 /* ktab */
        start local 3 // javax.security.auth.kerberos.KeyTab ktab
        12: .line 197
            aload 3 /* ktab */
            invokevirtual javax.security.auth.kerberos.KeyTab.getPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            ifnonnull 15
            aload 3 /* ktab */
            invokevirtual javax.security.auth.kerberos.KeyTab.isBound:()Z
            ifeq 15
        13: .line 200
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.allPrincs:Ljava/util/Set;
            aload 1 /* princ */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifne 15
        14: .line 201
            goto 20
        15: .line 204
      StackMap locals: sun.security.jgss.krb5.ServiceCreds javax.security.auth.kerberos.KerberosPrincipal java.util.ArrayList javax.security.auth.kerberos.KeyTab java.util.Iterator
      StackMap stack:
            aload 3 /* ktab */
            aload 1 /* princ */
            invokevirtual javax.security.auth.kerberos.KeyTab.getKeys:(Ljavax/security/auth/kerberos/KerberosPrincipal;)[Ljavax/security/auth/kerberos/KerberosKey;
            dup
            astore 8
            arraylength
            istore 7
            iconst_0
            istore 6
            goto 19
      StackMap locals: sun.security.jgss.krb5.ServiceCreds javax.security.auth.kerberos.KerberosPrincipal java.util.ArrayList javax.security.auth.kerberos.KeyTab java.util.Iterator top int int javax.security.auth.kerberos.KerberosKey[]
      StackMap stack:
        16: aload 8
            iload 6
            aaload
            astore 5 /* k */
        start local 5 // javax.security.auth.kerberos.KerberosKey k
        17: .line 205
            aload 2 /* keys */
            aload 5 /* k */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        end local 5 // javax.security.auth.kerberos.KerberosKey k
        18: .line 204
            iinc 6 1
      StackMap locals:
      StackMap stack:
        19: iload 6
            iload 7
            if_icmplt 16
        end local 3 // javax.security.auth.kerberos.KeyTab ktab
        20: .line 196
      StackMap locals: sun.security.jgss.krb5.ServiceCreds javax.security.auth.kerberos.KerberosPrincipal java.util.ArrayList top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 11
        21: .line 208
            aload 2 /* keys */
            aload 2 /* keys */
            invokevirtual java.util.ArrayList.size:()I
            anewarray javax.security.auth.kerberos.KerberosKey
            invokevirtual java.util.ArrayList.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosKey[]
            areturn
        end local 2 // java.util.ArrayList keys
        end local 1 // javax.security.auth.kerberos.KerberosPrincipal princ
        end local 0 // sun.security.jgss.krb5.ServiceCreds this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   22     0   this  Lsun/security/jgss/krb5/ServiceCreds;
            0   22     1  princ  Ljavax/security/auth/kerberos/KerberosPrincipal;
            3   22     2   keys  Ljava/util/ArrayList<Ljavax/security/auth/kerberos/KerberosKey;>;
            7    9     3      k  Ljavax/security/auth/kerberos/KerberosKey;
           12   20     3   ktab  Ljavax/security/auth/kerberos/KeyTab;
           17   18     5      k  Ljavax/security/auth/kerberos/KerberosKey;
    MethodParameters:
       Name  Flags
      princ  

  public sun.security.krb5.EncryptionKey[] getEKeys(sun.security.krb5.PrincipalName);
    descriptor: (Lsun/security/krb5/PrincipalName;)[Lsun/security/krb5/EncryptionKey;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=10, locals=5, args_size=2
        start local 0 // sun.security.jgss.krb5.ServiceCreds this
        start local 1 // sun.security.krb5.PrincipalName princ
         0: .line 217
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.destroyed:Z
            ifeq 2
         1: .line 218
            new java.lang.IllegalStateException
            dup
            ldc "This object is destroyed"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 220
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
            aload 1 /* princ */
            invokevirtual sun.security.krb5.PrincipalName.getName:()Ljava/lang/String;
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;)V
            invokevirtual sun.security.jgss.krb5.ServiceCreds.getKKeys:(Ljavax/security/auth/kerberos/KerberosPrincipal;)[Ljavax/security/auth/kerberos/KerberosKey;
            astore 2 /* kkeys */
        start local 2 // javax.security.auth.kerberos.KerberosKey[] kkeys
         3: .line 221
            aload 2 /* kkeys */
            arraylength
            ifne 5
         4: .line 228
            aload 0 /* this */
            invokevirtual sun.security.jgss.krb5.ServiceCreds.getKKeys:()[Ljavax/security/auth/kerberos/KerberosKey;
            astore 2 /* kkeys */
         5: .line 230
      StackMap locals: javax.security.auth.kerberos.KerberosKey[]
      StackMap stack:
            aload 2 /* kkeys */
            arraylength
            anewarray sun.security.krb5.EncryptionKey
            astore 3 /* ekeys */
        start local 3 // sun.security.krb5.EncryptionKey[] ekeys
         6: .line 231
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         7: goto 13
         8: .line 232
      StackMap locals: sun.security.krb5.EncryptionKey[] int
      StackMap stack:
            aload 3 /* ekeys */
            iload 4 /* i */
            new sun.security.krb5.EncryptionKey
            dup
         9: .line 233
            aload 2 /* kkeys */
            iload 4 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getEncoded:()[B
            aload 2 /* kkeys */
            iload 4 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getKeyType:()I
        10: .line 234
            new java.lang.Integer
            dup
            aload 2 /* kkeys */
            iload 4 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getVersionNumber:()I
            invokespecial java.lang.Integer.<init>:(I)V
            invokespecial sun.security.krb5.EncryptionKey.<init>:([BILjava/lang/Integer;)V
        11: .line 232
            aastore
        12: .line 231
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
        13: iload 4 /* i */
            aload 3 /* ekeys */
            arraylength
            if_icmplt 8
        end local 4 // int i
        14: .line 236
            aload 3 /* ekeys */
            areturn
        end local 3 // sun.security.krb5.EncryptionKey[] ekeys
        end local 2 // javax.security.auth.kerberos.KerberosKey[] kkeys
        end local 1 // sun.security.krb5.PrincipalName princ
        end local 0 // sun.security.jgss.krb5.ServiceCreds this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   15     0   this  Lsun/security/jgss/krb5/ServiceCreds;
            0   15     1  princ  Lsun/security/krb5/PrincipalName;
            3   15     2  kkeys  [Ljavax/security/auth/kerberos/KerberosKey;
            6   15     3  ekeys  [Lsun/security/krb5/EncryptionKey;
            7   14     4      i  I
    MethodParameters:
       Name  Flags
      princ  

  public sun.security.krb5.Credentials getInitCred();
    descriptor: ()Lsun/security/krb5/Credentials;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.jgss.krb5.ServiceCreds this
         0: .line 240
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.destroyed:Z
            ifeq 2
         1: .line 241
            new java.lang.IllegalStateException
            dup
            ldc "This object is destroyed"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 243
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.tgt:Ljavax/security/auth/kerberos/KerberosTicket;
            ifnonnull 4
         3: .line 244
            aconst_null
            areturn
         4: .line 247
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.tgt:Ljavax/security/auth/kerberos/KerberosTicket;
            invokestatic sun.security.jgss.krb5.Krb5Util.ticketToCreds:(Ljavax/security/auth/kerberos/KerberosTicket;)Lsun/security/krb5/Credentials;
         5: areturn
         6: .line 248
      StackMap locals:
      StackMap stack: java.lang.Exception
            pop
         7: .line 249
            aconst_null
            areturn
        end local 0 // sun.security.jgss.krb5.ServiceCreds this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lsun/security/jgss/krb5/ServiceCreds;
      Exception table:
        from    to  target  type
           4     5       6  Class sun.security.krb5.KrbException
           4     5       6  Class java.io.IOException

  public void destroy();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.jgss.krb5.ServiceCreds this
         0: .line 256
            aload 0 /* this */
            iconst_1
            putfield sun.security.jgss.krb5.ServiceCreds.destroyed:Z
         1: .line 257
            aload 0 /* this */
            aconst_null
            putfield sun.security.jgss.krb5.ServiceCreds.kp:Ljavax/security/auth/kerberos/KerberosPrincipal;
         2: .line 258
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.ktabs:Ljava/util/List;
            invokeinterface java.util.List.clear:()V
         3: .line 259
            aload 0 /* this */
            getfield sun.security.jgss.krb5.ServiceCreds.kk:Ljava/util/List;
            invokeinterface java.util.List.clear:()V
         4: .line 260
            aload 0 /* this */
            aconst_null
            putfield sun.security.jgss.krb5.ServiceCreds.tgt:Ljavax/security/auth/kerberos/KerberosTicket;
         5: .line 261
            return
        end local 0 // sun.security.jgss.krb5.ServiceCreds this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lsun/security/jgss/krb5/ServiceCreds;
}
SourceFile: "ServiceCreds.java"