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 48
            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 46
            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=6, args_size=2
        start local 0 // sun.security.krb5.PrincipalName client
        start local 1 // sun.security.krb5.Credentials ccreds
         0: .line 63
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.isForwardable:()Z
            ifne 2
         1: .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
         2: .line 66
      StackMap locals:
      StackMap stack:
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            astore 2 /* sname */
        start local 2 // sun.security.krb5.PrincipalName sname
         3: .line 67
            aload 0 /* client */
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 3 /* uRealm */
        start local 3 // java.lang.String uRealm
         4: .line 68
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 4 /* localRealm */
        start local 4 // java.lang.String localRealm
         5: .line 69
            aload 3 /* uRealm */
            aload 4 /* localRealm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 13
         6: .line 72
            getstatic sun.security.krb5.Config.DISABLE_REFERRALS:Z
            ifeq 8
         7: .line 73
            new sun.security.krb5.KrbException
            dup
            ldc "Cross-realm S4U2Self request not possible when referrals are disabled."
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 76
      StackMap locals: sun.security.krb5.PrincipalName java.lang.String java.lang.String
      StackMap stack:
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClientAlias:()Lsun/security/krb5/PrincipalName;
            ifnull 10
         9: .line 83
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClientAlias:()Lsun/security/krb5/PrincipalName;
            astore 2 /* sname */
        10: .line 85
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.PrincipalName
            dup
            aload 2 /* sname */
            invokevirtual sun.security.krb5.PrincipalName.getNameType:()I
        11: .line 86
            aload 2 /* sname */
            invokevirtual sun.security.krb5.PrincipalName.getNameStrings:()[Ljava/lang/String;
            new sun.security.krb5.Realm
            dup
            aload 3 /* uRealm */
            invokespecial sun.security.krb5.Realm.<init>:(Ljava/lang/String;)V
        12: .line 85
            invokespecial sun.security.krb5.PrincipalName.<init>:(I[Ljava/lang/String;Lsun/security/krb5/Realm;)V
            astore 2 /* sname */
        13: .line 88
      StackMap locals:
      StackMap stack:
            iconst_1
            newarray 10
            dup
            iconst_0
        14: .line 89
            iconst_1
            iastore
            invokestatic sun.security.krb5.internal.KDCOptions.with:([I)Lsun/security/krb5/internal/KDCOptions;
        15: .line 90
            aload 1 /* ccreds */
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            aload 2 /* sname */
            aconst_null
        16: .line 91
            iconst_2
            anewarray sun.security.krb5.internal.PAData
            dup
            iconst_0
        17: .line 92
            new sun.security.krb5.internal.PAData
            dup
            sipush 129
        18: .line 93
            new sun.security.krb5.internal.PAForUserEnc
            dup
            aload 0 /* client */
        19: .line 94
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getSessionKey:()Lsun/security/krb5/EncryptionKey;
        20: .line 93
            invokespecial sun.security.krb5.internal.PAForUserEnc.<init>:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/EncryptionKey;)V
        21: .line 94
            invokevirtual sun.security.krb5.internal.PAForUserEnc.asn1Encode:()[B
        22: .line 92
            invokespecial sun.security.krb5.internal.PAData.<init>:(I[B)V
            aastore
            dup
            iconst_1
        23: .line 95
            new sun.security.krb5.internal.PAData
            dup
            sipush 167
        24: .line 96
            new sun.security.krb5.internal.PaPacOptions
            dup
            invokespecial sun.security.krb5.internal.PaPacOptions.<init>:()V
        25: .line 97
            iconst_1
            invokevirtual sun.security.krb5.internal.PaPacOptions.setResourceBasedConstrainedDelegation:(Z)Lsun/security/krb5/internal/PaPacOptions;
        26: .line 98
            iconst_1
            invokevirtual sun.security.krb5.internal.PaPacOptions.setClaims:(Z)Lsun/security/krb5/internal/PaPacOptions;
        27: .line 99
            invokevirtual sun.security.krb5.internal.PaPacOptions.asn1Encode:()[B
        28: .line 95
            invokespecial sun.security.krb5.internal.PAData.<init>:(I[B)V
            aastore
        29: .line 100
            getstatic sun.security.krb5.internal.CredentialsUtil$S4U2Type.SELF:Lsun/security/krb5/internal/CredentialsUtil$S4U2Type;
        30: .line 88
            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/internal/CredentialsUtil$S4U2Type;)Lsun/security/krb5/Credentials;
            astore 5 /* creds */
        start local 5 // sun.security.krb5.Credentials creds
        31: .line 101
            aload 5 /* 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 33
        32: .line 102
            new sun.security.krb5.KrbException
            dup
            ldc "S4U2self request not honored by KDC"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
        33: .line 104
      StackMap locals: sun.security.krb5.Credentials
      StackMap stack:
            aload 5 /* creds */
            invokevirtual sun.security.krb5.Credentials.isForwardable:()Z
            ifne 35
        34: .line 105
            new sun.security.krb5.KrbException
            dup
            ldc "S4U2self ticket must be FORWARDABLE"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
        35: .line 107
      StackMap locals:
      StackMap stack:
            aload 5 /* creds */
            areturn
        end local 5 // sun.security.krb5.Credentials creds
        end local 4 // java.lang.String localRealm
        end local 3 // java.lang.String uRealm
        end local 2 // sun.security.krb5.PrincipalName sname
        end local 1 // sun.security.krb5.Credentials ccreds
        end local 0 // sun.security.krb5.PrincipalName client
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   36     0      client  Lsun/security/krb5/PrincipalName;
            0   36     1      ccreds  Lsun/security/krb5/Credentials;
            3   36     2       sname  Lsun/security/krb5/PrincipalName;
            4   36     3      uRealm  Ljava/lang/String;
            5   36     4  localRealm  Ljava/lang/String;
           31   36     5       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=13, locals=8, 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 122
            new sun.security.krb5.PrincipalName
            dup
            aload 0 /* backend */
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;)V
            astore 4 /* backendPrincipal */
        start local 4 // sun.security.krb5.PrincipalName backendPrincipal
         1: .line 123
            aload 4 /* backendPrincipal */
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 5 /* backendRealm */
        start local 5 // java.lang.String backendRealm
         2: .line 124
            aload 3 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 6 /* localRealm */
        start local 6 // java.lang.String localRealm
         3: .line 125
            aload 5 /* backendRealm */
            aload 6 /* localRealm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 11
         4: .line 128
            getstatic sun.security.krb5.Config.DISABLE_REFERRALS:Z
            ifeq 6
         5: .line 129
            new sun.security.krb5.KrbException
            dup
            ldc "Cross-realm S4U2Proxy request not possible when referrals are disabled."
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 132
      StackMap locals: sun.security.krb5.PrincipalName java.lang.String java.lang.String
      StackMap stack:
            new sun.security.krb5.PrincipalName
            dup
         7: .line 133
            aload 4 /* backendPrincipal */
            invokevirtual sun.security.krb5.PrincipalName.getNameType:()I
         8: .line 134
            aload 4 /* backendPrincipal */
            invokevirtual sun.security.krb5.PrincipalName.getNameStrings:()[Ljava/lang/String;
         9: .line 135
            new sun.security.krb5.Realm
            dup
            aload 6 /* localRealm */
            invokespecial sun.security.krb5.Realm.<init>:(Ljava/lang/String;)V
        10: .line 132
            invokespecial sun.security.krb5.PrincipalName.<init>:(I[Ljava/lang/String;Lsun/security/krb5/Realm;)V
            astore 4 /* backendPrincipal */
        11: .line 137
      StackMap locals:
      StackMap stack:
            iconst_2
            newarray 10
            dup
            iconst_0
        12: .line 138
            bipush 14
            iastore
            dup
            iconst_1
            iconst_1
            iastore
        13: .line 137
            invokestatic sun.security.krb5.internal.KDCOptions.with:([I)Lsun/security/krb5/internal/KDCOptions;
        14: .line 139
            aload 3 /* ccreds */
            aload 3 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            aload 4 /* backendPrincipal */
        15: .line 140
            iconst_1
            anewarray sun.security.krb5.internal.Ticket
            dup
            iconst_0
            aload 1 /* second */
            aastore
            iconst_1
            anewarray sun.security.krb5.internal.PAData
            dup
            iconst_0
        16: .line 141
            new sun.security.krb5.internal.PAData
            dup
            sipush 167
        17: .line 142
            new sun.security.krb5.internal.PaPacOptions
            dup
            invokespecial sun.security.krb5.internal.PaPacOptions.<init>:()V
        18: .line 143
            iconst_1
            invokevirtual sun.security.krb5.internal.PaPacOptions.setResourceBasedConstrainedDelegation:(Z)Lsun/security/krb5/internal/PaPacOptions;
        19: .line 144
            iconst_1
            invokevirtual sun.security.krb5.internal.PaPacOptions.setClaims:(Z)Lsun/security/krb5/internal/PaPacOptions;
        20: .line 145
            invokevirtual sun.security.krb5.internal.PaPacOptions.asn1Encode:()[B
        21: .line 141
            invokespecial sun.security.krb5.internal.PAData.<init>:(I[B)V
            aastore
        22: .line 146
            getstatic sun.security.krb5.internal.CredentialsUtil$S4U2Type.PROXY:Lsun/security/krb5/internal/CredentialsUtil$S4U2Type;
        23: .line 137
            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/internal/CredentialsUtil$S4U2Type;)Lsun/security/krb5/Credentials;
            astore 7 /* creds */
        start local 7 // sun.security.krb5.Credentials creds
        24: .line 147
            aload 7 /* 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 26
        25: .line 148
            new sun.security.krb5.KrbException
            dup
            ldc "S4U2proxy request not honored by KDC"
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
        26: .line 150
      StackMap locals: sun.security.krb5.Credentials
      StackMap stack:
            aload 7 /* creds */
            areturn
        end local 7 // sun.security.krb5.Credentials creds
        end local 6 // java.lang.String localRealm
        end local 5 // java.lang.String backendRealm
        end local 4 // sun.security.krb5.PrincipalName backendPrincipal
        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   27     0           backend  Ljava/lang/String;
            0   27     1            second  Lsun/security/krb5/internal/Ticket;
            0   27     2            client  Lsun/security/krb5/PrincipalName;
            0   27     3            ccreds  Lsun/security/krb5/Credentials;
            1   27     4  backendPrincipal  Lsun/security/krb5/PrincipalName;
            2   27     5      backendRealm  Ljava/lang/String;
            3   27     6        localRealm  Ljava/lang/String;
           24   27     7             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 167
            new sun.security.krb5.PrincipalName
            dup
            aload 0 /* service */
         1: .line 168
            iconst_0
         2: .line 167
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;I)V
            astore 2 /* sname */
        start local 2 // sun.security.krb5.PrincipalName sname
         3: .line 169
            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 187
            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 189
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         2: iconst_0
            istore 6 /* k */
        start local 6 // int k
         3: .line 190
            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 191
            aconst_null
            astore 10 /* tempService */
        start local 10 // sun.security.krb5.PrincipalName tempService
         7: .line 192
            aconst_null
            astore 11 /* newTgtRealm */
        start local 11 // java.lang.String newTgtRealm
         8: .line 194
            aload 3 /* okAsDelegate */
            iconst_0
            iconst_1
            bastore
         9: .line 195
            aload 2 /* ccreds */
            astore 7 /* cTgt */
            iconst_0
            istore 5 /* i */
            goto 69
        10: .line 196
      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 198
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 17
        12: .line 199
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        13: .line 200
            new java.lang.StringBuilder
            dup
            ldc ">>> Credentials acquireServiceCreds: main loop: ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        14: .line 201
            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 200
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        16: .line 199
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        17: .line 205
      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 206
            goto 21
      StackMap locals:
      StackMap stack: java.lang.Exception
        19: pop
        20: .line 207
            aconst_null
            astore 8 /* newTgt */
        21: .line 210
      StackMap locals:
      StackMap stack:
            aload 8 /* newTgt */
            ifnonnull 41
        22: .line 211
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 24
        23: .line 212
            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 219
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 8 /* newTgt */
            iload 5 /* i */
            iconst_1
            iadd
            istore 6 /* k */
        25: .line 220
            goto 39
        26: .line 221
      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 222
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 34
        28: .line 223
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        29: .line 224
            new java.lang.StringBuilder
            dup
            ldc ">>> Credentials acquireServiceCreds: inner loop: ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        30: .line 225
            iload 6 /* k */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        31: .line 226
            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 224
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        33: .line 223
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        34: .line 229
      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 230
            goto 38
      StackMap locals:
      StackMap stack: java.lang.Exception
        36: pop
        37: .line 231
            aconst_null
            astore 8 /* newTgt */
        38: .line 220
      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 219
            if_icmplt 26
        41: .line 236
      StackMap locals:
      StackMap stack:
            aload 8 /* newTgt */
            ifnonnull 45
        42: .line 237
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 70
        43: .line 238
            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 241
            goto 70
        45: .line 248
      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 249
            aload 3 /* okAsDelegate */
            iconst_0
            baload
            ifeq 52
            aload 8 /* newTgt */
            invokevirtual sun.security.krb5.Credentials.checkDelegate:()Z
            ifne 52
        47: .line 250
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 51
        48: .line 251
            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 253
            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 251
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        51: .line 255
      StackMap locals:
      StackMap stack:
            aload 3 /* okAsDelegate */
            iconst_0
            iconst_0
            bastore
        52: .line 258
      StackMap locals:
      StackMap stack:
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 54
        53: .line 259
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Credentials acquireServiceCreds: got tgt"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        54: .line 263
      StackMap locals:
      StackMap stack:
            aload 11 /* newTgtRealm */
            aload 1 /* serviceRealm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 57
        55: .line 265
            aload 8 /* newTgt */
            astore 9 /* theTgt */
        56: .line 266
            goto 70
        57: .line 274
      StackMap locals:
      StackMap stack:
            iload 5 /* i */
            iconst_1
            iadd
            istore 6 /* k */
            goto 61
        58: .line 275
      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 276
            goto 62
        60: .line 274
      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 280
      StackMap locals:
      StackMap stack:
            iload 6 /* k */
            aload 4 /* realms */
            arraylength
            if_icmpge 70
        63: .line 285
            iload 6 /* k */
            istore 5 /* i */
        64: .line 286
            aload 8 /* newTgt */
            astore 7 /* cTgt */
        65: .line 288
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 69
        66: .line 289
            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 290
            iload 5 /* i */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        68: .line 289
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        69: .line 195
      StackMap locals:
      StackMap stack:
            iload 5 /* i */
            aload 4 /* realms */
            arraylength
            if_icmplt 10
        70: .line 305
      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=7, locals=2, args_size=2
        start local 0 // sun.security.krb5.PrincipalName service
        start local 1 // sun.security.krb5.Credentials ccreds
         0: .line 314
            new sun.security.krb5.internal.KDCOptions
            dup
            invokespecial sun.security.krb5.internal.KDCOptions.<init>:()V
            aload 1 /* ccreds */
         1: .line 315
            aload 1 /* ccreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            aload 0 /* service */
            aconst_null
            aconst_null
         2: .line 316
            getstatic sun.security.krb5.internal.CredentialsUtil$S4U2Type.NONE:Lsun/security/krb5/internal/CredentialsUtil$S4U2Type;
         3: .line 314
            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/internal/CredentialsUtil$S4U2Type;)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    4     0  service  Lsun/security/krb5/PrincipalName;
            0    4     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[], sun.security.krb5.internal.CredentialsUtil$S4U2Type);
    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/internal/CredentialsUtil$S4U2Type;)Lsun/security/krb5/Credentials;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=9, locals=7, args_size=7
        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
        start local 6 // sun.security.krb5.internal.CredentialsUtil$S4U2Type s4u2Type
         0: .line 331
            getstatic sun.security.krb5.Config.DISABLE_REFERRALS:Z
            ifne 6
         1: .line 333
            aload 0 /* options */
            aload 1 /* asCreds */
            aload 2 /* cname */
            aload 3 /* sname */
         2: .line 334
            aload 6 /* s4u2Type */
            aload 4 /* additionalTickets */
            aload 5 /* extraPAs */
         3: .line 333
            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/CredentialsUtil$S4U2Type;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
         4: areturn
         5: .line 335
      StackMap locals:
      StackMap stack: sun.security.krb5.KrbException
            pop
         6: .line 340
      StackMap locals:
      StackMap stack:
            aload 0 /* options */
            aload 1 /* asCreds */
            aload 2 /* cname */
         7: .line 341
            aload 1 /* asCreds */
            invokevirtual sun.security.krb5.Credentials.getClientAlias:()Lsun/security/krb5/PrincipalName;
            aload 3 /* sname */
            aload 3 /* sname */
            aload 6 /* s4u2Type */
         8: .line 342
            aload 4 /* additionalTickets */
            aload 5 /* extraPAs */
         9: .line 340
            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/CredentialsUtil$S4U2Type;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
            areturn
        end local 6 // sun.security.krb5.internal.CredentialsUtil$S4U2Type s4u2Type
        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;
            0   10     6           s4u2Type  Lsun/security/krb5/internal/CredentialsUtil$S4U2Type;
      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           
      s4u2Type           

  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.CredentialsUtil$S4U2Type, 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/CredentialsUtil$S4U2Type;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=9, locals=17, args_size=7
        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.CredentialsUtil$S4U2Type s4u2Type
        start local 5 // sun.security.krb5.internal.Ticket[] additionalTickets
        start local 6 // sun.security.krb5.internal.PAData[] extraPAs
         0: .line 355
            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 356
            aload 0 /* options */
            bipush 15
            iconst_1
            invokevirtual sun.security.krb5.internal.KDCOptions.set:(IZ)V
         2: .line 357
            aload 3 /* sname */
            astore 7 /* cSname */
        start local 7 // sun.security.krb5.PrincipalName cSname
         3: .line 358
            aload 3 /* sname */
            astore 8 /* refSname */
        start local 8 // sun.security.krb5.PrincipalName refSname
         4: .line 359
            aconst_null
            astore 9 /* creds */
        start local 9 // sun.security.krb5.Credentials creds
         5: .line 360
            iconst_0
            istore 10 /* isReferral */
        start local 10 // boolean isReferral
         6: .line 361
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            astore 11 /* referrals */
        start local 11 // java.util.List referrals
         7: .line 362
            aload 1 /* asCreds */
            invokevirtual sun.security.krb5.Credentials.getClientAlias:()Lsun/security/krb5/PrincipalName;
            astore 12 /* clientAlias */
        start local 12 // sun.security.krb5.PrincipalName clientAlias
         8: .line 363
            goto 64
         9: .line 365
      StackMap locals: sun.security.krb5.internal.KDCOptions sun.security.krb5.Credentials sun.security.krb5.PrincipalName sun.security.krb5.PrincipalName sun.security.krb5.internal.CredentialsUtil$S4U2Type 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 8 /* 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 364
            astore 13 /* ref */
        start local 13 // sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry ref
        11: .line 366
            aconst_null
            astore 14 /* toRealm */
        start local 14 // java.lang.String toRealm
        12: .line 367
            aload 13 /* ref */
            ifnonnull 37
        13: .line 368
            aload 0 /* options */
            aload 1 /* asCreds */
            aload 2 /* cname */
        14: .line 369
            aload 12 /* clientAlias */
            aload 8 /* refSname */
            aload 7 /* cSname */
            aload 4 /* s4u2Type */
        15: .line 370
            aload 5 /* additionalTickets */
            aload 6 /* extraPAs */
        16: .line 368
            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/CredentialsUtil$S4U2Type;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
            astore 9 /* creds */
        17: .line 371
            aload 9 /* creds */
            invokevirtual sun.security.krb5.Credentials.getServer:()Lsun/security/krb5/PrincipalName;
            astore 15 /* server */
        start local 15 // sun.security.krb5.PrincipalName server
        18: .line 372
            aload 8 /* refSname */
            aload 15 /* server */
            invokevirtual sun.security.krb5.PrincipalName.equals:(Ljava/lang/Object;)Z
            ifne 40
        19: .line 373
            aload 15 /* server */
            invokevirtual sun.security.krb5.PrincipalName.getNameStrings:()[Ljava/lang/String;
            astore 16 /* serverNameStrings */
        start local 16 // java.lang.String[] serverNameStrings
        20: .line 374
            aload 16 /* serverNameStrings */
            arraylength
            iconst_2
            if_icmpne 40
        21: .line 375
            aload 16 /* serverNameStrings */
            iconst_0
            aaload
        22: .line 376
            ldc "krbtgt"
        23: .line 375
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        24: .line 376
            ifeq 40
        25: .line 377
            aload 8 /* refSname */
            invokevirtual sun.security.krb5.PrincipalName.getRealmAsString:()Ljava/lang/String;
        26: .line 378
            aload 16 /* serverNameStrings */
            iconst_1
            aaload
        27: .line 377
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        28: .line 378
            ifne 40
        29: .line 381
            aload 4 /* s4u2Type */
            getstatic sun.security.krb5.internal.CredentialsUtil$S4U2Type.NONE:Lsun/security/krb5/internal/CredentialsUtil$S4U2Type;
            if_acmpne 34
        30: .line 386
            aload 2 /* cname */
            aload 3 /* sname */
        31: .line 387
            aload 15 /* server */
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
        32: .line 388
            aload 16 /* serverNameStrings */
            iconst_1
            aaload
            aload 9 /* creds */
        33: .line 386
            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
        34: .line 390
      StackMap locals: sun.security.krb5.internal.KDCOptions sun.security.krb5.Credentials sun.security.krb5.PrincipalName sun.security.krb5.PrincipalName sun.security.krb5.internal.CredentialsUtil$S4U2Type 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 sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry java.lang.String sun.security.krb5.PrincipalName java.lang.String[]
      StackMap stack:
            aload 16 /* serverNameStrings */
            iconst_1
            aaload
            astore 14 /* toRealm */
        35: .line 391
            iconst_1
            istore 10 /* isReferral */
        end local 16 // java.lang.String[] serverNameStrings
        end local 15 // sun.security.krb5.PrincipalName server
        36: .line 394
            goto 40
        37: .line 395
      StackMap locals:
      StackMap stack:
            aload 13 /* ref */
            invokevirtual sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry.getCreds:()Lsun/security/krb5/Credentials;
            astore 9 /* creds */
        38: .line 396
            aload 13 /* ref */
            invokevirtual sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry.getToRealm:()Ljava/lang/String;
            astore 14 /* toRealm */
        39: .line 397
            iconst_1
            istore 10 /* isReferral */
        40: .line 399
      StackMap locals:
      StackMap stack:
            iload 10 /* isReferral */
            ifeq 65
        41: .line 400
            aload 4 /* s4u2Type */
            getstatic sun.security.krb5.internal.CredentialsUtil$S4U2Type.PROXY:Lsun/security/krb5/internal/CredentialsUtil$S4U2Type;
            if_acmpne 54
        42: .line 402
            iconst_2
            anewarray sun.security.krb5.Credentials
            dup
            iconst_0
            aload 9 /* creds */
            aastore
        43: .line 401
            astore 15 /* credsInOut */
        start local 15 // sun.security.krb5.Credentials[] credsInOut
        44: .line 403
            aload 1 /* asCreds */
        45: .line 404
            aload 15 /* credsInOut */
            aload 3 /* sname */
        46: .line 403
            invokestatic sun.security.krb5.internal.CredentialsUtil.handleS4U2ProxyReferral:(Lsun/security/krb5/Credentials;[Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;)Ljava/lang/String;
            astore 14 /* toRealm */
        47: .line 405
            aload 15 /* credsInOut */
            iconst_0
            aaload
            astore 9 /* creds */
        48: .line 406
            aload 5 /* additionalTickets */
            ifnull 51
        49: .line 407
            aload 5 /* additionalTickets */
            arraylength
            ifeq 51
        50: .line 408
            aload 15 /* credsInOut */
            iconst_1
            aaload
            ifnonnull 52
        51: .line 409
      StackMap locals: sun.security.krb5.Credentials[]
      StackMap stack:
            new sun.security.krb5.KrbException
            dup
            ldc "Additional tickets expected for S4U2Proxy."
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
        52: .line 412
      StackMap locals:
      StackMap stack:
            aload 5 /* additionalTickets */
            iconst_0
            aload 15 /* credsInOut */
            iconst_1
            aaload
            invokevirtual sun.security.krb5.Credentials.getTicket:()Lsun/security/krb5/internal/Ticket;
            aastore
        end local 15 // sun.security.krb5.Credentials[] credsInOut
        53: .line 413
            goto 56
      StackMap locals:
      StackMap stack:
        54: aload 4 /* s4u2Type */
            getstatic sun.security.krb5.internal.CredentialsUtil$S4U2Type.SELF:Lsun/security/krb5/internal/CredentialsUtil$S4U2Type;
            if_acmpne 56
        55: .line 414
            aload 6 /* extraPAs */
            aload 1 /* asCreds */
            aload 9 /* creds */
            invokestatic sun.security.krb5.internal.CredentialsUtil.handleS4U2SelfReferral:([Lsun/security/krb5/internal/PAData;Lsun/security/krb5/Credentials;Lsun/security/krb5/Credentials;)V
        56: .line 416
      StackMap locals:
      StackMap stack:
            aload 11 /* referrals */
            aload 14 /* toRealm */
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
            ifeq 58
        57: .line 418
            aconst_null
            areturn
        58: .line 420
      StackMap locals:
      StackMap stack:
            aload 9 /* creds */
            astore 1 /* asCreds */
        59: .line 421
            new sun.security.krb5.PrincipalName
            dup
            aload 8 /* refSname */
            invokevirtual sun.security.krb5.PrincipalName.getNameString:()Ljava/lang/String;
        60: .line 422
            aload 8 /* refSname */
            invokevirtual sun.security.krb5.PrincipalName.getNameType:()I
            aload 14 /* toRealm */
        61: .line 421
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;ILjava/lang/String;)V
            astore 8 /* refSname */
        62: .line 423
            aload 11 /* referrals */
            aload 14 /* toRealm */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        63: .line 424
            iconst_0
            istore 10 /* isReferral */
        end local 14 // java.lang.String toRealm
        end local 13 // sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry ref
        64: .line 363
      StackMap locals:
      StackMap stack:
            aload 11 /* referrals */
            invokeinterface java.util.List.size:()I
            getstatic sun.security.krb5.Config.MAX_REFERRALS:I
            if_icmple 9
        65: .line 429
      StackMap locals:
      StackMap stack:
            aload 9 /* creds */
            areturn
        end local 12 // sun.security.krb5.PrincipalName clientAlias
        end local 11 // java.util.List referrals
        end local 10 // boolean isReferral
        end local 9 // sun.security.krb5.Credentials creds
        end local 8 // sun.security.krb5.PrincipalName refSname
        end local 7 // sun.security.krb5.PrincipalName cSname
        end local 6 // sun.security.krb5.internal.PAData[] extraPAs
        end local 5 // sun.security.krb5.internal.Ticket[] additionalTickets
        end local 4 // sun.security.krb5.internal.CredentialsUtil$S4U2Type s4u2Type
        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   66     0            options  Lsun/security/krb5/internal/KDCOptions;
            0   66     1            asCreds  Lsun/security/krb5/Credentials;
            0   66     2              cname  Lsun/security/krb5/PrincipalName;
            0   66     3              sname  Lsun/security/krb5/PrincipalName;
            0   66     4           s4u2Type  Lsun/security/krb5/internal/CredentialsUtil$S4U2Type;
            0   66     5  additionalTickets  [Lsun/security/krb5/internal/Ticket;
            0   66     6           extraPAs  [Lsun/security/krb5/internal/PAData;
            3   66     7             cSname  Lsun/security/krb5/PrincipalName;
            4   66     8           refSname  Lsun/security/krb5/PrincipalName;
            5   66     9              creds  Lsun/security/krb5/Credentials;
            6   66    10         isReferral  Z
            7   66    11          referrals  Ljava/util/List<Ljava/lang/String;>;
            8   66    12        clientAlias  Lsun/security/krb5/PrincipalName;
           11   64    13                ref  Lsun/security/krb5/internal/ReferralsCache$ReferralCacheEntry;
           12   64    14            toRealm  Ljava/lang/String;
           18   36    15             server  Lsun/security/krb5/PrincipalName;
           20   36    16  serverNameStrings  [Ljava/lang/String;
           44   53    15         credsInOut  [Lsun/security/krb5/Credentials;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
                   Name  Flags
      options            
      asCreds            
      cname              
      sname              
      s4u2Type           
      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.CredentialsUtil$S4U2Type, 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/CredentialsUtil$S4U2Type;[Lsun/security/krb5/internal/Ticket;[Lsun/security/krb5/internal/PAData;)Lsun/security/krb5/Credentials;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=10, locals=15, args_size=9
        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.CredentialsUtil$S4U2Type s4u2Type
        start local 7 // sun.security.krb5.internal.Ticket[] additionalTickets
        start local 8 // sun.security.krb5.internal.PAData[] extraPAs
         0: .line 446
            aconst_null
            astore 9 /* theCreds */
        start local 9 // sun.security.krb5.Credentials theCreds
         1: .line 447
            iconst_1
            newarray 4
            dup
            iconst_0
            iconst_1
            bastore
            astore 10 /* okAsDelegate */
        start local 10 // boolean[] okAsDelegate
         2: .line 448
            aload 1 /* asCreds */
            invokevirtual sun.security.krb5.Credentials.getServer:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getNameStrings:()[Ljava/lang/String;
            astore 11 /* serverAsCredsNames */
        start local 11 // java.lang.String[] serverAsCredsNames
         3: .line 449
            aload 11 /* serverAsCredsNames */
            iconst_1
            aaload
            astore 12 /* tgtRealm */
        start local 12 // java.lang.String tgtRealm
         4: .line 450
            aload 4 /* refSname */
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
            astore 13 /* serviceRealm */
        start local 13 // java.lang.String serviceRealm
         5: .line 451
            aload 13 /* serviceRealm */
            aload 12 /* tgtRealm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 27
         6: .line 453
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 12
         7: .line 454
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> serviceCredsSingle: cross-realm authentication"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         8: .line 456
            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 457
            aload 12 /* tgtRealm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        10: .line 458
            ldc " to "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 13 /* serviceRealm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 456
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        12: .line 460
      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.CredentialsUtil$S4U2Type 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 12 /* tgtRealm */
            aload 13 /* serviceRealm */
        13: .line 461
            aload 1 /* asCreds */
            aload 10 /* okAsDelegate */
        14: .line 460
            invokestatic sun.security.krb5.internal.CredentialsUtil.getTGTforRealm:(Ljava/lang/String;Ljava/lang/String;Lsun/security/krb5/Credentials;[Z)Lsun/security/krb5/Credentials;
            astore 14 /* newTgt */
        start local 14 // sun.security.krb5.Credentials newTgt
        15: .line 462
            aload 14 /* newTgt */
            ifnonnull 19
        16: .line 463
            new sun.security.krb5.internal.KrbApErrException
            dup
            bipush 63
        17: .line 464
            ldc "No service creds"
        18: .line 463
            invokespecial sun.security.krb5.internal.KrbApErrException.<init>:(ILjava/lang/String;)V
            athrow
        19: .line 466
      StackMap locals: sun.security.krb5.Credentials
      StackMap stack:
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 22
        20: .line 467
            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 469
            aload 14 /* newTgt */
            invokestatic sun.security.krb5.Credentials.printDebug:(Lsun/security/krb5/Credentials;)V
        22: .line 471
      StackMap locals:
      StackMap stack:
            aload 6 /* s4u2Type */
            getstatic sun.security.krb5.internal.CredentialsUtil$S4U2Type.SELF:Lsun/security/krb5/internal/CredentialsUtil$S4U2Type;
            if_acmpne 24
        23: .line 472
            aload 8 /* extraPAs */
            aload 1 /* asCreds */
            aload 14 /* newTgt */
            invokestatic sun.security.krb5.internal.CredentialsUtil.handleS4U2SelfReferral:([Lsun/security/krb5/internal/PAData;Lsun/security/krb5/Credentials;Lsun/security/krb5/Credentials;)V
        24: .line 474
      StackMap locals:
      StackMap stack:
            aload 14 /* newTgt */
            astore 1 /* asCreds */
        25: .line 475
            aload 1 /* asCreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            astore 2 /* cname */
        end local 14 // sun.security.krb5.Credentials newTgt
        26: .line 476
            goto 29
      StackMap locals:
      StackMap stack:
        27: getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 29
        28: .line 477
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Credentials serviceCredsSingle: same realm"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        29: .line 480
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.KrbTgsReq
            dup
            aload 0 /* options */
            aload 1 /* asCreds */
            aload 2 /* cname */
            aload 3 /* clientAlias */
        30: .line 481
            aload 4 /* refSname */
            aload 5 /* sname */
            aload 7 /* additionalTickets */
            aload 8 /* extraPAs */
        31: .line 480
            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 14 /* req */
        start local 14 // sun.security.krb5.KrbTgsReq req
        32: .line 482
            aload 14 /* req */
            invokevirtual sun.security.krb5.KrbTgsReq.sendAndGetCreds:()Lsun/security/krb5/Credentials;
            astore 9 /* theCreds */
        33: .line 483
            aload 9 /* theCreds */
            ifnull 39
        34: .line 484
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 37
        35: .line 485
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> TGS credentials serviceCredsSingle:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        36: .line 486
            aload 9 /* theCreds */
            invokestatic sun.security.krb5.Credentials.printDebug:(Lsun/security/krb5/Credentials;)V
        37: .line 488
      StackMap locals: sun.security.krb5.KrbTgsReq
      StackMap stack:
            aload 10 /* okAsDelegate */
            iconst_0
            baload
            ifne 39
        38: .line 489
            aload 9 /* theCreds */
            invokevirtual sun.security.krb5.Credentials.resetDelegate:()V
        39: .line 492
      StackMap locals:
      StackMap stack:
            aload 9 /* theCreds */
            areturn
        end local 14 // sun.security.krb5.KrbTgsReq req
        end local 13 // java.lang.String serviceRealm
        end local 12 // java.lang.String tgtRealm
        end local 11 // java.lang.String[] serverAsCredsNames
        end local 10 // boolean[] okAsDelegate
        end local 9 // sun.security.krb5.Credentials theCreds
        end local 8 // sun.security.krb5.internal.PAData[] extraPAs
        end local 7 // sun.security.krb5.internal.Ticket[] additionalTickets
        end local 6 // sun.security.krb5.internal.CredentialsUtil$S4U2Type s4u2Type
        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   40     0             options  Lsun/security/krb5/internal/KDCOptions;
            0   40     1             asCreds  Lsun/security/krb5/Credentials;
            0   40     2               cname  Lsun/security/krb5/PrincipalName;
            0   40     3         clientAlias  Lsun/security/krb5/PrincipalName;
            0   40     4            refSname  Lsun/security/krb5/PrincipalName;
            0   40     5               sname  Lsun/security/krb5/PrincipalName;
            0   40     6            s4u2Type  Lsun/security/krb5/internal/CredentialsUtil$S4U2Type;
            0   40     7   additionalTickets  [Lsun/security/krb5/internal/Ticket;
            0   40     8            extraPAs  [Lsun/security/krb5/internal/PAData;
            1   40     9            theCreds  Lsun/security/krb5/Credentials;
            2   40    10        okAsDelegate  [Z
            3   40    11  serverAsCredsNames  [Ljava/lang/String;
            4   40    12            tgtRealm  Ljava/lang/String;
            5   40    13        serviceRealm  Ljava/lang/String;
           15   26    14              newTgt  Lsun/security/krb5/Credentials;
           32   40    14                 req  Lsun/security/krb5/KrbTgsReq;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
                   Name  Flags
      options            
      asCreds            
      cname              
      clientAlias        
      refSname           
      sname              
      s4u2Type           
      additionalTickets  
      extraPAs           

  private static void handleS4U2SelfReferral(sun.security.krb5.internal.PAData[], sun.security.krb5.Credentials, sun.security.krb5.Credentials);
    descriptor: ([Lsun/security/krb5/internal/PAData;Lsun/security/krb5/Credentials;Lsun/security/krb5/Credentials;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=9, locals=6, args_size=3
        start local 0 // sun.security.krb5.internal.PAData[] pas
        start local 1 // sun.security.krb5.Credentials oldCeds
        start local 2 // sun.security.krb5.Credentials newCreds
         0: .line 503
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 2
         1: .line 504
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Handling S4U2Self referral"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 506
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         3: goto 18
         4: .line 507
      StackMap locals: int
      StackMap stack:
            aload 0 /* pas */
            iload 3 /* i */
            aaload
            astore 4 /* pa */
        start local 4 // sun.security.krb5.internal.PAData pa
         5: .line 508
            aload 4 /* pa */
            invokevirtual sun.security.krb5.internal.PAData.getType:()I
            sipush 129
            if_icmpne 17
         6: .line 509
            new sun.security.krb5.internal.PAForUserEnc
            dup
         7: .line 510
            new sun.security.util.DerValue
            dup
            aload 4 /* pa */
            invokevirtual sun.security.krb5.internal.PAData.getValue:()[B
            invokespecial sun.security.util.DerValue.<init>:([B)V
         8: .line 511
            aload 1 /* oldCeds */
            invokevirtual sun.security.krb5.Credentials.getSessionKey:()Lsun/security/krb5/EncryptionKey;
         9: .line 509
            invokespecial sun.security.krb5.internal.PAForUserEnc.<init>:(Lsun/security/util/DerValue;Lsun/security/krb5/EncryptionKey;)V
            astore 5 /* paForUser */
        start local 5 // sun.security.krb5.internal.PAForUserEnc paForUser
        10: .line 512
            aload 0 /* pas */
            iload 3 /* i */
            new sun.security.krb5.internal.PAData
            dup
            sipush 129
        11: .line 513
            new sun.security.krb5.internal.PAForUserEnc
            dup
            aload 5 /* paForUser */
            invokevirtual sun.security.krb5.internal.PAForUserEnc.getName:()Lsun/security/krb5/PrincipalName;
        12: .line 514
            aload 2 /* newCreds */
            invokevirtual sun.security.krb5.Credentials.getSessionKey:()Lsun/security/krb5/EncryptionKey;
        13: .line 513
            invokespecial sun.security.krb5.internal.PAForUserEnc.<init>:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/EncryptionKey;)V
        14: .line 514
            invokevirtual sun.security.krb5.internal.PAForUserEnc.asn1Encode:()[B
            invokespecial sun.security.krb5.internal.PAData.<init>:(I[B)V
        15: .line 512
            aastore
        16: .line 515
            goto 19
        end local 5 // sun.security.krb5.internal.PAForUserEnc paForUser
        end local 4 // sun.security.krb5.internal.PAData pa
        17: .line 506
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
        18: iload 3 /* i */
            aload 0 /* pas */
            arraylength
            if_icmplt 4
        end local 3 // int i
        19: .line 518
      StackMap locals:
      StackMap stack:
            return
        end local 2 // sun.security.krb5.Credentials newCreds
        end local 1 // sun.security.krb5.Credentials oldCeds
        end local 0 // sun.security.krb5.internal.PAData[] pas
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   20     0        pas  [Lsun/security/krb5/internal/PAData;
            0   20     1    oldCeds  Lsun/security/krb5/Credentials;
            0   20     2   newCreds  Lsun/security/krb5/Credentials;
            3   19     3          i  I
            5   17     4         pa  Lsun/security/krb5/internal/PAData;
           10   17     5  paForUser  Lsun/security/krb5/internal/PAForUserEnc;
    Exceptions:
      throws sun.security.krb5.Asn1Exception, sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
          Name  Flags
      pas       
      oldCeds   
      newCreds  

  private static java.lang.String handleS4U2ProxyReferral(sun.security.krb5.Credentials, sun.security.krb5.Credentials[], sun.security.krb5.PrincipalName);
    descriptor: (Lsun/security/krb5/Credentials;[Lsun/security/krb5/Credentials;Lsun/security/krb5/PrincipalName;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=7, args_size=3
        start local 0 // sun.security.krb5.Credentials asCreds
        start local 1 // sun.security.krb5.Credentials[] credsInOut
        start local 2 // sun.security.krb5.PrincipalName sname
         0: .line 543
            getstatic sun.security.krb5.internal.CredentialsUtil.DEBUG:Z
            ifeq 2
         1: .line 544
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Handling S4U2Proxy referral"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 546
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 3 /* refTGT */
        start local 3 // sun.security.krb5.Credentials refTGT
         3: .line 550
            aload 2 /* sname */
            aload 0 /* asCreds */
            invokestatic sun.security.krb5.internal.CredentialsUtil.serviceCreds:(Lsun/security/krb5/PrincipalName;Lsun/security/krb5/Credentials;)Lsun/security/krb5/Credentials;
         4: .line 549
            astore 4 /* middleSvcCredsInBackendRealm */
        start local 4 // sun.security.krb5.Credentials middleSvcCredsInBackendRealm
         5: .line 552
            aload 4 /* middleSvcCredsInBackendRealm */
            invokevirtual sun.security.krb5.Credentials.getServer:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
         6: .line 551
            astore 5 /* backendRealm */
        start local 5 // java.lang.String backendRealm
         7: .line 553
            aload 1 /* credsInOut */
            iconst_0
            aaload
            invokevirtual sun.security.krb5.Credentials.getServer:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getNameStrings:()[Ljava/lang/String;
            iconst_1
            aaload
            astore 6 /* toRealm */
        start local 6 // java.lang.String toRealm
         8: .line 554
            aload 6 /* toRealm */
            aload 5 /* backendRealm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 13
         9: .line 557
            aload 6 /* toRealm */
            aload 5 /* backendRealm */
            aload 1 /* credsInOut */
            iconst_0
            aaload
        10: .line 558
            iconst_1
            newarray 4
        11: .line 557
            invokestatic sun.security.krb5.internal.CredentialsUtil.getTGTforRealm:(Ljava/lang/String;Ljava/lang/String;Lsun/security/krb5/Credentials;[Z)Lsun/security/krb5/Credentials;
            astore 3 /* refTGT */
        12: .line 559
            goto 14
        13: .line 562
      StackMap locals: sun.security.krb5.Credentials sun.security.krb5.Credentials[] sun.security.krb5.PrincipalName sun.security.krb5.Credentials sun.security.krb5.Credentials java.lang.String java.lang.String
      StackMap stack:
            aload 1 /* credsInOut */
            iconst_0
            aaload
            astore 3 /* refTGT */
        14: .line 564
      StackMap locals:
      StackMap stack:
            aload 1 /* credsInOut */
            iconst_0
            aload 0 /* asCreds */
            invokevirtual sun.security.krb5.Credentials.getClient:()Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getRealmString:()Ljava/lang/String;
        15: .line 565
            aload 5 /* backendRealm */
            aload 0 /* asCreds */
            iconst_1
            newarray 4
        16: .line 564
            invokestatic sun.security.krb5.internal.CredentialsUtil.getTGTforRealm:(Ljava/lang/String;Ljava/lang/String;Lsun/security/krb5/Credentials;[Z)Lsun/security/krb5/Credentials;
            aastore
        17: .line 566
            aload 1 /* credsInOut */
            iconst_1
            aload 3 /* refTGT */
            aastore
        18: .line 567
            aload 5 /* backendRealm */
            areturn
        end local 6 // java.lang.String toRealm
        end local 5 // java.lang.String backendRealm
        end local 4 // sun.security.krb5.Credentials middleSvcCredsInBackendRealm
        end local 3 // sun.security.krb5.Credentials refTGT
        end local 2 // sun.security.krb5.PrincipalName sname
        end local 1 // sun.security.krb5.Credentials[] credsInOut
        end local 0 // sun.security.krb5.Credentials asCreds
      LocalVariableTable:
        Start  End  Slot                          Name  Signature
            0   19     0                       asCreds  Lsun/security/krb5/Credentials;
            0   19     1                    credsInOut  [Lsun/security/krb5/Credentials;
            0   19     2                         sname  Lsun/security/krb5/PrincipalName;
            3   19     3                        refTGT  Lsun/security/krb5/Credentials;
            5   19     4  middleSvcCredsInBackendRealm  Lsun/security/krb5/Credentials;
            7   19     5                  backendRealm  Ljava/lang/String;
            8   19     6                       toRealm  Ljava/lang/String;
    Exceptions:
      throws sun.security.krb5.KrbException, java.io.IOException
    MethodParameters:
            Name  Flags
      asCreds     
      credsInOut  
      sname       
}
SourceFile: "CredentialsUtil.java"
NestMembers:
  sun.security.krb5.internal.CredentialsUtil$S4U2Type
InnerClasses:
  private final S4U2Type = sun.security.krb5.internal.CredentialsUtil$S4U2Type of sun.security.krb5.internal.CredentialsUtil
  final ReferralCacheEntry = sun.security.krb5.internal.ReferralsCache$ReferralCacheEntry of sun.security.krb5.internal.ReferralsCache