X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;ds=inline;f=parser.h;h=e5361a8aae020ba1c8ac8d2e2d74bcc78a55ecc9;hb=02b20dbd095a33dae17f3f1b5e84c9ea4b985f86;hp=7f07bdf404c5e746bec00091421fe912bbbf617a;hpb=aabefd1bfe0c5b08bea9341c1394cfa8b96d754d;p=xonotic%2Fgmqcc.git diff --git a/parser.h b/parser.h index 7f07bdf..e5361a8 100644 --- a/parser.h +++ b/parser.h @@ -4,47 +4,31 @@ #include "lexer.h" #include "ast.h" -struct parser_t; -struct intrin_t; - -struct fold_t { - parser_t *parser; - ast_value **imm_float; /* vector */ - ast_value **imm_vector; /* vector */ - ast_value **imm_string; /* vector */ - hash_table_t *imm_string_untranslate; /* map */ - hash_table_t *imm_string_dotranslate; /* map */ -}; +#include "intrin.h" +#include "fold.h" -struct intrin_func_t { - ast_expression *(*intrin)(intrin_t *); - const char *name; - const char *alias; - size_t args; -}; - -struct intrin_t { - intrin_func_t *intrinsics; /* vector */ - ast_expression **generated; /* vector */ - parser_t *parser; - fold_t *fold; -}; +struct parser_t; #define parser_ctx(p) ((p)->lex->tok.ctx) struct parser_t { + parser_t(); + ~parser_t(); + + void remove_ast(); + lex_file *lex; - int tok; + int tok; - bool ast_cleaned; + bool ast_cleaned; - ast_expression **globals; - ast_expression **fields; - ast_function **functions; - size_t translated; + std::vector globals; + std::vector fields; + std::vector functions; + size_t translated; /* must be deleted first, they reference immediates and values */ - ast_value **accessors; + std::vector accessors; ast_value *nil; ast_value *reserved_version; @@ -53,7 +37,7 @@ struct parser_t { size_t crc_fields; ast_function *function; - ht aliases; + ht aliases; /* All the labels the function defined... * Should they be in ast_function instead? @@ -64,17 +48,17 @@ struct parser_t { std::vector continues; /* A list of hashtables for each scope */ - ht *variables; + std::vector variables; ht htfields; ht htglobals; - ht *typedefs; + std::vector typedefs; /* not to be used directly, we use the hash table */ - ast_expression **_locals; - size_t *_blocklocals; - ast_value **_typedefs; - size_t *_blocktypedefs; - lex_ctx_t *_block_ctx; + std::vector _locals; + std::vector _blocklocals; + std::vector> _typedefs; + std::vector _blocktypedefs; + std::vector _block_ctx; /* we store the '=' operator info */ const oper_info *assign_op; @@ -86,10 +70,10 @@ struct parser_t { bool noref; /* collected information */ - size_t max_param_count; + size_t max_param_count; - fold_t *fold; - intrin_t *intrin; + fold m_fold; + intrin m_intrin; }; @@ -97,25 +81,4 @@ struct parser_t { char *parser_strdup (const char *str); ast_expression *parser_find_global(parser_t *parser, const char *name); -/* fold.c */ -fold_t *fold_init (parser_t *); -void fold_cleanup (fold_t *); -ast_expression *fold_constgen_float (fold_t *, qcfloat_t, bool); -ast_expression *fold_constgen_vector(fold_t *, vec3_t); -ast_expression *fold_constgen_string(fold_t *, const char *, bool); -bool fold_generate (fold_t *, ir_builder *); -ast_expression *fold_op (fold_t *, const oper_info *, ast_expression **); -ast_expression *fold_intrin (fold_t *, const char *, ast_expression **); - -ast_expression *fold_binary (lex_ctx_t ctx, int, ast_expression *, ast_expression *); -int fold_cond_ifthen (ir_value *, ast_function *, ast_ifthen *); -int fold_cond_ternary (ir_value *, ast_function *, ast_ternary *); - -/* intrin.c */ -intrin_t *intrin_init (parser_t *parser); -void intrin_cleanup (intrin_t *intrin); -ast_expression *intrin_fold (intrin_t *intrin, ast_value *, ast_expression **); -ast_expression *intrin_func (intrin_t *intrin, const char *name); -ast_expression *intrin_debug_typestring(intrin_t *intrin); - #endif