This page hosts a formal specification of .class file format using Kaitai Struct. This specification can be automatically translated into a variety of programming languages to get a parsing library.
All parsing code for C++98/STL generated by Kaitai Struct depends on the C++/STL runtime library. You have to install it before you can parse data.
For C++, the easiest way is to clone the runtime library sources and build them along with your project.
Using Kaitai Struct in C++/STL usually consists of 3 steps.
std::istream
). One can open local file for that, or use existing std::string
or char*
buffer.
#include <fstream>
std::ifstream is("path/to/local/file.class", std::ifstream::binary);
#include <sstream>
std::istringstream is(str);
#include <sstream>
const char buf[] = { ... };
std::string str(buf, sizeof buf);
std::istringstream is(str);
#include "kaitai/kaitaistream.h"
kaitai::kstream ks(&is);
java_class_t data(&ks);
After that, one can get various attributes from the structure by invoking getter methods like:
data.magic() // => get magic
#ifndef JAVA_CLASS_H_
#define JAVA_CLASS_H_
// This is a generated file! Please edit source .ksy file and use kaitai-struct-compiler to rebuild
#include "kaitai/kaitaistruct.h"
#include <stdint.h>
#include <vector>
#if KAITAI_STRUCT_VERSION < 9000L
#error "Incompatible Kaitai Struct C++/STL API: version 0.9 or later is required"
#endif
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se19/html/jvms-4.html Source
* \sa https://docs.oracle.com/javase/specs/jls/se6/jls3.pdf Source
* \sa https://github.com/openjdk/jdk/blob/jdk-21%2B14/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/runtime/ClassConstants.java Source
* \sa https://github.com/openjdk/jdk/blob/jdk-21%2B14/src/java.base/share/native/include/classfile_constants.h.template Source
* \sa https://github.com/openjdk/jdk/blob/jdk-21%2B14/src/hotspot/share/classfile/classFileParser.cpp Source
*/
class java_class_t : public kaitai::kstruct {
public:
class version_guard_t;
class float_cp_info_t;
class attribute_info_t;
class method_ref_cp_info_t;
class field_info_t;
class double_cp_info_t;
class dynamic_cp_info_t;
class long_cp_info_t;
class invoke_dynamic_cp_info_t;
class method_handle_cp_info_t;
class module_package_cp_info_t;
class name_and_type_cp_info_t;
class utf8_cp_info_t;
class string_cp_info_t;
class method_type_cp_info_t;
class interface_method_ref_cp_info_t;
class class_cp_info_t;
class constant_pool_entry_t;
class method_info_t;
class integer_cp_info_t;
class field_ref_cp_info_t;
java_class_t(kaitai::kstream* p__io, kaitai::kstruct* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~java_class_t();
/**
* `class` file format version 45.3 (appeared in the very first publicly
* known release of Java SE AND JDK 1.0.2, released 23th January 1996) is so
* ancient that it's taken for granted. Earlier formats seem to be
* undocumented. Changes of `version_minor` don't change `class` format.
* Earlier `version_major`s likely belong to Oak programming language, the
* proprietary predecessor of Java.
* \sa James Gosling, Bill Joy and Guy Steele. The Java Language Specification. English. Ed. by Lisa Friendly. Addison-Wesley, Aug. 1996, p. 825. ISBN: 0-201-63451-1.
* \sa Frank Yellin and Tim Lindholm. The Java Virtual Machine Specification. English. Ed. by Lisa Friendly. Addison-Wesley, Sept. 1996, p. 475. ISBN: 0-201-63452-X.
*/
class version_guard_t : public kaitai::kstruct {
public:
version_guard_t(uint16_t p_major, kaitai::kstream* p__io, kaitai::kstruct* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~version_guard_t();
private:
std::string m__unnamed0;
uint16_t m_major;
java_class_t* m__root;
kaitai::kstruct* m__parent;
public:
std::string _unnamed0() const { return m__unnamed0; }
uint16_t major() const { return m_major; }
java_class_t* _root() const { return m__root; }
kaitai::kstruct* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.5 Source
*/
class float_cp_info_t : public kaitai::kstruct {
public:
float_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~float_cp_info_t();
private:
float m_value;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
float value() const { return m_value; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7 Source
*/
class attribute_info_t : public kaitai::kstruct {
public:
class attr_body_code_t;
class attr_body_exceptions_t;
class attr_body_source_file_t;
class attr_body_line_number_table_t;
attribute_info_t(kaitai::kstream* p__io, kaitai::kstruct* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~attribute_info_t();
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7.3 Source
*/
class attr_body_code_t : public kaitai::kstruct {
public:
class exception_entry_t;
attr_body_code_t(kaitai::kstream* p__io, java_class_t::attribute_info_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~attr_body_code_t();
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7.3 Source
*/
class exception_entry_t : public kaitai::kstruct {
public:
exception_entry_t(kaitai::kstream* p__io, java_class_t::attribute_info_t::attr_body_code_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~exception_entry_t();
private:
bool f_catch_exception;
constant_pool_entry_t* m_catch_exception;
bool n_catch_exception;
public:
bool _is_null_catch_exception() { catch_exception(); return n_catch_exception; };
private:
public:
constant_pool_entry_t* catch_exception();
private:
uint16_t m_start_pc;
uint16_t m_end_pc;
uint16_t m_handler_pc;
uint16_t m_catch_type;
java_class_t* m__root;
java_class_t::attribute_info_t::attr_body_code_t* m__parent;
public:
/**
* Start of a code region where exception handler is being
* active, index in code array (inclusive)
*/
uint16_t start_pc() const { return m_start_pc; }
/**
* End of a code region where exception handler is being
* active, index in code array (exclusive)
*/
uint16_t end_pc() const { return m_end_pc; }
/**
* Start of exception handler code, index in code array
*/
uint16_t handler_pc() const { return m_handler_pc; }
/**
* Exception class that this handler catches, index in constant
* pool, or 0 (catch all exceptions handler, used to implement
* `finally`).
*/
uint16_t catch_type() const { return m_catch_type; }
java_class_t* _root() const { return m__root; }
java_class_t::attribute_info_t::attr_body_code_t* _parent() const { return m__parent; }
};
private:
uint16_t m_max_stack;
uint16_t m_max_locals;
uint32_t m_code_length;
std::string m_code;
uint16_t m_exception_table_length;
std::vector<exception_entry_t*>* m_exception_table;
uint16_t m_attributes_count;
std::vector<attribute_info_t*>* m_attributes;
java_class_t* m__root;
java_class_t::attribute_info_t* m__parent;
public:
uint16_t max_stack() const { return m_max_stack; }
uint16_t max_locals() const { return m_max_locals; }
uint32_t code_length() const { return m_code_length; }
std::string code() const { return m_code; }
uint16_t exception_table_length() const { return m_exception_table_length; }
std::vector<exception_entry_t*>* exception_table() const { return m_exception_table; }
uint16_t attributes_count() const { return m_attributes_count; }
std::vector<attribute_info_t*>* attributes() const { return m_attributes; }
java_class_t* _root() const { return m__root; }
java_class_t::attribute_info_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7.5 Source
*/
class attr_body_exceptions_t : public kaitai::kstruct {
public:
class exception_table_entry_t;
attr_body_exceptions_t(kaitai::kstream* p__io, java_class_t::attribute_info_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~attr_body_exceptions_t();
class exception_table_entry_t : public kaitai::kstruct {
public:
exception_table_entry_t(kaitai::kstream* p__io, java_class_t::attribute_info_t::attr_body_exceptions_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~exception_table_entry_t();
private:
bool f_as_info;
java_class_t::class_cp_info_t* m_as_info;
public:
java_class_t::class_cp_info_t* as_info();
private:
bool f_name_as_str;
std::string m_name_as_str;
public:
std::string name_as_str();
private:
uint16_t m_index;
java_class_t* m__root;
java_class_t::attribute_info_t::attr_body_exceptions_t* m__parent;
public:
uint16_t index() const { return m_index; }
java_class_t* _root() const { return m__root; }
java_class_t::attribute_info_t::attr_body_exceptions_t* _parent() const { return m__parent; }
};
private:
uint16_t m_number_of_exceptions;
std::vector<exception_table_entry_t*>* m_exceptions;
java_class_t* m__root;
java_class_t::attribute_info_t* m__parent;
public:
uint16_t number_of_exceptions() const { return m_number_of_exceptions; }
std::vector<exception_table_entry_t*>* exceptions() const { return m_exceptions; }
java_class_t* _root() const { return m__root; }
java_class_t::attribute_info_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7.10 Source
*/
class attr_body_source_file_t : public kaitai::kstruct {
public:
attr_body_source_file_t(kaitai::kstream* p__io, java_class_t::attribute_info_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~attr_body_source_file_t();
private:
bool f_sourcefile_as_str;
std::string m_sourcefile_as_str;
public:
std::string sourcefile_as_str();
private:
uint16_t m_sourcefile_index;
java_class_t* m__root;
java_class_t::attribute_info_t* m__parent;
public:
uint16_t sourcefile_index() const { return m_sourcefile_index; }
java_class_t* _root() const { return m__root; }
java_class_t::attribute_info_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7.12 Source
*/
class attr_body_line_number_table_t : public kaitai::kstruct {
public:
class line_number_table_entry_t;
attr_body_line_number_table_t(kaitai::kstream* p__io, java_class_t::attribute_info_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~attr_body_line_number_table_t();
class line_number_table_entry_t : public kaitai::kstruct {
public:
line_number_table_entry_t(kaitai::kstream* p__io, java_class_t::attribute_info_t::attr_body_line_number_table_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~line_number_table_entry_t();
private:
uint16_t m_start_pc;
uint16_t m_line_number;
java_class_t* m__root;
java_class_t::attribute_info_t::attr_body_line_number_table_t* m__parent;
public:
uint16_t start_pc() const { return m_start_pc; }
uint16_t line_number() const { return m_line_number; }
java_class_t* _root() const { return m__root; }
java_class_t::attribute_info_t::attr_body_line_number_table_t* _parent() const { return m__parent; }
};
private:
uint16_t m_line_number_table_length;
std::vector<line_number_table_entry_t*>* m_line_number_table;
java_class_t* m__root;
java_class_t::attribute_info_t* m__parent;
public:
uint16_t line_number_table_length() const { return m_line_number_table_length; }
std::vector<line_number_table_entry_t*>* line_number_table() const { return m_line_number_table; }
java_class_t* _root() const { return m__root; }
java_class_t::attribute_info_t* _parent() const { return m__parent; }
};
private:
bool f_name_as_str;
std::string m_name_as_str;
public:
std::string name_as_str();
private:
uint16_t m_name_index;
uint32_t m_attribute_length;
kaitai::kstruct* m_info;
bool n_info;
public:
bool _is_null_info() { info(); return n_info; };
private:
java_class_t* m__root;
kaitai::kstruct* m__parent;
std::string m__raw_info;
kaitai::kstream* m__io__raw_info;
public:
uint16_t name_index() const { return m_name_index; }
uint32_t attribute_length() const { return m_attribute_length; }
kaitai::kstruct* info() const { return m_info; }
java_class_t* _root() const { return m__root; }
kaitai::kstruct* _parent() const { return m__parent; }
std::string _raw_info() const { return m__raw_info; }
kaitai::kstream* _io__raw_info() const { return m__io__raw_info; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.2 Source
*/
class method_ref_cp_info_t : public kaitai::kstruct {
public:
method_ref_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~method_ref_cp_info_t();
private:
bool f_class_as_info;
java_class_t::class_cp_info_t* m_class_as_info;
public:
java_class_t::class_cp_info_t* class_as_info();
private:
bool f_name_and_type_as_info;
java_class_t::name_and_type_cp_info_t* m_name_and_type_as_info;
public:
java_class_t::name_and_type_cp_info_t* name_and_type_as_info();
private:
uint16_t m_class_index;
uint16_t m_name_and_type_index;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
uint16_t class_index() const { return m_class_index; }
uint16_t name_and_type_index() const { return m_name_and_type_index; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.5 Source
*/
class field_info_t : public kaitai::kstruct {
public:
field_info_t(kaitai::kstream* p__io, java_class_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~field_info_t();
private:
bool f_name_as_str;
std::string m_name_as_str;
public:
std::string name_as_str();
private:
uint16_t m_access_flags;
uint16_t m_name_index;
uint16_t m_descriptor_index;
uint16_t m_attributes_count;
std::vector<attribute_info_t*>* m_attributes;
java_class_t* m__root;
java_class_t* m__parent;
public:
uint16_t access_flags() const { return m_access_flags; }
uint16_t name_index() const { return m_name_index; }
uint16_t descriptor_index() const { return m_descriptor_index; }
uint16_t attributes_count() const { return m_attributes_count; }
std::vector<attribute_info_t*>* attributes() const { return m_attributes; }
java_class_t* _root() const { return m__root; }
java_class_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.6 Source
*/
class double_cp_info_t : public kaitai::kstruct {
public:
double_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~double_cp_info_t();
private:
double m_value;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
double value() const { return m_value; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se19/html/jvms-4.html#jvms-4.4.10 Source
*/
class dynamic_cp_info_t : public kaitai::kstruct {
public:
dynamic_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~dynamic_cp_info_t();
private:
version_guard_t* m__unnamed0;
uint16_t m_bootstrap_method_attr_index;
uint16_t m_name_and_type_index;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
version_guard_t* _unnamed0() const { return m__unnamed0; }
uint16_t bootstrap_method_attr_index() const { return m_bootstrap_method_attr_index; }
uint16_t name_and_type_index() const { return m_name_and_type_index; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.5 Source
*/
class long_cp_info_t : public kaitai::kstruct {
public:
long_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~long_cp_info_t();
private:
uint64_t m_value;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
uint64_t value() const { return m_value; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.10 Source
*/
class invoke_dynamic_cp_info_t : public kaitai::kstruct {
public:
invoke_dynamic_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~invoke_dynamic_cp_info_t();
private:
version_guard_t* m__unnamed0;
uint16_t m_bootstrap_method_attr_index;
uint16_t m_name_and_type_index;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
version_guard_t* _unnamed0() const { return m__unnamed0; }
uint16_t bootstrap_method_attr_index() const { return m_bootstrap_method_attr_index; }
uint16_t name_and_type_index() const { return m_name_and_type_index; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.8 Source
*/
class method_handle_cp_info_t : public kaitai::kstruct {
public:
enum reference_kind_enum_t {
REFERENCE_KIND_ENUM_GET_FIELD = 1,
REFERENCE_KIND_ENUM_GET_STATIC = 2,
REFERENCE_KIND_ENUM_PUT_FIELD = 3,
REFERENCE_KIND_ENUM_PUT_STATIC = 4,
REFERENCE_KIND_ENUM_INVOKE_VIRTUAL = 5,
REFERENCE_KIND_ENUM_INVOKE_STATIC = 6,
REFERENCE_KIND_ENUM_INVOKE_SPECIAL = 7,
REFERENCE_KIND_ENUM_NEW_INVOKE_SPECIAL = 8,
REFERENCE_KIND_ENUM_INVOKE_INTERFACE = 9
};
method_handle_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~method_handle_cp_info_t();
private:
version_guard_t* m__unnamed0;
reference_kind_enum_t m_reference_kind;
uint16_t m_reference_index;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
version_guard_t* _unnamed0() const { return m__unnamed0; }
reference_kind_enum_t reference_kind() const { return m_reference_kind; }
uint16_t reference_index() const { return m_reference_index; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* Project Jigsaw modules introduced in Java 9
* \sa https://docs.oracle.com/javase/specs/jvms/se19/html/jvms-3.html#jvms-3.16 Source
* \sa https://docs.oracle.com/javase/specs/jvms/se19/html/jvms-4.html#jvms-4.4.11 Source
* \sa https://docs.oracle.com/javase/specs/jvms/se19/html/jvms-4.html#jvms-4.4.12 Source
*/
class module_package_cp_info_t : public kaitai::kstruct {
public:
module_package_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~module_package_cp_info_t();
private:
bool f_name_as_info;
java_class_t::utf8_cp_info_t* m_name_as_info;
public:
java_class_t::utf8_cp_info_t* name_as_info();
private:
bool f_name_as_str;
std::string m_name_as_str;
public:
std::string name_as_str();
private:
version_guard_t* m__unnamed0;
uint16_t m_name_index;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
version_guard_t* _unnamed0() const { return m__unnamed0; }
uint16_t name_index() const { return m_name_index; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.6 Source
*/
class name_and_type_cp_info_t : public kaitai::kstruct {
public:
name_and_type_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~name_and_type_cp_info_t();
private:
bool f_name_as_info;
java_class_t::utf8_cp_info_t* m_name_as_info;
public:
java_class_t::utf8_cp_info_t* name_as_info();
private:
bool f_name_as_str;
std::string m_name_as_str;
public:
std::string name_as_str();
private:
bool f_descriptor_as_info;
java_class_t::utf8_cp_info_t* m_descriptor_as_info;
public:
java_class_t::utf8_cp_info_t* descriptor_as_info();
private:
bool f_descriptor_as_str;
std::string m_descriptor_as_str;
public:
std::string descriptor_as_str();
private:
uint16_t m_name_index;
uint16_t m_descriptor_index;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
uint16_t name_index() const { return m_name_index; }
uint16_t descriptor_index() const { return m_descriptor_index; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.7 Source
*/
class utf8_cp_info_t : public kaitai::kstruct {
public:
utf8_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~utf8_cp_info_t();
private:
uint16_t m_str_len;
std::string m_value;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
uint16_t str_len() const { return m_str_len; }
std::string value() const { return m_value; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.3 Source
*/
class string_cp_info_t : public kaitai::kstruct {
public:
string_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~string_cp_info_t();
private:
uint16_t m_string_index;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
uint16_t string_index() const { return m_string_index; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.9 Source
*/
class method_type_cp_info_t : public kaitai::kstruct {
public:
method_type_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~method_type_cp_info_t();
private:
version_guard_t* m__unnamed0;
uint16_t m_descriptor_index;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
version_guard_t* _unnamed0() const { return m__unnamed0; }
uint16_t descriptor_index() const { return m_descriptor_index; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.2 Source
*/
class interface_method_ref_cp_info_t : public kaitai::kstruct {
public:
interface_method_ref_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~interface_method_ref_cp_info_t();
private:
bool f_class_as_info;
java_class_t::class_cp_info_t* m_class_as_info;
public:
java_class_t::class_cp_info_t* class_as_info();
private:
bool f_name_and_type_as_info;
java_class_t::name_and_type_cp_info_t* m_name_and_type_as_info;
public:
java_class_t::name_and_type_cp_info_t* name_and_type_as_info();
private:
uint16_t m_class_index;
uint16_t m_name_and_type_index;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
uint16_t class_index() const { return m_class_index; }
uint16_t name_and_type_index() const { return m_name_and_type_index; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.1 Source
*/
class class_cp_info_t : public kaitai::kstruct {
public:
class_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~class_cp_info_t();
private:
bool f_name_as_info;
java_class_t::utf8_cp_info_t* m_name_as_info;
public:
java_class_t::utf8_cp_info_t* name_as_info();
private:
bool f_name_as_str;
std::string m_name_as_str;
public:
std::string name_as_str();
private:
uint16_t m_name_index;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
uint16_t name_index() const { return m_name_index; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4 Source
*/
class constant_pool_entry_t : public kaitai::kstruct {
public:
enum tag_enum_t {
TAG_ENUM_UTF8 = 1,
TAG_ENUM_INTEGER = 3,
TAG_ENUM_FLOAT = 4,
TAG_ENUM_LONG = 5,
TAG_ENUM_DOUBLE = 6,
TAG_ENUM_CLASS_TYPE = 7,
TAG_ENUM_STRING = 8,
TAG_ENUM_FIELD_REF = 9,
TAG_ENUM_METHOD_REF = 10,
TAG_ENUM_INTERFACE_METHOD_REF = 11,
TAG_ENUM_NAME_AND_TYPE = 12,
TAG_ENUM_METHOD_HANDLE = 15,
TAG_ENUM_METHOD_TYPE = 16,
TAG_ENUM_DYNAMIC = 17,
TAG_ENUM_INVOKE_DYNAMIC = 18,
TAG_ENUM_MODULE = 19,
TAG_ENUM_PACKAGE = 20
};
constant_pool_entry_t(bool p_is_prev_two_entries, kaitai::kstream* p__io, java_class_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~constant_pool_entry_t();
private:
bool f_is_two_entries;
bool m_is_two_entries;
public:
bool is_two_entries();
private:
tag_enum_t m_tag;
bool n_tag;
public:
bool _is_null_tag() { tag(); return n_tag; };
private:
kaitai::kstruct* m_cp_info;
bool n_cp_info;
public:
bool _is_null_cp_info() { cp_info(); return n_cp_info; };
private:
bool m_is_prev_two_entries;
java_class_t* m__root;
java_class_t* m__parent;
public:
tag_enum_t tag() const { return m_tag; }
kaitai::kstruct* cp_info() const { return m_cp_info; }
bool is_prev_two_entries() const { return m_is_prev_two_entries; }
java_class_t* _root() const { return m__root; }
java_class_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.6 Source
*/
class method_info_t : public kaitai::kstruct {
public:
method_info_t(kaitai::kstream* p__io, java_class_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~method_info_t();
private:
bool f_name_as_str;
std::string m_name_as_str;
public:
std::string name_as_str();
private:
uint16_t m_access_flags;
uint16_t m_name_index;
uint16_t m_descriptor_index;
uint16_t m_attributes_count;
std::vector<attribute_info_t*>* m_attributes;
java_class_t* m__root;
java_class_t* m__parent;
public:
uint16_t access_flags() const { return m_access_flags; }
uint16_t name_index() const { return m_name_index; }
uint16_t descriptor_index() const { return m_descriptor_index; }
uint16_t attributes_count() const { return m_attributes_count; }
std::vector<attribute_info_t*>* attributes() const { return m_attributes; }
java_class_t* _root() const { return m__root; }
java_class_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.4 Source
*/
class integer_cp_info_t : public kaitai::kstruct {
public:
integer_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~integer_cp_info_t();
private:
uint32_t m_value;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
uint32_t value() const { return m_value; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
/**
* \sa https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.2 Source
*/
class field_ref_cp_info_t : public kaitai::kstruct {
public:
field_ref_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent = 0, java_class_t* p__root = 0);
private:
void _read();
void _clean_up();
public:
~field_ref_cp_info_t();
private:
bool f_class_as_info;
java_class_t::class_cp_info_t* m_class_as_info;
public:
java_class_t::class_cp_info_t* class_as_info();
private:
bool f_name_and_type_as_info;
java_class_t::name_and_type_cp_info_t* m_name_and_type_as_info;
public:
java_class_t::name_and_type_cp_info_t* name_and_type_as_info();
private:
uint16_t m_class_index;
uint16_t m_name_and_type_index;
java_class_t* m__root;
java_class_t::constant_pool_entry_t* m__parent;
public:
uint16_t class_index() const { return m_class_index; }
uint16_t name_and_type_index() const { return m_name_and_type_index; }
java_class_t* _root() const { return m__root; }
java_class_t::constant_pool_entry_t* _parent() const { return m__parent; }
};
private:
std::string m_magic;
uint16_t m_version_minor;
uint16_t m_version_major;
uint16_t m_constant_pool_count;
std::vector<constant_pool_entry_t*>* m_constant_pool;
uint16_t m_access_flags;
uint16_t m_this_class;
uint16_t m_super_class;
uint16_t m_interfaces_count;
std::vector<uint16_t>* m_interfaces;
uint16_t m_fields_count;
std::vector<field_info_t*>* m_fields;
uint16_t m_methods_count;
std::vector<method_info_t*>* m_methods;
uint16_t m_attributes_count;
std::vector<attribute_info_t*>* m_attributes;
java_class_t* m__root;
kaitai::kstruct* m__parent;
public:
std::string magic() const { return m_magic; }
uint16_t version_minor() const { return m_version_minor; }
uint16_t version_major() const { return m_version_major; }
uint16_t constant_pool_count() const { return m_constant_pool_count; }
std::vector<constant_pool_entry_t*>* constant_pool() const { return m_constant_pool; }
uint16_t access_flags() const { return m_access_flags; }
uint16_t this_class() const { return m_this_class; }
uint16_t super_class() const { return m_super_class; }
uint16_t interfaces_count() const { return m_interfaces_count; }
std::vector<uint16_t>* interfaces() const { return m_interfaces; }
uint16_t fields_count() const { return m_fields_count; }
std::vector<field_info_t*>* fields() const { return m_fields; }
uint16_t methods_count() const { return m_methods_count; }
std::vector<method_info_t*>* methods() const { return m_methods; }
uint16_t attributes_count() const { return m_attributes_count; }
std::vector<attribute_info_t*>* attributes() const { return m_attributes; }
java_class_t* _root() const { return m__root; }
kaitai::kstruct* _parent() const { return m__parent; }
};
#endif // JAVA_CLASS_H_
// This is a generated file! Please edit source .ksy file and use kaitai-struct-compiler to rebuild
#include "java_class.h"
#include "kaitai/exceptions.h"
java_class_t::java_class_t(kaitai::kstream* p__io, kaitai::kstruct* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = this;
m_constant_pool = 0;
m_interfaces = 0;
m_fields = 0;
m_methods = 0;
m_attributes = 0;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::_read() {
m_magic = m__io->read_bytes(4);
if (!(magic() == std::string("\xCA\xFE\xBA\xBE", 4))) {
throw kaitai::validation_not_equal_error<std::string>(std::string("\xCA\xFE\xBA\xBE", 4), magic(), _io(), std::string("/seq/0"));
}
m_version_minor = m__io->read_u2be();
m_version_major = m__io->read_u2be();
if (!(version_major() >= 43)) {
throw kaitai::validation_less_than_error<uint16_t>(43, version_major(), _io(), std::string("/seq/2"));
}
m_constant_pool_count = m__io->read_u2be();
m_constant_pool = new std::vector<constant_pool_entry_t*>();
const int l_constant_pool = (constant_pool_count() - 1);
for (int i = 0; i < l_constant_pool; i++) {
m_constant_pool->push_back(new constant_pool_entry_t(((i != 0) ? (constant_pool()->at((i - 1))->is_two_entries()) : (false)), m__io, this, m__root));
}
m_access_flags = m__io->read_u2be();
m_this_class = m__io->read_u2be();
m_super_class = m__io->read_u2be();
m_interfaces_count = m__io->read_u2be();
m_interfaces = new std::vector<uint16_t>();
const int l_interfaces = interfaces_count();
for (int i = 0; i < l_interfaces; i++) {
m_interfaces->push_back(m__io->read_u2be());
}
m_fields_count = m__io->read_u2be();
m_fields = new std::vector<field_info_t*>();
const int l_fields = fields_count();
for (int i = 0; i < l_fields; i++) {
m_fields->push_back(new field_info_t(m__io, this, m__root));
}
m_methods_count = m__io->read_u2be();
m_methods = new std::vector<method_info_t*>();
const int l_methods = methods_count();
for (int i = 0; i < l_methods; i++) {
m_methods->push_back(new method_info_t(m__io, this, m__root));
}
m_attributes_count = m__io->read_u2be();
m_attributes = new std::vector<attribute_info_t*>();
const int l_attributes = attributes_count();
for (int i = 0; i < l_attributes; i++) {
m_attributes->push_back(new attribute_info_t(m__io, this, m__root));
}
}
java_class_t::~java_class_t() {
_clean_up();
}
void java_class_t::_clean_up() {
if (m_constant_pool) {
for (std::vector<constant_pool_entry_t*>::iterator it = m_constant_pool->begin(); it != m_constant_pool->end(); ++it) {
delete *it;
}
delete m_constant_pool; m_constant_pool = 0;
}
if (m_interfaces) {
delete m_interfaces; m_interfaces = 0;
}
if (m_fields) {
for (std::vector<field_info_t*>::iterator it = m_fields->begin(); it != m_fields->end(); ++it) {
delete *it;
}
delete m_fields; m_fields = 0;
}
if (m_methods) {
for (std::vector<method_info_t*>::iterator it = m_methods->begin(); it != m_methods->end(); ++it) {
delete *it;
}
delete m_methods; m_methods = 0;
}
if (m_attributes) {
for (std::vector<attribute_info_t*>::iterator it = m_attributes->begin(); it != m_attributes->end(); ++it) {
delete *it;
}
delete m_attributes; m_attributes = 0;
}
}
java_class_t::version_guard_t::version_guard_t(uint16_t p_major, kaitai::kstream* p__io, kaitai::kstruct* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m_major = p_major;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::version_guard_t::_read() {
m__unnamed0 = m__io->read_bytes(0);
{
std::string _ = _unnamed0();
if (!(_root()->version_major() >= major())) {
throw kaitai::validation_expr_error<std::string>(_unnamed0(), _io(), std::string("/types/version_guard/seq/0"));
}
}
}
java_class_t::version_guard_t::~version_guard_t() {
_clean_up();
}
void java_class_t::version_guard_t::_clean_up() {
}
java_class_t::float_cp_info_t::float_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::float_cp_info_t::_read() {
m_value = m__io->read_f4be();
}
java_class_t::float_cp_info_t::~float_cp_info_t() {
_clean_up();
}
void java_class_t::float_cp_info_t::_clean_up() {
}
java_class_t::attribute_info_t::attribute_info_t(kaitai::kstream* p__io, kaitai::kstruct* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m__io__raw_info = 0;
f_name_as_str = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::attribute_info_t::_read() {
m_name_index = m__io->read_u2be();
m_attribute_length = m__io->read_u4be();
n_info = true;
{
std::string on = name_as_str();
if (on == std::string("SourceFile")) {
n_info = false;
m__raw_info = m__io->read_bytes(attribute_length());
m__io__raw_info = new kaitai::kstream(m__raw_info);
m_info = new attr_body_source_file_t(m__io__raw_info, this, m__root);
}
else if (on == std::string("LineNumberTable")) {
n_info = false;
m__raw_info = m__io->read_bytes(attribute_length());
m__io__raw_info = new kaitai::kstream(m__raw_info);
m_info = new attr_body_line_number_table_t(m__io__raw_info, this, m__root);
}
else if (on == std::string("Exceptions")) {
n_info = false;
m__raw_info = m__io->read_bytes(attribute_length());
m__io__raw_info = new kaitai::kstream(m__raw_info);
m_info = new attr_body_exceptions_t(m__io__raw_info, this, m__root);
}
else if (on == std::string("Code")) {
n_info = false;
m__raw_info = m__io->read_bytes(attribute_length());
m__io__raw_info = new kaitai::kstream(m__raw_info);
m_info = new attr_body_code_t(m__io__raw_info, this, m__root);
}
else {
m__raw_info = m__io->read_bytes(attribute_length());
}
}
}
java_class_t::attribute_info_t::~attribute_info_t() {
_clean_up();
}
void java_class_t::attribute_info_t::_clean_up() {
if (!n_info) {
if (m__io__raw_info) {
delete m__io__raw_info; m__io__raw_info = 0;
}
if (m_info) {
delete m_info; m_info = 0;
}
}
}
java_class_t::attribute_info_t::attr_body_code_t::attr_body_code_t(kaitai::kstream* p__io, java_class_t::attribute_info_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m_exception_table = 0;
m_attributes = 0;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::attribute_info_t::attr_body_code_t::_read() {
m_max_stack = m__io->read_u2be();
m_max_locals = m__io->read_u2be();
m_code_length = m__io->read_u4be();
m_code = m__io->read_bytes(code_length());
m_exception_table_length = m__io->read_u2be();
m_exception_table = new std::vector<exception_entry_t*>();
const int l_exception_table = exception_table_length();
for (int i = 0; i < l_exception_table; i++) {
m_exception_table->push_back(new exception_entry_t(m__io, this, m__root));
}
m_attributes_count = m__io->read_u2be();
m_attributes = new std::vector<attribute_info_t*>();
const int l_attributes = attributes_count();
for (int i = 0; i < l_attributes; i++) {
m_attributes->push_back(new attribute_info_t(m__io, this, m__root));
}
}
java_class_t::attribute_info_t::attr_body_code_t::~attr_body_code_t() {
_clean_up();
}
void java_class_t::attribute_info_t::attr_body_code_t::_clean_up() {
if (m_exception_table) {
for (std::vector<exception_entry_t*>::iterator it = m_exception_table->begin(); it != m_exception_table->end(); ++it) {
delete *it;
}
delete m_exception_table; m_exception_table = 0;
}
if (m_attributes) {
for (std::vector<attribute_info_t*>::iterator it = m_attributes->begin(); it != m_attributes->end(); ++it) {
delete *it;
}
delete m_attributes; m_attributes = 0;
}
}
java_class_t::attribute_info_t::attr_body_code_t::exception_entry_t::exception_entry_t(kaitai::kstream* p__io, java_class_t::attribute_info_t::attr_body_code_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
f_catch_exception = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::attribute_info_t::attr_body_code_t::exception_entry_t::_read() {
m_start_pc = m__io->read_u2be();
m_end_pc = m__io->read_u2be();
m_handler_pc = m__io->read_u2be();
m_catch_type = m__io->read_u2be();
}
java_class_t::attribute_info_t::attr_body_code_t::exception_entry_t::~exception_entry_t() {
_clean_up();
}
void java_class_t::attribute_info_t::attr_body_code_t::exception_entry_t::_clean_up() {
}
java_class_t::constant_pool_entry_t* java_class_t::attribute_info_t::attr_body_code_t::exception_entry_t::catch_exception() {
if (f_catch_exception)
return m_catch_exception;
n_catch_exception = true;
if (catch_type() != 0) {
n_catch_exception = false;
m_catch_exception = _root()->constant_pool()->at((catch_type() - 1));
}
f_catch_exception = true;
return m_catch_exception;
}
java_class_t::attribute_info_t::attr_body_exceptions_t::attr_body_exceptions_t(kaitai::kstream* p__io, java_class_t::attribute_info_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m_exceptions = 0;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::attribute_info_t::attr_body_exceptions_t::_read() {
m_number_of_exceptions = m__io->read_u2be();
m_exceptions = new std::vector<exception_table_entry_t*>();
const int l_exceptions = number_of_exceptions();
for (int i = 0; i < l_exceptions; i++) {
m_exceptions->push_back(new exception_table_entry_t(m__io, this, m__root));
}
}
java_class_t::attribute_info_t::attr_body_exceptions_t::~attr_body_exceptions_t() {
_clean_up();
}
void java_class_t::attribute_info_t::attr_body_exceptions_t::_clean_up() {
if (m_exceptions) {
for (std::vector<exception_table_entry_t*>::iterator it = m_exceptions->begin(); it != m_exceptions->end(); ++it) {
delete *it;
}
delete m_exceptions; m_exceptions = 0;
}
}
java_class_t::attribute_info_t::attr_body_exceptions_t::exception_table_entry_t::exception_table_entry_t(kaitai::kstream* p__io, java_class_t::attribute_info_t::attr_body_exceptions_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
f_as_info = false;
f_name_as_str = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::attribute_info_t::attr_body_exceptions_t::exception_table_entry_t::_read() {
m_index = m__io->read_u2be();
}
java_class_t::attribute_info_t::attr_body_exceptions_t::exception_table_entry_t::~exception_table_entry_t() {
_clean_up();
}
void java_class_t::attribute_info_t::attr_body_exceptions_t::exception_table_entry_t::_clean_up() {
}
java_class_t::class_cp_info_t* java_class_t::attribute_info_t::attr_body_exceptions_t::exception_table_entry_t::as_info() {
if (f_as_info)
return m_as_info;
m_as_info = static_cast<java_class_t::class_cp_info_t*>(_root()->constant_pool()->at((index() - 1))->cp_info());
f_as_info = true;
return m_as_info;
}
std::string java_class_t::attribute_info_t::attr_body_exceptions_t::exception_table_entry_t::name_as_str() {
if (f_name_as_str)
return m_name_as_str;
m_name_as_str = as_info()->name_as_str();
f_name_as_str = true;
return m_name_as_str;
}
java_class_t::attribute_info_t::attr_body_source_file_t::attr_body_source_file_t(kaitai::kstream* p__io, java_class_t::attribute_info_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
f_sourcefile_as_str = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::attribute_info_t::attr_body_source_file_t::_read() {
m_sourcefile_index = m__io->read_u2be();
}
java_class_t::attribute_info_t::attr_body_source_file_t::~attr_body_source_file_t() {
_clean_up();
}
void java_class_t::attribute_info_t::attr_body_source_file_t::_clean_up() {
}
std::string java_class_t::attribute_info_t::attr_body_source_file_t::sourcefile_as_str() {
if (f_sourcefile_as_str)
return m_sourcefile_as_str;
m_sourcefile_as_str = static_cast<java_class_t::utf8_cp_info_t*>(_root()->constant_pool()->at((sourcefile_index() - 1))->cp_info())->value();
f_sourcefile_as_str = true;
return m_sourcefile_as_str;
}
java_class_t::attribute_info_t::attr_body_line_number_table_t::attr_body_line_number_table_t(kaitai::kstream* p__io, java_class_t::attribute_info_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m_line_number_table = 0;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::attribute_info_t::attr_body_line_number_table_t::_read() {
m_line_number_table_length = m__io->read_u2be();
m_line_number_table = new std::vector<line_number_table_entry_t*>();
const int l_line_number_table = line_number_table_length();
for (int i = 0; i < l_line_number_table; i++) {
m_line_number_table->push_back(new line_number_table_entry_t(m__io, this, m__root));
}
}
java_class_t::attribute_info_t::attr_body_line_number_table_t::~attr_body_line_number_table_t() {
_clean_up();
}
void java_class_t::attribute_info_t::attr_body_line_number_table_t::_clean_up() {
if (m_line_number_table) {
for (std::vector<line_number_table_entry_t*>::iterator it = m_line_number_table->begin(); it != m_line_number_table->end(); ++it) {
delete *it;
}
delete m_line_number_table; m_line_number_table = 0;
}
}
java_class_t::attribute_info_t::attr_body_line_number_table_t::line_number_table_entry_t::line_number_table_entry_t(kaitai::kstream* p__io, java_class_t::attribute_info_t::attr_body_line_number_table_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::attribute_info_t::attr_body_line_number_table_t::line_number_table_entry_t::_read() {
m_start_pc = m__io->read_u2be();
m_line_number = m__io->read_u2be();
}
java_class_t::attribute_info_t::attr_body_line_number_table_t::line_number_table_entry_t::~line_number_table_entry_t() {
_clean_up();
}
void java_class_t::attribute_info_t::attr_body_line_number_table_t::line_number_table_entry_t::_clean_up() {
}
std::string java_class_t::attribute_info_t::name_as_str() {
if (f_name_as_str)
return m_name_as_str;
m_name_as_str = static_cast<java_class_t::utf8_cp_info_t*>(_root()->constant_pool()->at((name_index() - 1))->cp_info())->value();
f_name_as_str = true;
return m_name_as_str;
}
java_class_t::method_ref_cp_info_t::method_ref_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
f_class_as_info = false;
f_name_and_type_as_info = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::method_ref_cp_info_t::_read() {
m_class_index = m__io->read_u2be();
m_name_and_type_index = m__io->read_u2be();
}
java_class_t::method_ref_cp_info_t::~method_ref_cp_info_t() {
_clean_up();
}
void java_class_t::method_ref_cp_info_t::_clean_up() {
}
java_class_t::class_cp_info_t* java_class_t::method_ref_cp_info_t::class_as_info() {
if (f_class_as_info)
return m_class_as_info;
m_class_as_info = static_cast<java_class_t::class_cp_info_t*>(_root()->constant_pool()->at((class_index() - 1))->cp_info());
f_class_as_info = true;
return m_class_as_info;
}
java_class_t::name_and_type_cp_info_t* java_class_t::method_ref_cp_info_t::name_and_type_as_info() {
if (f_name_and_type_as_info)
return m_name_and_type_as_info;
m_name_and_type_as_info = static_cast<java_class_t::name_and_type_cp_info_t*>(_root()->constant_pool()->at((name_and_type_index() - 1))->cp_info());
f_name_and_type_as_info = true;
return m_name_and_type_as_info;
}
java_class_t::field_info_t::field_info_t(kaitai::kstream* p__io, java_class_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m_attributes = 0;
f_name_as_str = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::field_info_t::_read() {
m_access_flags = m__io->read_u2be();
m_name_index = m__io->read_u2be();
m_descriptor_index = m__io->read_u2be();
m_attributes_count = m__io->read_u2be();
m_attributes = new std::vector<attribute_info_t*>();
const int l_attributes = attributes_count();
for (int i = 0; i < l_attributes; i++) {
m_attributes->push_back(new attribute_info_t(m__io, this, m__root));
}
}
java_class_t::field_info_t::~field_info_t() {
_clean_up();
}
void java_class_t::field_info_t::_clean_up() {
if (m_attributes) {
for (std::vector<attribute_info_t*>::iterator it = m_attributes->begin(); it != m_attributes->end(); ++it) {
delete *it;
}
delete m_attributes; m_attributes = 0;
}
}
std::string java_class_t::field_info_t::name_as_str() {
if (f_name_as_str)
return m_name_as_str;
m_name_as_str = static_cast<java_class_t::utf8_cp_info_t*>(_root()->constant_pool()->at((name_index() - 1))->cp_info())->value();
f_name_as_str = true;
return m_name_as_str;
}
java_class_t::double_cp_info_t::double_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::double_cp_info_t::_read() {
m_value = m__io->read_f8be();
}
java_class_t::double_cp_info_t::~double_cp_info_t() {
_clean_up();
}
void java_class_t::double_cp_info_t::_clean_up() {
}
java_class_t::dynamic_cp_info_t::dynamic_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m__unnamed0 = 0;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::dynamic_cp_info_t::_read() {
m__unnamed0 = new version_guard_t(55, m__io, this, m__root);
m_bootstrap_method_attr_index = m__io->read_u2be();
m_name_and_type_index = m__io->read_u2be();
}
java_class_t::dynamic_cp_info_t::~dynamic_cp_info_t() {
_clean_up();
}
void java_class_t::dynamic_cp_info_t::_clean_up() {
if (m__unnamed0) {
delete m__unnamed0; m__unnamed0 = 0;
}
}
java_class_t::long_cp_info_t::long_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::long_cp_info_t::_read() {
m_value = m__io->read_u8be();
}
java_class_t::long_cp_info_t::~long_cp_info_t() {
_clean_up();
}
void java_class_t::long_cp_info_t::_clean_up() {
}
java_class_t::invoke_dynamic_cp_info_t::invoke_dynamic_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m__unnamed0 = 0;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::invoke_dynamic_cp_info_t::_read() {
m__unnamed0 = new version_guard_t(51, m__io, this, m__root);
m_bootstrap_method_attr_index = m__io->read_u2be();
m_name_and_type_index = m__io->read_u2be();
}
java_class_t::invoke_dynamic_cp_info_t::~invoke_dynamic_cp_info_t() {
_clean_up();
}
void java_class_t::invoke_dynamic_cp_info_t::_clean_up() {
if (m__unnamed0) {
delete m__unnamed0; m__unnamed0 = 0;
}
}
java_class_t::method_handle_cp_info_t::method_handle_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m__unnamed0 = 0;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::method_handle_cp_info_t::_read() {
m__unnamed0 = new version_guard_t(51, m__io, this, m__root);
m_reference_kind = static_cast<java_class_t::method_handle_cp_info_t::reference_kind_enum_t>(m__io->read_u1());
m_reference_index = m__io->read_u2be();
}
java_class_t::method_handle_cp_info_t::~method_handle_cp_info_t() {
_clean_up();
}
void java_class_t::method_handle_cp_info_t::_clean_up() {
if (m__unnamed0) {
delete m__unnamed0; m__unnamed0 = 0;
}
}
java_class_t::module_package_cp_info_t::module_package_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m__unnamed0 = 0;
f_name_as_info = false;
f_name_as_str = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::module_package_cp_info_t::_read() {
m__unnamed0 = new version_guard_t(53, m__io, this, m__root);
m_name_index = m__io->read_u2be();
}
java_class_t::module_package_cp_info_t::~module_package_cp_info_t() {
_clean_up();
}
void java_class_t::module_package_cp_info_t::_clean_up() {
if (m__unnamed0) {
delete m__unnamed0; m__unnamed0 = 0;
}
}
java_class_t::utf8_cp_info_t* java_class_t::module_package_cp_info_t::name_as_info() {
if (f_name_as_info)
return m_name_as_info;
m_name_as_info = static_cast<java_class_t::utf8_cp_info_t*>(_root()->constant_pool()->at((name_index() - 1))->cp_info());
f_name_as_info = true;
return m_name_as_info;
}
std::string java_class_t::module_package_cp_info_t::name_as_str() {
if (f_name_as_str)
return m_name_as_str;
m_name_as_str = name_as_info()->value();
f_name_as_str = true;
return m_name_as_str;
}
java_class_t::name_and_type_cp_info_t::name_and_type_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
f_name_as_info = false;
f_name_as_str = false;
f_descriptor_as_info = false;
f_descriptor_as_str = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::name_and_type_cp_info_t::_read() {
m_name_index = m__io->read_u2be();
m_descriptor_index = m__io->read_u2be();
}
java_class_t::name_and_type_cp_info_t::~name_and_type_cp_info_t() {
_clean_up();
}
void java_class_t::name_and_type_cp_info_t::_clean_up() {
}
java_class_t::utf8_cp_info_t* java_class_t::name_and_type_cp_info_t::name_as_info() {
if (f_name_as_info)
return m_name_as_info;
m_name_as_info = static_cast<java_class_t::utf8_cp_info_t*>(_root()->constant_pool()->at((name_index() - 1))->cp_info());
f_name_as_info = true;
return m_name_as_info;
}
std::string java_class_t::name_and_type_cp_info_t::name_as_str() {
if (f_name_as_str)
return m_name_as_str;
m_name_as_str = name_as_info()->value();
f_name_as_str = true;
return m_name_as_str;
}
java_class_t::utf8_cp_info_t* java_class_t::name_and_type_cp_info_t::descriptor_as_info() {
if (f_descriptor_as_info)
return m_descriptor_as_info;
m_descriptor_as_info = static_cast<java_class_t::utf8_cp_info_t*>(_root()->constant_pool()->at((descriptor_index() - 1))->cp_info());
f_descriptor_as_info = true;
return m_descriptor_as_info;
}
std::string java_class_t::name_and_type_cp_info_t::descriptor_as_str() {
if (f_descriptor_as_str)
return m_descriptor_as_str;
m_descriptor_as_str = descriptor_as_info()->value();
f_descriptor_as_str = true;
return m_descriptor_as_str;
}
java_class_t::utf8_cp_info_t::utf8_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::utf8_cp_info_t::_read() {
m_str_len = m__io->read_u2be();
m_value = kaitai::kstream::bytes_to_str(m__io->read_bytes(str_len()), std::string("UTF-8"));
}
java_class_t::utf8_cp_info_t::~utf8_cp_info_t() {
_clean_up();
}
void java_class_t::utf8_cp_info_t::_clean_up() {
}
java_class_t::string_cp_info_t::string_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::string_cp_info_t::_read() {
m_string_index = m__io->read_u2be();
}
java_class_t::string_cp_info_t::~string_cp_info_t() {
_clean_up();
}
void java_class_t::string_cp_info_t::_clean_up() {
}
java_class_t::method_type_cp_info_t::method_type_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m__unnamed0 = 0;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::method_type_cp_info_t::_read() {
m__unnamed0 = new version_guard_t(51, m__io, this, m__root);
m_descriptor_index = m__io->read_u2be();
}
java_class_t::method_type_cp_info_t::~method_type_cp_info_t() {
_clean_up();
}
void java_class_t::method_type_cp_info_t::_clean_up() {
if (m__unnamed0) {
delete m__unnamed0; m__unnamed0 = 0;
}
}
java_class_t::interface_method_ref_cp_info_t::interface_method_ref_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
f_class_as_info = false;
f_name_and_type_as_info = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::interface_method_ref_cp_info_t::_read() {
m_class_index = m__io->read_u2be();
m_name_and_type_index = m__io->read_u2be();
}
java_class_t::interface_method_ref_cp_info_t::~interface_method_ref_cp_info_t() {
_clean_up();
}
void java_class_t::interface_method_ref_cp_info_t::_clean_up() {
}
java_class_t::class_cp_info_t* java_class_t::interface_method_ref_cp_info_t::class_as_info() {
if (f_class_as_info)
return m_class_as_info;
m_class_as_info = static_cast<java_class_t::class_cp_info_t*>(_root()->constant_pool()->at((class_index() - 1))->cp_info());
f_class_as_info = true;
return m_class_as_info;
}
java_class_t::name_and_type_cp_info_t* java_class_t::interface_method_ref_cp_info_t::name_and_type_as_info() {
if (f_name_and_type_as_info)
return m_name_and_type_as_info;
m_name_and_type_as_info = static_cast<java_class_t::name_and_type_cp_info_t*>(_root()->constant_pool()->at((name_and_type_index() - 1))->cp_info());
f_name_and_type_as_info = true;
return m_name_and_type_as_info;
}
java_class_t::class_cp_info_t::class_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
f_name_as_info = false;
f_name_as_str = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::class_cp_info_t::_read() {
m_name_index = m__io->read_u2be();
}
java_class_t::class_cp_info_t::~class_cp_info_t() {
_clean_up();
}
void java_class_t::class_cp_info_t::_clean_up() {
}
java_class_t::utf8_cp_info_t* java_class_t::class_cp_info_t::name_as_info() {
if (f_name_as_info)
return m_name_as_info;
m_name_as_info = static_cast<java_class_t::utf8_cp_info_t*>(_root()->constant_pool()->at((name_index() - 1))->cp_info());
f_name_as_info = true;
return m_name_as_info;
}
std::string java_class_t::class_cp_info_t::name_as_str() {
if (f_name_as_str)
return m_name_as_str;
m_name_as_str = name_as_info()->value();
f_name_as_str = true;
return m_name_as_str;
}
java_class_t::constant_pool_entry_t::constant_pool_entry_t(bool p_is_prev_two_entries, kaitai::kstream* p__io, java_class_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m_is_prev_two_entries = p_is_prev_two_entries;
f_is_two_entries = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::constant_pool_entry_t::_read() {
n_tag = true;
if (!(is_prev_two_entries())) {
n_tag = false;
m_tag = static_cast<java_class_t::constant_pool_entry_t::tag_enum_t>(m__io->read_u1());
}
n_cp_info = true;
if (!(is_prev_two_entries())) {
n_cp_info = false;
n_cp_info = true;
switch (tag()) {
case java_class_t::constant_pool_entry_t::TAG_ENUM_INTERFACE_METHOD_REF: {
n_cp_info = false;
m_cp_info = new interface_method_ref_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_CLASS_TYPE: {
n_cp_info = false;
m_cp_info = new class_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_DYNAMIC: {
n_cp_info = false;
m_cp_info = new dynamic_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_UTF8: {
n_cp_info = false;
m_cp_info = new utf8_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_METHOD_TYPE: {
n_cp_info = false;
m_cp_info = new method_type_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_INTEGER: {
n_cp_info = false;
m_cp_info = new integer_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_STRING: {
n_cp_info = false;
m_cp_info = new string_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_FLOAT: {
n_cp_info = false;
m_cp_info = new float_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_MODULE: {
n_cp_info = false;
m_cp_info = new module_package_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_LONG: {
n_cp_info = false;
m_cp_info = new long_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_METHOD_REF: {
n_cp_info = false;
m_cp_info = new method_ref_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_DOUBLE: {
n_cp_info = false;
m_cp_info = new double_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_INVOKE_DYNAMIC: {
n_cp_info = false;
m_cp_info = new invoke_dynamic_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_FIELD_REF: {
n_cp_info = false;
m_cp_info = new field_ref_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_METHOD_HANDLE: {
n_cp_info = false;
m_cp_info = new method_handle_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_PACKAGE: {
n_cp_info = false;
m_cp_info = new module_package_cp_info_t(m__io, this, m__root);
break;
}
case java_class_t::constant_pool_entry_t::TAG_ENUM_NAME_AND_TYPE: {
n_cp_info = false;
m_cp_info = new name_and_type_cp_info_t(m__io, this, m__root);
break;
}
}
}
}
java_class_t::constant_pool_entry_t::~constant_pool_entry_t() {
_clean_up();
}
void java_class_t::constant_pool_entry_t::_clean_up() {
if (!n_tag) {
}
if (!n_cp_info) {
if (m_cp_info) {
delete m_cp_info; m_cp_info = 0;
}
}
}
bool java_class_t::constant_pool_entry_t::is_two_entries() {
if (f_is_two_entries)
return m_is_two_entries;
m_is_two_entries = ((is_prev_two_entries()) ? (false) : ( ((tag() == java_class_t::constant_pool_entry_t::TAG_ENUM_LONG) || (tag() == java_class_t::constant_pool_entry_t::TAG_ENUM_DOUBLE)) ));
f_is_two_entries = true;
return m_is_two_entries;
}
java_class_t::method_info_t::method_info_t(kaitai::kstream* p__io, java_class_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
m_attributes = 0;
f_name_as_str = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::method_info_t::_read() {
m_access_flags = m__io->read_u2be();
m_name_index = m__io->read_u2be();
m_descriptor_index = m__io->read_u2be();
m_attributes_count = m__io->read_u2be();
m_attributes = new std::vector<attribute_info_t*>();
const int l_attributes = attributes_count();
for (int i = 0; i < l_attributes; i++) {
m_attributes->push_back(new attribute_info_t(m__io, this, m__root));
}
}
java_class_t::method_info_t::~method_info_t() {
_clean_up();
}
void java_class_t::method_info_t::_clean_up() {
if (m_attributes) {
for (std::vector<attribute_info_t*>::iterator it = m_attributes->begin(); it != m_attributes->end(); ++it) {
delete *it;
}
delete m_attributes; m_attributes = 0;
}
}
std::string java_class_t::method_info_t::name_as_str() {
if (f_name_as_str)
return m_name_as_str;
m_name_as_str = static_cast<java_class_t::utf8_cp_info_t*>(_root()->constant_pool()->at((name_index() - 1))->cp_info())->value();
f_name_as_str = true;
return m_name_as_str;
}
java_class_t::integer_cp_info_t::integer_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::integer_cp_info_t::_read() {
m_value = m__io->read_u4be();
}
java_class_t::integer_cp_info_t::~integer_cp_info_t() {
_clean_up();
}
void java_class_t::integer_cp_info_t::_clean_up() {
}
java_class_t::field_ref_cp_info_t::field_ref_cp_info_t(kaitai::kstream* p__io, java_class_t::constant_pool_entry_t* p__parent, java_class_t* p__root) : kaitai::kstruct(p__io) {
m__parent = p__parent;
m__root = p__root;
f_class_as_info = false;
f_name_and_type_as_info = false;
try {
_read();
} catch(...) {
_clean_up();
throw;
}
}
void java_class_t::field_ref_cp_info_t::_read() {
m_class_index = m__io->read_u2be();
m_name_and_type_index = m__io->read_u2be();
}
java_class_t::field_ref_cp_info_t::~field_ref_cp_info_t() {
_clean_up();
}
void java_class_t::field_ref_cp_info_t::_clean_up() {
}
java_class_t::class_cp_info_t* java_class_t::field_ref_cp_info_t::class_as_info() {
if (f_class_as_info)
return m_class_as_info;
m_class_as_info = static_cast<java_class_t::class_cp_info_t*>(_root()->constant_pool()->at((class_index() - 1))->cp_info());
f_class_as_info = true;
return m_class_as_info;
}
java_class_t::name_and_type_cp_info_t* java_class_t::field_ref_cp_info_t::name_and_type_as_info() {
if (f_name_and_type_as_info)
return m_name_and_type_as_info;
m_name_and_type_as_info = static_cast<java_class_t::name_and_type_cp_info_t*>(_root()->constant_pool()->at((name_and_type_index() - 1))->cp_info());
f_name_and_type_as_info = true;
return m_name_and_type_as_info;
}