class javax.security.auth.kerberos.KrbServicePermissionCollection$1 implements java.util.function.BiFunction<java.security.Permission, java.security.Permission, java.security.Permission>
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: javax.security.auth.kerberos.KrbServicePermissionCollection$1
  super_class: java.lang.Object
{
  final javax.security.auth.kerberos.KrbServicePermissionCollection this$0;
    descriptor: Ljavax/security/auth/kerberos/KrbServicePermissionCollection;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  private final java.lang.String val$princName;
    descriptor: Ljava/lang/String;
    flags: (0x1012) ACC_PRIVATE, ACC_FINAL, ACC_SYNTHETIC

  void <init>(javax.security.auth.kerberos.KrbServicePermissionCollection, java.lang.String);
    descriptor: (Ljavax/security/auth/kerberos/KrbServicePermissionCollection;Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // javax.security.auth.kerberos.KrbServicePermissionCollection$1 this
         0: .line 575
            aload 0 /* this */
            aload 1
            putfield javax.security.auth.kerberos.KrbServicePermissionCollection$1.this$0:Ljavax/security/auth/kerberos/KrbServicePermissionCollection;
            aload 0 /* this */
            aload 2
            putfield javax.security.auth.kerberos.KrbServicePermissionCollection$1.val$princName:Ljava/lang/String;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // javax.security.auth.kerberos.KrbServicePermissionCollection$1 this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/kerberos/KrbServicePermissionCollection$1;
    MethodParameters:
               Name  Flags
      this$0         final
      val$princName  final

  public java.security.Permission apply(java.security.Permission, java.security.Permission);
    descriptor: (Ljava/security/Permission;Ljava/security/Permission;)Ljava/security/Permission;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // javax.security.auth.kerberos.KrbServicePermissionCollection$1 this
        start local 1 // java.security.Permission existingVal
        start local 2 // java.security.Permission newVal
         0: .line 579
            aload 1 /* existingVal */
            checkcast javax.security.auth.kerberos.ServicePermission
            invokevirtual javax.security.auth.kerberos.ServicePermission.getMask:()I
            istore 3 /* oldMask */
        start local 3 // int oldMask
         1: .line 580
            aload 2 /* newVal */
            checkcast javax.security.auth.kerberos.ServicePermission
            invokevirtual javax.security.auth.kerberos.ServicePermission.getMask:()I
            istore 4 /* newMask */
        start local 4 // int newMask
         2: .line 581
            iload 3 /* oldMask */
            iload 4 /* newMask */
            if_icmpeq 8
         3: .line 582
            iload 3 /* oldMask */
            iload 4 /* newMask */
            ior
            istore 5 /* effective */
        start local 5 // int effective
         4: .line 583
            iload 5 /* effective */
            iload 4 /* newMask */
            if_icmpne 6
         5: .line 584
            aload 2 /* newVal */
            areturn
         6: .line 586
      StackMap locals: int int int
      StackMap stack:
            iload 5 /* effective */
            iload 3 /* oldMask */
            if_icmpeq 8
         7: .line 587
            new javax.security.auth.kerberos.ServicePermission
            dup
            aload 0 /* this */
            getfield javax.security.auth.kerberos.KrbServicePermissionCollection$1.val$princName:Ljava/lang/String;
            iload 5 /* effective */
            invokespecial javax.security.auth.kerberos.ServicePermission.<init>:(Ljava/lang/String;I)V
            areturn
        end local 5 // int effective
         8: .line 590
      StackMap locals:
      StackMap stack:
            aload 1 /* existingVal */
            areturn
        end local 4 // int newMask
        end local 3 // int oldMask
        end local 2 // java.security.Permission newVal
        end local 1 // java.security.Permission existingVal
        end local 0 // javax.security.auth.kerberos.KrbServicePermissionCollection$1 this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    9     0         this  Ljavax/security/auth/kerberos/KrbServicePermissionCollection$1;
            0    9     1  existingVal  Ljava/security/Permission;
            0    9     2       newVal  Ljava/security/Permission;
            1    9     3      oldMask  I
            2    9     4      newMask  I
            4    8     5    effective  I
    MethodParameters:
             Name  Flags
      existingVal  
      newVal       

  public java.lang.Object apply(java.lang.Object, java.lang.Object);
    descriptor: (Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
         0: .line 1
            aload 0
            aload 1
            checkcast java.security.Permission
            aload 2
            checkcast java.security.Permission
            invokevirtual javax.security.auth.kerberos.KrbServicePermissionCollection$1.apply:(Ljava/security/Permission;Ljava/security/Permission;)Ljava/security/Permission;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
Signature: Ljava/lang/Object;Ljava/util/function/BiFunction<Ljava/security/Permission;Ljava/security/Permission;Ljava/security/Permission;>;
SourceFile: "ServicePermission.java"
EnclosingMethod: javax.security.auth.kerberos.KrbServicePermissionCollection.add:(Ljava/security/Permission;)V
NestHost: javax.security.auth.kerberos.KrbServicePermissionCollection
InnerClasses:
  javax.security.auth.kerberos.KrbServicePermissionCollection$1