2013-07-31 09:04:19 +00:00
|
|
|
#ifndef GMQCC_PARSER_HDR
|
|
|
|
#define GMQCC_PARSER_HDR
|
|
|
|
#include "gmqcc.h"
|
|
|
|
#include "lexer.h"
|
|
|
|
#include "ast.h"
|
|
|
|
|
2013-08-14 06:02:15 +00:00
|
|
|
typedef struct intrin_s intrin_t;
|
|
|
|
typedef struct parser_s parser_t;
|
|
|
|
|
2013-07-31 09:04:19 +00:00
|
|
|
typedef struct {
|
|
|
|
struct parser_s *parser;
|
|
|
|
ast_value **imm_float; /* vector<ast_value*> */
|
|
|
|
ast_value **imm_vector; /* vector<ast_value*> */
|
|
|
|
ast_value **imm_string; /* vector<ast_value*> */
|
|
|
|
hash_table_t *imm_string_untranslate; /* map<string, ast_value*> */
|
|
|
|
hash_table_t *imm_string_dotranslate; /* map<string, ast_value*> */
|
|
|
|
} fold_t;
|
|
|
|
|
2013-08-14 06:02:15 +00:00
|
|
|
typedef struct {
|
|
|
|
ast_expression *(*intrin)(intrin_t *);
|
|
|
|
const char *name;
|
|
|
|
const char *alias;
|
2013-10-17 04:14:42 +00:00
|
|
|
size_t args;
|
2013-08-14 06:02:15 +00:00
|
|
|
} intrin_func_t;
|
|
|
|
|
|
|
|
struct intrin_s {
|
2013-10-16 04:04:39 +00:00
|
|
|
intrin_func_t *intrinsics; /* vector<intrin_func_t> */
|
|
|
|
ast_expression **generated; /* vector<ast_expression*> */
|
2013-08-14 06:02:15 +00:00
|
|
|
parser_t *parser;
|
|
|
|
fold_t *fold;
|
|
|
|
};
|
|
|
|
|
2013-07-31 16:31:45 +00:00
|
|
|
#define parser_ctx(p) ((p)->lex->tok.ctx)
|
|
|
|
|
2013-08-14 06:02:15 +00:00
|
|
|
struct parser_s {
|
2013-07-31 09:04:19 +00:00
|
|
|
lex_file *lex;
|
|
|
|
int tok;
|
|
|
|
|
|
|
|
bool ast_cleaned;
|
|
|
|
|
|
|
|
ast_expression **globals;
|
|
|
|
ast_expression **fields;
|
|
|
|
ast_function **functions;
|
|
|
|
size_t translated;
|
|
|
|
|
|
|
|
/* must be deleted first, they reference immediates and values */
|
|
|
|
ast_value **accessors;
|
|
|
|
|
|
|
|
ast_value *nil;
|
|
|
|
ast_value *reserved_version;
|
|
|
|
|
|
|
|
size_t crc_globals;
|
|
|
|
size_t crc_fields;
|
|
|
|
|
|
|
|
ast_function *function;
|
|
|
|
ht aliases;
|
|
|
|
|
|
|
|
/* All the labels the function defined...
|
|
|
|
* Should they be in ast_function instead?
|
|
|
|
*/
|
|
|
|
ast_label **labels;
|
|
|
|
ast_goto **gotos;
|
|
|
|
const char **breaks;
|
|
|
|
const char **continues;
|
|
|
|
|
|
|
|
/* A list of hashtables for each scope */
|
|
|
|
ht *variables;
|
|
|
|
ht htfields;
|
|
|
|
ht htglobals;
|
|
|
|
ht *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;
|
|
|
|
|
|
|
|
/* we store the '=' operator info */
|
|
|
|
const oper_info *assign_op;
|
|
|
|
|
|
|
|
/* magic values */
|
|
|
|
ast_value *const_vec[3];
|
|
|
|
|
|
|
|
/* pragma flags */
|
|
|
|
bool noref;
|
|
|
|
|
|
|
|
/* collected information */
|
|
|
|
size_t max_param_count;
|
|
|
|
|
2013-08-14 06:02:15 +00:00
|
|
|
fold_t *fold;
|
|
|
|
intrin_t *intrin;
|
|
|
|
};
|
2013-07-31 09:04:19 +00:00
|
|
|
|
|
|
|
|
2013-08-14 06:02:15 +00:00
|
|
|
/* parser.c */
|
|
|
|
char *parser_strdup (const char *str);
|
|
|
|
ast_expression *parser_find_global(parser_t *parser, const char *name);
|
2013-07-31 09:04:19 +00:00
|
|
|
|
|
|
|
/* fold.c */
|
|
|
|
fold_t *fold_init (parser_t *);
|
|
|
|
void fold_cleanup (fold_t *);
|
2014-05-24 13:53:38 +00:00
|
|
|
ast_expression *fold_constgen_float (fold_t *, qcfloat_t, bool);
|
2013-07-31 09:04:19 +00:00
|
|
|
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 *);
|
2013-08-28 16:46:22 +00:00
|
|
|
ast_expression *fold_op (fold_t *, const oper_info *, ast_expression **);
|
|
|
|
ast_expression *fold_intrin (fold_t *, const char *, ast_expression **);
|
2013-07-31 19:34:38 +00:00
|
|
|
|
2013-10-25 11:40:31 +00:00
|
|
|
ast_expression *fold_binary (lex_ctx_t ctx, int, ast_expression *, ast_expression *);
|
2013-09-26 10:51:49 +00:00
|
|
|
int fold_cond_ifthen (ir_value *, ast_function *, ast_ifthen *);
|
|
|
|
int fold_cond_ternary (ir_value *, ast_function *, ast_ternary *);
|
2013-07-31 19:34:38 +00:00
|
|
|
|
2013-08-14 06:02:15 +00:00
|
|
|
/* intrin.c */
|
|
|
|
intrin_t *intrin_init (parser_t *parser);
|
|
|
|
void intrin_cleanup (intrin_t *intrin);
|
2013-08-28 16:46:22 +00:00
|
|
|
ast_expression *intrin_fold (intrin_t *intrin, ast_value *, ast_expression **);
|
2013-08-14 06:02:15 +00:00
|
|
|
ast_expression *intrin_func (intrin_t *intrin, const char *name);
|
|
|
|
ast_expression *intrin_debug_typestring(intrin_t *intrin);
|
|
|
|
|
2013-07-31 09:04:19 +00:00
|
|
|
#endif
|