-- EFL LuaJIT bindings: Eolian -- For use with Elua local ffi = require("ffi") local bit = require("bit") ffi.cdef [[ void eina_stringshare_del(const char *str); void free(void *ptr); ]] ffi.cdef [[ typedef unsigned char Eina_Bool; typedef struct _Eina_Iterator Eina_Iterator; typedef struct _Eolian_Class Eolian_Class; typedef struct _Eolian_Function Eolian_Function; typedef struct _Eolian_Type Eolian_Type; typedef struct _Eolian_Typedecl Eolian_Typedecl; typedef struct _Eolian_Function_Parameter Eolian_Function_Parameter; typedef struct _Eolian_Implement Eolian_Implement; typedef struct _Eolian_Constructor Eolian_Constructor; typedef struct _Eolian_Event Eolian_Event; typedef struct _Eolian_Expression Eolian_Expression; typedef struct _Eolian_Variable Eolian_Variable; typedef struct _Eolian_Struct_Type_Field Eolian_Struct_Type_Field; typedef struct _Eolian_Enum_Type_Field Eolian_Enum_Type_Field; typedef struct _Eolian_Declaration Eolian_Declaration; typedef struct _Eolian_Documentation Eolian_Documentation; typedef struct _Eolian_Value Eolian_Value; typedef struct _Eolian_Unit Eolian_Unit; typedef enum { EOLIAN_UNRESOLVED = 0, EOLIAN_PROPERTY, EOLIAN_PROP_SET, EOLIAN_PROP_GET, EOLIAN_METHOD } Eolian_Function_Type; typedef enum { EOLIAN_UNKNOWN_PARAM = 0, EOLIAN_IN_PARAM, EOLIAN_OUT_PARAM, EOLIAN_INOUT_PARAM } Eolian_Parameter_Dir; typedef enum { EOLIAN_CLASS_UNKNOWN_TYPE = 0, EOLIAN_CLASS_REGULAR, EOLIAN_CLASS_ABSTRACT, EOLIAN_CLASS_MIXIN, EOLIAN_CLASS_INTERFACE } Eolian_Class_Type; typedef enum { EOLIAN_SCOPE_UNKNOWN = 0, EOLIAN_SCOPE_PUBLIC, EOLIAN_SCOPE_PRIVATE, EOLIAN_SCOPE_PROTECTED } Eolian_Object_Scope; typedef enum { EOLIAN_TYPEDECL_UNKNOWN = 0, EOLIAN_TYPEDECL_STRUCT, EOLIAN_TYPEDECL_STRUCT_OPAQUE, EOLIAN_TYPEDECL_ENUM, EOLIAN_TYPEDECL_ALIAS } Eolian_Typedecl_Type; typedef enum { EOLIAN_TYPE_UNKNOWN_TYPE = 0, EOLIAN_TYPE_VOID, EOLIAN_TYPE_REGULAR, EOLIAN_TYPE_COMPLEX, EOLIAN_TYPE_CLASS, EOLIAN_TYPE_STATIC_ARRAY, EOLIAN_TYPE_TERMINATED_ARRAY, EOLIAN_TYPE_UNDEFINED } Eolian_Type_Type; typedef enum { EOLIAN_EXPR_UNKNOWN = 0, EOLIAN_EXPR_INT, EOLIAN_EXPR_UINT, EOLIAN_EXPR_LONG, EOLIAN_EXPR_ULONG, EOLIAN_EXPR_LLONG, EOLIAN_EXPR_ULLONG, EOLIAN_EXPR_FLOAT, EOLIAN_EXPR_DOUBLE, EOLIAN_EXPR_STRING, EOLIAN_EXPR_CHAR, EOLIAN_EXPR_NULL, EOLIAN_EXPR_BOOL, EOLIAN_EXPR_NAME, EOLIAN_EXPR_UNARY, EOLIAN_EXPR_BINARY } Eolian_Expression_Type; typedef enum { EOLIAN_MASK_SINT = 1 << 0, EOLIAN_MASK_UINT = 1 << 1, EOLIAN_MASK_INT = EOLIAN_MASK_SINT | EOLIAN_MASK_UINT, EOLIAN_MASK_FLOAT = 1 << 2, EOLIAN_MASK_BOOL = 1 << 3, EOLIAN_MASK_STRING = 1 << 4, EOLIAN_MASK_CHAR = 1 << 5, EOLIAN_MASK_NULL = 1 << 6, EOLIAN_MASK_SIGNED = EOLIAN_MASK_SINT | EOLIAN_MASK_FLOAT, EOLIAN_MASK_NUMBER = EOLIAN_MASK_INT | EOLIAN_MASK_FLOAT, EOLIAN_MASK_ALL = EOLIAN_MASK_NUMBER | EOLIAN_MASK_BOOL | EOLIAN_MASK_STRING | EOLIAN_MASK_CHAR | EOLIAN_MASK_NULL } Eolian_Expression_Mask; typedef enum { EOLIAN_VAR_UNKNOWN = 0, EOLIAN_VAR_CONSTANT, EOLIAN_VAR_GLOBAL } Eolian_Variable_Type; typedef union { char c; Eina_Bool b; const char *s; signed int i; unsigned int u; signed long l; unsigned long ul; signed long long ll; unsigned long long ull; float f; double d; } Eolian_Value_Union; typedef struct _Eolian_Value_t { Eolian_Expression_Type type; Eolian_Value_Union value; } Eolian_Value_t; typedef enum { EOLIAN_BINOP_INVALID = 0, EOLIAN_BINOP_ADD, /* + int, float */ EOLIAN_BINOP_SUB, /* - int, float */ EOLIAN_BINOP_MUL, /* * int, float */ EOLIAN_BINOP_DIV, /* / int, float */ EOLIAN_BINOP_MOD, /* % int */ EOLIAN_BINOP_EQ, /* == all types */ EOLIAN_BINOP_NQ, /* != all types */ EOLIAN_BINOP_GT, /* > int, float */ EOLIAN_BINOP_LT, /* < int, float */ EOLIAN_BINOP_GE, /* >= int, float */ EOLIAN_BINOP_LE, /* <= int, float */ EOLIAN_BINOP_AND, /* && all types */ EOLIAN_BINOP_OR, /* || all types */ EOLIAN_BINOP_BAND, /* & int */ EOLIAN_BINOP_BOR, /* | int */ EOLIAN_BINOP_BXOR, /* ^ int */ EOLIAN_BINOP_LSH, /* << int */ EOLIAN_BINOP_RSH /* >> int */ } Eolian_Binary_Operator; typedef enum { EOLIAN_UNOP_INVALID = 0, EOLIAN_UNOP_UNM, /* - sint */ EOLIAN_UNOP_UNP, /* + sint */ EOLIAN_UNOP_NOT, /* ! int, float, bool */ EOLIAN_UNOP_BNOT, /* ~ int */ } Eolian_Unary_Operator; typedef enum { EOLIAN_DECL_UNKNOWN = 0, EOLIAN_DECL_CLASS, EOLIAN_DECL_ALIAS, EOLIAN_DECL_STRUCT, EOLIAN_DECL_ENUM, EOLIAN_DECL_VAR } Eolian_Declaration_Type; typedef enum { EOLIAN_DOC_TOKEN_UNKNOWN = 0, EOLIAN_DOC_TOKEN_TEXT, EOLIAN_DOC_TOKEN_REF, EOLIAN_DOC_TOKEN_MARK_NOTE, EOLIAN_DOC_TOKEN_MARK_WARNING, EOLIAN_DOC_TOKEN_MARK_REMARK, EOLIAN_DOC_TOKEN_MARK_TODO, EOLIAN_DOC_TOKEN_MARKUP_MONOSPACE } Eolian_Doc_Token_Type; typedef enum { EOLIAN_DOC_REF_INVALID = 0, EOLIAN_DOC_REF_CLASS, EOLIAN_DOC_REF_FUNC, EOLIAN_DOC_REF_EVENT, EOLIAN_DOC_REF_ALIAS, EOLIAN_DOC_REF_STRUCT, EOLIAN_DOC_REF_STRUCT_FIELD, EOLIAN_DOC_REF_ENUM, EOLIAN_DOC_REF_ENUM_FIELD, EOLIAN_DOC_REF_VAR } Eolian_Doc_Ref_Type; typedef struct _Eolian_Doc_Token { Eolian_Doc_Token_Type type; const char *text, *text_end; } Eolian_Doc_Token; const Eolian_Unit *eolian_file_parse(const char *filepath); Eina_Iterator *eolian_all_eo_file_paths_get(void); Eina_Iterator *eolian_all_eot_file_paths_get(void); Eina_Iterator *eolian_all_eo_files_get(void); Eina_Iterator *eolian_all_eot_files_get(void); int eolian_init(void); int eolian_shutdown(void); Eina_Bool eolian_directory_scan(const char *dir); Eina_Bool eolian_system_directory_scan(); Eina_Bool eolian_all_eo_files_parse(); Eina_Bool eolian_all_eot_files_parse(); Eina_Bool eolian_database_validate(); const Eolian_Class *eolian_class_get_by_name(const Eolian_Unit *unit, const char *class_name); const Eolian_Class *eolian_class_get_by_file(const Eolian_Unit *unit, const char *file_name); const char *eolian_class_file_get(const Eolian_Class *klass); const char *eolian_class_full_name_get(const Eolian_Class *klass); const char *eolian_class_name_get(const Eolian_Class *klass); Eina_Iterator *eolian_class_namespaces_get(const Eolian_Class *klass); Eolian_Class_Type eolian_class_type_get(const Eolian_Class *klass); Eina_Iterator *eolian_all_classes_get(const Eolian_Unit *unit); const Eolian_Documentation *eolian_class_documentation_get(const Eolian_Class *klass); const char *eolian_class_legacy_prefix_get(const Eolian_Class *klass); const char *eolian_class_eo_prefix_get(const Eolian_Class *klass); const char *eolian_class_data_type_get(const Eolian_Class *klass); Eina_Iterator *eolian_class_inherits_get(const Eolian_Class *klass); Eina_Iterator *eolian_class_functions_get(const Eolian_Class *klass, Eolian_Function_Type func_type); Eolian_Function_Type eolian_function_type_get(const Eolian_Function *function_id); Eolian_Object_Scope eolian_function_scope_get(const Eolian_Function *function_id, Eolian_Function_Type ftype); const char *eolian_function_name_get(const Eolian_Function *function_id); const char *eolian_function_full_c_name_get(const Eolian_Function *function_id, Eolian_Function_Type ftype, Eina_Bool use_legacy); const Eolian_Function *eolian_class_function_get_by_name(const Eolian_Class *klass, const char *func_name, Eolian_Function_Type f_type); const char *eolian_function_legacy_get(const Eolian_Function *function_id, Eolian_Function_Type f_type); const Eolian_Implement *eolian_function_implement_get(const Eolian_Function *function_id); Eina_Bool eolian_function_is_legacy_only(const Eolian_Function *function_id, Eolian_Function_Type ftype); Eina_Bool eolian_function_is_class(const Eolian_Function *function_id); Eina_Bool eolian_function_is_c_only(const Eolian_Function *function_id); Eina_Iterator *eolian_property_keys_get(const Eolian_Function *foo_id, Eolian_Function_Type ftype); Eina_Iterator *eolian_property_values_get(const Eolian_Function *foo_id, Eolian_Function_Type ftype); Eina_Iterator *eolian_function_parameters_get(const Eolian_Function *function_id); Eolian_Parameter_Dir eolian_parameter_direction_get(const Eolian_Function_Parameter *param); const Eolian_Type *eolian_parameter_type_get(const Eolian_Function_Parameter *param); const Eolian_Expression *eolian_parameter_default_value_get(const Eolian_Function_Parameter *param); const char *eolian_parameter_name_get(const Eolian_Function_Parameter *param); const Eolian_Documentation *eolian_parameter_documentation_get(const Eolian_Function_Parameter *param); Eina_Bool eolian_parameter_is_nonull(const Eolian_Function_Parameter *param_desc); Eina_Bool eolian_parameter_is_nullable(const Eolian_Function_Parameter *param_desc); Eina_Bool eolian_parameter_is_optional(const Eolian_Function_Parameter *param_desc); const Eolian_Type *eolian_function_return_type_get(const Eolian_Function *function_id, Eolian_Function_Type ftype); const Eolian_Expression *eolian_function_return_default_value_get(const Eolian_Function *foo_id, Eolian_Function_Type ftype); const Eolian_Documentation *eolian_function_return_documentation_get(const Eolian_Function *foo_id, Eolian_Function_Type ftype); Eina_Bool eolian_function_return_is_warn_unused(const Eolian_Function *foo_id, Eolian_Function_Type ftype); Eina_Bool eolian_function_object_is_const(const Eolian_Function *function_id); const char *eolian_implement_full_name_get(const Eolian_Implement *impl); const Eolian_Class *eolian_implement_class_get(const Eolian_Implement *impl); const Eolian_Function *eolian_implement_function_get(const Eolian_Implement *impl, Eolian_Function_Type *func_type); const Eolian_Documentation *eolian_implement_documentation_get(const Eolian_Implement *impl, Eolian_Function_Type f_type); Eina_Bool eolian_implement_is_auto(const Eolian_Implement *impl, Eolian_Function_Type ftype); Eina_Bool eolian_implement_is_empty(const Eolian_Implement *impl, Eolian_Function_Type ftype); Eina_Bool eolian_implement_is_pure_virtual(const Eolian_Implement *impl, Eolian_Function_Type ftype); Eina_Bool eolian_implement_is_prop_get(const Eolian_Implement *impl); Eina_Bool eolian_implement_is_prop_set(const Eolian_Implement *impl); Eina_Iterator *eolian_class_implements_get(const Eolian_Class *klass); const char *eolian_constructor_full_name_get(const Eolian_Constructor *ctor); const Eolian_Class *eolian_constructor_class_get(const Eolian_Constructor *ctor); const Eolian_Function *eolian_constructor_function_get(const Eolian_Constructor *ctor); Eina_Bool eolian_constructor_is_optional(const Eolian_Constructor *ctor); Eina_Iterator *eolian_class_constructors_get(const Eolian_Class *klass); Eina_Iterator *eolian_class_events_get(const Eolian_Class *klass); const char *eolian_event_name_get(const Eolian_Event *event); const Eolian_Type *eolian_event_type_get(const Eolian_Event *event); const Eolian_Documentation *eolian_event_documentation_get(const Eolian_Event *event); Eolian_Object_Scope eolian_event_scope_get(const Eolian_Event *event); Eina_Bool eolian_event_is_beta(const Eolian_Event *event); Eina_Bool eolian_event_is_hot(const Eolian_Event *event); Eina_Bool eolian_event_is_restart(const Eolian_Event *event); const char *eolian_event_c_name_get(const Eolian_Event *event); Eina_Bool eolian_class_ctor_enable_get(const Eolian_Class *klass); Eina_Bool eolian_class_dtor_enable_get(const Eolian_Class *klass); const char *eolian_class_c_get_function_name_get(const Eolian_Class *klass); const Eolian_Typedecl *eolian_typedecl_alias_get_by_name(const char *name); const Eolian_Typedecl *eolian_typedecl_struct_get_by_name(const char *name); const Eolian_Typedecl *eolian_typedecl_enum_get_by_name(const char *name); Eina_Iterator *eolian_typedecl_aliases_get_by_file(const char *fname); Eina_Iterator *eolian_typedecl_structs_get_by_file(const char *fname); Eina_Iterator *eolian_typedecl_enums_get_by_file(const char *fname); Eina_Iterator *eolian_typedecl_all_aliases_get(void); Eina_Iterator *eolian_typedecl_all_structs_get(void); Eina_Iterator *eolian_typedecl_all_enums_get(void); Eolian_Type_Type eolian_type_type_get(const Eolian_Type *tp); Eolian_Typedecl_Type eolian_typedecl_type_get(const Eolian_Typedecl *tp); Eina_Iterator *eolian_typedecl_struct_fields_get(const Eolian_Typedecl *tp); const Eolian_Struct_Type_Field *eolian_typedecl_struct_field_get(const Eolian_Typedecl *tp, const char *field); const char *eolian_typedecl_struct_field_name_get(const Eolian_Struct_Type_Field *fl); const Eolian_Documentation *eolian_typedecl_struct_field_documentation_get(const Eolian_Struct_Type_Field *fl); const Eolian_Type *eolian_typedecl_struct_field_type_get(const Eolian_Struct_Type_Field *fl); Eina_Iterator *eolian_typedecl_enum_fields_get(const Eolian_Typedecl *tp); const Eolian_Enum_Type_Field *eolian_typedecl_enum_field_get(const Eolian_Typedecl *tp, const char *field); const char *eolian_typedecl_enum_field_name_get(const Eolian_Enum_Type_Field *fl); const char *eolian_typedecl_enum_field_c_name_get(const Eolian_Enum_Type_Field *fl); const Eolian_Documentation *eolian_typedecl_enum_field_documentation_get(const Eolian_Enum_Type_Field *fl); const Eolian_Expression *eolian_typedecl_enum_field_value_get(const Eolian_Enum_Type_Field *fl, Eina_Bool force); const char *eolian_typedecl_enum_legacy_prefix_get(const Eolian_Typedecl *tp); const Eolian_Documentation *eolian_typedecl_documentation_get(const Eolian_Typedecl *tp); const char *eolian_type_file_get(const Eolian_Type *tp); const char *eolian_typedecl_file_get(const Eolian_Typedecl *tp); const Eolian_Type *eolian_type_base_type_get(const Eolian_Type *tp); const Eolian_Type *eolian_type_next_type_get(const Eolian_Type *tp); const Eolian_Type *eolian_typedecl_base_type_get(const Eolian_Typedecl *tp); const Eolian_Typedecl *eolian_type_typedecl_get(const Eolian_Type *tp); const Eolian_Type *eolian_type_aliased_base_get(const Eolian_Type *tp); const Eolian_Type *eolian_typedecl_aliased_base_get(const Eolian_Typedecl *tp); const Eolian_Class *eolian_type_class_get(const Eolian_Type *tp); size_t eolian_type_array_size_get(const Eolian_Type *tp); Eina_Bool eolian_type_is_own(const Eolian_Type *tp); Eina_Bool eolian_type_is_const(const Eolian_Type *tp); Eina_Bool eolian_type_is_ptr(const Eolian_Type *tp); Eina_Bool eolian_typedecl_is_extern(const Eolian_Typedecl *tp); const char *eolian_type_c_type_get(const Eolian_Type *tp); const char *eolian_typedecl_c_type_get(const Eolian_Typedecl *tp); const char *eolian_type_name_get(const Eolian_Type *tp); const char *eolian_typedecl_name_get(const Eolian_Typedecl *tp); const char *eolian_type_full_name_get(const Eolian_Type *tp); const char *eolian_typedecl_full_name_get(const Eolian_Typedecl *tp); Eina_Iterator *eolian_type_namespaces_get(const Eolian_Type *tp); Eina_Iterator *eolian_typedecl_namespaces_get(const Eolian_Typedecl *tp); const char *eolian_type_free_func_get(const Eolian_Type *tp); const char *eolian_typedecl_free_func_get(const Eolian_Typedecl *tp); Eolian_Value_t eolian_expression_eval(const Eolian_Expression *expr, Eolian_Expression_Mask m); Eolian_Value_t eolian_expression_eval_type(const Eolian_Expression *expr, const Eolian_Type *type); const char *eolian_expression_value_to_literal(const Eolian_Value *v); const char *eolian_expression_serialize(const Eolian_Expression *expr); Eolian_Expression_Type eolian_expression_type_get(const Eolian_Expression *expr); Eolian_Binary_Operator eolian_expression_binary_operator_get(const Eolian_Expression *expr); const Eolian_Expression *eolian_expression_binary_lhs_get(const Eolian_Expression *expr); const Eolian_Expression *eolian_expression_binary_rhs_get(const Eolian_Expression *expr); Eolian_Unary_Operator eolian_expression_unary_operator_get(const Eolian_Expression *expr); const Eolian_Expression *eolian_expression_unary_expression_get(const Eolian_Expression *expr); Eolian_Value_t eolian_expression_value_get(const Eolian_Expression *expr); const Eolian_Variable *eolian_variable_global_get_by_name(const Eolian_Unit *unit, const char *name); const Eolian_Variable *eolian_variable_constant_get_by_name(const Eolian_Unit *unit, const char *name); Eina_Iterator *eolian_variable_globals_get_by_file(const Eolian_Unit *unit, const char *fname); Eina_Iterator *eolian_variable_constants_get_by_file(const Eolian_Unit *unit, const char *fname); Eina_Iterator *eolian_variable_all_constants_get(const Eolian_Unit *unit); Eina_Iterator *eolian_variable_all_globals_get(const Eolian_Unit *unit); Eolian_Variable_Type eolian_variable_type_get(const Eolian_Variable *var); const Eolian_Documentation *eolian_variable_documentation_get(const Eolian_Variable *var); const char *eolian_variable_file_get(const Eolian_Variable *var); const Eolian_Type *eolian_variable_base_type_get(const Eolian_Variable *var); const Eolian_Expression *eolian_variable_value_get(const Eolian_Variable *var); const char *eolian_variable_name_get(const Eolian_Variable *var); const char *eolian_variable_full_name_get(const Eolian_Variable *var); Eina_Iterator *eolian_variable_namespaces_get(const Eolian_Variable *var); Eina_Bool eolian_variable_is_extern(const Eolian_Variable *var); const Eolian_Declaration *eolian_declaration_get_by_name(const char *name); Eina_Iterator *eolian_declarations_get_by_file(const char *fname); Eina_Iterator *eolian_all_declarations_get(void); Eolian_Declaration_Type eolian_declaration_type_get(const Eolian_Declaration *decl); const char *eolian_declaration_name_get(const Eolian_Declaration *decl); const Eolian_Class *eolian_declaration_class_get(const Eolian_Declaration *decl); const Eolian_Type *eolian_declaration_data_type_get(const Eolian_Declaration *decl); const Eolian_Variable *eolian_declaration_variable_get(const Eolian_Declaration *decl); const char *eolian_documentation_summary_get(const Eolian_Documentation *doc); const char *eolian_documentation_description_get(const Eolian_Documentation *doc); const char *eolian_documentation_since_get(const Eolian_Documentation *doc); const char *eolian_documentation_tokenize(const char *doc, Eolian_Doc_Token *ret); void eolian_doc_token_init(Eolian_Doc_Token *tok); Eolian_Doc_Token_Type eolian_doc_token_type_get(const Eolian_Doc_Token *tok); char *eolian_doc_token_text_get(const Eolian_Doc_Token *tok); Eolian_Doc_Ref_Type eolian_doc_token_ref_get(const Eolian_Doc_Token *tok, const void **data, const void **data2); ]] local cutil = require("cutil") local util = require("util") local iterator = require("eina.iterator") local Ptr_Iterator = iterator.Ptr_Iterator local M = {} local eolian local eina local init = function() eolian = util.lib_load("eolian") eina = util.lib_load("eina") eolian.eolian_init() end local shutdown = function() eolian.eolian_shutdown() util.lib_unload("eolian") util.lib_unload("eina") end local ffi_stringshare = function(s) local r = ffi.string(s) eina.eina_stringshare_del(s) return r end cutil.init_module(init, shutdown) M.object_scope = { UNKNOWN = 0, PUBLIC = 1, PRIVATE = 2, PROTECTED = 3 } M.directory_scan = function(dir) return eolian.eolian_directory_scan(dir) ~= 0 end M.system_directory_scan = function() return eolian.eolian_system_directory_scan() ~= 0 end M.file_parse = function(fpath) return eolian.eolian_file_parse(fpath) end M.all_eo_files_parse = function() return eolian.eolian_all_eo_files_parse() ~= 0 end M.all_eot_files_parse = function() return eolian.eolian_all_eot_files_parse() ~= 0 end M.all_eo_file_paths_get = function() return iterator.String_Iterator(eolian.eolian_all_eo_file_paths_get()) end M.all_eot_file_paths_get = function() return iterator.String_Iterator(eolian.eolian_all_eot_file_paths_get()) end M.all_eo_files_get = function() return iterator.String_Iterator(eolian.eolian_all_eo_files_get()) end M.all_eot_files_get = function() return iterator.String_Iterator(eolian.eolian_all_eot_files_get()) end M.database_validate = function() return eolian.eolian_database_validate() ~= 0 end M.declaration_type = { UNKNOWN = 0, CLASS = 0, ALIAS = 1, STRUCT = 2, ENUM = 3, VAR = 4 } M.type_type = { UNKNOWN = 0, VOID = 1, REGULAR = 2, COMPLEX = 3, CLASS = 4, STATIC_ARRAY = 5, TERMINATED_ARRAY = 6, UNDEFINED = 7 } M.typedecl_type = { UNKNOWN = 0, STRUCT = 1, STRUCT_OPAQUE = 2, ENUM = 3, ALIAS = 4 } ffi.metatype("Eolian_Struct_Type_Field", { __index = { name_get = function(self) local v = eolian.eolian_typedecl_struct_field_name_get(self) if v == nil then return nil end return ffi.string(v) end, documentation_get = function(self) local v = eolian.eolian_typedecl_struct_field_documentation_get(self) if v == nil then return nil end return v end, type_get = function(self) local v = eolian.eolian_typedecl_struct_field_type_get(self) if v == nil then return nil end return v end } }) ffi.metatype("Eolian_Enum_Type_Field", { __index = { name_get = function(self) local v = eolian.eolian_typedecl_enum_field_name_get(self) if v == nil then return nil end return ffi.string(v) end, c_name_get = function(self) local v = eolian.eolian_typedecl_enum_field_c_name_get(self) if v == nil then return nil end return ffi_stringshare(v) end, documentation_get = function(self) local v = eolian.eolian_typedecl_enum_field_documentation_get(self) if v == nil then return nil end return v end, value_get = function(self, force) local v = eolian.eolian_typedecl_enum_field_value_get(self, force and 1 or 0) if v == nil then return nil end return v end } }) M.Typedecl = ffi.metatype("Eolian_Typedecl", { __index = { type_get = function(self) return tonumber(eolian.eolian_typedecl_type_get(self)) end, struct_fields_get = function(self) return Ptr_Iterator("const Eolian_Struct_Type_Field*", eolian.eolian_typedecl_struct_fields_get(self)) end, struct_field_get = function(self, name) local v = eolian.eolian_typedecl_struct_field_get(self, name) if v == nil then return nil end return v end, enum_fields_get = function(self) return Ptr_Iterator("const Eolian_Enum_Type_Field*", eolian.eolian_typedecl_enum_fields_get(self)) end, enum_field_get = function(self, field) local v = eolian.eolian_typedecl_enum_field_get(self, field) if v == nil then return nil end return v end, enum_legacy_prefix_get = function(self) local v = eolian.eolian_typedecl_enum_legacy_prefix_get(self) if v == nil then return nil end return ffi.string(v) end, documentation_get = function(self, name) local v = eolian.eolian_typedecl_documentation_get(self) if v == nil then return nil end return v end, file_get = function(self, name) local v = eolian.eolian_typedecl_file_get(self) if v == nil then return nil end return ffi.string(v) end, base_type_get = function(self) local v = eolian.eolian_typedecl_base_type_get(self) if v == nil then return nil end return v end, aliased_base_get = function(self) local v = eolian.eolian_typedecl_aliased_byse_get(self) if v == nil then return nil end return v end, is_extern = function(self) return eolian.eolian_typedecl_is_extern(self) ~= 0 end, c_type_get = function(self) local v = eolian.eolian_typedecl_c_type_get(self) if v == nil then return nil end return ffi_stringshare(v) end, name_get = function(self) local v = eolian.eolian_typedecl_name_get(self) if v == nil then return nil end return ffi.string(v) end, full_name_get = function(self) local v = eolian.eolian_typedecl_full_name_get(self) if v == nil then return nil end return ffi.string(v) end, namespaces_get = function(self) return iterator.String_Iterator( eolian.eolian_typedecl_namespaces_get(self)) end, free_func_get = function(self) local v = eolian.eolian_typedecl_free_func_get(self) if v == nil then return nil end return ffi.string(v) end } }) M.Type = ffi.metatype("Eolian_Type", { __index = { type_get = function(self) return tonumber(eolian.eolian_type_type_get(self)) end, file_get = function(self, name) local v = eolian.eolian_type_file_get(self) if v == nil then return nil end return ffi.string(v) end, base_type_get = function(self) local v = eolian.eolian_type_base_type_get(self) if v == nil then return nil end return v end, next_type_get = function(self) local v = eolian.eolian_type_next_type_get(self) if v == nil then return nil end return v end, typedecl_get = function(self) local v = eolian.eolian_type_typedecl_get(self) if v == nil then return nil end return v end, aliased_base_get = function(self) local v = eolian.eolian_type_aliased_byse_get(self) if v == nil then return nil end return v end, class_get = function(self) local v = eolian.eolian_type_class_get(self) if v == nil then return nil end return v end, array_size_get = function(self) return tonumber(eolian.eolian_type_array_size_get(self)) end, is_own = function(self) return eolian.eolian_type_is_own(self) ~= 0 end, is_const = function(self) return eolian.eolian_type_is_const(self) ~= 0 end, is_ptr = function(self) return eolian.eolian_type_is_ptr(self) ~= 0 end, c_type_get = function(self) local v = eolian.eolian_type_c_type_get(self) if v == nil then return nil end return ffi_stringshare(v) end, name_get = function(self) local v = eolian.eolian_type_name_get(self) if v == nil then return nil end return ffi.string(v) end, full_name_get = function(self) local v = eolian.eolian_type_full_name_get(self) if v == nil then return nil end return ffi.string(v) end, namespaces_get = function(self) return iterator.String_Iterator( eolian.eolian_type_namespaces_get(self)) end, free_func_get = function(self) local v = eolian.eolian_type_free_func_get(self) if v == nil then return nil end return ffi.string(v) end } }) M.function_type = { UNRESOLVED = 0, PROPERTY = 1, PROP_SET = 2, PROP_GET = 3, METHOD = 4 } M.Function = ffi.metatype("Eolian_Function", { __index = { type_get = function(self) return tonumber(eolian.eolian_function_type_get(self)) end, scope_get = function(self, ftype) return tonumber(eolian.eolian_function_scope_get(self, ftype)) end, name_get = function(self) local v = eolian.eolian_function_name_get(self) if v == nil then return nil end return ffi.string(v) end, full_c_name_get = function(self, ftype, use_legacy) local v = eolian.eolian_function_full_c_name_get(self, ftype, use_legacy or false) if v == nil then return nil end return ffi_stringshare(v) end, legacy_get = function(self, ftype) local v = eolian.eolian_function_legacy_get(self, ftype) if v == nil then return nil end return ffi.string(v) end, implement_get = function(self) local v = eolian.eolian_function_implement_get(self) if v == nil then return nil end return v end, is_legacy_only = function(self, ftype) return eolian.eolian_function_is_legacy_only(self, ftype) ~= 0 end, is_class = function(self) return eolian.eolian_function_is_class(self) ~= 0 end, is_c_only = function(self) return eolian.eolian_function_is_c_only(self) ~= 0 end, property_keys_get = function(self, ftype) return Ptr_Iterator("const Eolian_Function_Parameter*", eolian.eolian_property_keys_get(self, ftype)) end, property_values_get = function(self, ftype) return Ptr_Iterator("const Eolian_Function_Parameter*", eolian.eolian_property_values_get(self, ftype)) end, parameters_get = function(self) return Ptr_Iterator("const Eolian_Function_Parameter*", eolian.eolian_function_parameters_get(self)) end, return_type_get = function(self, ftype) local v = eolian.eolian_function_return_type_get(self, ftype) if v == nil then return nil end return v end, return_default_value_get = function(self, ftype) local v = eolian.eolian_function_return_default_value_get(self, ftype) if v == nil then return nil end return v end, return_documentation_get = function(self, ftype) local v = eolian.eolian_function_return_documentation_get(self, ftype) if v == nil then return nil end return v end, return_is_warn_unused = function(self, ftype) return eolian.eolian_function_return_is_warn_unused(self, ftype) ~= 0 end, is_const = function(self) return eolian.eolian_function_object_is_const(self) ~= 0 end } }) M.parameter_dir = { UNKNOWN = 0, IN = 1, OUT = 2, INOUT = 3 } ffi.metatype("Eolian_Function_Parameter", { __index = { direction_get = function(self) return tonumber(eolian.eolian_parameter_direction_get(self)) end, type_get = function(self) local v = eolian.eolian_parameter_type_get(self) if v == nil then return nil end return v end, default_value_get = function(self) local v = eolian.eolian_parameter_default_value_get(self) if v == nil then return nil end return v end, name_get = function(self) local v = eolian.eolian_parameter_name_get(self) if v == nil then return nil end return ffi.string(v) end, documentation_get = function(self) local v = eolian.eolian_parameter_documentation_get(self) if v == nil then return nil end return v end, is_nonull = function(self) return eolian.eolian_parameter_is_nonull(self) ~= 0 end, is_nullable = function(self) return eolian.eolian_parameter_is_nullable(self) ~= 0 end, is_optional = function(self) return eolian.eolian_parameter_is_optional(self) ~= 0 end } }) ffi.metatype("Eolian_Implement", { __index = { full_name_get = function(self) local v = eolian.eolian_implement_full_name_get(self) if v == nil then return nil end return ffi.string(v) end, class_get = function(self) local v = eolian.eolian_implement_class_get(self) if v == nil then return nil end return v end, function_get = function(self) local tp = ffi.new("Eolian_Function_Type[1]") local v = eolian.eolian_implement_function_get(self, tp) if v == nil then return nil end return v, tp[0] end, documentation_get = function(self, ftype) local v = eolian.eolian_implement_documentation_get(self, ftype) if v == nil then return nil end return v end, is_auto = function(self, ftype) return eolian.eolian_implement_is_auto(self, ftype) ~= 0 end, is_empty = function(self, ftype) return eolian.eolian_implement_is_empty(self, ftype) ~= 0 end, is_pure_virtual = function(self, ftype) return eolian.eolian_implement_is_pure_virtual(self, ftype) ~= 0 end, is_prop_get = function(self) return eolian.eolian_implement_is_prop_get(self) ~= 0 end, is_prop_set = function(self) return eolian.eolian_implement_is_prop_set(self) ~= 0 end } }) ffi.metatype("Eolian_Constructor", { __index = { full_name_get = function(self) local v = eolian.eolian_constructor_full_name_get(self) if v == nil then return nil end return ffi.string(v) end, class_get = function(self) local v = eolian.eolian_constructor_class_get(self) if v == nil then return nil end return v end, function_get = function(self) local v = eolian.eolian_constructor_function_get(self) if v == nil then return nil end return v end, is_optional = function(self) return eolian.eolian_constructor_is_optional(self) ~= 0 end } }) ffi.metatype("Eolian_Event", { __index = { name_get = function(self) local v = eolian.eolian_event_name_get(self) if v == nil then return nil end return ffi.string(v) end, type_get = function(self) local v = eolian.eolian_event_type_get(self) if v == nil then return nil end return v end, documentation_get = function(self) local v = eolian.eolian_event_documentation_get(self) if v == nil then return nil end return v end, scope_get = function(self) return tonumber(eolian.eolian_event_scope_get(self)) end, c_name_get = function(self) local v = eolian.eolian_event_c_name_get(self) if v == nil then return nil end return ffi_stringshare(v) end, is_beta = function(self) return eolian.eolian_event_is_beta(self) ~= 0 end, is_hot = function(self) return eolian.eolian_event_is_hot(self) ~= 0 end, is_restart = function(self) return eolian.eolian_event_is_restart(self) ~= 0 end } }) M.class_get_by_name = function(unit, cname) local v = eolian.eolian_class_get_by_name(unit, cname) if v == nil then return nil end return v end M.class_get_by_file = function(unit, fname) local v = eolian.eolian_class_get_by_file(unit, fname) if v == nil then return nil end return v end M.all_classes_get = function(unit) return Ptr_Iterator("const Eolian_Class*", eolian.eolian_all_classes_get(unit)) end M.class_type = { UNKNOWN = 0, REGULAR = 1, ABSTRACT = 2, MIXIN = 3, INTERFACE = 4 } M.Class = ffi.metatype("Eolian_Class", { __index = { file_get = function(self) local v = eolian.eolian_class_file_get(self) if v == nil then return nil end return ffi.string(v) end, full_name_get = function(self) local v = eolian.eolian_class_full_name_get(self) if v == nil then return nil end return ffi.string(v) end, name_get = function(self) local v = eolian.eolian_class_name_get(self) if v == nil then return nil end return ffi.string(v) end, namespaces_get = function(self) return iterator.String_Iterator( eolian.eolian_class_namespaces_get(self)) end, type_get = function(self) return tonumber(eolian.eolian_class_type_get(self)) end, documentation_get = function(self) local v = eolian.eolian_class_documentation_get(self) if v == nil then return nil end return v end, legacy_prefix_get = function(self) local v = eolian.eolian_class_legacy_prefix_get(self) if v == nil then return nil end return ffi.string(v) end, eo_prefix_get = function(self) local v = eolian.eolian_class_eo_prefix_get(self) if v == nil then local buf = self:namespaces_get() buf[#buf + 1] = self:name_get() return table.concat(buf, "_"):lower() end return ffi.string(v) end, data_type_get = function(self) local v = eolian.eolian_class_data_type_get(self) if v == nil then return nil end return ffi.string(v) end, inherits_get = function(self) return iterator.String_Iterator( eolian.eolian_class_inherits_get(self)) end, functions_get = function(self, func_type) return Ptr_Iterator("const Eolian_Function*", eolian.eolian_class_functions_get(self, func_type)) end, function_get_by_name = function(self, fname, ftype) local v = eolian.eolian_class_function_get_by_name(self, fname, ftype) if v == nil then return nil end return v end, implements_get = function(self) return Ptr_Iterator("const Eolian_Implement*", eolian.eolian_class_implements_get(self)) end, constructors_get = function(self) return Ptr_Iterator("const Eolian_Constructor*", eolian.eolian_class_constructors_get(self)) end, events_get = function(self) return Ptr_Iterator("const Eolian_Event*", eolian.eolian_class_events_get(self)) end, ctor_enable_get = function(self) return eolian.eolian_class_ctor_enable_get(self) ~= 0 end, dtor_enable_get = function(self) return eolian.eolian_class_dtor_enable_get(self) ~= 0 end, c_get_function_name_get = function(self) local v = eolian.eolian_class_c_get_function_name_get(self) if v == nil then return nil end return ffi_stringshare(v) end } }) M.typedecl_alias_get_by_name = function(name) local v = eolian.eolian_typedecl_alias_get_by_name(name) if v == nil then return nil end return v end M.typedecl_struct_get_by_name = function(name) local v = eolian.eolian_typedecl_struct_get_by_name(name) if v == nil then return nil end return v end M.typedecl_enum_get_by_name = function(name) local v = eolian.eolian_typedecl_enum_get_by_name(name) if v == nil then return nil end return v end M.typedecl_aliases_get_by_file = function(fname) return Ptr_Iterator("const Eolian_Typedecl *", eolian.eolian_type_aliases_get_by_file(self)) end M.typedecl_structs_get_by_file = function(fname) return Ptr_Iterator("const Eolian_Typedecl *", eolian.eolian_type_structs_get_by_file(self)) end M.typedecl_enums_get_by_file = function(fname) return Ptr_Iterator("const Eolian_Typedecl *", eolian.eolian_type_enums_get_by_file(self)) end M.typedecl_all_aliases_get = function() return Ptr_Iterator("const Eolian_Typedecl *", eolian.eolian_typedecl_all_aliases_get()) end M.typedecl_all_structs_get = function() return Ptr_Iterator("const Eolian_Typedecl *", eolian.eolian_typedecl_all_structs_get()) end M.typedecl_all_enums_get = function() return Ptr_Iterator("const Eolian_Typedecl *", eolian.eolian_typedecl_all_enums_get()) end M.expression_type = { UNKNOWN = 0, INT = 1, UINT = 2, LONG = 3, ULONG = 4, LLONG = 5, ULLONG = 6, FLOAT = 7, DOUBLE = 8, STRING = 9, CHAR = 10, NULL = 11, BOOL = 12, NAME = 13, UNARY = 15, BINARY = 16 } local etype = M.expression_type M.expression_mask = { SINT = bit.lshift(1, 0), UINT = bit.lshift(1, 1), FLOAT = bit.lshift(1, 2), BOOL = bit.lshift(1, 3), STRING = bit.lshift(1, 4), CHAR = bit.lshift(1, 5), NULL = bit.lshift(1, 6) } local emask = M.expression_mask emask.INT = bit.bor(emask.SINT , emask.UINT ) emask.SIGNED = bit.bor(emask.SINT , emask.FLOAT) emask.NUMBER = bit.bor(emask.INT , emask.FLOAT) emask.ALL = bit.bor(emask.NUMBER, emask.BOOL, emask.STRING, emask.CHAR, emask.NULL) M.variable_type = { UNKNOWN = 0, CONSTANT = 1, GLOBAL = 2 } local value_con = { [etype.INT ] = function(v) return tonumber(v.value.i ) end, [etype.UINT ] = function(v) return tonumber(v.value.u ) end, [etype.LONG ] = function(v) return v.value.l end, [etype.ULONG ] = function(v) return v.value.ul end, [etype.LLONG ] = function(v) return v.value.ll end, [etype.ULLONG] = function(v) return v.value.ull end, [etype.FLOAT ] = function(v) return tonumber(v.value.f ) end, [etype.DOUBLE] = function(v) return tonumber(v.value.d ) end, [etype.STRING] = function(v) return ffi.string(v.value.s ) end, [etype.CHAR ] = function(v) return string.char(v.value.c) end, [etype.NULL ] = function(v) return nil end, [etype.BOOL ] = function(v) return v.value.b ~= 0 end } M.Value = ffi.metatype("Eolian_Value", { __index = { get_type = function(self) return tonumber(ffi.cast("Eolian_Value_t*", self).type) end, get_value = function(self) local tp = self:get_type() local fun = value_con[tonumber(tp)] if not fun then return nil end return fun() end, to_literal = function(self) local v = eolian.eolian_expression_value_to_literal(self) if v == nil then return nil end return ffi_stringshare(v) end } }) M.binary_operator = { INVALID = 0, ADD = 1, SUB = 2, MUL = 3, DIV = 4, MOD = 5, EQ = 6, NQ = 7, GT = 8, LT = 9, GE = 10, LE = 11, AND = 12, OR = 13, BAND = 14, BOR = 15, BXOR = 16, LSH = 17, RSH = 18 } M.unary_operator = { INVALID = 0, UNM = 1, UNP = 2, NOT = 3, BNOT = 4 } M.Expression = ffi.metatype("Eolian_Expression", { __index = { eval = function(self, mask) mask = mask or emask.ALL local v = eolian.eolian_expression_eval(self, mask) if v == nil then return nil end return ffi.cast("Eolian_Value*", v) end, eval_type = function(self, tp) local v = eolian.eolian_expression_eval_type(self, tp) if v == nil then return nil end return ffi.cast("Eolian_Value*", v) end, serialize = function(self) local v = eolian.eolian_expression_serialize(self) if v == nil then return nil end return ffi_stringshare(v) end, type_get = function(self) return tonumber(eolian.eolian_expression_type_get(self)) end, binary_operator_get = function(self) return tonumber(eolian.eolian_expression_binary_operator_get(self)) end, binary_lhs_get = function(self) local v = eolian.eolian_expression_binary_lhs_get(self) if v == nil then return nil end return v end, binary_rhs_get = function(self) local v = eolian.eolian_expression_binary_rhs_get(self) if v == nil then return nil end return v end, unary_operator_get = function(self) return tonumber(eolian.eolian_expression_unary_operator_get(self)) end, unary_expression_get = function(self) local v = eolian.eolian_expression_unary_expression_get(self) if v == nil then return nil end return v end, value_get = function(self) local v = eolian.eolian_expression_value_get(self) if v == nil then return nil end return ffi.cast("Eolian_Value*", v) end } }) M.variable_global_get_by_name = function(unit, name) local v = eolian.eolian_variable_global_get_by_name(unit, name) if v == nil then return nil end return v end M.variable_constant_get_by_name = function(unit, name) local v = eolian.eolian_variable_constant_get_by_name(unit, name) if v == nil then return nil end return v end M.variable_globals_get_by_file = function(unit, fname) return Ptr_Iterator("const Eolian_Variable*", eolian.eolian_variable_globals_get_by_file(unit, fname)) end M.variable_constants_get_by_file = function(unit, fname) return Ptr_Iterator("const Eolian_Variable*", eolian.eolian_variable_constants_get_by_file(unit, fname)) end M.variable_all_constants_get = function(unit) return Ptr_Iterator("const Eolian_Variable *", eolian.eolian_variable_all_constants_get(unit)) end M.variable_all_globals_get = function(unit) return Ptr_Iterator("const Eolian_Variable *", eolian.eolian_variable_all_globals_get(unit)) end M.Variable = ffi.metatype("Eolian_Variable", { __index = { type_get = function(self) return tonumber(eolian.eolian_variable_type_get(self)) end, documentation_get = function(self) local v = eolian.eolian_variable_documentation_get(self) if v == nil then return nil end return v end, file_get = function(self) local v = eolian.eolian_variable_file_get(self) if v == nil then return nil end return ffi.string(v) end, base_type_get = function(self) local v = eolian.eolian_variable_base_type_get(self) if v == nil then return nil end return v end, value_get = function(self) local v = eolian.eolian_variable_value_get(self) if v == nil then return nil end return v end, name_get = function(self) local v = eolian.eolian_variable_name_get(self) if v == nil then return nil end return ffi.string(v) end, full_name_get = function(self) local v = eolian.eolian_variable_full_name_get(self) if v == nil then return nil end return ffi.string(v) end, namespaces_get = function(self) return iterator.String_Iterator( eolian.eolian_variable_namespaces_get(self)) end, is_extern = function(self) return eolian.eolian_variable_is_extern(self) ~= 0 end } }) M.declaration_get_by_name = function(name) local v = eolian.eolian_declaration_get_by_name(name) if v == nil then return nil end return v end M.declarations_get_by_file = function(fname) return Ptr_ITerator("const Eolian_Declaration*", eolian.eolian_declarations_get_by_file(fname)) end M.all_declarations_get = function() return Ptr_Iterator("const Eolian_Declaration *", eolian.eolian_all_declarations_get()) end M.Declaration = ffi.metatype("Eolian_Declaration", { __index = { type_get = function(self) return tonumber(eolian.eolian_declaration_type_get(self)) end, name_get = function(self) local v = eolian.eolian_declaration_name_get(self) if v == nil then return nil end return ffi.string(v) end, class_get = function(self) local v = eolian.eolian_declaration_class_get(self) if v == nil then return nil end return v end, data_type_get = function(self) local v = eolian.eolian_declaration_data_type_get(self) if v == nil then return nil end return v end, variable_get = function(self) local v = eolian.eolian_declaration_variable_get(self) if v == nil then return nil end return v end } }) M.Documentation = ffi.metatype("Eolian_Documentation", { __index = { summary_get = function(self) local v = eolian.eolian_documentation_summary_get(self) if v == nil then return nil end return ffi.string(v) end, description_get = function(self) local v = eolian.eolian_documentation_description_get(self) if v == nil then return nil end return ffi.string(v) end, since_get = function(self) local v = eolian.eolian_documentation_since_get(self) if v == nil then return nil end return ffi.string(v) end } }) M.doc_token_type = { UNKNOWN = 0, TEXT = 1, REF = 2, MARK_NOTE = 3, MARK_WARNING = 4, MARK_REMARK = 5, MARK_TODO = 6, MARKUP_MONOSPACE = 7 } M.doc_ref_type = { INVALID = 0, CLASS = 1, FUNC = 2, EVENT = 3, ALIAS = 4, STRUCT = 5, STRUCT_FIELD = 6, ENUM = 7, ENUM_FIELD = 8, VAR = 9 } M.documentation_string_split = function(str) if not str then return {} end local sep = str:find("\n\n", 1, true) local ret = {} while true do local pstr = (sep and str:sub(1, sep - 1) or str):match("^%s*(.-)%s*$") if #pstr > 0 then ret[#ret + 1] = pstr end if not sep then break end str = str:sub(sep + 2) sep = str:find("\n\n", 1, true) end return ret end M.documentation_tokenize = function(doc, ret) local ret = eolian.eolian_documentation_tokenize(doc, ret) if ret == nil then return nil end return ffi.string(ret) end M.doc_token_init = function() local ret = ffi.new("Eolian_Doc_Token") eolian.eolian_doc_token_init(ret) return ret end M.Eolian_Doc_Token = ffi.metatype("Eolian_Doc_Token", { __index = { type_get = function(self) return tonumber(eolian.eolian_doc_token_type_get(self)) end, text_get = function(self) local str = eolian.eolian_doc_token_text_get(self) if str == nil then return nil end local ret = ffi.string(str) ffi.C.free(str) return ret end, ref_get = function(self) local stor = ffi.new("const void *[2]") local tp = tonumber(eolian.eolian_doc_token_ref_get(self, stor, stor + 1)) local reft = M.doc_ref_type if tp == reft.CLASS then return tp, ffi.cast("const Eolian_Class *", stor[0]) elseif tp == reft.FUNC then return tp, ffi.cast("const Eolian_Class *", stor[0]), ffi.cast("const Eolian_Function *", stor[1]) elseif tp == reft.EVENT then return tp, ffi.cast("const Eolian_Class *", stor[0]), ffi.cast("const Eolian_Event *", stor[1]) elseif tp == reft.ALIAS then return tp, ffi.cast("const Eolian_Typedecl *", stor[0]) elseif tp == reft.STRUCT then return tp, ffi.cast("const Eolian_Typedecl *", stor[0]) elseif tp == reft.STRUCT_FIELD then return tp, ffi.cast("const Eolian_Typedecl *", stor[0]), ffi.cast("const Eolian_Struct_Type_Field *", stor[1]) elseif tp == reft.ENUM then return tp, ffi.cast("const Eolian_Typedecl *", stor[0]) elseif tp == reft.ENUM_FIELD then return tp, ffi.cast("const Eolian_Typedecl *", stor[0]), ffi.cast("const Eolian_Enum_Type_Field *", stor[1]) elseif tp == reft.VAR then return tp, ffi.cast("const Eolian_Variable *", stor[0]) else return reft.INVALID end end } }) return M