public class jdk.security.jarsigner.JarSigner$Builder
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: jdk.security.jarsigner.JarSigner$Builder
  super_class: java.lang.Object
{
  final java.security.PrivateKey privateKey;
    descriptor: Ljava/security/PrivateKey;
    flags: (0x0010) ACC_FINAL

  final java.security.cert.X509Certificate[] certChain;
    descriptor: [Ljava/security/cert/X509Certificate;
    flags: (0x0010) ACC_FINAL

  java.lang.String[] digestalg;
    descriptor: [Ljava/lang/String;
    flags: (0x0000) 

  java.lang.String sigalg;
    descriptor: Ljava/lang/String;
    flags: (0x0000) 

  java.security.Provider digestProvider;
    descriptor: Ljava/security/Provider;
    flags: (0x0000) 

  java.security.Provider sigProvider;
    descriptor: Ljava/security/Provider;
    flags: (0x0000) 

  java.net.URI tsaUrl;
    descriptor: Ljava/net/URI;
    flags: (0x0000) 

  java.lang.String signerName;
    descriptor: Ljava/lang/String;
    flags: (0x0000) 

  java.util.function.BiConsumer<java.lang.String, java.lang.String> handler;
    descriptor: Ljava/util/function/BiConsumer;
    flags: (0x0000) 
    Signature: Ljava/util/function/BiConsumer<Ljava/lang/String;Ljava/lang/String;>;

  java.lang.String tSAPolicyID;
    descriptor: Ljava/lang/String;
    flags: (0x0000) 

  java.lang.String tSADigestAlg;
    descriptor: Ljava/lang/String;
    flags: (0x0000) 

  boolean signManifest;
    descriptor: Z
    flags: (0x0000) 

  boolean externalSF;
    descriptor: Z
    flags: (0x0000) 

  java.lang.String altSignerPath;
    descriptor: Ljava/lang/String;
    flags: (0x0000) 

  java.lang.String altSigner;
    descriptor: Ljava/lang/String;
    flags: (0x0000) 

  public void <init>(java.security.KeyStore$PrivateKeyEntry);
    descriptor: (Ljava/security/KeyStore$PrivateKeyEntry;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // jdk.security.jarsigner.JarSigner$Builder this
        start local 1 // java.security.KeyStore$PrivateKeyEntry entry
         0: .line 121
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 110
            aload 0 /* this */
            iconst_1
            putfield jdk.security.jarsigner.JarSigner$Builder.signManifest:Z
         2: .line 111
            aload 0 /* this */
            iconst_1
            putfield jdk.security.jarsigner.JarSigner$Builder.externalSF:Z
         3: .line 122
            aload 0 /* this */
            aload 1 /* entry */
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getPrivateKey:()Ljava/security/PrivateKey;
            putfield jdk.security.jarsigner.JarSigner$Builder.privateKey:Ljava/security/PrivateKey;
         4: .line 125
            aload 1 /* entry */
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getCertificateChain:()[Ljava/security/cert/Certificate;
            astore 2 /* certs */
        start local 2 // java.security.cert.Certificate[] certs
         5: .line 126
            aload 0 /* this */
            aload 2 /* certs */
            aload 2 /* certs */
            arraylength
         6: .line 127
            ldc [Ljava/security/cert/X509Certificate;
         7: .line 126
            invokestatic java.util.Arrays.copyOf:([Ljava/lang/Object;ILjava/lang/Class;)[Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate[]
            putfield jdk.security.jarsigner.JarSigner$Builder.certChain:[Ljava/security/cert/X509Certificate;
        end local 2 // java.security.cert.Certificate[] certs
         8: .line 128
            goto 13
      StackMap locals: jdk.security.jarsigner.JarSigner$Builder java.security.KeyStore$PrivateKeyEntry
      StackMap stack: java.lang.ArrayStoreException
         9: pop
        10: .line 130
            new java.lang.IllegalArgumentException
            dup
        11: .line 131
            ldc "Entry does not contain X509Certificate"
        12: .line 130
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 133
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.security.KeyStore$PrivateKeyEntry entry
        end local 0 // jdk.security.jarsigner.JarSigner$Builder this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   14     0   this  Ljdk/security/jarsigner/JarSigner$Builder;
            0   14     1  entry  Ljava/security/KeyStore$PrivateKeyEntry;
            5    8     2  certs  [Ljava/security/cert/Certificate;
      Exception table:
        from    to  target  type
           4     8       9  Class java.lang.ArrayStoreException
    MethodParameters:
       Name  Flags
      entry  

  public void <init>(java.security.PrivateKey, java.security.cert.CertPath);
    descriptor: (Ljava/security/PrivateKey;Ljava/security/cert/CertPath;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // jdk.security.jarsigner.JarSigner$Builder this
        start local 1 // java.security.PrivateKey privateKey
        start local 2 // java.security.cert.CertPath certPath
         0: .line 146
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 110
            aload 0 /* this */
            iconst_1
            putfield jdk.security.jarsigner.JarSigner$Builder.signManifest:Z
         2: .line 111
            aload 0 /* this */
            iconst_1
            putfield jdk.security.jarsigner.JarSigner$Builder.externalSF:Z
         3: .line 147
            aload 2 /* certPath */
            invokevirtual java.security.cert.CertPath.getCertificates:()Ljava/util/List;
            astore 3 /* certs */
        start local 3 // java.util.List certs
         4: .line 148
            aload 3 /* certs */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 6
         5: .line 149
            new java.lang.IllegalArgumentException
            dup
            ldc "certPath cannot be empty"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 151
      StackMap locals: jdk.security.jarsigner.JarSigner$Builder java.security.PrivateKey java.security.cert.CertPath java.util.List
      StackMap stack:
            aload 1 /* privateKey */
            invokeinterface java.security.PrivateKey.getAlgorithm:()Ljava/lang/String;
         7: .line 152
            aload 3 /* certs */
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.security.cert.Certificate
            invokevirtual java.security.cert.Certificate.getPublicKey:()Ljava/security/PublicKey;
            invokeinterface java.security.PublicKey.getAlgorithm:()Ljava/lang/String;
         8: .line 151
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
         9: .line 152
            ifne 13
        10: .line 153
            new java.lang.IllegalArgumentException
            dup
        11: .line 154
            ldc "private key algorithm does not match algorithm of public key in end entity certificate (the 1st in certPath)"
        12: .line 153
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 158
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* privateKey */
            putfield jdk.security.jarsigner.JarSigner$Builder.privateKey:Ljava/security/PrivateKey;
        14: .line 160
            aload 0 /* this */
            aload 3 /* certs */
            aload 3 /* certs */
            invokeinterface java.util.List.size:()I
            anewarray java.security.cert.X509Certificate
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate[]
            putfield jdk.security.jarsigner.JarSigner$Builder.certChain:[Ljava/security/cert/X509Certificate;
        15: .line 161
            goto 20
      StackMap locals:
      StackMap stack: java.lang.ArrayStoreException
        16: pop
        17: .line 163
            new java.lang.IllegalArgumentException
            dup
        18: .line 164
            ldc "Entry does not contain X509Certificate"
        19: .line 163
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 166
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.util.List certs
        end local 2 // java.security.cert.CertPath certPath
        end local 1 // java.security.PrivateKey privateKey
        end local 0 // jdk.security.jarsigner.JarSigner$Builder this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   21     0        this  Ljdk/security/jarsigner/JarSigner$Builder;
            0   21     1  privateKey  Ljava/security/PrivateKey;
            0   21     2    certPath  Ljava/security/cert/CertPath;
            4   21     3       certs  Ljava/util/List<+Ljava/security/cert/Certificate;>;
      Exception table:
        from    to  target  type
          14    15      16  Class java.lang.ArrayStoreException
    MethodParameters:
            Name  Flags
      privateKey  
      certPath    

  public jdk.security.jarsigner.JarSigner$Builder digestAlgorithm(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljdk/security/jarsigner/JarSigner$Builder;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // jdk.security.jarsigner.JarSigner$Builder this
        start local 1 // java.lang.String algorithm
         0: .line 182
            aload 1 /* algorithm */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
            pop
         1: .line 183
            aload 0 /* this */
            iconst_1
            anewarray java.lang.String
            dup
            iconst_0
            aload 1 /* algorithm */
            aastore
            putfield jdk.security.jarsigner.JarSigner$Builder.digestalg:[Ljava/lang/String;
         2: .line 184
            aload 0 /* this */
            aconst_null
            putfield jdk.security.jarsigner.JarSigner$Builder.digestProvider:Ljava/security/Provider;
         3: .line 185
            aload 0 /* this */
            areturn
        end local 1 // java.lang.String algorithm
        end local 0 // jdk.security.jarsigner.JarSigner$Builder this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0       this  Ljdk/security/jarsigner/JarSigner$Builder;
            0    4     1  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  public jdk.security.jarsigner.JarSigner$Builder digestAlgorithm(java.lang.String, java.security.Provider);
    descriptor: (Ljava/lang/String;Ljava/security/Provider;)Ljdk/security/jarsigner/JarSigner$Builder;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // jdk.security.jarsigner.JarSigner$Builder this
        start local 1 // java.lang.String algorithm
        start local 2 // java.security.Provider provider
         0: .line 206
            aload 1 /* algorithm */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
         1: .line 207
            aload 2 /* provider */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.Provider
         2: .line 205
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/MessageDigest;
            pop
         3: .line 208
            aload 0 /* this */
            iconst_1
            anewarray java.lang.String
            dup
            iconst_0
            aload 1 /* algorithm */
            aastore
            putfield jdk.security.jarsigner.JarSigner$Builder.digestalg:[Ljava/lang/String;
         4: .line 209
            aload 0 /* this */
            aload 2 /* provider */
            putfield jdk.security.jarsigner.JarSigner$Builder.digestProvider:Ljava/security/Provider;
         5: .line 210
            aload 0 /* this */
            areturn
        end local 2 // java.security.Provider provider
        end local 1 // java.lang.String algorithm
        end local 0 // jdk.security.jarsigner.JarSigner$Builder this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Ljdk/security/jarsigner/JarSigner$Builder;
            0    6     1  algorithm  Ljava/lang/String;
            0    6     2   provider  Ljava/security/Provider;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  
      provider   

  public jdk.security.jarsigner.JarSigner$Builder signatureAlgorithm(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljdk/security/jarsigner/JarSigner$Builder;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // jdk.security.jarsigner.JarSigner$Builder this
        start local 1 // java.lang.String algorithm
         0: .line 232
            aload 1 /* algorithm */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;)Ljava/security/Signature;
            pop
         1: .line 234
            aload 0 /* this */
            getfield jdk.security.jarsigner.JarSigner$Builder.privateKey:Ljava/security/PrivateKey;
            invokeinterface java.security.PrivateKey.getAlgorithm:()Ljava/lang/String;
            aload 1 /* algorithm */
         2: .line 233
            invokestatic sun.security.x509.AlgorithmId.checkKeyAndSigAlgMatch:(Ljava/lang/String;Ljava/lang/String;)V
         3: .line 235
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield jdk.security.jarsigner.JarSigner$Builder.sigalg:Ljava/lang/String;
         4: .line 236
            aload 0 /* this */
            aconst_null
            putfield jdk.security.jarsigner.JarSigner$Builder.sigProvider:Ljava/security/Provider;
         5: .line 237
            aload 0 /* this */
            areturn
        end local 1 // java.lang.String algorithm
        end local 0 // jdk.security.jarsigner.JarSigner$Builder this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Ljdk/security/jarsigner/JarSigner$Builder;
            0    6     1  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  public jdk.security.jarsigner.JarSigner$Builder signatureAlgorithm(java.lang.String, java.security.Provider);
    descriptor: (Ljava/lang/String;Ljava/security/Provider;)Ljdk/security/jarsigner/JarSigner$Builder;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // jdk.security.jarsigner.JarSigner$Builder this
        start local 1 // java.lang.String algorithm
        start local 2 // java.security.Provider provider
         0: .line 262
            aload 1 /* algorithm */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
         1: .line 263
            aload 2 /* provider */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.Provider
         2: .line 261
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/Signature;
            pop
         3: .line 265
            aload 0 /* this */
            getfield jdk.security.jarsigner.JarSigner$Builder.privateKey:Ljava/security/PrivateKey;
            invokeinterface java.security.PrivateKey.getAlgorithm:()Ljava/lang/String;
            aload 1 /* algorithm */
         4: .line 264
            invokestatic sun.security.x509.AlgorithmId.checkKeyAndSigAlgMatch:(Ljava/lang/String;Ljava/lang/String;)V
         5: .line 266
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield jdk.security.jarsigner.JarSigner$Builder.sigalg:Ljava/lang/String;
         6: .line 267
            aload 0 /* this */
            aload 2 /* provider */
            putfield jdk.security.jarsigner.JarSigner$Builder.sigProvider:Ljava/security/Provider;
         7: .line 268
            aload 0 /* this */
            areturn
        end local 2 // java.security.Provider provider
        end local 1 // java.lang.String algorithm
        end local 0 // jdk.security.jarsigner.JarSigner$Builder this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    8     0       this  Ljdk/security/jarsigner/JarSigner$Builder;
            0    8     1  algorithm  Ljava/lang/String;
            0    8     2   provider  Ljava/security/Provider;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  
      provider   

  public jdk.security.jarsigner.JarSigner$Builder tsa(java.net.URI);
    descriptor: (Ljava/net/URI;)Ljdk/security/jarsigner/JarSigner$Builder;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // jdk.security.jarsigner.JarSigner$Builder this
        start local 1 // java.net.URI uri
         0: .line 278
            aload 0 /* this */
            aload 1 /* uri */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.net.URI
            putfield jdk.security.jarsigner.JarSigner$Builder.tsaUrl:Ljava/net/URI;
         1: .line 279
            aload 0 /* this */
            areturn
        end local 1 // java.net.URI uri
        end local 0 // jdk.security.jarsigner.JarSigner$Builder this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljdk/security/jarsigner/JarSigner$Builder;
            0    2     1   uri  Ljava/net/URI;
    MethodParameters:
      Name  Flags
      uri   

  public jdk.security.jarsigner.JarSigner$Builder signerName(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljdk/security/jarsigner/JarSigner$Builder;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // jdk.security.jarsigner.JarSigner$Builder this
        start local 1 // java.lang.String name
         0: .line 295
            aload 1 /* name */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 1
            aload 1 /* name */
            invokevirtual java.lang.String.length:()I
            bipush 8
            if_icmple 2
         1: .line 296
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            ldc "Name too long"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 299
      StackMap locals:
      StackMap stack:
            aload 1 /* name */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toUpperCase:(Ljava/util/Locale;)Ljava/lang/String;
            astore 1 /* name */
         3: .line 301
            iconst_0
            istore 2 /* j */
        start local 2 // int j
         4: goto 14
         5: .line 302
      StackMap locals: int
      StackMap stack:
            aload 1 /* name */
            iload 2 /* j */
            invokevirtual java.lang.String.charAt:(I)C
            istore 3 /* c */
        start local 3 // char c
         6: .line 304
            iload 3 /* c */
            bipush 65
            if_icmplt 7
            iload 3 /* c */
            bipush 90
            if_icmple 13
         7: .line 305
      StackMap locals: int
      StackMap stack:
            iload 3 /* c */
            bipush 48
            if_icmplt 8
            iload 3 /* c */
            bipush 57
            if_icmple 13
         8: .line 306
      StackMap locals:
      StackMap stack:
            iload 3 /* c */
            bipush 45
            if_icmpeq 13
         9: .line 307
            iload 3 /* c */
            bipush 95
            if_icmpeq 13
        10: .line 308
            new java.lang.IllegalArgumentException
            dup
        11: .line 309
            ldc "Invalid characters in name"
        12: .line 308
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // char c
        13: .line 301
      StackMap locals:
      StackMap stack:
            iinc 2 /* j */ 1
      StackMap locals:
      StackMap stack:
        14: iload 2 /* j */
            aload 1 /* name */
            invokevirtual java.lang.String.length:()I
            if_icmplt 5
        end local 2 // int j
        15: .line 312
            aload 0 /* this */
            aload 1 /* name */
            putfield jdk.security.jarsigner.JarSigner$Builder.signerName:Ljava/lang/String;
        16: .line 313
            aload 0 /* this */
            areturn
        end local 1 // java.lang.String name
        end local 0 // jdk.security.jarsigner.JarSigner$Builder this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   17     0  this  Ljdk/security/jarsigner/JarSigner$Builder;
            0   17     1  name  Ljava/lang/String;
            4   15     2     j  I
            6   13     3     c  C
    MethodParameters:
      Name  Flags
      name  

  public jdk.security.jarsigner.JarSigner$Builder eventHandler(java.util.function.BiConsumer<java.lang.String, java.lang.String>);
    descriptor: (Ljava/util/function/BiConsumer;)Ljdk/security/jarsigner/JarSigner$Builder;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // jdk.security.jarsigner.JarSigner$Builder this
        start local 1 // java.util.function.BiConsumer handler
         0: .line 329
            aload 0 /* this */
            aload 1 /* handler */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.function.BiConsumer
            putfield jdk.security.jarsigner.JarSigner$Builder.handler:Ljava/util/function/BiConsumer;
         1: .line 330
            aload 0 /* this */
            areturn
        end local 1 // java.util.function.BiConsumer handler
        end local 0 // jdk.security.jarsigner.JarSigner$Builder this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Ljdk/security/jarsigner/JarSigner$Builder;
            0    2     1  handler  Ljava/util/function/BiConsumer<Ljava/lang/String;Ljava/lang/String;>;
    Signature: (Ljava/util/function/BiConsumer<Ljava/lang/String;Ljava/lang/String;>;)Ljdk/security/jarsigner/JarSigner$Builder;
    MethodParameters:
         Name  Flags
      handler  

  public jdk.security.jarsigner.JarSigner$Builder setProperty(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)Ljdk/security/jarsigner/JarSigner$Builder;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=3
        start local 0 // jdk.security.jarsigner.JarSigner$Builder this
        start local 1 // java.lang.String key
        start local 2 // java.lang.String value
         0: .line 361
            aload 1 /* key */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 362
            aload 2 /* value */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 363
            aload 1 /* key */
            getstatic java.util.Locale.US:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            dup
            astore 3
            invokevirtual java.lang.String.hashCode:()I
            lookupswitch { // 6
          -2094658161: 3
          -1591141936: 4
          -1015724525: 5
           -593336136: 6
            668841690: 7
           1890315734: 8
              default: 43
          }
      StackMap locals: java.lang.String
      StackMap stack:
         3: aload 3
            ldc "tsapolicyid"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 17
            goto 43
      StackMap locals:
      StackMap stack:
         4: aload 3
            ldc "internalsf"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 19
            goto 43
      StackMap locals:
      StackMap stack:
         5: aload 3
            ldc "altsigner"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 41
            goto 43
      StackMap locals:
      StackMap stack:
         6: aload 3
            ldc "altsignerpath"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 39
            goto 43
      StackMap locals:
      StackMap stack:
         7: aload 3
            ldc "sectionsonly"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 29
            goto 43
      StackMap locals:
      StackMap stack:
         8: aload 3
            ldc "tsadigestalg"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 9
            goto 43
         9: .line 366
      StackMap locals:
      StackMap stack:
            aload 2 /* value */
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
            pop
        10: .line 367
            goto 15
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
        11: astore 4 /* nsae */
        start local 4 // java.security.NoSuchAlgorithmException nsae
        12: .line 368
            new java.lang.IllegalArgumentException
            dup
        13: .line 369
            ldc "Invalid tsadigestalg"
            aload 4 /* nsae */
        14: .line 368
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.security.NoSuchAlgorithmException nsae
        15: .line 371
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* value */
            putfield jdk.security.jarsigner.JarSigner$Builder.tSADigestAlg:Ljava/lang/String;
        16: .line 372
            goto 46
        17: .line 374
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* value */
            putfield jdk.security.jarsigner.JarSigner$Builder.tSAPolicyID:Ljava/lang/String;
        18: .line 375
            goto 46
        19: .line 377
      StackMap locals:
      StackMap stack:
            aload 2 /* value */
            dup
            astore 4
            invokevirtual java.lang.String.hashCode:()I
            lookupswitch { // 2
              3569038: 20
             97196323: 21
              default: 26
          }
      StackMap locals: java.lang.String
      StackMap stack:
        20: aload 4
            ldc "true"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 22
            goto 26
      StackMap locals:
      StackMap stack:
        21: aload 4
            ldc "false"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 24
            goto 26
        22: .line 379
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield jdk.security.jarsigner.JarSigner$Builder.externalSF:Z
        23: .line 380
            goto 46
        24: .line 382
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield jdk.security.jarsigner.JarSigner$Builder.externalSF:Z
        25: .line 383
            goto 46
        26: .line 385
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
        27: .line 386
            ldc "Invalid internalsf value"
        28: .line 385
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        29: .line 390
      StackMap locals:
      StackMap stack:
            aload 2 /* value */
            dup
            astore 5
            invokevirtual java.lang.String.hashCode:()I
            lookupswitch { // 2
              3569038: 30
             97196323: 31
              default: 36
          }
      StackMap locals: jdk.security.jarsigner.JarSigner$Builder java.lang.String java.lang.String java.lang.String top java.lang.String
      StackMap stack:
        30: aload 5
            ldc "true"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 32
            goto 36
      StackMap locals:
      StackMap stack:
        31: aload 5
            ldc "false"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 34
            goto 36
        32: .line 392
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield jdk.security.jarsigner.JarSigner$Builder.signManifest:Z
        33: .line 393
            goto 46
        34: .line 395
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield jdk.security.jarsigner.JarSigner$Builder.signManifest:Z
        35: .line 396
            goto 46
        36: .line 398
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
        37: .line 399
            ldc "Invalid signManifest value"
        38: .line 398
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        39: .line 403
      StackMap locals: jdk.security.jarsigner.JarSigner$Builder java.lang.String java.lang.String java.lang.String
      StackMap stack:
            aload 0 /* this */
            aload 2 /* value */
            putfield jdk.security.jarsigner.JarSigner$Builder.altSignerPath:Ljava/lang/String;
        40: .line 404
            goto 46
        41: .line 406
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* value */
            putfield jdk.security.jarsigner.JarSigner$Builder.altSigner:Ljava/lang/String;
        42: .line 407
            goto 46
        43: .line 409
      StackMap locals:
      StackMap stack:
            new java.lang.UnsupportedOperationException
            dup
        44: .line 410
            new java.lang.StringBuilder
            dup
            ldc "Unsupported key "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* key */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        45: .line 409
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        46: .line 412
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            areturn
        end local 2 // java.lang.String value
        end local 1 // java.lang.String key
        end local 0 // jdk.security.jarsigner.JarSigner$Builder this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   47     0   this  Ljdk/security/jarsigner/JarSigner$Builder;
            0   47     1    key  Ljava/lang/String;
            0   47     2  value  Ljava/lang/String;
           12   15     4   nsae  Ljava/security/NoSuchAlgorithmException;
      Exception table:
        from    to  target  type
           9    10      11  Class java.security.NoSuchAlgorithmException
    MethodParameters:
       Name  Flags
      key    
      value  

  public static java.lang.String getDefaultDigestAlgorithm();
    descriptor: ()Ljava/lang/String;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 424
            ldc "SHA-256"
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static java.lang.String getDefaultSignatureAlgorithm(java.security.PrivateKey);
    descriptor: (Ljava/security/PrivateKey;)Ljava/lang/String;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.PrivateKey key
         0: .line 450
            aload 0 /* key */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.PrivateKey
            invokestatic sun.security.x509.AlgorithmId.getDefaultSigAlgForKey:(Ljava/security/PrivateKey;)Ljava/lang/String;
            areturn
        end local 0 // java.security.PrivateKey key
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0   key  Ljava/security/PrivateKey;
    MethodParameters:
      Name  Flags
      key   

  public jdk.security.jarsigner.JarSigner build();
    descriptor: ()Ljdk/security/jarsigner/JarSigner;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // jdk.security.jarsigner.JarSigner$Builder this
         0: .line 469
            new jdk.security.jarsigner.JarSigner
            dup
            aload 0 /* this */
            invokespecial jdk.security.jarsigner.JarSigner.<init>:(Ljdk/security/jarsigner/JarSigner$Builder;)V
            areturn
        end local 0 // jdk.security.jarsigner.JarSigner$Builder this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljdk/security/jarsigner/JarSigner$Builder;
}
SourceFile: "JarSigner.java"
NestHost: jdk.security.jarsigner.JarSigner
InnerClasses:
  public final PrivateKeyEntry = java.security.KeyStore$PrivateKeyEntry of java.security.KeyStore
  public Builder = jdk.security.jarsigner.JarSigner$Builder of jdk.security.jarsigner.JarSigner