public class sun.security.krb5.internal.CredentialsUtil
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.security.krb5.internal.CredentialsUtil
  super_class: java.lang.Object
{
  private static boolean DEBUG;
    descriptor: Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

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

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.krb5.internal.CredentialsUtil this
         0: .line 44
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // sun.security.krb5.internal.CredentialsUtil this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/internal/CredentialsUtil;

  public static sun.security.krb5.Credentials acquireS4U2selfCreds(sun.security.krb5.PrincipalName, sun.security.krb5.Credentials);
    descriptor: (Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=15, locals=5, args_size=2
        start local 0 // sun.security.krb5.PrincipalName client
        start local 1 // sun.security.krb5.Credentials ccreds
         0: .line 57
            aload 0 /* client */
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 2 /* uRealm */
        start local 2 // java.lang.String uRealm
         1: .line 58
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 3 /* localRealm */
        start local 3 // java.lang.String localRealm
         2: .line 59
            aload 2 /* uRealm */
            aload 3 /* localRealm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 4
         3: .line 61
            new sun.security.krb5.KrbException
            dup
            ldc "Cross realm impersonation not supported"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 63
      StackMap locals: java.lang.String java.lang.String
      StackMap stack:
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.isForwardable:()Z
            ifne 6
         5: .line 64
            new sun.security.krb5.KrbException
            dup
            ldc "S4U2self needs a FORWARDABLE ticket"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 66
      StackMap locals:
      StackMap stack:
            iconst_1
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            invokestatic sun.security.krb5.internal.KDCOptions.with:([I)Lsun/security/krb5/internal/KDCOptions;
         7: .line 67
            aload 1 /* ccreds */
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            aconst_null
         8: .line 68
            iconst_1
            anewarray sun.security.krb5.internal.PAData
            dup
            iconst_0
            new sun.security.krb5.internal.PAData
            dup
            sipush 129
         9: .line 69
            new sun.security.krb5.internal.PAForUserEnc
            dup
            aload 0 /* client */
        10: .line 70
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getSessionKey:()Lsun/security/krb5/EncryptionKey;
        11: .line 69
            invokespecial sun.security.krb5.internal.PAForUserEnc.<init>:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/EncryptionKey;)V
        12: .line 70
            invokevirtual sun.security.krb5.internal.PAForUserEnc.asn1Encode:()[B
        13: .line 68
            invokespecial sun.security.krb5.internal.PAData.<init>:(I[B)V
            aastore
        14: .line 66
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCreds:(Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
            astore 4 /* creds */
        start local 4 // sun.security.krb5.Credentials creds
        15: .line 71
            aload 4 /* creds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            aload 0 /* client */
            invokevirtual sun.security.krb5.PrincipalName.equals:(Ljava/lang/Object;)Z
            ifne 17
        16: .line 72
            new sun.security.krb5.KrbException
            dup
            ldc "S4U2self request not honored by KDC"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
        17: .line 74
      StackMap locals: sun.security.krb5.Credentials
      StackMap stack:
            aload 4 /* creds */
            invokevirtual sun.security.krb5.Credentials.isForwardable:()Z
            ifne 19
        18: .line 75
            new sun.security.krb5.KrbException
            dup
            ldc "S4U2self ticket must be FORWARDABLE"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
        19: .line 77
      StackMap locals:
      StackMap stack:
            aload 4 /* creds */
            areturn
        end local 4 // sun.security.krb5.Credentials creds
        end local 3 // java.lang.String localRealm
        end local 2 // java.lang.String uRealm
        end local 1 // sun.security.krb5.Credentials ccreds
        end local 0 // sun.security.krb5.PrincipalName client
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   20     0      client  Lsun/security/krb5/PrincipalName;
            0   20     1      ccreds  Lsun/security/krb5/Credentials;
            1   20     2      uRealm  Ljava/lang/String;
            2   20     3  localRealm  Ljava/lang/String;
           15   20     4       creds  Lsun/security/krb5/Credentials;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
        Name  Flags
      client  
      ccreds  

  public static sun.security.krb5.Credentials acquireS4U2proxyCreds(java.lang.String, sun.security.krb5.internal.Ticket, sun.security.krb5.PrincipalName, sun.security.krb5.Credentials);
    descriptor: (Ljava/lang/String;Lsun/security/krb5/internal/Ticket;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=8, locals=5, args_size=4
        start local 0 // java.lang.String backend
        start local 1 // sun.security.krb5.internal.Ticket second
        start local 2 // sun.security.krb5.PrincipalName client
        start local 3 // sun.security.krb5.Credentials ccreds
         0: .line 92
            iconst_2
            newarray 10
            dup
            iconst_0
         1: .line 93
            bipush 14
            iastore
            dup
            iconst_1
            iconst_1
            iastore
         2: .line 92
            invokestatic sun.security.krb5.internal.KDCOptions.with:([I)Lsun/security/krb5/internal/KDCOptions;
         3: .line 94
            aload 3 /* ccreds */
            aload 3 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            new sun.security.krb5.PrincipalName
            dup
            aload 0 /* backend */
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;)V
         4: .line 95
            iconst_1
            anewarray sun.security.krb5.internal.Ticket
            dup
            iconst_0
            aload 1 /* second */
            aastore
            aconst_null
         5: .line 92
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCreds:(Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
            astore 4 /* creds */
        start local 4 // sun.security.krb5.Credentials creds
         6: .line 96
            aload 4 /* creds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            aload 2 /* client */
            invokevirtual sun.security.krb5.PrincipalName.equals:(Ljava/lang/Object;)Z
            ifne 8
         7: .line 97
            new sun.security.krb5.KrbException
            dup
            ldc "S4U2proxy request not honored by KDC"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 99
      StackMap locals: sun.security.krb5.Credentials
      StackMap stack:
            aload 4 /* creds */
            areturn
        end local 4 // sun.security.krb5.Credentials creds
        end local 3 // sun.security.krb5.Credentials ccreds
        end local 2 // sun.security.krb5.PrincipalName client
        end local 1 // sun.security.krb5.internal.Ticket second
        end local 0 // java.lang.String backend
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    9     0  backend  Ljava/lang/String;
            0    9     1   second  Lsun/security/krb5/internal/Ticket;
            0    9     2   client  Lsun/security/krb5/PrincipalName;
            0    9     3   ccreds  Lsun/security/krb5/Credentials;
            6    9     4    creds  Lsun/security/krb5/Credentials;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
         Name  Flags
      backend  
      second   
      client   
      ccreds   

  public static sun.security.krb5.Credentials acquireServiceCreds(java.lang.String, sun.security.krb5.Credentials);
    descriptor: (Ljava/lang/String;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // java.lang.String service
        start local 1 // sun.security.krb5.Credentials ccreds
         0: .line 116
            new sun.security.krb5.PrincipalName
            dup
            aload 0 /* service */
         1: .line 117
            iconst_3
         2: .line 116
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;I)V
            astore 2 /* sname */
        start local 2 // sun.security.krb5.PrincipalName sname
         3: .line 118
            aload 2 /* sname */
            aload 1 /* ccreds */
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCreds:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
            areturn
        end local 2 // sun.security.krb5.PrincipalName sname
        end local 1 // sun.security.krb5.Credentials ccreds
        end local 0 // java.lang.String service
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    4     0  service  Ljava/lang/String;
            0    4     1   ccreds  Lsun/security/krb5/Credentials;
            3    4     2    sname  Lsun/security/krb5/PrincipalName;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
         Name  Flags
      service  
      ccreds   

  private static sun.security.krb5.Credentials getTGTforRealm(java.lang.String, java.lang.String, sun.security.krb5.Credentials, boolean[]);
    descriptor: (Ljava/lang/String;Ljava/lang/String;Lsun/security/krb5/Credentials;[Z)Lsun/security/krb5/Credentials;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=12, args_size=4
        start local 0 // java.lang.String localRealm
        start local 1 // java.lang.String serviceRealm
        start local 2 // sun.security.krb5.Credentials ccreds
        start local 3 // boolean[] okAsDelegate
         0: .line 136
            aload 0 /* localRealm */
            aload 1 /* serviceRealm */
            invokestatic sun.security.krb5.Realm.getRealmsList:(Ljava/lang/String;Ljava/lang/String;)[Ljava/lang/String;
            astore 4 /* realms */
        start local 4 // java.lang.String[] realms
         1: .line 138
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         2: iconst_0
            istore 6 /* k */
        start local 6 // int k
         3: .line 139
            aconst_null
            astore 7 /* cTgt */
        start local 7 // sun.security.krb5.Credentials cTgt
         4: aconst_null
            astore 8 /* newTgt */
        start local 8 // sun.security.krb5.Credentials newTgt
         5: aconst_null
            astore 9 /* theTgt */
        start local 9 // sun.security.krb5.Credentials theTgt
         6: .line 140
            aconst_null
            astore 10 /* tempService */
        start local 10 // sun.security.krb5.PrincipalName tempService
         7: .line 141
            aconst_null
            astore 11 /* newTgtRealm */
        start local 11 // java.lang.String newTgtRealm
         8: .line 143
            aload 3 /* okAsDelegate */
            iconst_0
            iconst_1
            bastore
         9: .line 144
            aload 2 /* ccreds */
            astore 7 /* cTgt */
            iconst_0
            istore 5 /* i */
            goto 69
        10: .line 145
      StackMap locals: java.lang.String java.lang.String sun.security.krb5.Credentials boolean[] java.lang.String[] int int sun.security.krb5.Credentials sun.security.krb5.Credentials sun.security.krb5.Credentials sun.security.krb5.PrincipalName java.lang.String
      StackMap stack:
            aload 1 /* serviceRealm */
            aload 4 /* realms */
            iload 5 /* i */
            aaload
            invokestatic sun.security.krb5.PrincipalName.tgsService:(Ljava/lang/String;Ljava/lang/String;)Lsun/security/krb5/PrincipalName;
            astore 10 /* tempService */
        11: .line 147
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 17
        12: .line 148
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        13: .line 149
            new java.lang.StringBuilder
            dup
            ldc ">>> Credentials acquireServiceCreds: main loop: ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        14: .line 150
            iload 5 /* i */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "] tempService="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 10 /* tempService */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        15: .line 149
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        16: .line 148
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        17: .line 154
      StackMap locals:
      StackMap stack:
            aload 10 /* tempService */
            aload 7 /* cTgt */
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCreds:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
            astore 8 /* newTgt */
        18: .line 155
            goto 21
      StackMap locals:
      StackMap stack: java.lang.Exception
        19: pop
        20: .line 156
            aconst_null
            astore 8 /* newTgt */
        21: .line 159
      StackMap locals:
      StackMap stack:
            aload 8 /* newTgt */
            ifnonnull 41
        22: .line 160
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 24
        23: .line 161
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Credentials acquireServiceCreds: no tgt; searching thru capath"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        24: .line 168
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 8 /* newTgt */
            iload 5 /* i */
            iconst_1
            iadd
            istore 6 /* k */
        25: .line 169
            goto 39
        26: .line 170
      StackMap locals:
      StackMap stack:
            aload 4 /* realms */
            iload 6 /* k */
            aaload
            aload 4 /* realms */
            iload 5 /* i */
            aaload
            invokestatic sun.security.krb5.PrincipalName.tgsService:(Ljava/lang/String;Ljava/lang/String;)Lsun/security/krb5/PrincipalName;
            astore 10 /* tempService */
        27: .line 171
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 34
        28: .line 172
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        29: .line 173
            new java.lang.StringBuilder
            dup
            ldc ">>> Credentials acquireServiceCreds: inner loop: ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        30: .line 174
            iload 6 /* k */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        31: .line 175
            ldc "] tempService="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 10 /* tempService */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        32: .line 173
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        33: .line 172
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        34: .line 178
      StackMap locals:
      StackMap stack:
            aload 10 /* tempService */
            aload 7 /* cTgt */
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCreds:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
            astore 8 /* newTgt */
        35: .line 179
            goto 38
      StackMap locals:
      StackMap stack: java.lang.Exception
        36: pop
        37: .line 180
            aconst_null
            astore 8 /* newTgt */
        38: .line 169
      StackMap locals:
      StackMap stack:
            iinc 6 /* k */ 1
      StackMap locals:
      StackMap stack:
        39: aload 8 /* newTgt */
            ifnonnull 41
            iload 6 /* k */
            aload 4 /* realms */
            arraylength
        40: .line 168
            if_icmplt 26
        41: .line 185
      StackMap locals:
      StackMap stack:
            aload 8 /* newTgt */
            ifnonnull 45
        42: .line 186
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 70
        43: .line 187
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Credentials acquireServiceCreds: no tgt; cannot get creds"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        44: .line 190
            goto 70
        45: .line 197
      StackMap locals:
      StackMap stack:
            aload 8 /* newTgt */
            invokevirtual sun.security.krb5.Credentials.getServer:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getInstanceComponent:()Ljava/lang/String;
            astore 11 /* newTgtRealm */
        46: .line 198
            aload 3 /* okAsDelegate */
            iconst_0
            baload
            ifeq 52
            aload 8 /* newTgt */
            invokevirtual sun.security.krb5.Credentials.checkDelegate:()Z
            ifne 52
        47: .line 199
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 51
        48: .line 200
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc ">>> Credentials acquireServiceCreds: global OK-AS-DELEGATE turned off at "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        49: .line 202
            aload 8 /* newTgt */
            invokevirtual sun.security.krb5.Credentials.getServer:()Lsun/security/krb5/PrincipalName;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        50: .line 200
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        51: .line 204
      StackMap locals:
      StackMap stack:
            aload 3 /* okAsDelegate */
            iconst_0
            iconst_0
            bastore
        52: .line 207
      StackMap locals:
      StackMap stack:
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 54
        53: .line 208
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Credentials acquireServiceCreds: got tgt"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        54: .line 212
      StackMap locals:
      StackMap stack:
            aload 11 /* newTgtRealm */
            aload 1 /* serviceRealm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 57
        55: .line 214
            aload 8 /* newTgt */
            astore 9 /* theTgt */
        56: .line 215
            goto 70
        57: .line 223
      StackMap locals:
      StackMap stack:
            iload 5 /* i */
            iconst_1
            iadd
            istore 6 /* k */
            goto 61
        58: .line 224
      StackMap locals:
      StackMap stack:
            aload 11 /* newTgtRealm */
            aload 4 /* realms */
            iload 6 /* k */
            aaload
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 60
        59: .line 225
            goto 62
        60: .line 223
      StackMap locals:
      StackMap stack:
            iinc 6 /* k */ 1
      StackMap locals:
      StackMap stack:
        61: iload 6 /* k */
            aload 4 /* realms */
            arraylength
            if_icmplt 58
        62: .line 229
      StackMap locals:
      StackMap stack:
            iload 6 /* k */
            aload 4 /* realms */
            arraylength
            if_icmpge 70
        63: .line 234
            iload 6 /* k */
            istore 5 /* i */
        64: .line 235
            aload 8 /* newTgt */
            astore 7 /* cTgt */
        65: .line 237
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 69
        66: .line 238
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc ">>> Credentials acquireServiceCreds: continuing with main loop counter reset to "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        67: .line 239
            iload 5 /* i */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        68: .line 238
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        69: .line 144
      StackMap locals:
      StackMap stack:
            iload 5 /* i */
            aload 4 /* realms */
            arraylength
            if_icmplt 10
        70: .line 254
      StackMap locals:
      StackMap stack:
            aload 9 /* theTgt */
            areturn
        end local 11 // java.lang.String newTgtRealm
        end local 10 // sun.security.krb5.PrincipalName tempService
        end local 9 // sun.security.krb5.Credentials theTgt
        end local 8 // sun.security.krb5.Credentials newTgt
        end local 7 // sun.security.krb5.Credentials cTgt
        end local 6 // int k
        end local 5 // int i
        end local 4 // java.lang.String[] realms
        end local 3 // boolean[] okAsDelegate
        end local 2 // sun.security.krb5.Credentials ccreds
        end local 1 // java.lang.String serviceRealm
        end local 0 // java.lang.String localRealm
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   71     0    localRealm  Ljava/lang/String;
            0   71     1  serviceRealm  Ljava/lang/String;
            0   71     2        ccreds  Lsun/security/krb5/Credentials;
            0   71     3  okAsDelegate  [Z
            1   71     4        realms  [Ljava/lang/String;
            2   71     5             i  I
            3   71     6             k  I
            4   71     7          cTgt  Lsun/security/krb5/Credentials;
            5   71     8        newTgt  Lsun/security/krb5/Credentials;
            6   71     9        theTgt  Lsun/security/krb5/Credentials;
            7   71    10   tempService  Lsun/security/krb5/PrincipalName;
            8   71    11   newTgtRealm  Ljava/lang/String;
      Exception table:
        from    to  target  type
          17    18      19  Class java.lang.Exception
          34    35      36  Class java.lang.Exception
    Exceptions:
      throws sun.security.krb5.KrbException
    MethodParameters:
              Name  Flags
      localRealm    
      serviceRealm  
      ccreds        
      okAsDelegate  

  private static sun.security.krb5.Credentials serviceCreds(sun.security.krb5.PrincipalName, sun.security.krb5.Credentials);
    descriptor: (Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=2, args_size=2
        start local 0 // sun.security.krb5.PrincipalName service
        start local 1 // sun.security.krb5.Credentials ccreds
         0: .line 263
            new sun.security.krb5.internal.KDCOptions
            dup
            invokespecial sun.security.krb5.internal.KDCOptions.<init>:()V
            aload 1 /* ccreds */
         1: .line 264
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            aload 0 /* service */
            aconst_null
            aconst_null
         2: .line 263
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCreds:(Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
            areturn
        end local 1 // sun.security.krb5.Credentials ccreds
        end local 0 // sun.security.krb5.PrincipalName service
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0  service  Lsun/security/krb5/PrincipalName;
            0    3     1   ccreds  Lsun/security/krb5/Credentials;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
         Name  Flags
      service  
      ccreds   

  private static sun.security.krb5.Credentials serviceCreds(sun.security.krb5.internal.KDCOptions, sun.security.krb5.Credentials, sun.security.krb5.PrincipalName, sun.security.krb5.PrincipalName, sun.security.krb5.internal.Ticket[], sun.security.krb5.internal.PAData[]);
    descriptor: (Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=8, locals=6, args_size=6
        start local 0 // sun.security.krb5.internal.KDCOptions options
        start local 1 // sun.security.krb5.Credentials asCreds
        start local 2 // sun.security.krb5.PrincipalName cname
        start local 3 // sun.security.krb5.PrincipalName sname
        start local 4 // sun.security.krb5.internal.Ticket[] additionalTickets
        start local 5 // sun.security.krb5.internal.PAData[] extraPAs
         0: .line 278
            getstatic sun.security.krb5.Config.DISABLE_REFERRALS:Z
            ifne 6
         1: .line 280
            aload 0 /* options */
            aload 1 /* asCreds */
         2: .line 281
            aload 2 /* cname */
            aload 3 /* sname */
            aload 4 /* additionalTickets */
            aload 5 /* extraPAs */
         3: .line 280
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCredsReferrals:(Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
         4: areturn
         5: .line 282
      StackMap locals:
      StackMap stack: sun.security.krb5.KrbException
            pop
         6: .line 287
      StackMap locals:
      StackMap stack:
            aload 0 /* options */
            aload 1 /* asCreds */
            aload 2 /* cname */
         7: .line 288
            aload 1 /* asCreds */
            invokevirtual sun.security.krb5.Credentials.getClientAlias:()Lsun/security/krb5/PrincipalName;
            aload 3 /* sname */
            aload 3 /* sname */
            aload 4 /* additionalTickets */
         8: .line 289
            aload 5 /* extraPAs */
         9: .line 287
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCredsSingle:(Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
            areturn
        end local 5 // sun.security.krb5.internal.PAData[] extraPAs
        end local 4 // sun.security.krb5.internal.Ticket[] additionalTickets
        end local 3 // sun.security.krb5.PrincipalName sname
        end local 2 // sun.security.krb5.PrincipalName cname
        end local 1 // sun.security.krb5.Credentials asCreds
        end local 0 // sun.security.krb5.internal.KDCOptions options
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   10     0            options  Lsun/security/krb5/internal/KDCOptions;
            0   10     1            asCreds  Lsun/security/krb5/Credentials;
            0   10     2              cname  Lsun/security/krb5/PrincipalName;
            0   10     3              sname  Lsun/security/krb5/PrincipalName;
            0   10     4  additionalTickets  [Lsun/security/krb5/internal/Ticket;
            0   10     5           extraPAs  [Lsun/security/krb5/internal/PAData;
      Exception table:
        from    to  target  type
           1     4       5  Class sun.security.krb5.KrbException
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
                   Name  Flags
      options            
      asCreds            
      cname              
      sname              
      additionalTickets  
      extraPAs           

  private static sun.security.krb5.Credentials serviceCredsReferrals(sun.security.krb5.internal.KDCOptions, sun.security.krb5.Credentials, sun.security.krb5.PrincipalName, sun.security.krb5.PrincipalName, sun.security.krb5.internal.Ticket[], sun.security.krb5.internal.PAData[]);
    descriptor: (Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=8, locals=16, args_size=6
        start local 0 // sun.security.krb5.internal.KDCOptions options
        start local 1 // sun.security.krb5.Credentials asCreds
        start local 2 // sun.security.krb5.PrincipalName cname
        start local 3 // sun.security.krb5.PrincipalName sname
        start local 4 // sun.security.krb5.internal.Ticket[] additionalTickets
        start local 5 // sun.security.krb5.internal.PAData[] extraPAs
         0: .line 301
            new sun.security.krb5.internal.KDCOptions
            dup
            aload 0 /* options */
            invokevirtual sun.security.krb5.internal.KDCOptions.toBooleanArray:()[Z
            invokespecial sun.security.krb5.internal.KDCOptions.<init>:([Z)V
            astore 0 /* options */
         1: .line 302
            aload 0 /* options */
            bipush 15
            iconst_1
            invokevirtual sun.security.krb5.internal.KDCOptions.set:(IZ)V
         2: .line 303
            aload 3 /* sname */
            astore 6 /* cSname */
        start local 6 // sun.security.krb5.PrincipalName cSname
         3: .line 304
            aload 3 /* sname */
            astore 7 /* refSname */
        start local 7 // sun.security.krb5.PrincipalName refSname
         4: .line 305
            aconst_null
            astore 8 /* creds */
        start local 8 // sun.security.krb5.Credentials creds
         5: .line 306
            iconst_0
            istore 9 /* isReferral */
        start local 9 // boolean isReferral
         6: .line 307
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            astore 10 /* referrals */
        start local 10 // java.util.List referrals
         7: .line 308
            aload 1 /* asCreds */
            invokevirtual sun.security.krb5.Credentials.getClientAlias:()Lsun/security/krb5/PrincipalName;
            astore 11 /* clientAlias */
        start local 11 // sun.security.krb5.PrincipalName clientAlias
         8: .line 309
            goto 44
         9: .line 311
      StackMap locals: sun.security.krb5.internal.KDCOptions sun.security.krb5.Credentials sun.security.krb5.PrincipalName sun.security.krb5.PrincipalName sun.security.krb5.internal.Ticket[] sun.security.krb5.internal.PAData[] sun.security.krb5.PrincipalName sun.security.krb5.PrincipalName sun.security.krb5.Credentials int java.util.List sun.security.krb5.PrincipalName
      StackMap stack:
            aload 2 /* cname */
            aload 3 /* sname */
            aload 7 /* refSname */
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            invokestatic sun.security.krb5.internal.ReferralsCache.get:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Ljava/lang/String;)Lsun/security/krb5/internal/ReferralsCache$ReferralCacheEntry;
        10: .line 310
            astore 12 /* ref */
        start local 12 // sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry ref
        11: .line 312
            aconst_null
            astore 13 /* toRealm */
        start local 13 // java.lang.String toRealm
        12: .line 313
            aload 12 /* ref */
            ifnonnull 33
        13: .line 314
            aload 0 /* options */
            aload 1 /* asCreds */
            aload 2 /* cname */
        14: .line 315
            aload 11 /* clientAlias */
            aload 7 /* refSname */
            aload 6 /* cSname */
            aload 4 /* additionalTickets */
        15: .line 316
            aload 5 /* extraPAs */
        16: .line 314
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCredsSingle:(Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
            astore 8 /* creds */
        17: .line 317
            aload 8 /* creds */
            invokevirtual sun.security.krb5.Credentials.getServer:()Lsun/security/krb5/PrincipalName;
            astore 14 /* server */
        start local 14 // sun.security.krb5.PrincipalName server
        18: .line 318
            aload 7 /* refSname */
            aload 14 /* server */
            invokevirtual sun.security.krb5.PrincipalName.equals:(Ljava/lang/Object;)Z
            ifne 36
        19: .line 319
            aload 14 /* server */
            invokevirtual sun.security.krb5.PrincipalName.getNameStrings:()[Ljava/lang/String;
            astore 15 /* serverNameStrings */
        start local 15 // java.lang.String[] serverNameStrings
        20: .line 320
            aload 15 /* serverNameStrings */
            arraylength
            iconst_2
            if_icmpne 36
        21: .line 321
            aload 15 /* serverNameStrings */
            iconst_0
            aaload
        22: .line 322
            ldc "krbtgt"
        23: .line 321
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        24: .line 322
            ifeq 36
        25: .line 323
            aload 7 /* refSname */
            invokevirtual sun.security.krb5.PrincipalName.getRealmAsString:()Ljava/lang/String;
            aload 15 /* serverNameStrings */
            iconst_1
            aaload
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 36
        26: .line 326
            aload 2 /* cname */
            aload 3 /* sname */
            aload 14 /* server */
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
        27: .line 327
            aload 15 /* serverNameStrings */
            iconst_1
            aaload
            aload 8 /* creds */
        28: .line 326
            invokestatic sun.security.krb5.internal.ReferralsCache.put:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Ljava/lang/String;Ljava/lang/String;Lsun/security/krb5/Credentials;)V
        29: .line 328
            aload 15 /* serverNameStrings */
            iconst_1
            aaload
            astore 13 /* toRealm */
        30: .line 329
            iconst_1
            istore 9 /* isReferral */
        31: .line 330
            aload 8 /* creds */
            astore 1 /* asCreds */
        end local 15 // java.lang.String[] serverNameStrings
        end local 14 // sun.security.krb5.PrincipalName server
        32: .line 333
            goto 36
        33: .line 334
      StackMap locals: sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry java.lang.String
      StackMap stack:
            aload 12 /* ref */
            invokevirtual sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry.getToRealm:()Ljava/lang/String;
            astore 13 /* toRealm */
        34: .line 335
            aload 12 /* ref */
            invokevirtual sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry.getCreds:()Lsun/security/krb5/Credentials;
            astore 1 /* asCreds */
        35: .line 336
            iconst_1
            istore 9 /* isReferral */
        36: .line 338
      StackMap locals:
      StackMap stack:
            iload 9 /* isReferral */
            ifeq 45
        37: .line 339
            aload 10 /* referrals */
            aload 13 /* toRealm */
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
            ifeq 39
        38: .line 341
            aconst_null
            areturn
        39: .line 343
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.PrincipalName
            dup
            aload 7 /* refSname */
            invokevirtual sun.security.krb5.PrincipalName.getNameString:()Ljava/lang/String;
        40: .line 344
            aload 7 /* refSname */
            invokevirtual sun.security.krb5.PrincipalName.getNameType:()I
            aload 13 /* toRealm */
        41: .line 343
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;ILjava/lang/String;)V
            astore 7 /* refSname */
        42: .line 345
            aload 10 /* referrals */
            aload 13 /* toRealm */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        43: .line 346
            iconst_0
            istore 9 /* isReferral */
        end local 13 // java.lang.String toRealm
        end local 12 // sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry ref
        44: .line 309
      StackMap locals:
      StackMap stack:
            aload 10 /* referrals */
            invokeinterface java.util.List.size:()I
            getstatic sun.security.krb5.Config.MAX_REFERRALS:I
            if_icmple 9
        45: .line 351
      StackMap locals:
      StackMap stack:
            aload 8 /* creds */
            areturn
        end local 11 // sun.security.krb5.PrincipalName clientAlias
        end local 10 // java.util.List referrals
        end local 9 // boolean isReferral
        end local 8 // sun.security.krb5.Credentials creds
        end local 7 // sun.security.krb5.PrincipalName refSname
        end local 6 // sun.security.krb5.PrincipalName cSname
        end local 5 // sun.security.krb5.internal.PAData[] extraPAs
        end local 4 // sun.security.krb5.internal.Ticket[] additionalTickets
        end local 3 // sun.security.krb5.PrincipalName sname
        end local 2 // sun.security.krb5.PrincipalName cname
        end local 1 // sun.security.krb5.Credentials asCreds
        end local 0 // sun.security.krb5.internal.KDCOptions options
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   46     0            options  Lsun/security/krb5/internal/KDCOptions;
            0   46     1            asCreds  Lsun/security/krb5/Credentials;
            0   46     2              cname  Lsun/security/krb5/PrincipalName;
            0   46     3              sname  Lsun/security/krb5/PrincipalName;
            0   46     4  additionalTickets  [Lsun/security/krb5/internal/Ticket;
            0   46     5           extraPAs  [Lsun/security/krb5/internal/PAData;
            3   46     6             cSname  Lsun/security/krb5/PrincipalName;
            4   46     7           refSname  Lsun/security/krb5/PrincipalName;
            5   46     8              creds  Lsun/security/krb5/Credentials;
            6   46     9         isReferral  Z
            7   46    10          referrals  Ljava/util/List<Ljava/lang/String;>;
            8   46    11        clientAlias  Lsun/security/krb5/PrincipalName;
           11   44    12                ref  Lsun/security/krb5/internal/ReferralsCache$ReferralCacheEntry;
           12   44    13            toRealm  Ljava/lang/String;
           18   32    14             server  Lsun/security/krb5/PrincipalName;
           20   32    15  serverNameStrings  [Ljava/lang/String;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
                   Name  Flags
      options            
      asCreds            
      cname              
      sname              
      additionalTickets  
      extraPAs           

  private static sun.security.krb5.Credentials serviceCredsSingle(sun.security.krb5.internal.KDCOptions, sun.security.krb5.Credentials, sun.security.krb5.PrincipalName, sun.security.krb5.PrincipalName, sun.security.krb5.PrincipalName, sun.security.krb5.PrincipalName, sun.security.krb5.internal.Ticket[], sun.security.krb5.internal.PAData[]);
    descriptor: (Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=10, locals=14, args_size=8
        start local 0 // sun.security.krb5.internal.KDCOptions options
        start local 1 // sun.security.krb5.Credentials asCreds
        start local 2 // sun.security.krb5.PrincipalName cname
        start local 3 // sun.security.krb5.PrincipalName clientAlias
        start local 4 // sun.security.krb5.PrincipalName refSname
        start local 5 // sun.security.krb5.PrincipalName sname
        start local 6 // sun.security.krb5.internal.Ticket[] additionalTickets
        start local 7 // sun.security.krb5.internal.PAData[] extraPAs
         0: .line 367
            aconst_null
            astore 8 /* theCreds */
        start local 8 // sun.security.krb5.Credentials theCreds
         1: .line 368
            iconst_1
            newarray 4
            dup
            iconst_0
            iconst_1
            bastore
            astore 9 /* okAsDelegate */
        start local 9 // boolean[] okAsDelegate
         2: .line 369
            aload 1 /* asCreds */
            invokevirtual sun.security.krb5.Credentials.getServer:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getNameStrings:()[Ljava/lang/String;
            astore 10 /* serverAsCredsNames */
        start local 10 // java.lang.String[] serverAsCredsNames
         3: .line 370
            aload 10 /* serverAsCredsNames */
            iconst_1
            aaload
            astore 11 /* tgtRealm */
        start local 11 // java.lang.String tgtRealm
         4: .line 371
            aload 4 /* refSname */
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 12 /* serviceRealm */
        start local 12 // java.lang.String serviceRealm
         5: .line 372
            aload 12 /* serviceRealm */
            aload 11 /* tgtRealm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 25
         6: .line 374
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 12
         7: .line 375
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> serviceCredsSingle: cross-realm authentication"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         8: .line 377
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc ">>> serviceCredsSingle: obtaining credentials from "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         9: .line 378
            aload 11 /* tgtRealm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        10: .line 379
            ldc " to "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 12 /* serviceRealm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 377
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        12: .line 381
      StackMap locals: sun.security.krb5.internal.KDCOptions sun.security.krb5.Credentials sun.security.krb5.PrincipalName sun.security.krb5.PrincipalName sun.security.krb5.PrincipalName sun.security.krb5.PrincipalName sun.security.krb5.internal.Ticket[] sun.security.krb5.internal.PAData[] sun.security.krb5.Credentials boolean[] java.lang.String[] java.lang.String java.lang.String
      StackMap stack:
            aload 11 /* tgtRealm */
            aload 12 /* serviceRealm */
        13: .line 382
            aload 1 /* asCreds */
            aload 9 /* okAsDelegate */
        14: .line 381
            invokestatic sun.security.krb5.internal.CredentialsUtil.getTGTforRealm:(Ljava/lang/String;Ljava/lang/String;Lsun/security/krb5/Credentials;[Z)Lsun/security/krb5/Credentials;
            astore 13 /* newTgt */
        start local 13 // sun.security.krb5.Credentials newTgt
        15: .line 383
            aload 13 /* newTgt */
            ifnonnull 19
        16: .line 384
            new sun.security.krb5.internal.KrbApErrException
            dup
            bipush 63
        17: .line 385
            ldc "No service creds"
        18: .line 384
            invokespecial sun.security.krb5.internal.KrbApErrException.<init>:(ILjava/lang/String;)V
            athrow
        19: .line 387
      StackMap locals: sun.security.krb5.Credentials
      StackMap stack:
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 22
        20: .line 388
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Cross-realm TGT Credentials serviceCredsSingle: "
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        21: .line 390
            aload 13 /* newTgt */
            invokestatic sun.security.krb5.Credentials.printDebug:(Lsun/security/krb5/Credentials;)V
        22: .line 392
      StackMap locals:
      StackMap stack:
            aload 13 /* newTgt */
            astore 1 /* asCreds */
        23: .line 393
            aload 1 /* asCreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            astore 2 /* cname */
        end local 13 // sun.security.krb5.Credentials newTgt
        24: .line 394
            goto 27
      StackMap locals:
      StackMap stack:
        25: getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 27
        26: .line 395
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Credentials serviceCredsSingle: same realm"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        27: .line 398
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.KrbTgsReq
            dup
            aload 0 /* options */
            aload 1 /* asCreds */
            aload 2 /* cname */
            aload 3 /* clientAlias */
        28: .line 399
            aload 4 /* refSname */
            aload 5 /* sname */
            aload 6 /* additionalTickets */
            aload 7 /* extraPAs */
        29: .line 398
            invokespecial sun.security.krb5.KrbTgsReq.<init>:(Lsun/security/krb5/internal/KDCOptions;Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;Lsun/security/krb5/PrincipalName;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)V
            astore 13 /* req */
        start local 13 // sun.security.krb5.KrbTgsReq req
        30: .line 400
            aload 13 /* req */
            invokevirtual sun.security.krb5.KrbTgsReq.sendAndGetCreds:()Lsun/security/krb5/Credentials;
            astore 8 /* theCreds */
        31: .line 401
            aload 8 /* theCreds */
            ifnull 37
        32: .line 402
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 35
        33: .line 403
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> TGS credentials serviceCredsSingle:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        34: .line 404
            aload 8 /* theCreds */
            invokestatic sun.security.krb5.Credentials.printDebug:(Lsun/security/krb5/Credentials;)V
        35: .line 406
      StackMap locals: sun.security.krb5.KrbTgsReq
      StackMap stack:
            aload 9 /* okAsDelegate */
            iconst_0
            baload
            ifne 37
        36: .line 407
            aload 8 /* theCreds */
            invokevirtual sun.security.krb5.Credentials.resetDelegate:()V
        37: .line 410
      StackMap locals:
      StackMap stack:
            aload 8 /* theCreds */
            areturn
        end local 13 // sun.security.krb5.KrbTgsReq req
        end local 12 // java.lang.String serviceRealm
        end local 11 // java.lang.String tgtRealm
        end local 10 // java.lang.String[] serverAsCredsNames
        end local 9 // boolean[] okAsDelegate
        end local 8 // sun.security.krb5.Credentials theCreds
        end local 7 // sun.security.krb5.internal.PAData[] extraPAs
        end local 6 // sun.security.krb5.internal.Ticket[] additionalTickets
        end local 5 // sun.security.krb5.PrincipalName sname
        end local 4 // sun.security.krb5.PrincipalName refSname
        end local 3 // sun.security.krb5.PrincipalName clientAlias
        end local 2 // sun.security.krb5.PrincipalName cname
        end local 1 // sun.security.krb5.Credentials asCreds
        end local 0 // sun.security.krb5.internal.KDCOptions options
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   38     0             options  Lsun/security/krb5/internal/KDCOptions;
            0   38     1             asCreds  Lsun/security/krb5/Credentials;
            0   38     2               cname  Lsun/security/krb5/PrincipalName;
            0   38     3         clientAlias  Lsun/security/krb5/PrincipalName;
            0   38     4            refSname  Lsun/security/krb5/PrincipalName;
            0   38     5               sname  Lsun/security/krb5/PrincipalName;
            0   38     6   additionalTickets  [Lsun/security/krb5/internal/Ticket;
            0   38     7            extraPAs  [Lsun/security/krb5/internal/PAData;
            1   38     8            theCreds  Lsun/security/krb5/Credentials;
            2   38     9        okAsDelegate  [Z
            3   38    10  serverAsCredsNames  [Ljava/lang/String;
            4   38    11            tgtRealm  Ljava/lang/String;
            5   38    12        serviceRealm  Ljava/lang/String;
           15   24    13              newTgt  Lsun/security/krb5/Credentials;
           30   38    13                 req  Lsun/security/krb5/KrbTgsReq;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
                   Name  Flags
      options            
      asCreds            
      cname              
      clientAlias        
      refSname           
      sname              
      additionalTickets  
      extraPAs           
}
SourceFile: "CredentialsUtil.java"
InnerClasses:
  final ReferralCacheEntry = sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry of sun.security.krb5.internal.ReferralsCache