class com.google.crypto.tink.Registry$4 implements com.google.crypto.tink.Registry$KeyDeriverContainer
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: com.google.crypto.tink.Registry$4
  super_class: java.lang.Object
{
  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.google.crypto.tink.Registry$4 this
         0: .line 281
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // com.google.crypto.tink.Registry$4 this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/google/crypto/tink/Registry$4;

  private <KeyFormatProtoT extends com.google.protobuf.MessageLite> com.google.protobuf.MessageLite deriveKeyWithFactory(com.google.protobuf.ByteString, java.io.InputStream, com.google.crypto.tink.KeyTypeManager$KeyFactory<KeyFormatProtoT, KeyProtoT>);
    descriptor: (Lcom/google/protobuf/ByteString;Ljava/io/InputStream;Lcom/google/crypto/tink/KeyTypeManager$KeyFactory;)Lcom/google/protobuf/MessageLite;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=6, args_size=4
        start local 0 // com.google.crypto.tink.Registry$4 this
        start local 1 // com.google.protobuf.ByteString serializedKeyFormat
        start local 2 // java.io.InputStream stream
        start local 3 // com.google.crypto.tink.KeyTypeManager$KeyFactory keyFactory
         0: .line 289
            aload 3 /* keyFactory */
            aload 1 /* serializedKeyFormat */
            invokevirtual com.google.crypto.tink.KeyTypeManager$KeyFactory.parseKeyFormat:(Lcom/google/protobuf/ByteString;)Lcom/google/protobuf/MessageLite;
            astore 4 /* keyFormat */
        start local 4 // com.google.protobuf.MessageLite keyFormat
         1: .line 290
            goto 4
        end local 4 // com.google.protobuf.MessageLite keyFormat
      StackMap locals:
      StackMap stack: com.google.protobuf.InvalidProtocolBufferException
         2: astore 5 /* e */
        start local 5 // com.google.protobuf.InvalidProtocolBufferException e
         3: .line 291
            new java.security.GeneralSecurityException
            dup
            ldc "parsing key format failed in deriveKey"
            aload 5 /* e */
            invokespecial java.security.GeneralSecurityException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // com.google.protobuf.InvalidProtocolBufferException e
        start local 4 // com.google.protobuf.MessageLite keyFormat
         4: .line 293
      StackMap locals: com.google.protobuf.MessageLite
      StackMap stack:
            aload 3 /* keyFactory */
            aload 4 /* keyFormat */
            invokevirtual com.google.crypto.tink.KeyTypeManager$KeyFactory.validateKeyFormat:(Lcom/google/protobuf/MessageLite;)V
         5: .line 294
            aload 3 /* keyFactory */
            aload 4 /* keyFormat */
            aload 2 /* stream */
            invokevirtual com.google.crypto.tink.KeyTypeManager$KeyFactory.deriveKey:(Lcom/google/protobuf/MessageLite;Ljava/io/InputStream;)Ljava/lang/Object;
            checkcast com.google.protobuf.MessageLite
            areturn
        end local 4 // com.google.protobuf.MessageLite keyFormat
        end local 3 // com.google.crypto.tink.KeyTypeManager$KeyFactory keyFactory
        end local 2 // java.io.InputStream stream
        end local 1 // com.google.protobuf.ByteString serializedKeyFormat
        end local 0 // com.google.crypto.tink.Registry$4 this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    6     0                 this  Lcom/google/crypto/tink/Registry$4;
            0    6     1  serializedKeyFormat  Lcom/google/protobuf/ByteString;
            0    6     2               stream  Ljava/io/InputStream;
            0    6     3           keyFactory  Lcom/google/crypto/tink/KeyTypeManager$KeyFactory<TKeyFormatProtoT;TKeyProtoT;>;
            1    2     4            keyFormat  TKeyFormatProtoT;
            4    6     4            keyFormat  TKeyFormatProtoT;
            3    4     5                    e  Lcom/google/protobuf/InvalidProtocolBufferException;
      Exception table:
        from    to  target  type
           0     1       2  Class com.google.protobuf.InvalidProtocolBufferException
    Exceptions:
      throws java.security.GeneralSecurityException
    Signature: <KeyFormatProtoT::Lcom/google/protobuf/MessageLite;>(Lcom/google/protobuf/ByteString;Ljava/io/InputStream;Lcom/google/crypto/tink/KeyTypeManager$KeyFactory<TKeyFormatProtoT;TKeyProtoT;>;)Lcom/google/protobuf/MessageLite;
    MethodParameters:
                     Name  Flags
      serializedKeyFormat  
      stream               
      keyFactory           

  public KeyData deriveKey(com.google.protobuf.ByteString, java.io.InputStream);
    descriptor: (Lcom/google/protobuf/ByteString;Ljava/io/InputStream;)LKeyData;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // com.google.crypto.tink.Registry$4 this
         0: .line 298
            new java.lang.Error
            dup
            ldc "Unresolved compilation problems: \n\tKeyData cannot be resolved to a type\n\tKeyData cannot be resolved to a type\n\tKeyData cannot be resolved\n\tThe method keyMaterialType() from the type KeyTypeManager<KeyProtoT> refers to the missing type KeyMaterialType\n"
            invokespecial java.lang.Error.<init>:(Ljava/lang/String;)V
            athrow
        end local 0 // com.google.crypto.tink.Registry$4 this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/google/crypto/tink/Registry$4;
    Exceptions:
      throws java.security.GeneralSecurityException
    MethodParameters:
                     Name  Flags
      serializedKeyFormat  
      stream               

  public KeyData deriveKey(com.google.protobuf.ByteString, java.io.InputStream);
    descriptor: (Lcom/google/protobuf/ByteString;Ljava/io/InputStream;)LKeyData;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
         0: .line 1
            aload 0
            aload 1
            aload 2
            invokevirtual com.google.crypto.tink.Registry$4.deriveKey:(Lcom/google/protobuf/ByteString;Ljava/io/InputStream;)LKeyData;
            checkcast KeyData
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.security.GeneralSecurityException
}
SourceFile: "Registry.java"
EnclosingMethod: com.google.crypto.tink.Registry.createDeriverFor:(Lcom/google/crypto/tink/KeyTypeManager;)Lcom/google/crypto/tink/Registry$KeyDeriverContainer;
NestHost: com.google.crypto.tink.Registry
InnerClasses:
  public abstract KeyFactory = com.google.crypto.tink.KeyTypeManager$KeyFactory of com.google.crypto.tink.KeyTypeManager
  com.google.crypto.tink.Registry$4
  private abstract KeyDeriverContainer = com.google.crypto.tink.Registry$KeyDeriverContainer of com.google.crypto.tink.Registry