abstract class sun.security.ssl.TrustManagerFactoryImpl extends javax.net.ssl.TrustManagerFactorySpi
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: sun.security.ssl.TrustManagerFactoryImpl
  super_class: javax.net.ssl.TrustManagerFactorySpi
{
  private static final sun.security.ssl.Debug debug;
    descriptor: Lsun/security/ssl/Debug;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private javax.net.ssl.X509TrustManager trustManager;
    descriptor: Ljavax/net/ssl/X509TrustManager;
    flags: (0x0002) ACC_PRIVATE

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 40
            ldc "ssl"
            invokestatic sun.security.ssl.Debug.getInstance:(Ljava/lang/String;)Lsun/security/ssl/Debug;
            putstatic sun.security.ssl.TrustManagerFactoryImpl.debug:Lsun/security/ssl/Debug;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.ssl.TrustManagerFactoryImpl this
         0: .line 44
            aload 0 /* this */
            invokespecial javax.net.ssl.TrustManagerFactorySpi.<init>:()V
         1: .line 41
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.TrustManagerFactoryImpl.trustManager:Ljavax/net/ssl/X509TrustManager;
         2: .line 42
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.TrustManagerFactoryImpl.isInitialized:Z
         3: .line 46
            return
        end local 0 // sun.security.ssl.TrustManagerFactoryImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lsun/security/ssl/TrustManagerFactoryImpl;

  protected void engineInit(java.security.KeyStore);
    descriptor: (Ljava/security/KeyStore;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // sun.security.ssl.TrustManagerFactoryImpl this
        start local 1 // java.security.KeyStore ks
         0: .line 49
            aload 1 /* ks */
            ifnonnull 29
         1: .line 51
            ldc "trustmanager"
            invokestatic sun.security.ssl.TrustManagerFactoryImpl.getCacertsKeyStore:(Ljava/lang/String;)Ljava/security/KeyStore;
            astore 1 /* ks */
         2: .line 52
            goto 29
      StackMap locals:
      StackMap stack: java.lang.SecurityException
         3: astore 2 /* se */
        start local 2 // java.lang.SecurityException se
         4: .line 54
            getstatic sun.security.ssl.TrustManagerFactoryImpl.debug:Lsun/security/ssl/Debug;
            ifnull 29
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 29
         5: .line 55
            getstatic java.lang.System.out:Ljava/io/PrintStream;
         6: .line 56
            new java.lang.StringBuilder
            dup
            ldc "SunX509: skip default keystore: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* se */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         7: .line 55
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 2 // java.lang.SecurityException se
         8: goto 29
         9: .line 58
      StackMap locals:
      StackMap stack: java.lang.Error
            astore 2 /* err */
        start local 2 // java.lang.Error err
        10: .line 59
            getstatic sun.security.ssl.TrustManagerFactoryImpl.debug:Lsun/security/ssl/Debug;
            ifnull 14
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 14
        11: .line 60
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        12: .line 61
            new java.lang.StringBuilder
            dup
            ldc "SunX509: skip default keystore: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* err */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 60
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        14: .line 63
      StackMap locals: java.lang.Error
      StackMap stack:
            aload 2 /* err */
            athrow
        end local 2 // java.lang.Error err
        15: .line 64
      StackMap locals: sun.security.ssl.TrustManagerFactoryImpl java.security.KeyStore
      StackMap stack: java.lang.RuntimeException
            astore 2 /* re */
        start local 2 // java.lang.RuntimeException re
        16: .line 65
            getstatic sun.security.ssl.TrustManagerFactoryImpl.debug:Lsun/security/ssl/Debug;
            ifnull 20
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 20
        17: .line 66
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        18: .line 67
            new java.lang.StringBuilder
            dup
            ldc "SunX509: skip default keystore: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* re */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        19: .line 66
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        20: .line 69
      StackMap locals: java.lang.RuntimeException
      StackMap stack:
            aload 2 /* re */
            athrow
        end local 2 // java.lang.RuntimeException re
        21: .line 70
      StackMap locals: sun.security.ssl.TrustManagerFactoryImpl java.security.KeyStore
      StackMap stack: java.lang.Exception
            astore 2 /* e */
        start local 2 // java.lang.Exception e
        22: .line 71
            getstatic sun.security.ssl.TrustManagerFactoryImpl.debug:Lsun/security/ssl/Debug;
            ifnull 26
            ldc "trustmanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 26
        23: .line 72
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        24: .line 73
            new java.lang.StringBuilder
            dup
            ldc "SunX509: skip default keystore: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        25: .line 72
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        26: .line 75
      StackMap locals: java.lang.Exception
      StackMap stack:
            new java.security.KeyStoreException
            dup
        27: .line 76
            new java.lang.StringBuilder
            dup
            ldc "problem accessing trust store"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        28: .line 75
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // java.lang.Exception e
        29: .line 79
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            aload 1 /* ks */
            invokevirtual sun.security.ssl.TrustManagerFactoryImpl.getInstance:(Ljava/security/KeyStore;)Ljavax/net/ssl/X509TrustManager;
            putfield sun.security.ssl.TrustManagerFactoryImpl.trustManager:Ljavax/net/ssl/X509TrustManager;
        30: .line 80
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.TrustManagerFactoryImpl.isInitialized:Z
        31: .line 81
            return
        end local 1 // java.security.KeyStore ks
        end local 0 // sun.security.ssl.TrustManagerFactoryImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   32     0  this  Lsun/security/ssl/TrustManagerFactoryImpl;
            0   32     1    ks  Ljava/security/KeyStore;
            4    8     2    se  Ljava/lang/SecurityException;
           10   15     2   err  Ljava/lang/Error;
           16   21     2    re  Ljava/lang/RuntimeException;
           22   29     2     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1     2       3  Class java.lang.SecurityException
           1     2       9  Class java.lang.Error
           1     2      15  Class java.lang.RuntimeException
           1     2      21  Class java.lang.Exception
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
      Name  Flags
      ks    

  abstract javax.net.ssl.X509TrustManager getInstance(java.security.KeyStore);
    descriptor: (Ljava/security/KeyStore;)Ljavax/net/ssl/X509TrustManager;
    flags: (0x0400) ACC_ABSTRACT
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
      Name  Flags
      ks    

  abstract javax.net.ssl.X509TrustManager getInstance(javax.net.ssl.ManagerFactoryParameters);
    descriptor: (Ljavax/net/ssl/ManagerFactoryParameters;)Ljavax/net/ssl/X509TrustManager;
    flags: (0x0400) ACC_ABSTRACT
    Exceptions:
      throws java.security.InvalidAlgorithmParameterException
    MethodParameters:
      Name  Flags
      spec  

  protected void engineInit(javax.net.ssl.ManagerFactoryParameters);
    descriptor: (Ljavax/net/ssl/ManagerFactoryParameters;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.ssl.TrustManagerFactoryImpl this
        start local 1 // javax.net.ssl.ManagerFactoryParameters spec
         0: .line 90
            aload 0 /* this */
            aload 0 /* this */
            aload 1 /* spec */
            invokevirtual sun.security.ssl.TrustManagerFactoryImpl.getInstance:(Ljavax/net/ssl/ManagerFactoryParameters;)Ljavax/net/ssl/X509TrustManager;
            putfield sun.security.ssl.TrustManagerFactoryImpl.trustManager:Ljavax/net/ssl/X509TrustManager;
         1: .line 91
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.TrustManagerFactoryImpl.isInitialized:Z
         2: .line 92
            return
        end local 1 // javax.net.ssl.ManagerFactoryParameters spec
        end local 0 // sun.security.ssl.TrustManagerFactoryImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/TrustManagerFactoryImpl;
            0    3     1  spec  Ljavax/net/ssl/ManagerFactoryParameters;
    Exceptions:
      throws java.security.InvalidAlgorithmParameterException
    MethodParameters:
      Name  Flags
      spec  

  protected javax.net.ssl.TrustManager[] engineGetTrustManagers();
    descriptor: ()[Ljavax/net/ssl/TrustManager;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // sun.security.ssl.TrustManagerFactoryImpl this
         0: .line 98
            aload 0 /* this */
            getfield sun.security.ssl.TrustManagerFactoryImpl.isInitialized:Z
            ifne 4
         1: .line 99
            new java.lang.IllegalStateException
            dup
         2: .line 100
            ldc "TrustManagerFactoryImpl is not initialized"
         3: .line 99
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 102
      StackMap locals:
      StackMap stack:
            iconst_1
            anewarray javax.net.ssl.TrustManager
            dup
            iconst_0
            aload 0 /* this */
            getfield sun.security.ssl.TrustManagerFactoryImpl.trustManager:Ljavax/net/ssl/X509TrustManager;
            aastore
            areturn
        end local 0 // sun.security.ssl.TrustManagerFactoryImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/ssl/TrustManagerFactoryImpl;

  private static java.io.FileInputStream getFileInputStream(java.io.File);
    descriptor: (Ljava/io/File;)Ljava/io/FileInputStream;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // java.io.File file
         0: .line 111
            new sun.security.ssl.TrustManagerFactoryImpl$1
            dup
            aload 0 /* file */
            invokespecial sun.security.ssl.TrustManagerFactoryImpl$1.<init>:(Ljava/io/File;)V
         1: .line 110
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            checkcast java.io.FileInputStream
            areturn
        end local 0 // java.io.File file
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  file  Ljava/io/File;
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
      Name  Flags
      file  final

  static java.security.KeyStore getCacertsKeyStore(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/KeyStore;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=12, args_size=1
        start local 0 // java.lang.String dbgname
         0: .line 132
            aconst_null
            astore 1 /* storeFileName */
        start local 1 // java.lang.String storeFileName
         1: .line 133
            aconst_null
            astore 2 /* storeFile */
        start local 2 // java.io.File storeFile
         2: .line 134
            aconst_null
            astore 3 /* fis */
        start local 3 // java.io.FileInputStream fis
         3: .line 137
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            astore 6 /* props */
        start local 6 // java.util.HashMap props
         4: .line 138
            getstatic java.io.File.separator:Ljava/lang/String;
            astore 7 /* sep */
        start local 7 // java.lang.String sep
         5: .line 139
            aconst_null
            astore 8 /* ks */
        start local 8 // java.security.KeyStore ks
         6: .line 141
            new sun.security.ssl.TrustManagerFactoryImpl$2
            dup
            aload 6 /* props */
            invokespecial sun.security.ssl.TrustManagerFactoryImpl$2.<init>:(Ljava/util/HashMap;)V
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            pop
         7: .line 167
            aload 6 /* props */
            ldc "trustStore"
            invokevirtual java.util.HashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 1 /* storeFileName */
         8: .line 168
            ldc "NONE"
            aload 1 /* storeFileName */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 28
         9: .line 169
            aload 1 /* storeFileName */
            ifnull 13
        10: .line 170
            new java.io.File
            dup
            aload 1 /* storeFileName */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 2 /* storeFile */
        11: .line 171
            aload 2 /* storeFile */
            invokestatic sun.security.ssl.TrustManagerFactoryImpl.getFileInputStream:(Ljava/io/File;)Ljava/io/FileInputStream;
            astore 3 /* fis */
        12: .line 172
            goto 24
        13: .line 173
      StackMap locals: java.lang.String java.lang.String java.io.File java.io.FileInputStream top top java.util.HashMap java.lang.String java.security.KeyStore
      StackMap stack:
            aload 6 /* props */
            ldc "javaHome"
            invokevirtual java.util.HashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 9 /* javaHome */
        start local 9 // java.lang.String javaHome
        14: .line 174
            new java.io.File
            dup
            new java.lang.StringBuilder
            dup
            aload 9 /* javaHome */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* sep */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "lib"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 7 /* sep */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        15: .line 175
            ldc "security"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 7 /* sep */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        16: .line 176
            ldc "jssecacerts"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        17: .line 174
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 2 /* storeFile */
        18: .line 177
            aload 2 /* storeFile */
            invokestatic sun.security.ssl.TrustManagerFactoryImpl.getFileInputStream:(Ljava/io/File;)Ljava/io/FileInputStream;
            dup
            astore 3 /* fis */
            ifnonnull 24
        19: .line 178
            new java.io.File
            dup
            new java.lang.StringBuilder
            dup
            aload 9 /* javaHome */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* sep */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "lib"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 7 /* sep */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        20: .line 179
            ldc "security"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 7 /* sep */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        21: .line 180
            ldc "cacerts"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        22: .line 178
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 2 /* storeFile */
        23: .line 181
            aload 2 /* storeFile */
            invokestatic sun.security.ssl.TrustManagerFactoryImpl.getFileInputStream:(Ljava/io/File;)Ljava/io/FileInputStream;
            astore 3 /* fis */
        end local 9 // java.lang.String javaHome
        24: .line 185
      StackMap locals:
      StackMap stack:
            aload 3 /* fis */
            ifnull 27
        25: .line 186
            aload 2 /* storeFile */
            invokevirtual java.io.File.getPath:()Ljava/lang/String;
            astore 1 /* storeFileName */
        26: .line 187
            goto 28
        27: .line 188
      StackMap locals:
      StackMap stack:
            ldc "No File Available, using empty keystore."
            astore 1 /* storeFileName */
        28: .line 192
      StackMap locals:
      StackMap stack:
            aload 6 /* props */
            ldc "trustStoreType"
            invokevirtual java.util.HashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* defaultTrustStoreType */
        start local 4 // java.lang.String defaultTrustStoreType
        29: .line 193
            aload 6 /* props */
            ldc "trustStoreProvider"
            invokevirtual java.util.HashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 5 /* defaultTrustStoreProvider */
        start local 5 // java.lang.String defaultTrustStoreProvider
        30: .line 194
            getstatic sun.security.ssl.TrustManagerFactoryImpl.debug:Lsun/security/ssl/Debug;
            ifnull 38
            aload 0 /* dbgname */
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 38
        31: .line 195
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "trustStore is: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* storeFileName */
            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
        32: .line 196
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "trustStore type is : "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        33: .line 197
            aload 4 /* defaultTrustStoreType */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        34: .line 196
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        35: .line 198
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "trustStore provider is : "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        36: .line 199
            aload 5 /* defaultTrustStoreProvider */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        37: .line 198
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        38: .line 205
      StackMap locals: java.lang.String java.lang.String java.io.File java.io.FileInputStream java.lang.String java.lang.String java.util.HashMap java.lang.String java.security.KeyStore
      StackMap stack:
            aload 4 /* defaultTrustStoreType */
            invokevirtual java.lang.String.length:()I
            ifeq 58
        39: .line 206
            getstatic sun.security.ssl.TrustManagerFactoryImpl.debug:Lsun/security/ssl/Debug;
            ifnull 41
            aload 0 /* dbgname */
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 41
        40: .line 207
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "init truststore"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        41: .line 209
      StackMap locals:
      StackMap stack:
            aload 5 /* defaultTrustStoreProvider */
            invokevirtual java.lang.String.length:()I
            ifne 44
        42: .line 210
            aload 4 /* defaultTrustStoreType */
            invokestatic java.security.KeyStore.getInstance:(Ljava/lang/String;)Ljava/security/KeyStore;
            astore 8 /* ks */
        43: .line 211
            goto 47
        44: .line 212
      StackMap locals:
      StackMap stack:
            aload 4 /* defaultTrustStoreType */
        45: .line 213
            aload 5 /* defaultTrustStoreProvider */
        46: .line 212
            invokestatic java.security.KeyStore.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/KeyStore;
            astore 8 /* ks */
        47: .line 215
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 9 /* passwd */
        start local 9 // char[] passwd
        48: .line 216
            aload 6 /* props */
            ldc "trustStorePasswd"
            invokevirtual java.util.HashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 10 /* defaultTrustStorePassword */
        start local 10 // java.lang.String defaultTrustStorePassword
        49: .line 217
            aload 10 /* defaultTrustStorePassword */
            invokevirtual java.lang.String.length:()I
            ifeq 51
        50: .line 218
            aload 10 /* defaultTrustStorePassword */
            invokevirtual java.lang.String.toCharArray:()[C
            astore 9 /* passwd */
        51: .line 221
      StackMap locals: char[] java.lang.String
      StackMap stack:
            aload 8 /* ks */
            aload 3 /* fis */
            aload 9 /* passwd */
            invokevirtual java.security.KeyStore.load:(Ljava/io/InputStream;[C)V
        52: .line 224
            aload 9 /* passwd */
            ifnull 58
        53: .line 225
            iconst_0
            istore 11 /* i */
        start local 11 // int i
        54: goto 57
        55: .line 226
      StackMap locals: int
      StackMap stack:
            aload 9 /* passwd */
            iload 11 /* i */
            iconst_0
            castore
        56: .line 225
            iinc 11 /* i */ 1
      StackMap locals:
      StackMap stack:
        57: iload 11 /* i */
            aload 9 /* passwd */
            arraylength
            if_icmplt 55
        end local 11 // int i
        end local 10 // java.lang.String defaultTrustStorePassword
        end local 9 // char[] passwd
        58: .line 231
      StackMap locals:
      StackMap stack:
            aload 3 /* fis */
            ifnull 60
        59: .line 232
            aload 3 /* fis */
            invokevirtual java.io.FileInputStream.close:()V
        60: .line 235
      StackMap locals:
      StackMap stack:
            aload 8 /* ks */
            areturn
        end local 8 // java.security.KeyStore ks
        end local 7 // java.lang.String sep
        end local 6 // java.util.HashMap props
        end local 5 // java.lang.String defaultTrustStoreProvider
        end local 4 // java.lang.String defaultTrustStoreType
        end local 3 // java.io.FileInputStream fis
        end local 2 // java.io.File storeFile
        end local 1 // java.lang.String storeFileName
        end local 0 // java.lang.String dbgname
      LocalVariableTable:
        Start  End  Slot                       Name  Signature
            0   61     0                    dbgname  Ljava/lang/String;
            1   61     1              storeFileName  Ljava/lang/String;
            2   61     2                  storeFile  Ljava/io/File;
            3   61     3                        fis  Ljava/io/FileInputStream;
           29   61     4      defaultTrustStoreType  Ljava/lang/String;
           30   61     5  defaultTrustStoreProvider  Ljava/lang/String;
            4   61     6                      props  Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/String;>;
            5   61     7                        sep  Ljava/lang/String;
            6   61     8                         ks  Ljava/security/KeyStore;
           14   24     9                   javaHome  Ljava/lang/String;
           48   58     9                     passwd  [C
           49   58    10  defaultTrustStorePassword  Ljava/lang/String;
           54   58    11                          i  I
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
         Name  Flags
      dbgname  
}
SourceFile: "TrustManagerFactoryImpl.java"
NestMembers:
  sun.security.ssl.TrustManagerFactoryImpl$1  sun.security.ssl.TrustManagerFactoryImpl$2  sun.security.ssl.TrustManagerFactoryImpl$PKIXFactory  sun.security.ssl.TrustManagerFactoryImpl$SimpleFactory
InnerClasses:
  sun.security.ssl.TrustManagerFactoryImpl$1
  sun.security.ssl.TrustManagerFactoryImpl$2
  public final PKIXFactory = sun.security.ssl.TrustManagerFactoryImpl$PKIXFactory of sun.security.ssl.TrustManagerFactoryImpl
  public final SimpleFactory = sun.security.ssl.TrustManagerFactoryImpl$SimpleFactory of sun.security.ssl.TrustManagerFactoryImpl