public class com.sun.security.auth.PolicyFile extends javax.security.auth.Policy
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: com.sun.security.auth.PolicyFile
  super_class: javax.security.auth.Policy
{
  static final java.util.ResourceBundle rb;
    descriptor: Ljava/util/ResourceBundle;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  private static final sun.security.util.Debug debug;
    descriptor: Lsun/security/util/Debug;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String AUTH_POLICY;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "java.security.auth.policy"

  private static final java.lang.String SECURITY_MANAGER;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "java.security.manager"

  private static final java.lang.String AUTH_POLICY_URL;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "auth.policy.url."

  private java.util.Vector<com.sun.security.auth.PolicyFile$PolicyEntry> policyEntries;
    descriptor: Ljava/util/Vector;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Vector<Lcom/sun/security/auth/PolicyFile$PolicyEntry;>;

  private java.util.Hashtable<java.lang.Object, java.lang.Object> aliasMapping;
    descriptor: Ljava/util/Hashtable;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Hashtable<Ljava/lang/Object;Ljava/lang/Object;>;

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

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

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

  private static final java.lang.Class[] PARAMS;
    descriptor: [Ljava/lang/Class;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 244
            new com.sun.security.auth.PolicyFile$1
            dup
            invokespecial com.sun.security.auth.PolicyFile$1.<init>:()V
         1: .line 243
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.util.ResourceBundle
         2: .line 242
            putstatic com.sun.security.auth.PolicyFile.rb:Ljava/util/ResourceBundle;
         3: .line 253
            ldc "policy"
            ldc "\t[Auth Policy]"
            invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;Ljava/lang/String;)Lsun/security/util/Debug;
         4: .line 252
            putstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
         5: .line 269
            iconst_2
            anewarray java.lang.Class
            dup
            iconst_0
            ldc Ljava/lang/String;
            aastore
            dup
            iconst_1
            ldc Ljava/lang/String;
            aastore
            putstatic com.sun.security.auth.PolicyFile.PARAMS:[Ljava/lang/Class;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // com.sun.security.auth.PolicyFile this
         0: .line 275
            aload 0 /* this */
            invokespecial javax.security.auth.Policy.<init>:()V
         1: .line 262
            aload 0 /* this */
            iconst_0
            putfield com.sun.security.auth.PolicyFile.initialized:Z
         2: .line 264
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.auth.PolicyFile.expandProperties:Z
         3: .line 265
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.auth.PolicyFile.ignoreIdentityScope:Z
         4: .line 278
            ldc "java.security.auth.policy"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* prop */
        start local 1 // java.lang.String prop
         5: .line 280
            aload 1 /* prop */
            ifnonnull 7
         6: .line 281
            ldc "java.security.manager"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* prop */
         7: .line 283
      StackMap locals: com.sun.security.auth.PolicyFile java.lang.String
      StackMap stack:
            aload 1 /* prop */
            ifnull 9
         8: .line 284
            aload 0 /* this */
            invokevirtual com.sun.security.auth.PolicyFile.init:()V
         9: .line 285
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String prop
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lcom/sun/security/auth/PolicyFile;
            5   10     1  prop  Ljava/lang/String;

  private synchronized void init();
    descriptor: ()V
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // com.sun.security.auth.PolicyFile this
         0: .line 289
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.initialized:Z
            ifeq 2
         1: .line 290
            return
         2: .line 292
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new java.util.Vector
            dup
            invokespecial java.util.Vector.<init>:()V
            putfield com.sun.security.auth.PolicyFile.policyEntries:Ljava/util/Vector;
         3: .line 293
            aload 0 /* this */
            new java.util.Hashtable
            dup
            bipush 11
            invokespecial java.util.Hashtable.<init>:(I)V
            putfield com.sun.security.auth.PolicyFile.aliasMapping:Ljava/util/Hashtable;
         4: .line 295
            aload 0 /* this */
            invokevirtual com.sun.security.auth.PolicyFile.initPolicyFile:()V
         5: .line 296
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.auth.PolicyFile.initialized:Z
         6: .line 297
            return
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lcom/sun/security/auth/PolicyFile;

  public synchronized void refresh();
    descriptor: ()V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // com.sun.security.auth.PolicyFile this
         0: .line 310
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 1 /* sm */
        start local 1 // java.lang.SecurityManager sm
         1: .line 311
            aload 1 /* sm */
            ifnull 5
         2: .line 312
            aload 1 /* sm */
            new javax.security.auth.AuthPermission
            dup
         3: .line 313
            ldc "refreshPolicy"
            invokespecial javax.security.auth.AuthPermission.<init>:(Ljava/lang/String;)V
         4: .line 312
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         5: .line 327
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield com.sun.security.auth.PolicyFile.initialized:Z
         6: .line 329
            new com.sun.security.auth.PolicyFile$2
            dup
            aload 0 /* this */
            invokespecial com.sun.security.auth.PolicyFile$2.<init>:(Lcom/sun/security/auth/PolicyFile;)V
         7: .line 328
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            pop
         8: .line 335
            return
        end local 1 // java.lang.SecurityManager sm
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lcom/sun/security/auth/PolicyFile;
            1    9     1    sm  Ljava/lang/SecurityManager;

  private java.security.KeyStore initKeyStore(java.net.URL, java.lang.String, java.lang.String);
    descriptor: (Ljava/net/URL;Ljava/lang/String;Ljava/lang/String;)Ljava/security/KeyStore;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=7, args_size=4
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // java.net.URL policyUrl
        start local 2 // java.lang.String keyStoreName
        start local 3 // java.lang.String keyStoreType
         0: .line 339
            aload 2 /* keyStoreName */
            ifnull 22
         1: .line 345
            aconst_null
            astore 4 /* keyStoreUrl */
        start local 4 // java.net.URL keyStoreUrl
         2: .line 347
            new java.net.URL
            dup
            aload 2 /* keyStoreName */
            invokespecial java.net.URL.<init>:(Ljava/lang/String;)V
            astore 4 /* keyStoreUrl */
         3: .line 349
            goto 6
      StackMap locals: com.sun.security.auth.PolicyFile java.net.URL java.lang.String java.lang.String java.net.URL
      StackMap stack: java.net.MalformedURLException
         4: pop
         5: .line 351
            new java.net.URL
            dup
            aload 1 /* policyUrl */
            aload 2 /* keyStoreName */
            invokespecial java.net.URL.<init>:(Ljava/net/URL;Ljava/lang/String;)V
            astore 4 /* keyStoreUrl */
         6: .line 354
      StackMap locals:
      StackMap stack:
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 8
         7: .line 355
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "reading keystore"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* keyStoreUrl */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         8: .line 359
      StackMap locals:
      StackMap stack:
            new java.io.BufferedInputStream
            dup
            aload 0 /* this */
            aload 4 /* keyStoreUrl */
            invokevirtual com.sun.security.auth.PolicyFile.getInputStream:(Ljava/net/URL;)Ljava/io/InputStream;
            invokespecial java.io.BufferedInputStream.<init>:(Ljava/io/InputStream;)V
         9: .line 358
            astore 5 /* inStream */
        start local 5 // java.io.InputStream inStream
        10: .line 362
            aload 3 /* keyStoreType */
            ifnull 13
        11: .line 363
            aload 3 /* keyStoreType */
            invokestatic java.security.KeyStore.getInstance:(Ljava/lang/String;)Ljava/security/KeyStore;
            astore 6 /* ks */
        start local 6 // java.security.KeyStore ks
        12: goto 14
        end local 6 // java.security.KeyStore ks
        13: .line 365
      StackMap locals: java.io.InputStream
      StackMap stack:
            invokestatic java.security.KeyStore.getDefaultType:()Ljava/lang/String;
            invokestatic java.security.KeyStore.getInstance:(Ljava/lang/String;)Ljava/security/KeyStore;
            astore 6 /* ks */
        start local 6 // java.security.KeyStore ks
        14: .line 366
      StackMap locals: java.security.KeyStore
      StackMap stack:
            aload 6 /* ks */
            aload 5 /* inStream */
            aconst_null
            invokevirtual java.security.KeyStore.load:(Ljava/io/InputStream;[C)V
        15: .line 367
            aload 5 /* inStream */
            invokevirtual java.io.InputStream.close:()V
        16: .line 368
            aload 6 /* ks */
        17: areturn
        end local 6 // java.security.KeyStore ks
        end local 5 // java.io.InputStream inStream
        end local 4 // java.net.URL keyStoreUrl
        18: .line 369
      StackMap locals: com.sun.security.auth.PolicyFile java.net.URL java.lang.String java.lang.String
      StackMap stack: java.lang.Exception
            astore 4 /* e */
        start local 4 // java.lang.Exception e
        19: .line 371
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 21
        20: .line 372
            aload 4 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        21: .line 374
      StackMap locals: java.lang.Exception
      StackMap stack:
            aconst_null
            areturn
        end local 4 // java.lang.Exception e
        22: .line 377
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 3 // java.lang.String keyStoreType
        end local 2 // java.lang.String keyStoreName
        end local 1 // java.net.URL policyUrl
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   23     0          this  Lcom/sun/security/auth/PolicyFile;
            0   23     1     policyUrl  Ljava/net/URL;
            0   23     2  keyStoreName  Ljava/lang/String;
            0   23     3  keyStoreType  Ljava/lang/String;
            2   18     4   keyStoreUrl  Ljava/net/URL;
           10   18     5      inStream  Ljava/io/InputStream;
           12   13     6            ks  Ljava/security/KeyStore;
           14   18     6            ks  Ljava/security/KeyStore;
           19   22     4             e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2     3       4  Class java.net.MalformedURLException
           1    17      18  Class java.lang.Exception
    MethodParameters:
              Name  Flags
      policyUrl     
      keyStoreName  
      keyStoreType  

  private void initPolicyFile();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=8, args_size=1
        start local 0 // com.sun.security.auth.PolicyFile this
         0: .line 382
            ldc "policy.expandProperties"
            invokestatic java.security.Security.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* prop */
        start local 1 // java.lang.String prop
         1: .line 384
            aload 1 /* prop */
            ifnull 2
            aload 0 /* this */
            aload 1 /* prop */
            ldc "true"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            putfield com.sun.security.auth.PolicyFile.expandProperties:Z
         2: .line 386
      StackMap locals: java.lang.String
      StackMap stack:
            ldc "policy.ignoreIdentityScope"
            invokestatic java.security.Security.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 2 /* iscp */
        start local 2 // java.lang.String iscp
         3: .line 388
            aload 2 /* iscp */
            ifnull 4
            aload 0 /* this */
            aload 2 /* iscp */
            ldc "true"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            putfield com.sun.security.auth.PolicyFile.ignoreIdentityScope:Z
         4: .line 390
      StackMap locals: java.lang.String
      StackMap stack:
            ldc "policy.allowSystemProperty"
            invokestatic java.security.Security.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 3 /* allowSys */
        start local 3 // java.lang.String allowSys
         5: .line 392
            aload 3 /* allowSys */
            ifnull 30
            aload 3 /* allowSys */
            ldc "true"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 30
         6: .line 394
            ldc "java.security.auth.policy"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 4 /* extra_policy */
        start local 4 // java.lang.String extra_policy
         7: .line 395
            aload 4 /* extra_policy */
            ifnull 30
         8: .line 396
            iconst_0
            istore 5 /* overrideAll */
        start local 5 // boolean overrideAll
         9: .line 397
            aload 4 /* extra_policy */
            ldc "="
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 12
        10: .line 398
            iconst_1
            istore 5 /* overrideAll */
        11: .line 399
            aload 4 /* extra_policy */
            iconst_1
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 4 /* extra_policy */
        12: .line 402
      StackMap locals: java.lang.String java.lang.String int
      StackMap stack:
            aload 4 /* extra_policy */
            invokestatic sun.security.util.PropertyExpander.expand:(Ljava/lang/String;)Ljava/lang/String;
            astore 4 /* extra_policy */
        13: .line 404
            new java.io.File
            dup
            aload 4 /* extra_policy */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 7 /* policyFile */
        start local 7 // java.io.File policyFile
        14: .line 405
            aload 7 /* policyFile */
            invokevirtual java.io.File.exists:()Z
            ifeq 18
        15: .line 407
            new java.net.URL
            dup
            new java.lang.StringBuilder
            dup
            ldc "file:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* policyFile */
            invokevirtual java.io.File.getCanonicalPath:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.net.URL.<init>:(Ljava/lang/String;)V
        16: .line 406
            astore 6 /* policyURL */
        start local 6 // java.net.URL policyURL
        17: .line 408
            goto 19
        end local 6 // java.net.URL policyURL
        18: .line 409
      StackMap locals: com.sun.security.auth.PolicyFile java.lang.String java.lang.String java.lang.String java.lang.String int top java.io.File
      StackMap stack:
            new java.net.URL
            dup
            aload 4 /* extra_policy */
            invokespecial java.net.URL.<init>:(Ljava/lang/String;)V
            astore 6 /* policyURL */
        start local 6 // java.net.URL policyURL
        19: .line 411
      StackMap locals: com.sun.security.auth.PolicyFile java.lang.String java.lang.String java.lang.String java.lang.String int java.net.URL java.io.File
      StackMap stack:
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 21
        20: .line 412
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "reading "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* policyURL */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        21: .line 413
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 6 /* policyURL */
            invokevirtual com.sun.security.auth.PolicyFile.init:(Ljava/net/URL;)V
        end local 7 // java.io.File policyFile
        end local 6 // java.net.URL policyURL
        22: .line 414
            goto 26
      StackMap locals: com.sun.security.auth.PolicyFile java.lang.String java.lang.String java.lang.String java.lang.String int
      StackMap stack: java.lang.Exception
        23: astore 6 /* e */
        start local 6 // java.lang.Exception e
        24: .line 416
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 26
        25: .line 417
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "caught exception: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 6 // java.lang.Exception e
        26: .line 421
      StackMap locals:
      StackMap stack:
            iload 5 /* overrideAll */
            ifeq 30
        27: .line 422
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 29
        28: .line 423
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ldc "overriding other policies!"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        29: .line 425
      StackMap locals:
      StackMap stack:
            return
        end local 5 // boolean overrideAll
        end local 4 // java.lang.String extra_policy
        30: .line 430
      StackMap locals:
      StackMap stack:
            iconst_1
            istore 4 /* n */
        start local 4 // int n
        31: .line 431
            iconst_0
            istore 5 /* loaded_one */
        start local 5 // boolean loaded_one
        32: .line 434
            goto 46
        start local 6 // java.lang.String policy_url
        33: .line 436
      StackMap locals: int int java.lang.String
      StackMap stack:
            aload 6 /* policy_url */
            invokestatic sun.security.util.PropertyExpander.expand:(Ljava/lang/String;)Ljava/lang/String;
        34: .line 437
            getstatic java.io.File.separatorChar:C
            bipush 47
        35: .line 436
            invokevirtual java.lang.String.replace:(CC)Ljava/lang/String;
            astore 6 /* policy_url */
        36: .line 438
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 38
        37: .line 439
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "reading "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* policy_url */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        38: .line 440
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new java.net.URL
            dup
            aload 6 /* policy_url */
            invokespecial java.net.URL.<init>:(Ljava/lang/String;)V
            invokevirtual com.sun.security.auth.PolicyFile.init:(Ljava/net/URL;)V
        39: .line 441
            iconst_1
            istore 5 /* loaded_one */
        40: .line 442
            goto 45
      StackMap locals:
      StackMap stack: java.lang.Exception
        41: astore 7 /* e */
        start local 7 // java.lang.Exception e
        42: .line 443
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 45
        43: .line 444
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "error reading policy "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        44: .line 445
            aload 7 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        end local 7 // java.lang.Exception e
        45: .line 449
      StackMap locals:
      StackMap stack:
            iinc 4 /* n */ 1
        end local 6 // java.lang.String policy_url
        46: .line 434
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            ldc "auth.policy.url."
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 4 /* n */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic java.security.Security.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            dup
            astore 6 /* policy_url */
        start local 6 // java.lang.String policy_url
        47: ifnonnull 33
        48: .line 455
            return
        end local 6 // java.lang.String policy_url
        end local 5 // boolean loaded_one
        end local 4 // int n
        end local 3 // java.lang.String allowSys
        end local 2 // java.lang.String iscp
        end local 1 // java.lang.String prop
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   49     0          this  Lcom/sun/security/auth/PolicyFile;
            1   49     1          prop  Ljava/lang/String;
            3   49     2          iscp  Ljava/lang/String;
            5   49     3      allowSys  Ljava/lang/String;
            7   30     4  extra_policy  Ljava/lang/String;
            9   30     5   overrideAll  Z
           17   18     6     policyURL  Ljava/net/URL;
           19   22     6     policyURL  Ljava/net/URL;
           14   22     7    policyFile  Ljava/io/File;
           24   26     6             e  Ljava/lang/Exception;
           31   49     4             n  I
           32   49     5    loaded_one  Z
           33   46     6    policy_url  Ljava/lang/String;
           47   49     6    policy_url  Ljava/lang/String;
           42   45     7             e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          12    22      23  Class java.lang.Exception
          33    40      41  Class java.lang.Exception

  private boolean checkForTrustedIdentity(java.security.cert.Certificate);
    descriptor: (Ljava/security/cert/Certificate;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // java.security.cert.Certificate cert
         0: .line 465
            iconst_0
            ireturn
        end local 1 // java.security.cert.Certificate cert
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/sun/security/auth/PolicyFile;
            0    1     1  cert  Ljava/security/cert/Certificate;
    MethodParameters:
      Name  Flags
      cert  final

  private void init(java.net.URL);
    descriptor: (Ljava/net/URL;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=7, args_size=2
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // java.net.URL policy
         0: .line 475
            new com.sun.security.auth.PolicyParser
            dup
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.expandProperties:Z
            invokespecial com.sun.security.auth.PolicyParser.<init>:(Z)V
            astore 2 /* pp */
        start local 2 // com.sun.security.auth.PolicyParser pp
         1: .line 478
            new java.io.InputStreamReader
            dup
            aload 0 /* this */
            aload 1 /* policy */
            invokevirtual com.sun.security.auth.PolicyFile.getInputStream:(Ljava/net/URL;)Ljava/io/InputStream;
            invokespecial java.io.InputStreamReader.<init>:(Ljava/io/InputStream;)V
         2: .line 477
            astore 3 /* isr */
        start local 3 // java.io.InputStreamReader isr
         3: .line 479
            aload 2 /* pp */
            aload 3 /* isr */
            invokevirtual com.sun.security.auth.PolicyParser.read:(Ljava/io/Reader;)V
         4: .line 480
            aload 3 /* isr */
            invokevirtual java.io.InputStreamReader.close:()V
         5: .line 481
            aload 0 /* this */
            aload 1 /* policy */
            aload 2 /* pp */
            invokevirtual com.sun.security.auth.PolicyParser.getKeyStoreUrl:()Ljava/lang/String;
         6: .line 482
            aload 2 /* pp */
            invokevirtual com.sun.security.auth.PolicyParser.getKeyStoreType:()Ljava/lang/String;
         7: .line 481
            invokevirtual com.sun.security.auth.PolicyFile.initKeyStore:(Ljava/net/URL;Ljava/lang/String;Ljava/lang/String;)Ljava/security/KeyStore;
            astore 4 /* keyStore */
        start local 4 // java.security.KeyStore keyStore
         8: .line 483
            aload 2 /* pp */
            invokevirtual com.sun.security.auth.PolicyParser.grantElements:()Ljava/util/Enumeration;
            astore 5 /* enum_ */
        start local 5 // java.util.Enumeration enum_
         9: .line 484
            goto 12
        10: .line 485
      StackMap locals: com.sun.security.auth.PolicyFile java.net.URL com.sun.security.auth.PolicyParser java.io.InputStreamReader java.security.KeyStore java.util.Enumeration
      StackMap stack:
            aload 5 /* enum_ */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast com.sun.security.auth.PolicyParser$GrantEntry
            astore 6 /* ge */
        start local 6 // com.sun.security.auth.PolicyParser$GrantEntry ge
        11: .line 486
            aload 0 /* this */
            aload 6 /* ge */
            aload 4 /* keyStore */
            invokevirtual com.sun.security.auth.PolicyFile.addGrantEntry:(Lcom/sun/security/auth/PolicyParser$GrantEntry;Ljava/security/KeyStore;)V
        end local 6 // com.sun.security.auth.PolicyParser$GrantEntry ge
        12: .line 484
      StackMap locals:
      StackMap stack:
            aload 5 /* enum_ */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 10
        end local 5 // java.util.Enumeration enum_
        end local 4 // java.security.KeyStore keyStore
        end local 3 // java.io.InputStreamReader isr
        13: .line 488
            goto 30
      StackMap locals: com.sun.security.auth.PolicyFile java.net.URL com.sun.security.auth.PolicyParser
      StackMap stack: com.sun.security.auth.PolicyParser$ParsingException
        14: astore 3 /* pe */
        start local 3 // com.sun.security.auth.PolicyParser$ParsingException pe
        15: .line 489
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "java.security.auth.policy"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        16: .line 490
            getstatic com.sun.security.auth.PolicyFile.rb:Ljava/util/ResourceBundle;
            ldc ".error.parsing."
            invokevirtual java.util.ResourceBundle.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* policy */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        17: .line 489
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        18: .line 491
            getstatic java.lang.System.err:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "java.security.auth.policy"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        19: .line 492
            getstatic com.sun.security.auth.PolicyFile.rb:Ljava/util/ResourceBundle;
            ldc "COLON"
            invokevirtual java.util.ResourceBundle.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        20: .line 493
            aload 3 /* pe */
            invokevirtual com.sun.security.auth.PolicyParser$ParsingException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        21: .line 491
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        22: .line 494
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 30
        23: .line 495
            aload 3 /* pe */
            invokevirtual com.sun.security.auth.PolicyParser$ParsingException.printStackTrace:()V
        end local 3 // com.sun.security.auth.PolicyParser$ParsingException pe
        24: goto 30
        25: .line 497
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 3 /* e */
        start local 3 // java.lang.Exception e
        26: .line 498
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 30
        27: .line 499
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "error parsing "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* policy */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        28: .line 500
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            aload 3 /* e */
            invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        29: .line 501
            aload 3 /* e */
            invokevirtual java.lang.Exception.printStackTrace:()V
        end local 3 // java.lang.Exception e
        30: .line 504
      StackMap locals:
      StackMap stack:
            return
        end local 2 // com.sun.security.auth.PolicyParser pp
        end local 1 // java.net.URL policy
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   31     0      this  Lcom/sun/security/auth/PolicyFile;
            0   31     1    policy  Ljava/net/URL;
            1   31     2        pp  Lcom/sun/security/auth/PolicyParser;
            3   13     3       isr  Ljava/io/InputStreamReader;
            8   13     4  keyStore  Ljava/security/KeyStore;
            9   13     5     enum_  Ljava/util/Enumeration<Lcom/sun/security/auth/PolicyParser$GrantEntry;>;
           11   12     6        ge  Lcom/sun/security/auth/PolicyParser$GrantEntry;
           15   24     3        pe  Lcom/sun/security/auth/PolicyParser$ParsingException;
           26   30     3         e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1    13      14  Class com.sun.security.auth.PolicyParser$ParsingException
           1    13      25  Class java.lang.Exception
    MethodParameters:
        Name  Flags
      policy  

  private java.io.InputStream getInputStream(java.net.URL);
    descriptor: (Ljava/net/URL;)Ljava/io/InputStream;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // java.net.URL url
         0: .line 514
            ldc "file"
            aload 1 /* url */
            invokevirtual java.net.URL.getProtocol:()Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 3
         1: .line 515
            aload 1 /* url */
            invokevirtual java.net.URL.getFile:()Ljava/lang/String;
            bipush 47
            getstatic java.io.File.separatorChar:C
            invokevirtual java.lang.String.replace:(CC)Ljava/lang/String;
            astore 2 /* path */
        start local 2 // java.lang.String path
         2: .line 516
            new java.io.FileInputStream
            dup
            aload 2 /* path */
            invokespecial java.io.FileInputStream.<init>:(Ljava/lang/String;)V
            areturn
        end local 2 // java.lang.String path
         3: .line 518
      StackMap locals:
      StackMap stack:
            aload 1 /* url */
            invokevirtual java.net.URL.openStream:()Ljava/io/InputStream;
            areturn
        end local 1 // java.net.URL url
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lcom/sun/security/auth/PolicyFile;
            0    4     1   url  Ljava/net/URL;
            2    3     2  path  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      url   

  java.security.CodeSource getCodeSource(com.sun.security.auth.PolicyParser$GrantEntry, java.security.KeyStore);
    descriptor: (Lcom/sun/security/auth/PolicyParser$GrantEntry;Ljava/security/KeyStore;)Ljava/security/CodeSource;
    flags: (0x0000) 
    Code:
      stack=7, locals=5, args_size=3
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // com.sun.security.auth.PolicyParser$GrantEntry ge
        start local 2 // java.security.KeyStore keyStore
         0: .line 530
            aconst_null
            astore 3 /* certs */
        start local 3 // java.security.cert.Certificate[] certs
         1: .line 531
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.signedBy:Ljava/lang/String;
            ifnull 9
         2: .line 532
            aload 0 /* this */
            aload 2 /* keyStore */
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.signedBy:Ljava/lang/String;
            invokevirtual com.sun.security.auth.PolicyFile.getCertificates:(Ljava/security/KeyStore;Ljava/lang/String;)[Ljava/security/cert/Certificate;
            astore 3 /* certs */
         3: .line 533
            aload 3 /* certs */
            ifnonnull 9
         4: .line 536
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 8
         5: .line 537
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc " no certs for alias "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         6: .line 538
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.signedBy:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ", ignoring."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         7: .line 537
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         8: .line 540
      StackMap locals: java.security.cert.Certificate[]
      StackMap stack:
            aconst_null
            areturn
         9: .line 546
      StackMap locals:
      StackMap stack:
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.codeBase:Ljava/lang/String;
            ifnull 12
        10: .line 547
            new java.net.URL
            dup
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.codeBase:Ljava/lang/String;
            invokespecial java.net.URL.<init>:(Ljava/lang/String;)V
            astore 4 /* location */
        start local 4 // java.net.URL location
        11: goto 13
        end local 4 // java.net.URL location
        12: .line 549
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* location */
        start local 4 // java.net.URL location
        13: .line 551
      StackMap locals: java.net.URL
      StackMap stack:
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.principals:Ljava/util/LinkedList;
            ifnull 14
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.principals:Ljava/util/LinkedList;
            invokevirtual java.util.LinkedList.size:()I
            ifne 18
        14: .line 552
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        15: .line 553
            new java.security.CodeSource
            dup
            aload 4 /* location */
            aload 3 /* certs */
            invokespecial java.security.CodeSource.<init>:(Ljava/net/URL;[Ljava/security/cert/Certificate;)V
        16: .line 554
            iconst_0
        17: .line 552
            invokevirtual com.sun.security.auth.PolicyFile.canonicalizeCodebase:(Ljava/security/CodeSource;Z)Ljava/security/CodeSource;
            areturn
        18: .line 556
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        19: .line 557
            new com.sun.security.auth.SubjectCodeSource
            dup
            aconst_null
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.principals:Ljava/util/LinkedList;
            aload 4 /* location */
            aload 3 /* certs */
            invokespecial com.sun.security.auth.SubjectCodeSource.<init>:(Ljavax/security/auth/Subject;Ljava/util/LinkedList;Ljava/net/URL;[Ljava/security/cert/Certificate;)V
        20: .line 558
            iconst_0
        21: .line 556
            invokevirtual com.sun.security.auth.PolicyFile.canonicalizeCodebase:(Ljava/security/CodeSource;Z)Ljava/security/CodeSource;
            areturn
        end local 4 // java.net.URL location
        end local 3 // java.security.cert.Certificate[] certs
        end local 2 // java.security.KeyStore keyStore
        end local 1 // com.sun.security.auth.PolicyParser$GrantEntry ge
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   22     0      this  Lcom/sun/security/auth/PolicyFile;
            0   22     1        ge  Lcom/sun/security/auth/PolicyParser$GrantEntry;
            0   22     2  keyStore  Ljava/security/KeyStore;
            1   22     3     certs  [Ljava/security/cert/Certificate;
           11   12     4  location  Ljava/net/URL;
           13   22     4  location  Ljava/net/URL;
    Exceptions:
      throws java.net.MalformedURLException
    MethodParameters:
          Name  Flags
      ge        
      keyStore  

  private void addGrantEntry(com.sun.security.auth.PolicyParser$GrantEntry, java.security.KeyStore);
    descriptor: (Lcom/sun/security/auth/PolicyParser$GrantEntry;Ljava/security/KeyStore;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=9, args_size=3
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // com.sun.security.auth.PolicyParser$GrantEntry ge
        start local 2 // java.security.KeyStore keyStore
         0: .line 568
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 14
         1: .line 569
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ldc "Adding policy entry: "
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         2: .line 570
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "  signedBy "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.signedBy:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         3: .line 571
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "  codeBase "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.codeBase:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         4: .line 572
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.principals:Ljava/util/LinkedList;
            ifnull 13
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.principals:Ljava/util/LinkedList;
            invokevirtual java.util.LinkedList.size:()I
            ifle 13
         5: .line 574
            aload 1 /* ge */
            getfield com.sun.security.auth.PolicyParser$GrantEntry.principals:Ljava/util/LinkedList;
            invokevirtual java.util.LinkedList.listIterator:()Ljava/util/ListIterator;
         6: .line 573
            astore 3 /* li */
        start local 3 // java.util.ListIterator li
         7: .line 575
            goto 12
         8: .line 576
      StackMap locals: java.util.ListIterator
      StackMap stack:
            aload 3 /* li */
            invokeinterface java.util.ListIterator.next:()Ljava/lang/Object;
            checkcast com.sun.security.auth.PolicyParser$PrincipalEntry
            astore 4 /* pppe */
        start local 4 // com.sun.security.auth.PolicyParser$PrincipalEntry pppe
         9: .line 577
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "  "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* pppe */
            getfield com.sun.security.auth.PolicyParser$PrincipalEntry.principalClass:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        10: .line 578
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* pppe */
            getfield com.sun.security.auth.PolicyParser$PrincipalEntry.principalName:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 577
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 4 // com.sun.security.auth.PolicyParser$PrincipalEntry pppe
        12: .line 575
      StackMap locals:
      StackMap stack:
            aload 3 /* li */
            invokeinterface java.util.ListIterator.hasNext:()Z
            ifne 8
        end local 3 // java.util.ListIterator li
        13: .line 581
      StackMap locals:
      StackMap stack:
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            invokevirtual sun.security.util.Debug.println:()V
        14: .line 585
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* ge */
            aload 2 /* keyStore */
            invokevirtual com.sun.security.auth.PolicyFile.getCodeSource:(Lcom/sun/security/auth/PolicyParser$GrantEntry;Ljava/security/KeyStore;)Ljava/security/CodeSource;
            astore 3 /* codesource */
        start local 3 // java.security.CodeSource codesource
        15: .line 587
            aload 3 /* codesource */
            ifnonnull 17
        16: return
        17: .line 589
      StackMap locals: java.security.CodeSource
      StackMap stack:
            new com.sun.security.auth.PolicyFile$PolicyEntry
            dup
            aload 3 /* codesource */
            invokespecial com.sun.security.auth.PolicyFile$PolicyEntry.<init>:(Ljava/security/CodeSource;)V
            astore 4 /* entry */
        start local 4 // com.sun.security.auth.PolicyFile$PolicyEntry entry
        18: .line 591
            aload 1 /* ge */
            invokevirtual com.sun.security.auth.PolicyParser$GrantEntry.permissionElements:()Ljava/util/Enumeration;
        19: .line 590
            astore 5 /* enum_ */
        start local 5 // java.util.Enumeration enum_
        20: .line 592
            goto 75
        21: .line 593
      StackMap locals: com.sun.security.auth.PolicyFile$PolicyEntry java.util.Enumeration
      StackMap stack:
            aload 5 /* enum_ */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast com.sun.security.auth.PolicyParser$PermissionEntry
            astore 6 /* pe */
        start local 6 // com.sun.security.auth.PolicyParser$PermissionEntry pe
        22: .line 597
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.permission:Ljava/lang/String;
        23: .line 598
            ldc "javax.security.auth.PrivateCredentialPermission"
        24: .line 597
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        25: .line 598
            ifeq 32
        26: .line 599
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.name:Ljava/lang/String;
            ldc " self"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 32
        27: .line 600
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.permission:Ljava/lang/String;
        28: .line 601
            new java.lang.StringBuilder
            dup
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.name:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " \"self\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        29: .line 602
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.action:Ljava/lang/String;
        30: .line 600
            invokestatic com.sun.security.auth.PolicyFile.getInstance:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/security/Permission;
            astore 7 /* perm */
        start local 7 // java.security.Permission perm
        31: .line 603
            goto 36
        end local 7 // java.security.Permission perm
        32: .line 604
      StackMap locals: com.sun.security.auth.PolicyParser$PermissionEntry
      StackMap stack:
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.permission:Ljava/lang/String;
        33: .line 605
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.name:Ljava/lang/String;
        34: .line 606
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.action:Ljava/lang/String;
        35: .line 604
            invokestatic com.sun.security.auth.PolicyFile.getInstance:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/security/Permission;
            astore 7 /* perm */
        start local 7 // java.security.Permission perm
        36: .line 608
      StackMap locals: java.security.Permission
      StackMap stack:
            aload 4 /* entry */
            aload 7 /* perm */
            invokevirtual com.sun.security.auth.PolicyFile$PolicyEntry.add:(Ljava/security/Permission;)V
        37: .line 609
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 75
        38: .line 610
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "  "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* perm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 7 // java.security.Permission perm
        39: .line 612
            goto 75
      StackMap locals: com.sun.security.auth.PolicyFile com.sun.security.auth.PolicyParser$GrantEntry java.security.KeyStore java.security.CodeSource com.sun.security.auth.PolicyFile$PolicyEntry java.util.Enumeration com.sun.security.auth.PolicyParser$PermissionEntry
      StackMap stack: java.lang.ClassNotFoundException
        40: pop
        41: .line 614
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.signedBy:Ljava/lang/String;
            ifnull 44
        42: .line 615
            aload 0 /* this */
            aload 2 /* keyStore */
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.signedBy:Ljava/lang/String;
            invokevirtual com.sun.security.auth.PolicyFile.getCertificates:(Ljava/security/KeyStore;Ljava/lang/String;)[Ljava/security/cert/Certificate;
            astore 7 /* certs */
        start local 7 // java.security.cert.Certificate[] certs
        43: goto 45
        end local 7 // java.security.cert.Certificate[] certs
        44: .line 617
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 7 /* certs */
        start local 7 // java.security.cert.Certificate[] certs
        45: .line 621
      StackMap locals: java.security.cert.Certificate[]
      StackMap stack:
            aload 7 /* certs */
            ifnonnull 46
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.signedBy:Ljava/lang/String;
            ifnonnull 75
        46: .line 622
      StackMap locals:
      StackMap stack:
            new java.security.UnresolvedPermission
            dup
        47: .line 623
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.permission:Ljava/lang/String;
        48: .line 624
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.name:Ljava/lang/String;
        49: .line 625
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.action:Ljava/lang/String;
        50: .line 626
            aload 7 /* certs */
        51: .line 622
            invokespecial java.security.UnresolvedPermission.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[Ljava/security/cert/Certificate;)V
            astore 8 /* perm */
        start local 8 // java.security.Permission perm
        52: .line 627
            aload 4 /* entry */
            aload 8 /* perm */
            invokevirtual com.sun.security.auth.PolicyFile$PolicyEntry.add:(Ljava/security/Permission;)V
        53: .line 628
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 75
        54: .line 629
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "  "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 8 /* perm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 8 // java.security.Permission perm
        end local 7 // java.security.cert.Certificate[] certs
        55: goto 75
        56: .line 632
      StackMap locals: com.sun.security.auth.PolicyFile com.sun.security.auth.PolicyParser$GrantEntry java.security.KeyStore java.security.CodeSource com.sun.security.auth.PolicyFile$PolicyEntry java.util.Enumeration com.sun.security.auth.PolicyParser$PermissionEntry
      StackMap stack: java.lang.reflect.InvocationTargetException
            astore 7 /* ite */
        start local 7 // java.lang.reflect.InvocationTargetException ite
        57: .line 633
            getstatic java.lang.System.err:Ljava/io/PrintStream;
        58: .line 634
            new java.lang.StringBuilder
            dup
            ldc "java.security.auth.policy"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        59: .line 635
            getstatic com.sun.security.auth.PolicyFile.rb:Ljava/util/ResourceBundle;
            ldc ".error.adding.Permission."
            invokevirtual java.util.ResourceBundle.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        60: .line 636
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.permission:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        61: .line 637
            getstatic com.sun.security.auth.PolicyFile.rb:Ljava/util/ResourceBundle;
            ldc "SPACE"
            invokevirtual java.util.ResourceBundle.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        62: .line 638
            aload 7 /* ite */
            invokevirtual java.lang.reflect.InvocationTargetException.getTargetException:()Ljava/lang/Throwable;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        63: .line 634
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        64: .line 633
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 7 // java.lang.reflect.InvocationTargetException ite
        65: goto 75
        66: .line 639
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 7 /* e */
        start local 7 // java.lang.Exception e
        67: .line 640
            getstatic java.lang.System.err:Ljava/io/PrintStream;
        68: .line 641
            new java.lang.StringBuilder
            dup
            ldc "java.security.auth.policy"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        69: .line 642
            getstatic com.sun.security.auth.PolicyFile.rb:Ljava/util/ResourceBundle;
            ldc ".error.adding.Permission."
            invokevirtual java.util.ResourceBundle.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        70: .line 643
            aload 6 /* pe */
            getfield com.sun.security.auth.PolicyParser$PermissionEntry.permission:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        71: .line 644
            getstatic com.sun.security.auth.PolicyFile.rb:Ljava/util/ResourceBundle;
            ldc "SPACE"
            invokevirtual java.util.ResourceBundle.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        72: .line 645
            aload 7 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        73: .line 641
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        74: .line 640
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 7 // java.lang.Exception e
        end local 6 // com.sun.security.auth.PolicyParser$PermissionEntry pe
        75: .line 592
      StackMap locals:
      StackMap stack:
            aload 5 /* enum_ */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 21
        76: .line 648
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.policyEntries:Ljava/util/Vector;
            aload 4 /* entry */
            invokevirtual java.util.Vector.addElement:(Ljava/lang/Object;)V
        end local 5 // java.util.Enumeration enum_
        end local 4 // com.sun.security.auth.PolicyFile$PolicyEntry entry
        end local 3 // java.security.CodeSource codesource
        77: .line 649
            goto 87
      StackMap locals: com.sun.security.auth.PolicyFile com.sun.security.auth.PolicyParser$GrantEntry java.security.KeyStore
      StackMap stack: java.lang.Exception
        78: astore 3 /* e */
        start local 3 // java.lang.Exception e
        79: .line 650
            getstatic java.lang.System.err:Ljava/io/PrintStream;
        80: .line 651
            new java.lang.StringBuilder
            dup
            ldc "java.security.auth.policy"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        81: .line 652
            getstatic com.sun.security.auth.PolicyFile.rb:Ljava/util/ResourceBundle;
            ldc ".error.adding.Entry."
            invokevirtual java.util.ResourceBundle.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        82: .line 653
            aload 1 /* ge */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        83: .line 654
            getstatic com.sun.security.auth.PolicyFile.rb:Ljava/util/ResourceBundle;
            ldc "SPACE"
            invokevirtual java.util.ResourceBundle.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        84: .line 655
            aload 3 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        85: .line 651
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        86: .line 650
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 3 // java.lang.Exception e
        87: .line 658
      StackMap locals:
      StackMap stack:
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 89
        88: .line 659
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            invokevirtual sun.security.util.Debug.println:()V
        89: .line 660
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.security.KeyStore keyStore
        end local 1 // com.sun.security.auth.PolicyParser$GrantEntry ge
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   90     0        this  Lcom/sun/security/auth/PolicyFile;
            0   90     1          ge  Lcom/sun/security/auth/PolicyParser$GrantEntry;
            0   90     2    keyStore  Ljava/security/KeyStore;
            7   13     3          li  Ljava/util/ListIterator<Lcom/sun/security/auth/PolicyParser$PrincipalEntry;>;
            9   12     4        pppe  Lcom/sun/security/auth/PolicyParser$PrincipalEntry;
           15   77     3  codesource  Ljava/security/CodeSource;
           18   77     4       entry  Lcom/sun/security/auth/PolicyFile$PolicyEntry;
           20   77     5       enum_  Ljava/util/Enumeration<Lcom/sun/security/auth/PolicyParser$PermissionEntry;>;
           22   75     6          pe  Lcom/sun/security/auth/PolicyParser$PermissionEntry;
           31   32     7        perm  Ljava/security/Permission;
           36   39     7        perm  Ljava/security/Permission;
           43   44     7       certs  [Ljava/security/cert/Certificate;
           45   55     7       certs  [Ljava/security/cert/Certificate;
           52   55     8        perm  Ljava/security/Permission;
           57   65     7         ite  Ljava/lang/reflect/InvocationTargetException;
           67   75     7           e  Ljava/lang/Exception;
           79   87     3           e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          22    39      40  Class java.lang.ClassNotFoundException
          22    39      56  Class java.lang.reflect.InvocationTargetException
          22    39      66  Class java.lang.Exception
          14    16      78  Class java.lang.Exception
          17    77      78  Class java.lang.Exception
    MethodParameters:
          Name  Flags
      ge        
      keyStore  

  private static final java.security.Permission getInstance(java.lang.String, java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)Ljava/security/Permission;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // java.lang.String type
        start local 1 // java.lang.String name
        start local 2 // java.lang.String actions
         0: .line 702
            aload 0 /* type */
            invokestatic java.lang.Class.forName:(Ljava/lang/String;)Ljava/lang/Class;
            astore 3 /* pc */
        start local 3 // java.lang.Class pc
         1: .line 703
            aload 3 /* pc */
            getstatic com.sun.security.auth.PolicyFile.PARAMS:[Ljava/lang/Class;
            invokevirtual java.lang.Class.getConstructor:([Ljava/lang/Class;)Ljava/lang/reflect/Constructor;
            astore 4 /* c */
        start local 4 // java.lang.reflect.Constructor c
         2: .line 704
            aload 4 /* c */
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 1 /* name */
            aastore
            dup
            iconst_1
            aload 2 /* actions */
            aastore
            invokevirtual java.lang.reflect.Constructor.newInstance:([Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.Permission
            areturn
        end local 4 // java.lang.reflect.Constructor c
        end local 3 // java.lang.Class pc
        end local 2 // java.lang.String actions
        end local 1 // java.lang.String name
        end local 0 // java.lang.String type
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     type  Ljava/lang/String;
            0    3     1     name  Ljava/lang/String;
            0    3     2  actions  Ljava/lang/String;
            1    3     3       pc  Ljava/lang/Class<*>;
            2    3     4        c  Ljava/lang/reflect/Constructor<*>;
    Exceptions:
      throws java.lang.ClassNotFoundException, java.lang.InstantiationException, java.lang.IllegalAccessException, java.lang.NoSuchMethodException, java.lang.reflect.InvocationTargetException
    MethodParameters:
         Name  Flags
      type     
      name     
      actions  

  java.security.cert.Certificate[] getCertificates(java.security.KeyStore, java.lang.String);
    descriptor: (Ljava/security/KeyStore;Ljava/lang/String;)[Ljava/security/cert/Certificate;
    flags: (0x0000) 
    Code:
      stack=4, locals=8, args_size=3
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // java.security.KeyStore keyStore
        start local 2 // java.lang.String aliases
         0: .line 713
            aconst_null
            astore 3 /* vcerts */
        start local 3 // java.util.Vector vcerts
         1: .line 715
            new java.util.StringTokenizer
            dup
            aload 2 /* aliases */
            ldc ","
            invokespecial java.util.StringTokenizer.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            astore 4 /* st */
        start local 4 // java.util.StringTokenizer st
         2: .line 716
            iconst_0
            istore 5 /* n */
        start local 5 // int n
         3: .line 718
            goto 19
         4: .line 719
      StackMap locals: java.util.Vector java.util.StringTokenizer int
      StackMap stack:
            aload 4 /* st */
            invokevirtual java.util.StringTokenizer.nextToken:()Ljava/lang/String;
            invokevirtual java.lang.String.trim:()Ljava/lang/String;
            astore 6 /* alias */
        start local 6 // java.lang.String alias
         5: .line 720
            iinc 5 /* n */ 1
         6: .line 721
            aconst_null
            astore 7 /* cert */
        start local 7 // java.security.cert.Certificate cert
         7: .line 723
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.aliasMapping:Ljava/util/Hashtable;
            aload 6 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.cert.Certificate
            astore 7 /* cert */
         8: .line 724
            aload 7 /* cert */
            ifnonnull 15
            aload 1 /* keyStore */
            ifnull 15
         9: .line 727
            aload 1 /* keyStore */
            aload 6 /* alias */
            invokevirtual java.security.KeyStore.getCertificate:(Ljava/lang/String;)Ljava/security/cert/Certificate;
            astore 7 /* cert */
        10: .line 728
            goto 12
      StackMap locals: com.sun.security.auth.PolicyFile java.security.KeyStore java.lang.String java.util.Vector java.util.StringTokenizer int java.lang.String java.security.cert.Certificate
      StackMap stack: java.security.KeyStoreException
        11: pop
        12: .line 732
      StackMap locals:
      StackMap stack:
            aload 7 /* cert */
            ifnull 15
        13: .line 733
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.aliasMapping:Ljava/util/Hashtable;
            aload 6 /* alias */
            aload 7 /* cert */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        14: .line 734
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.aliasMapping:Ljava/util/Hashtable;
            aload 7 /* cert */
            aload 6 /* alias */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        15: .line 738
      StackMap locals:
      StackMap stack:
            aload 7 /* cert */
            ifnull 19
        16: .line 739
            aload 3 /* vcerts */
            ifnonnull 18
        17: .line 740
            new java.util.Vector
            dup
            invokespecial java.util.Vector.<init>:()V
            astore 3 /* vcerts */
        18: .line 741
      StackMap locals:
      StackMap stack:
            aload 3 /* vcerts */
            aload 7 /* cert */
            invokevirtual java.util.Vector.addElement:(Ljava/lang/Object;)V
        end local 7 // java.security.cert.Certificate cert
        end local 6 // java.lang.String alias
        19: .line 718
      StackMap locals:
      StackMap stack:
            aload 4 /* st */
            invokevirtual java.util.StringTokenizer.hasMoreTokens:()Z
            ifne 4
        20: .line 746
            aload 3 /* vcerts */
            ifnull 24
            iload 5 /* n */
            aload 3 /* vcerts */
            invokevirtual java.util.Vector.size:()I
            if_icmpne 24
        21: .line 747
            aload 3 /* vcerts */
            invokevirtual java.util.Vector.size:()I
            anewarray java.security.cert.Certificate
            astore 6 /* certs */
        start local 6 // java.security.cert.Certificate[] certs
        22: .line 748
            aload 3 /* vcerts */
            aload 6 /* certs */
            invokevirtual java.util.Vector.copyInto:([Ljava/lang/Object;)V
        23: .line 749
            aload 6 /* certs */
            areturn
        end local 6 // java.security.cert.Certificate[] certs
        24: .line 751
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 5 // int n
        end local 4 // java.util.StringTokenizer st
        end local 3 // java.util.Vector vcerts
        end local 2 // java.lang.String aliases
        end local 1 // java.security.KeyStore keyStore
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   25     0      this  Lcom/sun/security/auth/PolicyFile;
            0   25     1  keyStore  Ljava/security/KeyStore;
            0   25     2   aliases  Ljava/lang/String;
            1   25     3    vcerts  Ljava/util/Vector<Ljava/security/cert/Certificate;>;
            2   25     4        st  Ljava/util/StringTokenizer;
            3   25     5         n  I
            5   19     6     alias  Ljava/lang/String;
            7   19     7      cert  Ljava/security/cert/Certificate;
           22   24     6     certs  [Ljava/security/cert/Certificate;
      Exception table:
        from    to  target  type
           9    10      11  Class java.security.KeyStoreException
    MethodParameters:
          Name  Flags
      keyStore  
      aliases   

  private final synchronized java.util.Enumeration<com.sun.security.auth.PolicyFile$PolicyEntry> elements();
    descriptor: ()Ljava/util/Enumeration;
    flags: (0x0032) ACC_PRIVATE, ACC_FINAL, ACC_SYNCHRONIZED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.security.auth.PolicyFile this
         0: .line 762
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.policyEntries:Ljava/util/Vector;
            invokevirtual java.util.Vector.elements:()Ljava/util/Enumeration;
            areturn
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/sun/security/auth/PolicyFile;
    Signature: ()Ljava/util/Enumeration<Lcom/sun/security/auth/PolicyFile$PolicyEntry;>;

  public java.security.PermissionCollection getPermissions(javax.security.auth.Subject, java.security.CodeSource);
    descriptor: (Ljavax/security/auth/Subject;Ljava/security/CodeSource;)Ljava/security/PermissionCollection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // javax.security.auth.Subject subject
        start local 2 // java.security.CodeSource codesource
         0: .line 841
            new com.sun.security.auth.PolicyFile$3
            dup
            aload 0 /* this */
            aload 1 /* subject */
            aload 2 /* codesource */
            invokespecial com.sun.security.auth.PolicyFile$3.<init>:(Lcom/sun/security/auth/PolicyFile;Ljavax/security/auth/Subject;Ljava/security/CodeSource;)V
         1: .line 840
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.security.PermissionCollection
            areturn
        end local 2 // java.security.CodeSource codesource
        end local 1 // javax.security.auth.Subject subject
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lcom/sun/security/auth/PolicyFile;
            0    2     1     subject  Ljavax/security/auth/Subject;
            0    2     2  codesource  Ljava/security/CodeSource;
    MethodParameters:
            Name  Flags
      subject     final
      codesource  final

  java.security.PermissionCollection getPermissions(java.security.CodeSource);
    descriptor: (Ljava/security/CodeSource;)Ljava/security/PermissionCollection;
    flags: (0x0000) 
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // java.security.CodeSource codesource
         0: .line 869
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.initialized:Z
            ifeq 2
         1: .line 870
            aload 0 /* this */
            new java.security.Permissions
            dup
            invokespecial java.security.Permissions.<init>:()V
            aload 1 /* codesource */
            invokevirtual com.sun.security.auth.PolicyFile.getPermissions:(Ljava/security/Permissions;Ljava/security/CodeSource;)Ljava/security/Permissions;
            areturn
         2: .line 872
      StackMap locals:
      StackMap stack:
            new com.sun.security.auth.PolicyPermissions
            dup
            aload 0 /* this */
            aload 1 /* codesource */
            invokespecial com.sun.security.auth.PolicyPermissions.<init>:(Lcom/sun/security/auth/PolicyFile;Ljava/security/CodeSource;)V
            areturn
        end local 1 // java.security.CodeSource codesource
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    3     0        this  Lcom/sun/security/auth/PolicyFile;
            0    3     1  codesource  Ljava/security/CodeSource;
    MethodParameters:
            Name  Flags
      codesource  

  java.security.Permissions getPermissions(java.security.Permissions, java.security.CodeSource);
    descriptor: (Ljava/security/Permissions;Ljava/security/CodeSource;)Ljava/security/Permissions;
    flags: (0x0000) 
    Code:
      stack=5, locals=8, args_size=3
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // java.security.Permissions perms
        start local 2 // java.security.CodeSource cs
         0: .line 890
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.initialized:Z
            ifne 2
         1: .line 891
            aload 0 /* this */
            invokevirtual com.sun.security.auth.PolicyFile.init:()V
         2: .line 894
      StackMap locals:
      StackMap stack:
            iconst_1
            anewarray java.security.CodeSource
            astore 3 /* codesource */
        start local 3 // java.security.CodeSource[] codesource
         3: .line 896
            aload 3 /* codesource */
            iconst_0
            aload 0 /* this */
            aload 2 /* cs */
            iconst_1
            invokevirtual com.sun.security.auth.PolicyFile.canonicalizeCodebase:(Ljava/security/CodeSource;Z)Ljava/security/CodeSource;
            aastore
         4: .line 898
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 6
         5: .line 899
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "evaluate("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* codesource */
            iconst_0
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc ")\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         6: .line 906
      StackMap locals: java.security.CodeSource[]
      StackMap stack:
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         7: goto 28
         8: .line 908
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.policyEntries:Ljava/util/Vector;
            iload 4 /* i */
            invokevirtual java.util.Vector.elementAt:(I)Ljava/lang/Object;
            checkcast com.sun.security.auth.PolicyFile$PolicyEntry
            astore 5 /* entry */
        start local 5 // com.sun.security.auth.PolicyFile$PolicyEntry entry
         9: .line 910
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 14
        10: .line 911
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "PolicyFile CodeSource implies: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        11: .line 912
            aload 5 /* entry */
            getfield com.sun.security.auth.PolicyFile$PolicyEntry.codesource:Ljava/security/CodeSource;
            invokevirtual java.security.CodeSource.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        12: .line 913
            ldc "\t"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* codesource */
            iconst_0
            aaload
            invokevirtual java.security.CodeSource.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\n\n"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 911
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        14: .line 916
      StackMap locals: com.sun.security.auth.PolicyFile$PolicyEntry
      StackMap stack:
            aload 5 /* entry */
            getfield com.sun.security.auth.PolicyFile$PolicyEntry.codesource:Ljava/security/CodeSource;
            aload 3 /* codesource */
            iconst_0
            aaload
            invokevirtual java.security.CodeSource.implies:(Ljava/security/CodeSource;)Z
            ifeq 27
        15: .line 917
            iconst_0
            istore 6 /* j */
        start local 6 // int j
        16: goto 26
        17: .line 918
      StackMap locals: int
      StackMap stack:
            aload 5 /* entry */
            getfield com.sun.security.auth.PolicyFile$PolicyEntry.permissions:Ljava/util/Vector;
            iload 6 /* j */
            invokevirtual java.util.Vector.elementAt:(I)Ljava/lang/Object;
            checkcast java.security.Permission
            astore 7 /* p */
        start local 7 // java.security.Permission p
        18: .line 919
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 20
        19: .line 920
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "  granting "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* p */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        20: .line 922
      StackMap locals: java.security.Permission
      StackMap stack:
            aload 0 /* this */
            aload 7 /* p */
            aload 5 /* entry */
            getfield com.sun.security.auth.PolicyFile$PolicyEntry.codesource:Ljava/security/CodeSource;
        21: .line 923
            aload 3 /* codesource */
            iconst_0
            aaload
            aload 1 /* perms */
        22: .line 922
            invokevirtual com.sun.security.auth.PolicyFile.addSelfPermissions:(Ljava/security/Permission;Ljava/security/CodeSource;Ljava/security/CodeSource;Ljava/security/Permissions;)Z
        23: .line 923
            ifne 25
        24: .line 928
            aload 1 /* perms */
            aload 7 /* p */
            invokevirtual java.security.Permissions.add:(Ljava/security/Permission;)V
        end local 7 // java.security.Permission p
        25: .line 917
      StackMap locals:
      StackMap stack:
            iinc 6 /* j */ 1
      StackMap locals:
      StackMap stack:
        26: iload 6 /* j */
            aload 5 /* entry */
            getfield com.sun.security.auth.PolicyFile$PolicyEntry.permissions:Ljava/util/Vector;
            invokevirtual java.util.Vector.size:()I
            if_icmplt 17
        end local 6 // int j
        end local 5 // com.sun.security.auth.PolicyFile$PolicyEntry entry
        27: .line 906
      StackMap locals:
      StackMap stack:
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
        28: iload 4 /* i */
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.policyEntries:Ljava/util/Vector;
            invokevirtual java.util.Vector.size:()I
            if_icmplt 8
        end local 4 // int i
        29: .line 936
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.ignoreIdentityScope:Z
            ifne 39
        30: .line 937
            aload 3 /* codesource */
            iconst_0
            aaload
            invokevirtual java.security.CodeSource.getCertificates:()[Ljava/security/cert/Certificate;
            astore 4 /* certs */
        start local 4 // java.security.cert.Certificate[] certs
        31: .line 938
            aload 4 /* certs */
            ifnull 39
        32: .line 939
            iconst_0
            istore 5 /* k */
        start local 5 // int k
        33: goto 38
        34: .line 940
      StackMap locals: com.sun.security.auth.PolicyFile java.security.Permissions java.security.CodeSource java.security.CodeSource[] java.security.cert.Certificate[] int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile.aliasMapping:Ljava/util/Hashtable;
            aload 4 /* certs */
            iload 5 /* k */
            aaload
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            ifnonnull 37
        35: .line 941
            aload 0 /* this */
            aload 4 /* certs */
            iload 5 /* k */
            aaload
            invokevirtual com.sun.security.auth.PolicyFile.checkForTrustedIdentity:(Ljava/security/cert/Certificate;)Z
            ifeq 37
        36: .line 946
            aload 1 /* perms */
            new java.security.AllPermission
            dup
            invokespecial java.security.AllPermission.<init>:()V
            invokevirtual java.security.Permissions.add:(Ljava/security/Permission;)V
        37: .line 939
      StackMap locals:
      StackMap stack:
            iinc 5 /* k */ 1
      StackMap locals:
      StackMap stack:
        38: iload 5 /* k */
            aload 4 /* certs */
            arraylength
            if_icmplt 34
        end local 5 // int k
        end local 4 // java.security.cert.Certificate[] certs
        39: .line 951
      StackMap locals:
      StackMap stack:
            aload 1 /* perms */
            areturn
        end local 3 // java.security.CodeSource[] codesource
        end local 2 // java.security.CodeSource cs
        end local 1 // java.security.Permissions perms
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   40     0        this  Lcom/sun/security/auth/PolicyFile;
            0   40     1       perms  Ljava/security/Permissions;
            0   40     2          cs  Ljava/security/CodeSource;
            3   40     3  codesource  [Ljava/security/CodeSource;
            7   29     4           i  I
            9   27     5       entry  Lcom/sun/security/auth/PolicyFile$PolicyEntry;
           16   27     6           j  I
           18   25     7           p  Ljava/security/Permission;
           31   39     4       certs  [Ljava/security/cert/Certificate;
           33   39     5           k  I
    MethodParameters:
       Name  Flags
      perms  final
      cs     final

  private boolean addSelfPermissions(java.security.Permission, java.security.CodeSource, java.security.CodeSource, java.security.Permissions);
    descriptor: (Ljava/security/Permission;Ljava/security/CodeSource;Ljava/security/CodeSource;Ljava/security/Permissions;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=13, args_size=5
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // java.security.Permission p
        start local 2 // java.security.CodeSource entryCs
        start local 3 // java.security.CodeSource accCs
        start local 4 // java.security.Permissions perms
         0: .line 975
            aload 1 /* p */
            instanceof javax.security.auth.PrivateCredentialPermission
            ifne 2
         1: .line 976
            iconst_0
            ireturn
         2: .line 978
      StackMap locals:
      StackMap stack:
            aload 2 /* entryCs */
            instanceof com.sun.security.auth.SubjectCodeSource
            ifne 4
         3: .line 979
            iconst_0
            ireturn
         4: .line 982
      StackMap locals:
      StackMap stack:
            aload 1 /* p */
            checkcast javax.security.auth.PrivateCredentialPermission
            astore 5 /* pcp */
        start local 5 // javax.security.auth.PrivateCredentialPermission pcp
         5: .line 983
            aload 2 /* entryCs */
            checkcast com.sun.security.auth.SubjectCodeSource
            astore 6 /* scs */
        start local 6 // com.sun.security.auth.SubjectCodeSource scs
         6: .line 986
            aload 5 /* pcp */
            invokevirtual javax.security.auth.PrivateCredentialPermission.getPrincipals:()[[Ljava/lang/String;
            astore 7 /* pPrincipals */
        start local 7 // java.lang.String[][] pPrincipals
         7: .line 987
            aload 7 /* pPrincipals */
            arraylength
            ifle 10
         8: .line 988
            aload 7 /* pPrincipals */
            iconst_0
            aaload
            iconst_0
            aaload
            ldc "self"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 10
         9: .line 989
            aload 7 /* pPrincipals */
            iconst_0
            aaload
            iconst_1
            aaload
            ldc "self"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 11
        10: .line 992
      StackMap locals: javax.security.auth.PrivateCredentialPermission com.sun.security.auth.SubjectCodeSource java.lang.String[][]
      StackMap stack:
            iconst_0
            ireturn
        11: .line 999
      StackMap locals:
      StackMap stack:
            aload 6 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getPrincipals:()Ljava/util/LinkedList;
            ifnonnull 13
        12: .line 1001
            iconst_1
            ireturn
        13: .line 1005
      StackMap locals:
      StackMap stack:
            aload 6 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getPrincipals:()Ljava/util/LinkedList;
            invokevirtual java.util.LinkedList.listIterator:()Ljava/util/ListIterator;
        14: .line 1004
            astore 8 /* pli */
        start local 8 // java.util.ListIterator pli
        15: .line 1006
            goto 39
        16: .line 1008
      StackMap locals: java.util.ListIterator
      StackMap stack:
            aload 8 /* pli */
            invokeinterface java.util.ListIterator.next:()Ljava/lang/Object;
            checkcast com.sun.security.auth.PolicyParser$PrincipalEntry
            astore 9 /* principal */
        start local 9 // com.sun.security.auth.PolicyParser$PrincipalEntry principal
        17: .line 1021
            aload 0 /* this */
        18: .line 1022
            aload 9 /* principal */
            aload 3 /* accCs */
        19: .line 1021
            invokevirtual com.sun.security.auth.PolicyFile.getPrincipalInfo:(Lcom/sun/security/auth/PolicyParser$PrincipalEntry;Ljava/security/CodeSource;)[[Ljava/lang/String;
            astore 10 /* principalInfo */
        start local 10 // java.lang.String[][] principalInfo
        20: .line 1024
            iconst_0
            istore 11 /* i */
        start local 11 // int i
        21: goto 38
        22: .line 1029
      StackMap locals: com.sun.security.auth.PolicyParser$PrincipalEntry java.lang.String[][] int
      StackMap stack:
            new javax.security.auth.PrivateCredentialPermission
            dup
        23: .line 1030
            new java.lang.StringBuilder
            dup
            aload 5 /* pcp */
            invokevirtual javax.security.auth.PrivateCredentialPermission.getCredentialClass:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        24: .line 1031
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        25: .line 1032
            aload 10 /* principalInfo */
            iload 11 /* i */
            aaload
            iconst_0
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        26: .line 1033
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        27: .line 1034
            ldc "\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 10 /* principalInfo */
            iload 11 /* i */
            aaload
            iconst_1
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        28: .line 1030
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        29: .line 1035
            ldc "read"
        30: .line 1029
            invokespecial javax.security.auth.PrivateCredentialPermission.<init>:(Ljava/lang/String;Ljava/lang/String;)V
        31: .line 1028
            astore 12 /* newPcp */
        start local 12 // javax.security.auth.PrivateCredentialPermission newPcp
        32: .line 1037
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 36
        33: .line 1038
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "adding SELF permission: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        34: .line 1039
            aload 12 /* newPcp */
            invokevirtual javax.security.auth.PrivateCredentialPermission.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        35: .line 1038
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        36: .line 1042
      StackMap locals: javax.security.auth.PrivateCredentialPermission
      StackMap stack:
            aload 4 /* perms */
            aload 12 /* newPcp */
            invokevirtual java.security.Permissions.add:(Ljava/security/Permission;)V
        end local 12 // javax.security.auth.PrivateCredentialPermission newPcp
        37: .line 1024
            iinc 11 /* i */ 1
      StackMap locals:
      StackMap stack:
        38: iload 11 /* i */
            aload 10 /* principalInfo */
            arraylength
            if_icmplt 22
        end local 11 // int i
        end local 10 // java.lang.String[][] principalInfo
        end local 9 // com.sun.security.auth.PolicyParser$PrincipalEntry principal
        39: .line 1006
      StackMap locals:
      StackMap stack:
            aload 8 /* pli */
            invokeinterface java.util.ListIterator.hasNext:()Z
            ifne 16
        end local 8 // java.util.ListIterator pli
        40: .line 1046
            iconst_1
            ireturn
        end local 7 // java.lang.String[][] pPrincipals
        end local 6 // com.sun.security.auth.SubjectCodeSource scs
        end local 5 // javax.security.auth.PrivateCredentialPermission pcp
        end local 4 // java.security.Permissions perms
        end local 3 // java.security.CodeSource accCs
        end local 2 // java.security.CodeSource entryCs
        end local 1 // java.security.Permission p
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   41     0           this  Lcom/sun/security/auth/PolicyFile;
            0   41     1              p  Ljava/security/Permission;
            0   41     2        entryCs  Ljava/security/CodeSource;
            0   41     3          accCs  Ljava/security/CodeSource;
            0   41     4          perms  Ljava/security/Permissions;
            5   41     5            pcp  Ljavax/security/auth/PrivateCredentialPermission;
            6   41     6            scs  Lcom/sun/security/auth/SubjectCodeSource;
            7   41     7    pPrincipals  [[Ljava/lang/String;
           15   40     8            pli  Ljava/util/ListIterator<Lcom/sun/security/auth/PolicyParser$PrincipalEntry;>;
           17   39     9      principal  Lcom/sun/security/auth/PolicyParser$PrincipalEntry;
           20   39    10  principalInfo  [[Ljava/lang/String;
           21   39    11              i  I
           32   37    12         newPcp  Ljavax/security/auth/PrivateCredentialPermission;
    MethodParameters:
         Name  Flags
      p        final
      entryCs  
      accCs    
      perms    

  private java.lang.String[][] getPrincipalInfo(com.sun.security.auth.PolicyParser$PrincipalEntry, java.security.CodeSource);
    descriptor: (Lcom/sun/security/auth/PolicyParser$PrincipalEntry;Ljava/security/CodeSource;)[[Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=9, args_size=3
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // com.sun.security.auth.PolicyParser$PrincipalEntry principal
        start local 2 // java.security.CodeSource accCs
         0: .line 1064
            aload 1 /* principal */
            getfield com.sun.security.auth.PolicyParser$PrincipalEntry.principalClass:Ljava/lang/String;
         1: .line 1065
            ldc "WILDCARD_PRINCIPAL_CLASS"
         2: .line 1064
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
         3: .line 1065
            ifne 12
         4: .line 1066
            aload 1 /* principal */
            getfield com.sun.security.auth.PolicyParser$PrincipalEntry.principalName:Ljava/lang/String;
         5: .line 1067
            ldc "WILDCARD_PRINCIPAL_NAME"
         6: .line 1066
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
         7: .line 1067
            ifne 12
         8: .line 1071
            iconst_1
            iconst_2
            multianewarray [[Ljava/lang/String; 2
            astore 3 /* info */
        start local 3 // java.lang.String[][] info
         9: .line 1072
            aload 3 /* info */
            iconst_0
            aaload
            iconst_0
            aload 1 /* principal */
            getfield com.sun.security.auth.PolicyParser$PrincipalEntry.principalClass:Ljava/lang/String;
            aastore
        10: .line 1073
            aload 3 /* info */
            iconst_0
            aaload
            iconst_1
            aload 1 /* principal */
            getfield com.sun.security.auth.PolicyParser$PrincipalEntry.principalName:Ljava/lang/String;
            aastore
        11: .line 1074
            aload 3 /* info */
            areturn
        end local 3 // java.lang.String[][] info
        12: .line 1076
      StackMap locals:
      StackMap stack:
            aload 1 /* principal */
            getfield com.sun.security.auth.PolicyParser$PrincipalEntry.principalClass:Ljava/lang/String;
        13: .line 1077
            ldc "WILDCARD_PRINCIPAL_CLASS"
        14: .line 1076
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        15: .line 1077
            ifne 44
        16: .line 1078
            aload 1 /* principal */
            getfield com.sun.security.auth.PolicyParser$PrincipalEntry.principalName:Ljava/lang/String;
        17: .line 1079
            ldc "WILDCARD_PRINCIPAL_NAME"
        18: .line 1078
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
        19: .line 1079
            ifeq 44
        20: .line 1086
            aload 2 /* accCs */
            checkcast com.sun.security.auth.SubjectCodeSource
            astore 3 /* scs */
        start local 3 // com.sun.security.auth.SubjectCodeSource scs
        21: .line 1088
            aconst_null
            astore 4 /* principalSet */
        start local 4 // java.util.Set principalSet
        22: .line 1094
            aload 1 /* principal */
            getfield com.sun.security.auth.PolicyParser$PrincipalEntry.principalClass:Ljava/lang/String;
            iconst_0
        23: .line 1095
            invokestatic java.lang.ClassLoader.getSystemClassLoader:()Ljava/lang/ClassLoader;
        24: .line 1094
            invokestatic java.lang.Class.forName:(Ljava/lang/String;ZLjava/lang/ClassLoader;)Ljava/lang/Class;
        25: .line 1093
            astore 5 /* pClass */
        start local 5 // java.lang.Class pClass
        26: .line 1096
            aload 3 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getSubject:()Ljavax/security/auth/Subject;
            aload 5 /* pClass */
            invokevirtual javax.security.auth.Subject.getPrincipals:(Ljava/lang/Class;)Ljava/util/Set;
            astore 4 /* principalSet */
        end local 5 // java.lang.Class pClass
        27: .line 1097
            goto 33
      StackMap locals: com.sun.security.auth.PolicyFile com.sun.security.auth.PolicyParser$PrincipalEntry java.security.CodeSource com.sun.security.auth.SubjectCodeSource java.util.Set
      StackMap stack: java.lang.Exception
        28: astore 5 /* e */
        start local 5 // java.lang.Exception e
        29: .line 1098
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            ifnull 33
        30: .line 1099
            getstatic com.sun.security.auth.PolicyFile.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "problem finding Principal Class when expanding SELF permission: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        31: .line 1101
            aload 5 /* e */
            invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        32: .line 1099
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 5 // java.lang.Exception e
        33: .line 1105
      StackMap locals:
      StackMap stack:
            aload 4 /* principalSet */
            ifnonnull 35
        34: .line 1107
            iconst_0
            iconst_0
            multianewarray [[Ljava/lang/String; 2
            areturn
        35: .line 1110
      StackMap locals:
      StackMap stack:
            aload 4 /* principalSet */
            invokeinterface java.util.Set.size:()I
            iconst_2
            multianewarray [[Ljava/lang/String; 2
            astore 5 /* info */
        start local 5 // java.lang.String[][] info
        36: .line 1112
            iconst_0
            istore 6 /* i */
        start local 6 // int i
        37: .line 1113
            aload 4 /* principalSet */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 8
            goto 42
      StackMap locals: com.sun.security.auth.PolicyFile com.sun.security.auth.PolicyParser$PrincipalEntry java.security.CodeSource com.sun.security.auth.SubjectCodeSource java.util.Set java.lang.String[][] int top java.util.Iterator
      StackMap stack:
        38: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.Principal
            astore 7 /* p */
        start local 7 // java.security.Principal p
        39: .line 1114
            aload 5 /* info */
            iload 6 /* i */
            aaload
            iconst_0
            aload 7 /* p */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            aastore
        40: .line 1115
            aload 5 /* info */
            iload 6 /* i */
            aaload
            iconst_1
            aload 7 /* p */
            invokeinterface java.security.Principal.getName:()Ljava/lang/String;
            aastore
        41: .line 1116
            iinc 6 /* i */ 1
        end local 7 // java.security.Principal p
        42: .line 1113
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 38
        43: .line 1118
            aload 5 /* info */
            areturn
        end local 6 // int i
        end local 5 // java.lang.String[][] info
        end local 4 // java.util.Set principalSet
        end local 3 // com.sun.security.auth.SubjectCodeSource scs
        44: .line 1127
      StackMap locals: com.sun.security.auth.PolicyFile com.sun.security.auth.PolicyParser$PrincipalEntry java.security.CodeSource
      StackMap stack:
            aload 2 /* accCs */
            checkcast com.sun.security.auth.SubjectCodeSource
            astore 3 /* scs */
        start local 3 // com.sun.security.auth.SubjectCodeSource scs
        45: .line 1128
            aload 3 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getSubject:()Ljavax/security/auth/Subject;
            invokevirtual javax.security.auth.Subject.getPrincipals:()Ljava/util/Set;
            astore 4 /* principalSet */
        start local 4 // java.util.Set principalSet
        46: .line 1130
            aload 4 /* principalSet */
            invokeinterface java.util.Set.size:()I
            iconst_2
            multianewarray [[Ljava/lang/String; 2
            astore 5 /* info */
        start local 5 // java.lang.String[][] info
        47: .line 1131
            aload 4 /* principalSet */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 6 /* pIterator */
        start local 6 // java.util.Iterator pIterator
        48: .line 1133
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        49: .line 1134
            goto 54
        50: .line 1135
      StackMap locals: com.sun.security.auth.PolicyFile com.sun.security.auth.PolicyParser$PrincipalEntry java.security.CodeSource com.sun.security.auth.SubjectCodeSource java.util.Set java.lang.String[][] java.util.Iterator int
      StackMap stack:
            aload 6 /* pIterator */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.Principal
            astore 8 /* p */
        start local 8 // java.security.Principal p
        51: .line 1136
            aload 5 /* info */
            iload 7 /* i */
            aaload
            iconst_0
            aload 8 /* p */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            aastore
        52: .line 1137
            aload 5 /* info */
            iload 7 /* i */
            aaload
            iconst_1
            aload 8 /* p */
            invokeinterface java.security.Principal.getName:()Ljava/lang/String;
            aastore
        53: .line 1138
            iinc 7 /* i */ 1
        end local 8 // java.security.Principal p
        54: .line 1134
      StackMap locals:
      StackMap stack:
            aload 6 /* pIterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 50
        55: .line 1140
            aload 5 /* info */
            areturn
        end local 7 // int i
        end local 6 // java.util.Iterator pIterator
        end local 5 // java.lang.String[][] info
        end local 4 // java.util.Set principalSet
        end local 3 // com.sun.security.auth.SubjectCodeSource scs
        end local 2 // java.security.CodeSource accCs
        end local 1 // com.sun.security.auth.PolicyParser$PrincipalEntry principal
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   56     0          this  Lcom/sun/security/auth/PolicyFile;
            0   56     1     principal  Lcom/sun/security/auth/PolicyParser$PrincipalEntry;
            0   56     2         accCs  Ljava/security/CodeSource;
            9   12     3          info  [[Ljava/lang/String;
           21   44     3           scs  Lcom/sun/security/auth/SubjectCodeSource;
           22   44     4  principalSet  Ljava/util/Set<+Ljava/security/Principal;>;
           26   27     5        pClass  Ljava/lang/Class<+Ljava/security/Principal;>;
           29   33     5             e  Ljava/lang/Exception;
           36   44     5          info  [[Ljava/lang/String;
           37   44     6             i  I
           39   42     7             p  Ljava/security/Principal;
           45   56     3           scs  Lcom/sun/security/auth/SubjectCodeSource;
           46   56     4  principalSet  Ljava/util/Set<Ljava/security/Principal;>;
           47   56     5          info  [[Ljava/lang/String;
           48   56     6     pIterator  Ljava/util/Iterator<Ljava/security/Principal;>;
           49   56     7             i  I
           51   54     8             p  Ljava/security/Principal;
      Exception table:
        from    to  target  type
          22    27      28  Class java.lang.Exception
    MethodParameters:
           Name  Flags
      principal  
      accCs      final

  java.security.cert.Certificate[] getSignerCertificates(java.security.CodeSource);
    descriptor: (Ljava/security/CodeSource;)[Ljava/security/cert/Certificate;
    flags: (0x0000) 
    Code:
      stack=4, locals=7, args_size=2
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // java.security.CodeSource cs
         0: .line 1158
            aconst_null
            astore 2 /* certs */
        start local 2 // java.security.cert.Certificate[] certs
         1: .line 1159
            aload 1 /* cs */
            invokevirtual java.security.CodeSource.getCertificates:()[Ljava/security/cert/Certificate;
            dup
            astore 2 /* certs */
            ifnonnull 3
         2: .line 1160
            aconst_null
            areturn
         3: .line 1161
      StackMap locals: java.security.cert.Certificate[]
      StackMap stack:
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         4: goto 8
         5: .line 1162
      StackMap locals: int
      StackMap stack:
            aload 2 /* certs */
            iload 3 /* i */
            aaload
            instanceof java.security.cert.X509Certificate
            ifne 7
         6: .line 1163
            aload 1 /* cs */
            invokevirtual java.security.CodeSource.getCertificates:()[Ljava/security/cert/Certificate;
            areturn
         7: .line 1161
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: iload 3 /* i */
            aload 2 /* certs */
            arraylength
            if_icmplt 5
        end local 3 // int i
         9: .line 1167
            iconst_0
            istore 3 /* i */
        start local 3 // int i
        10: .line 1168
            iconst_0
            istore 4 /* count */
        start local 4 // int count
        11: .line 1169
            goto 21
        12: .line 1170
      StackMap locals: int
      StackMap stack:
            iinc 4 /* count */ 1
        13: .line 1171
            goto 15
        14: .line 1174
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
        15: .line 1171
      StackMap locals:
      StackMap stack:
            iload 3 /* i */
            iconst_1
            iadd
            aload 2 /* certs */
            arraylength
            if_icmpge 20
        16: .line 1172
            aload 2 /* certs */
            iload 3 /* i */
            aaload
            checkcast java.security.cert.X509Certificate
            invokevirtual java.security.cert.X509Certificate.getIssuerDN:()Ljava/security/Principal;
        17: .line 1173
            aload 2 /* certs */
            iload 3 /* i */
            iconst_1
            iadd
            aaload
            checkcast java.security.cert.X509Certificate
            invokevirtual java.security.cert.X509Certificate.getSubjectDN:()Ljava/security/Principal;
        18: .line 1172
            invokeinterface java.security.Principal.equals:(Ljava/lang/Object;)Z
        19: .line 1173
            ifne 14
        20: .line 1176
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
        21: .line 1169
      StackMap locals:
      StackMap stack:
            iload 3 /* i */
            aload 2 /* certs */
            arraylength
            if_icmplt 12
        22: .line 1178
            iload 4 /* count */
            aload 2 /* certs */
            arraylength
            if_icmpne 24
        23: .line 1180
            aload 2 /* certs */
            areturn
        24: .line 1182
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 5 /* userCertList */
        start local 5 // java.util.ArrayList userCertList
        25: .line 1183
            iconst_0
            istore 3 /* i */
        26: .line 1184
            goto 36
        27: .line 1185
      StackMap locals: java.util.ArrayList
      StackMap stack:
            aload 5 /* userCertList */
            aload 2 /* certs */
            iload 3 /* i */
            aaload
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        28: .line 1186
            goto 30
        29: .line 1189
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
        30: .line 1186
      StackMap locals:
      StackMap stack:
            iload 3 /* i */
            iconst_1
            iadd
            aload 2 /* certs */
            arraylength
            if_icmpge 35
        31: .line 1187
            aload 2 /* certs */
            iload 3 /* i */
            aaload
            checkcast java.security.cert.X509Certificate
            invokevirtual java.security.cert.X509Certificate.getIssuerDN:()Ljava/security/Principal;
        32: .line 1188
            aload 2 /* certs */
            iload 3 /* i */
            iconst_1
            iadd
            aaload
            checkcast java.security.cert.X509Certificate
            invokevirtual java.security.cert.X509Certificate.getSubjectDN:()Ljava/security/Principal;
        33: .line 1187
            invokeinterface java.security.Principal.equals:(Ljava/lang/Object;)Z
        34: .line 1188
            ifne 29
        35: .line 1191
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
        36: .line 1184
      StackMap locals:
      StackMap stack:
            iload 3 /* i */
            aload 2 /* certs */
            arraylength
            if_icmplt 27
        37: .line 1193
            aload 5 /* userCertList */
            invokevirtual java.util.ArrayList.size:()I
            anewarray java.security.cert.Certificate
            astore 6 /* userCerts */
        start local 6 // java.security.cert.Certificate[] userCerts
        38: .line 1194
            aload 5 /* userCertList */
            aload 6 /* userCerts */
            invokevirtual java.util.ArrayList.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            pop
        39: .line 1195
            aload 6 /* userCerts */
            areturn
        end local 6 // java.security.cert.Certificate[] userCerts
        end local 5 // java.util.ArrayList userCertList
        end local 4 // int count
        end local 3 // int i
        end local 2 // java.security.cert.Certificate[] certs
        end local 1 // java.security.CodeSource cs
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   40     0          this  Lcom/sun/security/auth/PolicyFile;
            0   40     1            cs  Ljava/security/CodeSource;
            1   40     2         certs  [Ljava/security/cert/Certificate;
            4    9     3             i  I
           10   40     3             i  I
           11   40     4         count  I
           25   40     5  userCertList  Ljava/util/ArrayList<Ljava/security/cert/Certificate;>;
           38   40     6     userCerts  [Ljava/security/cert/Certificate;
    MethodParameters:
      Name  Flags
      cs    

  private java.security.CodeSource canonicalizeCodebase(java.security.CodeSource, boolean);
    descriptor: (Ljava/security/CodeSource;Z)Ljava/security/CodeSource;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=9, args_size=3
        start local 0 // com.sun.security.auth.PolicyFile this
        start local 1 // java.security.CodeSource cs
        start local 2 // boolean extractSignerCerts
         0: .line 1200
            aload 1 /* cs */
            astore 3 /* canonCs */
        start local 3 // java.security.CodeSource canonCs
         1: .line 1201
            aload 1 /* cs */
            invokevirtual java.security.CodeSource.getLocation:()Ljava/net/URL;
            ifnull 66
         2: .line 1202
            aload 1 /* cs */
            invokevirtual java.security.CodeSource.getLocation:()Ljava/net/URL;
            invokevirtual java.net.URL.getProtocol:()Ljava/lang/String;
            ldc "file"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 66
         3: .line 1204
            aload 1 /* cs */
            invokevirtual java.security.CodeSource.getLocation:()Ljava/net/URL;
            invokevirtual java.net.URL.getFile:()Ljava/lang/String;
         4: .line 1205
            bipush 47
         5: .line 1206
            getstatic java.io.File.separatorChar:C
         6: .line 1204
            invokevirtual java.lang.String.replace:(CC)Ljava/lang/String;
            astore 4 /* path */
        start local 4 // java.lang.String path
         7: .line 1207
            aconst_null
            astore 5 /* csUrl */
        start local 5 // java.net.URL csUrl
         8: .line 1208
            aload 4 /* path */
            ldc "*"
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 24
         9: .line 1211
            aload 4 /* path */
            iconst_0
            aload 4 /* path */
            invokevirtual java.lang.String.length:()I
            iconst_1
            isub
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 4 /* path */
        10: .line 1212
            iconst_0
            istore 6 /* appendFileSep */
        start local 6 // boolean appendFileSep
        11: .line 1213
            aload 4 /* path */
            getstatic java.io.File.separator:Ljava/lang/String;
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifeq 13
        12: .line 1214
            iconst_1
            istore 6 /* appendFileSep */
        13: .line 1215
      StackMap locals: com.sun.security.auth.PolicyFile java.security.CodeSource int java.security.CodeSource java.lang.String java.net.URL int
      StackMap stack:
            aload 4 /* path */
            ldc ""
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 15
        14: .line 1216
            ldc "user.dir"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 4 /* path */
        15: .line 1218
      StackMap locals:
      StackMap stack:
            new java.io.File
            dup
            aload 4 /* path */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            astore 7 /* f */
        start local 7 // java.io.File f
        16: .line 1219
            aload 7 /* f */
            invokevirtual java.io.File.getCanonicalPath:()Ljava/lang/String;
            astore 4 /* path */
        17: .line 1220
            new java.lang.StringBuffer
            dup
            aload 4 /* path */
            invokespecial java.lang.StringBuffer.<init>:(Ljava/lang/String;)V
            astore 8 /* sb */
        start local 8 // java.lang.StringBuffer sb
        18: .line 1224
            aload 4 /* path */
            getstatic java.io.File.separator:Ljava/lang/String;
            invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
            ifne 21
        19: .line 1225
            iload 6 /* appendFileSep */
            ifne 20
            aload 7 /* f */
            invokevirtual java.io.File.isDirectory:()Z
            ifeq 21
        20: .line 1226
      StackMap locals: java.io.File java.lang.StringBuffer
      StackMap stack:
            aload 8 /* sb */
            getstatic java.io.File.separatorChar:C
            invokevirtual java.lang.StringBuffer.append:(C)Ljava/lang/StringBuffer;
            pop
        21: .line 1227
      StackMap locals:
      StackMap stack:
            aload 8 /* sb */
            bipush 42
            invokevirtual java.lang.StringBuffer.append:(C)Ljava/lang/StringBuffer;
            pop
        22: .line 1228
            aload 8 /* sb */
            invokevirtual java.lang.StringBuffer.toString:()Ljava/lang/String;
            astore 4 /* path */
        end local 8 // java.lang.StringBuffer sb
        end local 7 // java.io.File f
        end local 6 // boolean appendFileSep
        23: .line 1229
            goto 25
        24: .line 1230
      StackMap locals:
      StackMap stack:
            new java.io.File
            dup
            aload 4 /* path */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            invokevirtual java.io.File.getCanonicalPath:()Ljava/lang/String;
            astore 4 /* path */
        25: .line 1232
      StackMap locals:
      StackMap stack:
            new java.io.File
            dup
            aload 4 /* path */
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            invokevirtual java.io.File.toURL:()Ljava/net/URL;
            astore 5 /* csUrl */
        26: .line 1234
            aload 1 /* cs */
            instanceof com.sun.security.auth.SubjectCodeSource
            ifeq 43
        27: .line 1235
            aload 1 /* cs */
            checkcast com.sun.security.auth.SubjectCodeSource
            astore 6 /* scs */
        start local 6 // com.sun.security.auth.SubjectCodeSource scs
        28: .line 1236
            iload 2 /* extractSignerCerts */
            ifeq 36
        29: .line 1237
            new com.sun.security.auth.SubjectCodeSource
            dup
        30: .line 1238
            aload 6 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getSubject:()Ljavax/security/auth/Subject;
        31: .line 1239
            aload 6 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getPrincipals:()Ljava/util/LinkedList;
        32: .line 1240
            aload 5 /* csUrl */
        33: .line 1241
            aload 0 /* this */
            aload 6 /* scs */
            invokevirtual com.sun.security.auth.PolicyFile.getSignerCertificates:(Ljava/security/CodeSource;)[Ljava/security/cert/Certificate;
        34: .line 1237
            invokespecial com.sun.security.auth.SubjectCodeSource.<init>:(Ljavax/security/auth/Subject;Ljava/util/LinkedList;Ljava/net/URL;[Ljava/security/cert/Certificate;)V
            astore 3 /* canonCs */
        35: .line 1242
            goto 78
        36: .line 1243
      StackMap locals: com.sun.security.auth.SubjectCodeSource
      StackMap stack:
            new com.sun.security.auth.SubjectCodeSource
            dup
        37: .line 1244
            aload 6 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getSubject:()Ljavax/security/auth/Subject;
        38: .line 1245
            aload 6 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getPrincipals:()Ljava/util/LinkedList;
        39: .line 1246
            aload 5 /* csUrl */
        40: .line 1247
            aload 6 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getCertificates:()[Ljava/security/cert/Certificate;
        41: .line 1243
            invokespecial com.sun.security.auth.SubjectCodeSource.<init>:(Ljavax/security/auth/Subject;Ljava/util/LinkedList;Ljava/net/URL;[Ljava/security/cert/Certificate;)V
            astore 3 /* canonCs */
        end local 6 // com.sun.security.auth.SubjectCodeSource scs
        42: .line 1249
            goto 78
        43: .line 1250
      StackMap locals:
      StackMap stack:
            iload 2 /* extractSignerCerts */
            ifeq 48
        44: .line 1251
            new java.security.CodeSource
            dup
            aload 5 /* csUrl */
        45: .line 1252
            aload 0 /* this */
            aload 1 /* cs */
            invokevirtual com.sun.security.auth.PolicyFile.getSignerCertificates:(Ljava/security/CodeSource;)[Ljava/security/cert/Certificate;
        46: .line 1251
            invokespecial java.security.CodeSource.<init>:(Ljava/net/URL;[Ljava/security/cert/Certificate;)V
            astore 3 /* canonCs */
        47: .line 1253
            goto 78
        48: .line 1254
      StackMap locals:
      StackMap stack:
            new java.security.CodeSource
            dup
            aload 5 /* csUrl */
        49: .line 1255
            aload 1 /* cs */
            invokevirtual java.security.CodeSource.getCertificates:()[Ljava/security/cert/Certificate;
        50: .line 1254
            invokespecial java.security.CodeSource.<init>:(Ljava/net/URL;[Ljava/security/cert/Certificate;)V
            astore 3 /* canonCs */
        end local 5 // java.net.URL csUrl
        end local 4 // java.lang.String path
        51: .line 1258
            goto 78
      StackMap locals: com.sun.security.auth.PolicyFile java.security.CodeSource int java.security.CodeSource
      StackMap stack: java.io.IOException
        52: pop
        53: .line 1261
            iload 2 /* extractSignerCerts */
            ifeq 78
        54: .line 1262
            aload 1 /* cs */
            instanceof com.sun.security.auth.SubjectCodeSource
            ifne 59
        55: .line 1263
            new java.security.CodeSource
            dup
            aload 1 /* cs */
            invokevirtual java.security.CodeSource.getLocation:()Ljava/net/URL;
        56: .line 1264
            aload 0 /* this */
            aload 1 /* cs */
            invokevirtual com.sun.security.auth.PolicyFile.getSignerCertificates:(Ljava/security/CodeSource;)[Ljava/security/cert/Certificate;
        57: .line 1263
            invokespecial java.security.CodeSource.<init>:(Ljava/net/URL;[Ljava/security/cert/Certificate;)V
            astore 3 /* canonCs */
        58: .line 1265
            goto 78
        59: .line 1266
      StackMap locals:
      StackMap stack:
            aload 1 /* cs */
            checkcast com.sun.security.auth.SubjectCodeSource
            astore 4 /* scs */
        start local 4 // com.sun.security.auth.SubjectCodeSource scs
        60: .line 1267
            new com.sun.security.auth.SubjectCodeSource
            dup
            aload 4 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getSubject:()Ljavax/security/auth/Subject;
        61: .line 1268
            aload 4 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getPrincipals:()Ljava/util/LinkedList;
        62: .line 1269
            aload 4 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getLocation:()Ljava/net/URL;
        63: .line 1270
            aload 0 /* this */
            aload 4 /* scs */
            invokevirtual com.sun.security.auth.PolicyFile.getSignerCertificates:(Ljava/security/CodeSource;)[Ljava/security/cert/Certificate;
        64: .line 1267
            invokespecial com.sun.security.auth.SubjectCodeSource.<init>:(Ljavax/security/auth/Subject;Ljava/util/LinkedList;Ljava/net/URL;[Ljava/security/cert/Certificate;)V
            astore 3 /* canonCs */
        end local 4 // com.sun.security.auth.SubjectCodeSource scs
        65: .line 1274
            goto 78
        66: .line 1275
      StackMap locals:
      StackMap stack:
            iload 2 /* extractSignerCerts */
            ifeq 78
        67: .line 1276
            aload 1 /* cs */
            instanceof com.sun.security.auth.SubjectCodeSource
            ifne 72
        68: .line 1277
            new java.security.CodeSource
            dup
            aload 1 /* cs */
            invokevirtual java.security.CodeSource.getLocation:()Ljava/net/URL;
        69: .line 1278
            aload 0 /* this */
            aload 1 /* cs */
            invokevirtual com.sun.security.auth.PolicyFile.getSignerCertificates:(Ljava/security/CodeSource;)[Ljava/security/cert/Certificate;
        70: .line 1277
            invokespecial java.security.CodeSource.<init>:(Ljava/net/URL;[Ljava/security/cert/Certificate;)V
            astore 3 /* canonCs */
        71: .line 1279
            goto 78
        72: .line 1280
      StackMap locals:
      StackMap stack:
            aload 1 /* cs */
            checkcast com.sun.security.auth.SubjectCodeSource
            astore 4 /* scs */
        start local 4 // com.sun.security.auth.SubjectCodeSource scs
        73: .line 1281
            new com.sun.security.auth.SubjectCodeSource
            dup
            aload 4 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getSubject:()Ljavax/security/auth/Subject;
        74: .line 1282
            aload 4 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getPrincipals:()Ljava/util/LinkedList;
        75: .line 1283
            aload 4 /* scs */
            invokevirtual com.sun.security.auth.SubjectCodeSource.getLocation:()Ljava/net/URL;
        76: .line 1284
            aload 0 /* this */
            aload 4 /* scs */
            invokevirtual com.sun.security.auth.PolicyFile.getSignerCertificates:(Ljava/security/CodeSource;)[Ljava/security/cert/Certificate;
        77: .line 1281
            invokespecial com.sun.security.auth.SubjectCodeSource.<init>:(Ljavax/security/auth/Subject;Ljava/util/LinkedList;Ljava/net/URL;[Ljava/security/cert/Certificate;)V
            astore 3 /* canonCs */
        end local 4 // com.sun.security.auth.SubjectCodeSource scs
        78: .line 1288
      StackMap locals:
      StackMap stack:
            aload 3 /* canonCs */
            areturn
        end local 3 // java.security.CodeSource canonCs
        end local 2 // boolean extractSignerCerts
        end local 1 // java.security.CodeSource cs
        end local 0 // com.sun.security.auth.PolicyFile this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   79     0                this  Lcom/sun/security/auth/PolicyFile;
            0   79     1                  cs  Ljava/security/CodeSource;
            0   79     2  extractSignerCerts  Z
            1   79     3             canonCs  Ljava/security/CodeSource;
            7   51     4                path  Ljava/lang/String;
            8   51     5               csUrl  Ljava/net/URL;
           11   23     6       appendFileSep  Z
           16   23     7                   f  Ljava/io/File;
           18   23     8                  sb  Ljava/lang/StringBuffer;
           28   42     6                 scs  Lcom/sun/security/auth/SubjectCodeSource;
           60   65     4                 scs  Lcom/sun/security/auth/SubjectCodeSource;
           73   78     4                 scs  Lcom/sun/security/auth/SubjectCodeSource;
      Exception table:
        from    to  target  type
           3    51      52  Class java.io.IOException
    MethodParameters:
                    Name  Flags
      cs                  
      extractSignerCerts  
}
SourceFile: "PolicyFile.java"
NestMembers:
  com.sun.security.auth.PolicyFile$1  com.sun.security.auth.PolicyFile$2  com.sun.security.auth.PolicyFile$3  com.sun.security.auth.PolicyFile$PolicyEntry
InnerClasses:
  com.sun.security.auth.PolicyFile$1
  com.sun.security.auth.PolicyFile$2
  com.sun.security.auth.PolicyFile$3
  private PolicyEntry = com.sun.security.auth.PolicyFile$PolicyEntry of com.sun.security.auth.PolicyFile
  GrantEntry = com.sun.security.auth.PolicyParser$GrantEntry of com.sun.security.auth.PolicyParser
  ParsingException = com.sun.security.auth.PolicyParser$ParsingException of com.sun.security.auth.PolicyParser
  PermissionEntry = com.sun.security.auth.PolicyParser$PermissionEntry of com.sun.security.auth.PolicyParser
  PrincipalEntry = com.sun.security.auth.PolicyParser$PrincipalEntry of com.sun.security.auth.PolicyParser
    RuntimeVisibleAnnotations: 
      java.lang.Deprecated()