mirror of
https://github.com/Ed94/raddebugger.git
synced 2026-06-14 08:02:23 -07:00
300 lines
8.7 KiB
C
300 lines
8.7 KiB
C
// Copyright (c) 2024 Epic Games Tools
|
|
// Licensed under the MIT license (https://opensource.org/license/mit/)
|
|
|
|
#ifndef EVAL_PARSE_H
|
|
#define EVAL_PARSE_H
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Generated Code
|
|
|
|
#include "generated/eval.meta.h"
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Token Types
|
|
|
|
typedef struct E_Token E_Token;
|
|
struct E_Token
|
|
{
|
|
E_TokenKind kind;
|
|
Rng1U64 range;
|
|
};
|
|
|
|
typedef struct E_TokenChunkNode E_TokenChunkNode;
|
|
struct E_TokenChunkNode
|
|
{
|
|
E_TokenChunkNode *next;
|
|
E_Token *v;
|
|
U64 count;
|
|
U64 cap;
|
|
};
|
|
|
|
typedef struct E_TokenChunkList E_TokenChunkList;
|
|
struct E_TokenChunkList
|
|
{
|
|
E_TokenChunkNode *first;
|
|
E_TokenChunkNode *last;
|
|
U64 node_count;
|
|
U64 total_count;
|
|
};
|
|
|
|
typedef struct E_TokenArray E_TokenArray;
|
|
struct E_TokenArray
|
|
{
|
|
E_Token *v;
|
|
U64 count;
|
|
};
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Expression Tree Types
|
|
|
|
typedef struct E_Expr E_Expr;
|
|
struct E_Expr
|
|
{
|
|
E_Expr *first;
|
|
E_Expr *last;
|
|
E_Expr *first_tag;
|
|
E_Expr *last_tag;
|
|
E_Expr *next;
|
|
E_Expr *prev;
|
|
E_Expr *ref;
|
|
void *location;
|
|
E_ExprKind kind;
|
|
E_Mode mode;
|
|
E_Space space;
|
|
E_TypeKey type_key;
|
|
E_Value value;
|
|
String8 string;
|
|
String8 qualifier;
|
|
String8 bytecode;
|
|
};
|
|
|
|
typedef struct E_ExprNode E_ExprNode;
|
|
struct E_ExprNode
|
|
{
|
|
E_ExprNode *next;
|
|
E_Expr *v;
|
|
};
|
|
|
|
typedef struct E_ExprList E_ExprList;
|
|
struct E_ExprList
|
|
{
|
|
E_ExprNode *first;
|
|
E_ExprNode *last;
|
|
U64 count;
|
|
};
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Map Types
|
|
|
|
//- rjf: string -> num
|
|
|
|
typedef struct E_String2NumMapNode E_String2NumMapNode;
|
|
struct E_String2NumMapNode
|
|
{
|
|
E_String2NumMapNode *order_next;
|
|
E_String2NumMapNode *hash_next;
|
|
String8 string;
|
|
U64 num;
|
|
};
|
|
|
|
typedef struct E_String2NumMapNodeArray E_String2NumMapNodeArray;
|
|
struct E_String2NumMapNodeArray
|
|
{
|
|
E_String2NumMapNode **v;
|
|
U64 count;
|
|
};
|
|
|
|
typedef struct E_String2NumMapSlot E_String2NumMapSlot;
|
|
struct E_String2NumMapSlot
|
|
{
|
|
E_String2NumMapNode *first;
|
|
E_String2NumMapNode *last;
|
|
};
|
|
|
|
typedef struct E_String2NumMap E_String2NumMap;
|
|
struct E_String2NumMap
|
|
{
|
|
U64 slots_count;
|
|
U64 node_count;
|
|
E_String2NumMapSlot *slots;
|
|
E_String2NumMapNode *first;
|
|
E_String2NumMapNode *last;
|
|
};
|
|
|
|
//- rjf: string -> expr
|
|
|
|
typedef struct E_String2ExprMapNode E_String2ExprMapNode;
|
|
struct E_String2ExprMapNode
|
|
{
|
|
E_String2ExprMapNode *hash_next;
|
|
String8 string;
|
|
E_Expr *expr;
|
|
U64 poison_count;
|
|
};
|
|
|
|
typedef struct E_String2ExprMapSlot E_String2ExprMapSlot;
|
|
struct E_String2ExprMapSlot
|
|
{
|
|
E_String2ExprMapNode *first;
|
|
E_String2ExprMapNode *last;
|
|
};
|
|
|
|
typedef struct E_String2ExprMap E_String2ExprMap;
|
|
struct E_String2ExprMap
|
|
{
|
|
U64 slots_count;
|
|
E_String2ExprMapSlot *slots;
|
|
};
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Parse Results
|
|
|
|
typedef struct E_Parse E_Parse;
|
|
struct E_Parse
|
|
{
|
|
E_Token *last_token;
|
|
E_Expr *first_expr;
|
|
E_Expr *last_expr;
|
|
E_MsgList msgs;
|
|
};
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Parse Context
|
|
|
|
typedef struct E_ParseCtx E_ParseCtx;
|
|
struct E_ParseCtx
|
|
{
|
|
// rjf: instruction pointer info
|
|
U64 ip_vaddr;
|
|
U64 ip_voff;
|
|
E_Space ip_thread_space;
|
|
|
|
// rjf: modules
|
|
E_Module *modules;
|
|
U64 modules_count;
|
|
E_Module *primary_module;
|
|
|
|
// rjf: local identifier resolution maps
|
|
E_String2NumMap *regs_map;
|
|
E_String2NumMap *reg_alias_map;
|
|
E_String2NumMap *locals_map; // (within `rdis[rdis_primary_idx]`)
|
|
E_String2NumMap *member_map; // (within `rdis[rdis_primary_idx]`)
|
|
};
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Parse State (stateful thread-local caching mechanisms, not provided by user)
|
|
|
|
typedef struct E_ParseCacheNode E_ParseCacheNode;
|
|
struct E_ParseCacheNode
|
|
{
|
|
E_ParseCacheNode *next;
|
|
String8 string;
|
|
E_Parse parse;
|
|
};
|
|
|
|
typedef struct E_ParseCacheSlot E_ParseCacheSlot;
|
|
struct E_ParseCacheSlot
|
|
{
|
|
E_ParseCacheNode *first;
|
|
E_ParseCacheNode *last;
|
|
};
|
|
|
|
typedef struct E_ParseState E_ParseState;
|
|
struct E_ParseState
|
|
{
|
|
Arena *arena;
|
|
U64 arena_eval_start_pos;
|
|
E_ParseCtx *ctx;
|
|
|
|
// rjf: string -> parse cache
|
|
E_ParseCacheSlot *parse_cache_slots;
|
|
U64 parse_cache_slots_count;
|
|
};
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Globals
|
|
|
|
global read_only E_String2NumMap e_string2num_map_nil = {0};
|
|
global read_only E_String2ExprMap e_string2expr_map_nil = {0};
|
|
global read_only E_Expr e_expr_nil = {&e_expr_nil, &e_expr_nil, &e_expr_nil, &e_expr_nil, &e_expr_nil};
|
|
thread_static E_ParseState *e_parse_state = 0;
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Basic Map Functions
|
|
|
|
//- rjf: string -> num
|
|
internal E_String2NumMap e_string2num_map_make(Arena *arena, U64 slot_count);
|
|
internal void e_string2num_map_insert(Arena *arena, E_String2NumMap *map, String8 string, U64 num);
|
|
internal U64 e_num_from_string(E_String2NumMap *map, String8 string);
|
|
internal E_String2NumMapNodeArray e_string2num_map_node_array_from_map(Arena *arena, E_String2NumMap *map);
|
|
internal int e_string2num_map_node_qsort_compare__num_ascending(E_String2NumMapNode **a, E_String2NumMapNode **b);
|
|
internal void e_string2num_map_node_array_sort__in_place(E_String2NumMapNodeArray *array);
|
|
|
|
//- rjf: string -> expr
|
|
internal E_String2ExprMap e_string2expr_map_make(Arena *arena, U64 slot_count);
|
|
internal void e_string2expr_map_insert(Arena *arena, E_String2ExprMap *map, String8 string, E_Expr *expr);
|
|
internal void e_string2expr_map_inc_poison(E_String2ExprMap *map, String8 string);
|
|
internal void e_string2expr_map_dec_poison(E_String2ExprMap *map, String8 string);
|
|
internal E_Expr *e_string2expr_lookup(E_String2ExprMap *map, String8 string);
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Debug-Info-Driven Map Building Functions
|
|
|
|
internal E_String2NumMap *e_push_locals_map_from_rdi_voff(Arena *arena, RDI_Parsed *rdi, U64 voff);
|
|
internal E_String2NumMap *e_push_member_map_from_rdi_voff(Arena *arena, RDI_Parsed *rdi, U64 voff);
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Tokenization Functions
|
|
|
|
#define e_token_at_it(it, arr) (((it) < (arr)->v+(arr)->count) ? (*(it)) : e_token_zero())
|
|
internal E_Token e_token_zero(void);
|
|
internal void e_token_chunk_list_push(Arena *arena, E_TokenChunkList *list, U64 chunk_size, E_Token *token);
|
|
internal E_TokenArray e_token_array_from_chunk_list(Arena *arena, E_TokenChunkList *list);
|
|
internal E_TokenArray e_token_array_from_text(Arena *arena, String8 text);
|
|
internal E_TokenArray e_token_array_make_first_opl(E_Token *first, E_Token *opl);
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Context Selection Functions (Selection Required For All Subsequent APIs)
|
|
|
|
internal E_ParseCtx *e_selected_parse_ctx(void);
|
|
internal void e_select_parse_ctx(E_ParseCtx *ctx);
|
|
internal U32 e_parse_ctx_module_idx_from_rdi(RDI_Parsed *rdi);
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Expression Tree Building Functions
|
|
|
|
internal E_Expr *e_push_expr(Arena *arena, E_ExprKind kind, void *location);
|
|
internal void e_expr_insert_child(E_Expr *parent, E_Expr *prev, E_Expr *child);
|
|
internal void e_expr_push_child(E_Expr *parent, E_Expr *child);
|
|
internal void e_expr_remove_child(E_Expr *parent, E_Expr *child);
|
|
internal void e_expr_push_tag(E_Expr *parent, E_Expr *child);
|
|
internal E_Expr *e_expr_ref(Arena *arena, E_Expr *ref);
|
|
internal E_Expr *e_expr_ref_addr(Arena *arena, E_Expr *rhs);
|
|
internal E_Expr *e_expr_ref_member_access(Arena *arena, E_Expr *lhs, String8 member_name);
|
|
internal E_Expr *e_expr_ref_array_index(Arena *arena, E_Expr *lhs, U64 index);
|
|
internal E_Expr *e_expr_ref_deref(Arena *arena, E_Expr *rhs);
|
|
internal E_Expr *e_expr_ref_cast(Arena *arena, E_TypeKey type_key, E_Expr *rhs);
|
|
internal E_Expr *e_expr_ref_bswap(Arena *arena, E_Expr *rhs);
|
|
internal E_Expr *e_expr_copy(Arena *arena, E_Expr *src);
|
|
internal void e_expr_list_push(Arena *arena, E_ExprList *list, E_Expr *expr);
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Expression Tree -> String Conversions
|
|
|
|
internal void e_append_strings_from_expr(Arena *arena, E_Expr *expr, String8List *out);
|
|
internal String8 e_string_from_expr(Arena *arena, E_Expr *expr);
|
|
|
|
////////////////////////////////
|
|
//~ rjf: Parsing Functions
|
|
|
|
internal E_TypeKey e_leaf_type_from_name(String8 name);
|
|
internal E_TypeKey e_type_from_expr(E_Expr *expr);
|
|
internal void e_push_leaf_ident_exprs_from_expr__in_place(Arena *arena, E_String2ExprMap *map, E_Expr *expr);
|
|
internal E_Parse e_parse_type_from_text_tokens(Arena *arena, String8 text, E_TokenArray *tokens);
|
|
internal E_Parse e_parse_expr_from_text_tokens__prec(Arena *arena, String8 text, E_TokenArray *tokens, S64 max_precedence, U64 max_chain_count);
|
|
internal E_Parse e_parse_expr_from_text_tokens(Arena *arena, String8 text, E_TokenArray *tokens);
|
|
internal E_Expr *e_parse_expr_from_text(Arena *arena, String8 text);
|
|
internal E_Parse e_parse_expr_from_text__cached(String8 text);
|
|
|
|
#endif // EVAL_PARSE_H
|