public class sun.security.krb5.internal.tools.Kinit
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.security.krb5.internal.tools.Kinit
  super_class: java.lang.Object
{
  private sun.security.krb5.internal.tools.KinitOptions options;
    descriptor: Lsun/security/krb5/internal/tools/KinitOptions;
    flags: (0x0002) ACC_PRIVATE

  private static final boolean DEBUG;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

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

  public static void main(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // java.lang.String[] args
         0: .line 99
            new sun.security.krb5.internal.tools.Kinit
            aload 0 /* args */
            invokespecial sun.security.krb5.internal.tools.Kinit.<init>:([Ljava/lang/String;)V
         1: .line 100
            goto 16
         2: .line 101
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 1 /* e */
        start local 1 // java.lang.Exception e
         3: .line 102
            aconst_null
            astore 2 /* msg */
        start local 2 // java.lang.String msg
         4: .line 103
            aload 1 /* e */
            instanceof sun.security.krb5.KrbException
            ifeq 9
         5: .line 104
            new java.lang.StringBuilder
            dup
            aload 1 /* e */
            checkcast sun.security.krb5.KrbException
            invokevirtual sun.security.krb5.KrbException.krbErrorMessage:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         6: .line 105
            aload 1 /* e */
            checkcast sun.security.krb5.KrbException
            invokevirtual sun.security.krb5.KrbException.returnCodeMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         7: .line 104
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 2 /* msg */
         8: .line 106
            goto 10
         9: .line 107
      StackMap locals: java.lang.Exception java.lang.String
      StackMap stack:
            aload 1 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            astore 2 /* msg */
        10: .line 109
      StackMap locals:
      StackMap stack:
            aload 2 /* msg */
            ifnull 13
        11: .line 110
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Exception: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* msg */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        12: .line 111
            goto 14
        13: .line 112
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Exception: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        14: .line 114
      StackMap locals:
      StackMap stack:
            aload 1 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        15: .line 115
            iconst_m1
            invokestatic java.lang.System.exit:(I)V
        end local 2 // java.lang.String msg
        end local 1 // java.lang.Exception e
        16: .line 117
      StackMap locals:
      StackMap stack:
            return
        end local 0 // java.lang.String[] args
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   17     0  args  [Ljava/lang/String;
            3   16     1     e  Ljava/lang/Exception;
            4   16     2   msg  Ljava/lang/String;
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.Exception
    MethodParameters:
      Name  Flags
      args  

  private void <init>(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // sun.security.krb5.internal.tools.Kinit this
        start local 1 // java.lang.String[] args
         0: .line 128
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 130
            aload 1 /* args */
            ifnull 2
            aload 1 /* args */
            arraylength
            ifne 4
         2: .line 131
      StackMap locals: sun.security.krb5.internal.tools.Kinit java.lang.String[]
      StackMap stack:
            aload 0 /* this */
            new sun.security.krb5.internal.tools.KinitOptions
            dup
            invokespecial sun.security.krb5.internal.tools.KinitOptions.<init>:()V
            putfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
         3: .line 132
            goto 5
         4: .line 133
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new sun.security.krb5.internal.tools.KinitOptions
            dup
            aload 1 /* args */
            invokespecial sun.security.krb5.internal.tools.KinitOptions.<init>:([Ljava/lang/String;)V
            putfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
         5: .line 135
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.action:I
            tableswitch { // 1 - 2
                    1: 6
                    2: 8
              default: 10
          }
         6: .line 137
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.krb5.internal.tools.Kinit.acquire:()V
         7: .line 138
            goto 13
         8: .line 140
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.krb5.internal.tools.Kinit.renew:()V
         9: .line 141
            goto 13
        10: .line 143
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.KrbException
            dup
            new java.lang.StringBuilder
            dup
            ldc "kinit does not support action "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        11: .line 144
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.action:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        12: .line 143
            invokespecial sun.security.krb5.KrbException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 146
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String[] args
        end local 0 // sun.security.krb5.internal.tools.Kinit this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   14     0  this  Lsun/security/krb5/internal/tools/Kinit;
            0   14     1  args  [Ljava/lang/String;
    Exceptions:
      throws java.io.IOException, sun.security.krb5.RealmException, sun.security.krb5.KrbException
    MethodParameters:
      Name  Flags
      args  

  private void renew();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=1
        start local 0 // sun.security.krb5.internal.tools.Kinit this
         0: .line 151
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            invokevirtual sun.security.krb5.internal.tools.KinitOptions.getPrincipal:()Lsun/security/krb5/PrincipalName;
            astore 1 /* principal */
        start local 1 // sun.security.krb5.PrincipalName principal
         1: .line 152
            aload 1 /* principal */
            invokevirtual sun.security.krb5.PrincipalName.getRealmAsString:()Ljava/lang/String;
            astore 2 /* realm */
        start local 2 // java.lang.String realm
         2: .line 153
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.cachename:Ljava/lang/String;
            invokestatic sun.security.krb5.internal.ccache.CredentialsCache.getInstance:(Ljava/lang/String;)Lsun/security/krb5/internal/ccache/CredentialsCache;
            astore 3 /* cache */
        start local 3 // sun.security.krb5.internal.ccache.CredentialsCache cache
         3: .line 155
            aload 3 /* cache */
            ifnonnull 7
         4: .line 156
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unable to find existing cache file "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         5: .line 157
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.cachename:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         6: .line 156
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 160
      StackMap locals: sun.security.krb5.PrincipalName java.lang.String sun.security.krb5.internal.ccache.CredentialsCache
      StackMap stack:
            aload 3 /* cache */
            aload 2 /* realm */
            aload 2 /* realm */
            invokestatic sun.security.krb5.PrincipalName.tgsService:(Ljava/lang/String;Ljava/lang/String;)Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.internal.ccache.CredentialsCache.getCreds:(Lsun/security/krb5/PrincipalName;)Lsun/security/krb5/internal/ccache/Credentials;
         8: .line 159
            astore 4 /* credentials */
        start local 4 // sun.security.krb5.internal.ccache.Credentials credentials
         9: .line 162
            aload 4 /* credentials */
            invokevirtual sun.security.krb5.internal.ccache.Credentials.setKrbCreds:()Lsun/security/krb5/Credentials;
        10: .line 163
            invokevirtual sun.security.krb5.Credentials.renew:()Lsun/security/krb5/Credentials;
        11: .line 164
            invokevirtual sun.security.krb5.Credentials.toCCacheCreds:()Lsun/security/krb5/internal/ccache/Credentials;
        12: .line 162
            astore 4 /* credentials */
        13: .line 166
            aload 1 /* principal */
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.cachename:Ljava/lang/String;
            invokestatic sun.security.krb5.internal.ccache.CredentialsCache.create:(Lsun/security/krb5/PrincipalName;Ljava/lang/String;)Lsun/security/krb5/internal/ccache/CredentialsCache;
            astore 3 /* cache */
        14: .line 167
            aload 3 /* cache */
            ifnonnull 18
        15: .line 168
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unable to create the cache file "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        16: .line 169
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.cachename:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        17: .line 168
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 171
      StackMap locals: sun.security.krb5.internal.ccache.Credentials
      StackMap stack:
            aload 3 /* cache */
            aload 4 /* credentials */
            invokevirtual sun.security.krb5.internal.ccache.CredentialsCache.update:(Lsun/security/krb5/internal/ccache/Credentials;)V
        19: .line 172
            aload 3 /* cache */
            invokevirtual sun.security.krb5.internal.ccache.CredentialsCache.save:()V
        20: .line 173
            return
        end local 4 // sun.security.krb5.internal.ccache.Credentials credentials
        end local 3 // sun.security.krb5.internal.ccache.CredentialsCache cache
        end local 2 // java.lang.String realm
        end local 1 // sun.security.krb5.PrincipalName principal
        end local 0 // sun.security.krb5.internal.tools.Kinit this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   21     0         this  Lsun/security/krb5/internal/tools/Kinit;
            1   21     1    principal  Lsun/security/krb5/PrincipalName;
            2   21     2        realm  Ljava/lang/String;
            3   21     3        cache  Lsun/security/krb5/internal/ccache/CredentialsCache;
            9   21     4  credentials  Lsun/security/krb5/internal/ccache/Credentials;
    Exceptions:
      throws java.io.IOException, sun.security.krb5.RealmException, sun.security.krb5.KrbException

  private void acquire();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=11, args_size=1
        start local 0 // sun.security.krb5.internal.tools.Kinit this
         0: .line 178
            aconst_null
            astore 1 /* princName */
        start local 1 // java.lang.String princName
         1: .line 179
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            invokevirtual sun.security.krb5.internal.tools.KinitOptions.getPrincipal:()Lsun/security/krb5/PrincipalName;
            astore 2 /* principal */
        start local 2 // sun.security.krb5.PrincipalName principal
         2: .line 180
            aload 2 /* principal */
            ifnull 4
         3: .line 181
            aload 2 /* principal */
            invokevirtual sun.security.krb5.PrincipalName.toString:()Ljava/lang/String;
            astore 1 /* princName */
         4: .line 184
      StackMap locals: java.lang.String sun.security.krb5.PrincipalName
      StackMap stack:
            getstatic sun.security.krb5.internal.tools.Kinit.DEBUG:Z
            ifeq 6
         5: .line 185
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Principal is "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* principal */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         6: .line 187
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.password:[C
            astore 4 /* psswd */
        start local 4 // char[] psswd
         7: .line 188
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            invokevirtual sun.security.krb5.internal.tools.KinitOptions.useKeytabFile:()Z
            istore 5 /* useKeytab */
        start local 5 // boolean useKeytab
         8: .line 189
            iload 5 /* useKeytab */
            ifne 23
         9: .line 190
            aload 1 /* princName */
            ifnonnull 13
        10: .line 191
            new java.lang.IllegalArgumentException
            dup
        11: .line 192
            ldc " Can not obtain principal name"
        12: .line 191
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 194
      StackMap locals: sun.security.krb5.internal.tools.Kinit java.lang.String sun.security.krb5.PrincipalName top char[] int
      StackMap stack:
            aload 4 /* psswd */
            ifnonnull 21
        14: .line 195
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Password for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* princName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ":"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
        15: .line 196
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.flush:()V
        16: .line 197
            getstatic java.lang.System.in:Ljava/io/InputStream;
            invokestatic sun.security.util.Password.readPassword:(Ljava/io/InputStream;)[C
            astore 4 /* psswd */
        17: .line 198
            getstatic sun.security.krb5.internal.tools.Kinit.DEBUG:Z
            ifeq 21
        18: .line 199
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc ">>> Kinit console input "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        19: .line 200
            new java.lang.String
            dup
            aload 4 /* psswd */
            invokespecial java.lang.String.<init>:([C)V
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        20: .line 199
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        21: .line 203
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.KrbAsReqBuilder
            dup
            aload 2 /* principal */
            aload 4 /* psswd */
            invokespecial sun.security.krb5.KrbAsReqBuilder.<init>:(Lsun/security/krb5/PrincipalName;[C)V
            astore 3 /* builder */
        start local 3 // sun.security.krb5.KrbAsReqBuilder builder
        22: .line 204
            goto 39
        end local 3 // sun.security.krb5.KrbAsReqBuilder builder
        23: .line 205
      StackMap locals:
      StackMap stack:
            getstatic sun.security.krb5.internal.tools.Kinit.DEBUG:Z
            ifeq 25
        24: .line 206
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Kinit using keytab"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        25: .line 208
      StackMap locals:
      StackMap stack:
            aload 1 /* princName */
            ifnonnull 29
        26: .line 209
            new java.lang.IllegalArgumentException
            dup
        27: .line 210
            ldc "Principal name must be specified."
        28: .line 209
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        29: .line 212
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            invokevirtual sun.security.krb5.internal.tools.KinitOptions.keytabFileName:()Ljava/lang/String;
            astore 6 /* ktabName */
        start local 6 // java.lang.String ktabName
        30: .line 213
            aload 6 /* ktabName */
            ifnull 35
        31: .line 214
            getstatic sun.security.krb5.internal.tools.Kinit.DEBUG:Z
            ifeq 35
        32: .line 215
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        33: .line 216
            new java.lang.StringBuilder
            dup
            ldc ">>> Kinit keytab file name: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* ktabName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        34: .line 215
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        35: .line 220
      StackMap locals: java.lang.String
      StackMap stack:
            new sun.security.krb5.KrbAsReqBuilder
            dup
            aload 2 /* principal */
            aload 6 /* ktabName */
            ifnonnull 37
        36: .line 221
            invokestatic javax.security.auth.kerberos.KeyTab.getInstance:()Ljavax/security/auth/kerberos/KeyTab;
            goto 38
        37: .line 222
      StackMap locals: sun.security.krb5.internal.tools.Kinit java.lang.String sun.security.krb5.PrincipalName top char[] int java.lang.String
      StackMap stack: new 35 new 35 sun.security.krb5.PrincipalName
            new java.io.File
            dup
            aload 6 /* ktabName */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            invokestatic javax.security.auth.kerberos.KeyTab.getInstance:(Ljava/io/File;)Ljavax/security/auth/kerberos/KeyTab;
        38: .line 220
      StackMap locals: sun.security.krb5.internal.tools.Kinit java.lang.String sun.security.krb5.PrincipalName top char[] int java.lang.String
      StackMap stack: new 35 new 35 sun.security.krb5.PrincipalName javax.security.auth.kerberos.KeyTab
            invokespecial sun.security.krb5.KrbAsReqBuilder.<init>:(Lsun/security/krb5/PrincipalName;Ljavax/security/auth/kerberos/KeyTab;)V
            astore 3 /* builder */
        end local 6 // java.lang.String ktabName
        start local 3 // sun.security.krb5.KrbAsReqBuilder builder
        39: .line 225
      StackMap locals: sun.security.krb5.internal.tools.Kinit java.lang.String sun.security.krb5.PrincipalName sun.security.krb5.KrbAsReqBuilder char[] int
      StackMap stack:
            new sun.security.krb5.internal.KDCOptions
            dup
            invokespecial sun.security.krb5.internal.KDCOptions.<init>:()V
            astore 6 /* opt */
        start local 6 // sun.security.krb5.internal.KDCOptions opt
        40: .line 226
            iconst_1
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.forwardable:S
            aload 6 /* opt */
            invokestatic sun.security.krb5.internal.tools.Kinit.setOptions:(IILsun/security/krb5/internal/KDCOptions;)V
        41: .line 227
            iconst_3
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.proxiable:S
            aload 6 /* opt */
            invokestatic sun.security.krb5.internal.tools.Kinit.setOptions:(IILsun/security/krb5/internal/KDCOptions;)V
        42: .line 228
            aload 3 /* builder */
            aload 6 /* opt */
            invokevirtual sun.security.krb5.KrbAsReqBuilder.setOptions:(Lsun/security/krb5/internal/KDCOptions;)V
        43: .line 229
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            invokevirtual sun.security.krb5.internal.tools.KinitOptions.getKDCRealm:()Ljava/lang/String;
            astore 7 /* realm */
        start local 7 // java.lang.String realm
        44: .line 230
            aload 7 /* realm */
            ifnonnull 46
        45: .line 231
            invokestatic sun.security.krb5.Config.getInstance:()Lsun/security/krb5/Config;
            invokevirtual sun.security.krb5.Config.getDefaultRealm:()Ljava/lang/String;
            astore 7 /* realm */
        46: .line 234
      StackMap locals: sun.security.krb5.internal.KDCOptions java.lang.String
      StackMap stack:
            getstatic sun.security.krb5.internal.tools.Kinit.DEBUG:Z
            ifeq 48
        47: .line 235
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc ">>> Kinit realm name is "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* realm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        48: .line 238
      StackMap locals:
      StackMap stack:
            aload 7 /* realm */
            aload 7 /* realm */
            invokestatic sun.security.krb5.PrincipalName.tgsService:(Ljava/lang/String;Ljava/lang/String;)Lsun/security/krb5/PrincipalName;
            astore 8 /* sname */
        start local 8 // sun.security.krb5.PrincipalName sname
        49: .line 239
            aload 3 /* builder */
            aload 8 /* sname */
            invokevirtual sun.security.krb5.KrbAsReqBuilder.setTarget:(Lsun/security/krb5/PrincipalName;)V
        50: .line 241
            getstatic sun.security.krb5.internal.tools.Kinit.DEBUG:Z
            ifeq 52
        51: .line 242
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc ">>> Creating KrbAsReq"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        52: .line 245
      StackMap locals: sun.security.krb5.PrincipalName
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            invokevirtual sun.security.krb5.internal.tools.KinitOptions.getAddressOption:()Z
            ifeq 54
        53: .line 246
            aload 3 /* builder */
            invokestatic sun.security.krb5.internal.HostAddresses.getLocalAddresses:()Lsun/security/krb5/internal/HostAddresses;
            invokevirtual sun.security.krb5.KrbAsReqBuilder.setAddresses:(Lsun/security/krb5/internal/HostAddresses;)V
        54: .line 248
      StackMap locals:
      StackMap stack:
            aload 3 /* builder */
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.lifetime:Lsun/security/krb5/internal/KerberosTime;
            invokevirtual sun.security.krb5.KrbAsReqBuilder.setTill:(Lsun/security/krb5/internal/KerberosTime;)V
        55: .line 249
            aload 3 /* builder */
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.renewable_lifetime:Lsun/security/krb5/internal/KerberosTime;
            invokevirtual sun.security.krb5.KrbAsReqBuilder.setRTime:(Lsun/security/krb5/internal/KerberosTime;)V
        56: .line 251
            aload 3 /* builder */
            invokevirtual sun.security.krb5.KrbAsReqBuilder.action:()Lsun/security/krb5/KrbAsReqBuilder;
            pop
        57: .line 254
            aload 3 /* builder */
            invokevirtual sun.security.krb5.KrbAsReqBuilder.getCCreds:()Lsun/security/krb5/internal/ccache/Credentials;
        58: .line 253
            astore 9 /* credentials */
        start local 9 // sun.security.krb5.internal.ccache.Credentials credentials
        59: .line 255
            aload 3 /* builder */
            invokevirtual sun.security.krb5.KrbAsReqBuilder.destroy:()V
        60: .line 259
            aload 2 /* principal */
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.cachename:Ljava/lang/String;
            invokestatic sun.security.krb5.internal.ccache.CredentialsCache.create:(Lsun/security/krb5/PrincipalName;Ljava/lang/String;)Lsun/security/krb5/internal/ccache/CredentialsCache;
        61: .line 258
            astore 10 /* cache */
        start local 10 // sun.security.krb5.internal.ccache.CredentialsCache cache
        62: .line 260
            aload 10 /* cache */
            ifnonnull 66
        63: .line 261
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unable to create the cache file "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        64: .line 262
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.cachename:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        65: .line 261
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        66: .line 264
      StackMap locals: sun.security.krb5.internal.ccache.Credentials sun.security.krb5.internal.ccache.CredentialsCache
      StackMap stack:
            aload 10 /* cache */
            aload 9 /* credentials */
            invokevirtual sun.security.krb5.internal.ccache.CredentialsCache.update:(Lsun/security/krb5/internal/ccache/Credentials;)V
        67: .line 265
            aload 10 /* cache */
            invokevirtual sun.security.krb5.internal.ccache.CredentialsCache.save:()V
        68: .line 267
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.password:[C
            ifnonnull 73
        69: .line 269
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "New ticket is stored in cache file "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        70: .line 270
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.cachename:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        71: .line 269
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        72: .line 271
            goto 74
        73: .line 272
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
            getfield sun.security.krb5.internal.tools.KinitOptions.password:[C
            bipush 48
            invokestatic java.util.Arrays.fill:([CC)V
        74: .line 276
      StackMap locals:
      StackMap stack:
            aload 4 /* psswd */
            ifnull 76
        75: .line 277
            aload 4 /* psswd */
            bipush 48
            invokestatic java.util.Arrays.fill:([CC)V
        76: .line 279
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield sun.security.krb5.internal.tools.Kinit.options:Lsun/security/krb5/internal/tools/KinitOptions;
        77: .line 280
            return
        end local 10 // sun.security.krb5.internal.ccache.CredentialsCache cache
        end local 9 // sun.security.krb5.internal.ccache.Credentials credentials
        end local 8 // sun.security.krb5.PrincipalName sname
        end local 7 // java.lang.String realm
        end local 6 // sun.security.krb5.internal.KDCOptions opt
        end local 5 // boolean useKeytab
        end local 4 // char[] psswd
        end local 3 // sun.security.krb5.KrbAsReqBuilder builder
        end local 2 // sun.security.krb5.PrincipalName principal
        end local 1 // java.lang.String princName
        end local 0 // sun.security.krb5.internal.tools.Kinit this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   78     0         this  Lsun/security/krb5/internal/tools/Kinit;
            1   78     1    princName  Ljava/lang/String;
            2   78     2    principal  Lsun/security/krb5/PrincipalName;
           22   23     3      builder  Lsun/security/krb5/KrbAsReqBuilder;
           39   78     3      builder  Lsun/security/krb5/KrbAsReqBuilder;
            7   78     4        psswd  [C
            8   78     5    useKeytab  Z
           30   39     6     ktabName  Ljava/lang/String;
           40   78     6          opt  Lsun/security/krb5/internal/KDCOptions;
           44   78     7        realm  Ljava/lang/String;
           49   78     8        sname  Lsun/security/krb5/PrincipalName;
           59   78     9  credentials  Lsun/security/krb5/internal/ccache/Credentials;
           62   78    10        cache  Lsun/security/krb5/internal/ccache/CredentialsCache;
    Exceptions:
      throws java.io.IOException, sun.security.krb5.RealmException, sun.security.krb5.KrbException

  private static void setOptions(int, int, sun.security.krb5.internal.KDCOptions);
    descriptor: (IILsun/security/krb5/internal/KDCOptions;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // int flag
        start local 1 // int option
        start local 2 // sun.security.krb5.internal.KDCOptions opt
         0: .line 283
            iload 1 /* option */
            tableswitch { // -1 - 1
                   -1: 2
                    0: 1
                    1: 4
              default: 5
          }
         1: .line 285
      StackMap locals:
      StackMap stack:
            goto 5
         2: .line 287
      StackMap locals:
      StackMap stack:
            aload 2 /* opt */
            iload 0 /* flag */
            iconst_0
            invokevirtual sun.security.krb5.internal.KDCOptions.set:(IZ)V
         3: .line 288
            goto 5
         4: .line 290
      StackMap locals:
      StackMap stack:
            aload 2 /* opt */
            iload 0 /* flag */
            iconst_1
            invokevirtual sun.security.krb5.internal.KDCOptions.set:(IZ)V
         5: .line 292
      StackMap locals:
      StackMap stack:
            return
        end local 2 // sun.security.krb5.internal.KDCOptions opt
        end local 1 // int option
        end local 0 // int flag
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    flag  I
            0    6     1  option  I
            0    6     2     opt  Lsun/security/krb5/internal/KDCOptions;
    MethodParameters:
        Name  Flags
      flag    
      option  
      opt     
}
SourceFile: "Kinit.java"