class com.sun.security.auth.PolicyFile$3 implements java.security.PrivilegedAction<java.security.PermissionCollection>
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: com.sun.security.auth.PolicyFile$3
  super_class: java.lang.Object
{
  final com.sun.security.auth.PolicyFile this$0;
    descriptor: Lcom/sun/security/auth/PolicyFile;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  private final javax.security.auth.Subject val$subject;
    descriptor: Ljavax/security/auth/Subject;
    flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC

  private final java.security.CodeSource val$codesource;
    descriptor: Ljava/security/CodeSource;
    flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC

  void <init>(com.sun.security.auth.PolicyFile, javax.security.auth.Subject, java.security.CodeSource);
    descriptor: (Lcom/sun/security/auth/PolicyFile;Ljavax/security/auth/Subject;Ljava/security/CodeSource;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // com.sun.security.auth.PolicyFile$3 this
         0: .line 841
            aload 0 /* this */
            aload 1
            putfield com.sun.security.auth.PolicyFile$3.this$0:Lcom/sun/security/auth/PolicyFile;
            aload 0 /* this */
            aload 2
            putfield com.sun.security.auth.PolicyFile$3.val$subject:Ljavax/security/auth/Subject;
            aload 0 /* this */
            aload 3
            putfield com.sun.security.auth.PolicyFile$3.val$codesource:Ljava/security/CodeSource;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // com.sun.security.auth.PolicyFile$3 this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/sun/security/auth/PolicyFile$3;
    MethodParameters:
                Name  Flags
      this$0          final
      val$subject     final
      val$codesource  final

  public java.security.PermissionCollection run();
    descriptor: ()Ljava/security/PermissionCollection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=2, args_size=1
        start local 0 // com.sun.security.auth.PolicyFile$3 this
         0: .line 843
            new com.sun.security.auth.SubjectCodeSource
            dup
         1: .line 844
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile$3.val$subject:Ljavax/security/auth/Subject;
         2: .line 845
            aconst_null
         3: .line 846
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile$3.val$codesource:Ljava/security/CodeSource;
            ifnonnull 4
            aconst_null
            goto 5
      StackMap locals: com.sun.security.auth.PolicyFile$3
      StackMap stack: new 0 new 0 javax.security.auth.Subject null
         4: aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile$3.val$codesource:Ljava/security/CodeSource;
            invokevirtual java.security.CodeSource.getLocation:()Ljava/net/URL;
         5: .line 847
      StackMap locals: com.sun.security.auth.PolicyFile$3
      StackMap stack: new 0 new 0 javax.security.auth.Subject null java.net.URL
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile$3.val$codesource:Ljava/security/CodeSource;
            ifnonnull 6
            aconst_null
            goto 7
      StackMap locals: com.sun.security.auth.PolicyFile$3
      StackMap stack: new 0 new 0 javax.security.auth.Subject null java.net.URL
         6: aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile$3.val$codesource:Ljava/security/CodeSource;
            invokevirtual java.security.CodeSource.getCertificates:()[Ljava/security/cert/Certificate;
         7: .line 843
      StackMap locals: com.sun.security.auth.PolicyFile$3
      StackMap stack: new 0 new 0 javax.security.auth.Subject null java.net.URL java.security.cert.Certificate[]
            invokespecial com.sun.security.auth.SubjectCodeSource.<init>:(Ljavax/security/auth/Subject;Ljava/util/LinkedList;Ljava/net/URL;[Ljava/security/cert/Certificate;)V
            astore 1 /* scs */
        start local 1 // com.sun.security.auth.SubjectCodeSource scs
         8: .line 848
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile$3.this$0:Lcom/sun/security/auth/PolicyFile;
            getfield com.sun.security.auth.PolicyFile.initialized:Z
            ifeq 10
         9: .line 849
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile$3.this$0:Lcom/sun/security/auth/PolicyFile;
            new java.security.Permissions
            dup
            invokespecial java.security.Permissions.<init>:()V
            aload 1 /* scs */
            invokevirtual com.sun.security.auth.PolicyFile.getPermissions:(Ljava/security/Permissions;Ljava/security/CodeSource;)Ljava/security/Permissions;
            areturn
        10: .line 851
      StackMap locals: com.sun.security.auth.SubjectCodeSource
      StackMap stack:
            new com.sun.security.auth.PolicyPermissions
            dup
            aload 0 /* this */
            getfield com.sun.security.auth.PolicyFile$3.this$0:Lcom/sun/security/auth/PolicyFile;
            aload 1 /* scs */
            invokespecial com.sun.security.auth.PolicyPermissions.<init>:(Lcom/sun/security/auth/PolicyFile;Ljava/security/CodeSource;)V
            areturn
        end local 1 // com.sun.security.auth.SubjectCodeSource scs
        end local 0 // com.sun.security.auth.PolicyFile$3 this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lcom/sun/security/auth/PolicyFile$3;
            8   11     1   scs  Lcom/sun/security/auth/SubjectCodeSource;

  public java.lang.Object run();
    descriptor: ()Ljava/lang/Object;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual com.sun.security.auth.PolicyFile$3.run:()Ljava/security/PermissionCollection;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
Signature: Ljava/lang/Object;Ljava/security/PrivilegedAction<Ljava/security/PermissionCollection;>;
SourceFile: "PolicyFile.java"
EnclosingMethod: com.sun.security.auth.PolicyFile.getPermissions:(Ljavax/security/auth/Subject;Ljava/security/CodeSource;)Ljava/security/PermissionCollection;
NestHost: com.sun.security.auth.PolicyFile
InnerClasses:
  com.sun.security.auth.PolicyFile$3
  PrincipalEntry = com.sun.security.auth.PolicyParser$PrincipalEntry of com.sun.security.auth.PolicyParser