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 sectionsonly;
    descriptor: Z
    flags: (0x0000) 

  boolean internalsf;
    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 133
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 122
            aload 0 /* this */
            iconst_0
            putfield jdk.security.jarsigner.JarSigner$Builder.sectionsonly:Z
         2: .line 123
            aload 0 /* this */
            iconst_0
            putfield jdk.security.jarsigner.JarSigner$Builder.internalsf:Z
         3: .line 134
            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 137
            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 138
            aload 0 /* this */
            aload 2 /* certs */
            aload 2 /* certs */
            arraylength
         6: .line 139
            ldc [Ljava/security/cert/X509Certificate;
         7: .line 138
            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 140
            goto 13
      StackMap locals: jdk.security.jarsigner.JarSigner$Builder java.security.KeyStore$PrivateKeyEntry
      StackMap stack: java.lang.ArrayStoreException
         9: pop
        10: .line 142
            new java.lang.IllegalArgumentException
            dup
        11: .line 143
            ldc "Entry does not contain X509Certificate"
        12: .line 142
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 145
      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 158
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 122
            aload 0 /* this */
            iconst_0
            putfield jdk.security.jarsigner.JarSigner$Builder.sectionsonly:Z
         2: .line 123
            aload 0 /* this */
            iconst_0
            putfield jdk.security.jarsigner.JarSigner$Builder.internalsf:Z
         3: .line 159
            aload 2 /* certPath */
            invokevirtual java.security.cert.CertPath.getCertificates:()Ljava/util/List;
            astore 3 /* certs */
        start local 3 // java.util.List certs
         4: .line 160
            aload 3 /* certs */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 6
         5: .line 161
            new java.lang.IllegalArgumentException
            dup
            ldc "certPath cannot be empty"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 163
      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 164
            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 163
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
         9: .line 164
            ifne 13
        10: .line 165
            new java.lang.IllegalArgumentException
            dup
        11: .line 166
            ldc "private key algorithm does not match algorithm of public key in end entity certificate (the 1st in certPath)"
        12: .line 165
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 170
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* privateKey */
            putfield jdk.security.jarsigner.JarSigner$Builder.privateKey:Ljava/security/PrivateKey;
        14: .line 172
            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 173
            goto 20
      StackMap locals:
      StackMap stack: java.lang.ArrayStoreException
        16: pop
        17: .line 175
            new java.lang.IllegalArgumentException
            dup
        18: .line 176
            ldc "Entry does not contain X509Certificate"
        19: .line 175
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 178
      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 194
            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 195
            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 196
            aload 0 /* this */
            aconst_null
            putfield jdk.security.jarsigner.JarSigner$Builder.digestProvider:Ljava/security/Provider;
         3: .line 197
            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 218
            aload 1 /* algorithm */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
         1: .line 219
            aload 2 /* provider */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.Provider
         2: .line 217
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/MessageDigest;
            pop
         3: .line 220
            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 221
            aload 0 /* this */
            aload 2 /* provider */
            putfield jdk.security.jarsigner.JarSigner$Builder.digestProvider:Ljava/security/Provider;
         5: .line 222
            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 244
            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 245
            aload 0 /* this */
            getfield jdk.security.jarsigner.JarSigner$Builder.privateKey:Ljava/security/PrivateKey;
            aload 1 /* algorithm */
            invokestatic sun.security.util.SignatureUtil.checkKeyAndSigAlgMatch:(Ljava/security/PrivateKey;Ljava/lang/String;)V
         2: .line 246
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield jdk.security.jarsigner.JarSigner$Builder.sigalg:Ljava/lang/String;
         3: .line 247
            aload 0 /* this */
            aconst_null
            putfield jdk.security.jarsigner.JarSigner$Builder.sigProvider:Ljava/security/Provider;
         4: .line 248
            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    5     0       this  Ljdk/security/jarsigner/JarSigner$Builder;
            0    5     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 273
            aload 1 /* algorithm */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
         1: .line 274
            aload 2 /* provider */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.Provider
         2: .line 272
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/Signature;
            pop
         3: .line 275
            aload 0 /* this */
            getfield jdk.security.jarsigner.JarSigner$Builder.privateKey:Ljava/security/PrivateKey;
            aload 1 /* algorithm */
            invokestatic sun.security.util.SignatureUtil.checkKeyAndSigAlgMatch:(Ljava/security/PrivateKey;Ljava/lang/String;)V
         4: .line 276
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield jdk.security.jarsigner.JarSigner$Builder.sigalg:Ljava/lang/String;
         5: .line 277
            aload 0 /* this */
            aload 2 /* provider */
            putfield jdk.security.jarsigner.JarSigner$Builder.sigProvider:Ljava/security/Provider;
         6: .line 278
            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    7     0       this  Ljdk/security/jarsigner/JarSigner$Builder;
            0    7     1  algorithm  Ljava/lang/String;
            0    7     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 288
            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 289
            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 305
            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 306
      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 309
      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 311
            iconst_0
            istore 2 /* j */
        start local 2 // int j
         4: goto 14
         5: .line 312
      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 314
            iload 3 /* c */
            bipush 65
            if_icmplt 7
            iload 3 /* c */
            bipush 90
            if_icmple 13
         7: .line 315
      StackMap locals: int
      StackMap stack:
            iload 3 /* c */
            bipush 48
            if_icmplt 8
            iload 3 /* c */
            bipush 57
            if_icmple 13
         8: .line 316
      StackMap locals:
      StackMap stack:
            iload 3 /* c */
            bipush 45
            if_icmpeq 13
         9: .line 317
            iload 3 /* c */
            bipush 95
            if_icmpeq 13
        10: .line 318
            new java.lang.IllegalArgumentException
            dup
        11: .line 319
            ldc "Invalid characters in name"
        12: .line 318
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // char c
        13: .line 311
      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 322
            aload 0 /* this */
            aload 1 /* name */
            putfield jdk.security.jarsigner.JarSigner$Builder.signerName:Ljava/lang/String;
        16: .line 323
            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 339
            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 340
            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=5, 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 371
            aload 1 /* key */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 372
            aload 2 /* value */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 373
            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: 27
          }
      StackMap locals: java.lang.String
      StackMap stack:
         3: aload 3
            ldc "tsapolicyid"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 17
            goto 27
      StackMap locals:
      StackMap stack:
         4: aload 3
            ldc "internalsf"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 19
            goto 27
      StackMap locals:
      StackMap stack:
         5: aload 3
            ldc "altsigner"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 25
            goto 27
      StackMap locals:
      StackMap stack:
         6: aload 3
            ldc "altsignerpath"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 23
            goto 27
      StackMap locals:
      StackMap stack:
         7: aload 3
            ldc "sectionsonly"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 21
            goto 27
      StackMap locals:
      StackMap stack:
         8: aload 3
            ldc "tsadigestalg"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 9
            goto 27
         9: .line 376
      StackMap locals:
      StackMap stack:
            aload 2 /* value */
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
            pop
        10: .line 377
            goto 15
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
        11: astore 4 /* nsae */
        start local 4 // java.security.NoSuchAlgorithmException nsae
        12: .line 378
            new java.lang.IllegalArgumentException
            dup
        13: .line 379
            ldc "Invalid tsadigestalg"
            aload 4 /* nsae */
        14: .line 378
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.security.NoSuchAlgorithmException nsae
        15: .line 381
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* value */
            putfield jdk.security.jarsigner.JarSigner$Builder.tSADigestAlg:Ljava/lang/String;
        16: .line 382
            goto 30
        17: .line 384
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* value */
            putfield jdk.security.jarsigner.JarSigner$Builder.tSAPolicyID:Ljava/lang/String;
        18: .line 385
            goto 30
        19: .line 387
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "interalsf"
            aload 2 /* value */
            invokestatic jdk.security.jarsigner.JarSigner$Builder.parseBoolean:(Ljava/lang/String;Ljava/lang/String;)Z
            putfield jdk.security.jarsigner.JarSigner$Builder.internalsf:Z
        20: .line 388
            goto 30
        21: .line 390
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "sectionsonly"
            aload 2 /* value */
            invokestatic jdk.security.jarsigner.JarSigner$Builder.parseBoolean:(Ljava/lang/String;Ljava/lang/String;)Z
            putfield jdk.security.jarsigner.JarSigner$Builder.sectionsonly:Z
        22: .line 391
            goto 30
        23: .line 393
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* value */
            putfield jdk.security.jarsigner.JarSigner$Builder.altSignerPath:Ljava/lang/String;
        24: .line 394
            goto 30
        25: .line 396
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* value */
            putfield jdk.security.jarsigner.JarSigner$Builder.altSigner:Ljava/lang/String;
        26: .line 397
            goto 30
        27: .line 399
      StackMap locals:
      StackMap stack:
            new java.lang.UnsupportedOperationException
            dup
        28: .line 400
            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;
        29: .line 399
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        30: .line 402
      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   31     0   this  Ljdk/security/jarsigner/JarSigner$Builder;
            0   31     1    key  Ljava/lang/String;
            0   31     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  

  private static boolean parseBoolean(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // java.lang.String name
        start local 1 // java.lang.String value
         0: .line 406
            aload 1 /* value */
            dup
            astore 2
            invokevirtual java.lang.String.hashCode:()I
            lookupswitch { // 2
              3569038: 1
             97196323: 2
              default: 5
          }
      StackMap locals: java.lang.String
      StackMap stack:
         1: aload 2
            ldc "true"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 3
            goto 5
      StackMap locals:
      StackMap stack:
         2: aload 2
            ldc "false"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 4
            goto 5
         3: .line 408
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
         4: .line 410
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
         5: .line 412
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
         6: .line 413
            new java.lang.StringBuilder
            dup
            ldc "Invalid "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* name */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " value"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         7: .line 412
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.lang.String value
        end local 0 // java.lang.String name
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    8     0   name  Ljava/lang/String;
            0    8     1  value  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      name   
      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 426
            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 454
            aload 0 /* key */
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.PrivateKey
            invokestatic sun.security.util.SignatureUtil.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 473
            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