adjust eval -> space range mapping to fix a few edge cases

This commit is contained in:
Ryan Fleury
2025-07-28 14:32:47 -07:00
parent c22ecf8e71
commit 5134d1ce4c
5 changed files with 49 additions and 54 deletions
+28 -25
View File
@@ -1350,38 +1350,41 @@ e_key_wrapf(E_Key key, char *fmt, ...)
////////////////////////////////
//~ rjf: Eval Info Extraction
internal U64
e_base_offset_from_eval(E_Eval eval)
internal Rng1U64
e_range_from_eval(E_Eval eval)
{
if(e_type_kind_is_pointer_or_ref(e_type_kind_from_key(e_type_key_unwrap(eval.irtree.type_key, E_TypeUnwrapFlag_AllDecorative))))
// rjf: choose base offset
U64 base_offset = 0;
{
eval = e_value_eval_from_eval(eval);
}
return eval.value.u64;
}
internal U64
e_range_size_from_eval(E_Eval eval)
{
U64 result = KB(16);
{
E_TypeKey type_core = e_type_key_unwrap(eval.irtree.type_key, E_TypeUnwrapFlag_AllDecorative);
E_TypeKind type_core_kind = e_type_kind_from_key(type_core);
B32 got_size = 0;
// rjf: try getting size from intrinsic type (e.g. arrays/etc.)
if(!got_size)
E_Eval base_off_eval = eval;
if(e_type_kind_is_pointer_or_ref(e_type_kind_from_key(e_type_key_unwrap(base_off_eval.irtree.type_key, E_TypeUnwrapFlag_AllDecorative))))
{
if(type_core_kind == E_TypeKind_Array ||
type_core_kind == E_TypeKind_Struct ||
type_core_kind == E_TypeKind_Union ||
type_core_kind == E_TypeKind_Class)
base_off_eval = e_value_eval_from_eval(base_off_eval);
}
base_offset = base_off_eval.value.u64;
}
// rjf: choose size
U64 size = KB(16);
{
E_TypeKey type_key = e_type_key_unwrap(eval.irtree.type_key, E_TypeUnwrapFlag_AllDecorative);
E_TypeKind type_kind = e_type_kind_from_key(type_key);
if(type_kind == E_TypeKind_Ptr)
{
E_Eval ptee_eval = e_eval_wrapf(eval, "*$");
U64 ptee_size = e_type_byte_size_from_key(ptee_eval.irtree.type_key);
if(ptee_size > 8)
{
result = e_type_byte_size_from_key(type_core);
got_size = 1;
size = ptee_size;
}
}
else
{
size = e_type_byte_size_from_key(type_key);
}
}
Rng1U64 result = r1u64(base_offset, base_offset+size);
return result;
}
+1 -2
View File
@@ -1294,8 +1294,7 @@ internal E_Key e_key_wrapf(E_Key key, char *fmt, ...);
////////////////////////////////
//~ rjf: Eval Info Extraction
internal U64 e_base_offset_from_eval(E_Eval eval);
internal U64 e_range_size_from_eval(E_Eval eval);
internal Rng1U64 e_range_from_eval(E_Eval eval);
////////////////////////////////
//~ rjf: Debug Functions
+12
View File
@@ -5640,6 +5640,18 @@ rd_view_setting_f32_from_name(String8 name)
//- rjf: evaluation & tag (a view's 'call') parameter extraction
internal Rng1U64
rd_space_range_from_eval(E_Eval eval)
{
Rng1U64 range = e_range_from_eval(eval);
U64 size_setting = rd_view_setting_value_from_name(str8_lit("size")).u64;
if(size_setting != 0)
{
range.max = range.min + size_setting;
}
return range;
}
internal TXT_LangKind
rd_lang_kind_from_eval(E_Eval eval)
{
+1
View File
@@ -934,6 +934,7 @@ internal U64 rd_view_setting_u64_from_name(String8 string);
internal F32 rd_view_setting_f32_from_name(String8 string);
//- rjf: evaluation & tag (a view's 'call') parameter extraction
internal Rng1U64 rd_space_range_from_eval(E_Eval eval);
internal TXT_LangKind rd_lang_kind_from_eval(E_Eval eval);
internal Arch rd_arch_from_eval(E_Eval eval);
+7 -27
View File
@@ -2061,13 +2061,7 @@ RD_VIEW_UI_FUNCTION_DEF(text)
if(rd_regs()->cursor.column == 0) { rd_regs()->cursor.column = 1; }
if(rd_regs()->mark.line == 0) { rd_regs()->mark.line = 1; }
if(rd_regs()->mark.column == 0) { rd_regs()->mark.column = 1; }
U64 base_offset = e_base_offset_from_eval(eval);
U64 size = rd_view_setting_value_from_name(str8_lit("size")).u64;
if(size == 0)
{
size = e_range_size_from_eval(eval);
}
Rng1U64 range = r1u64(base_offset, base_offset+size);
Rng1U64 range = rd_space_range_from_eval(eval);
rd_regs()->text_key = rd_key_from_eval_space_range(eval.space, range, 1);
String8 lang = rd_view_setting_from_name(str8_lit("lang"));
if(lang.size == 0)
@@ -2346,13 +2340,7 @@ RD_VIEW_UI_FUNCTION_DEF(disasm)
{
space = auto_space;
}
U64 base_offset = e_base_offset_from_eval(eval);
U64 size = rd_view_setting_value_from_name(str8_lit("size")).u64;
if(size == 0)
{
size = e_range_size_from_eval(eval);
}
Rng1U64 range = r1u64(base_offset, base_offset+size);
Rng1U64 range = rd_space_range_from_eval(eval);
Arch arch = rd_arch_from_eval(eval);
CTRL_Entity *space_entity = rd_ctrl_entity_from_eval_space(space);
CTRL_Entity *dasm_module = &ctrl_entity_nil;
@@ -2535,22 +2523,12 @@ RD_VIEW_UI_FUNCTION_DEF(memory)
Vec4F32 main_tx_color_rgba = ui_color_from_name(str8_lit("text"));
Vec4F32 main_tx_color_hsva = hsva_from_rgba(main_tx_color_rgba);
F32 main_font_size = ui_bottom_font_size();
U64 base_offset = e_base_offset_from_eval(eval);
U64 size = rd_view_setting_value_from_name(str8_lit("size")).u64;
if(size == 0)
{
size = e_range_size_from_eval(eval);
}
Rng1U64 view_range = r1u64(base_offset, base_offset+size);
Rng1U64 view_range = rd_space_range_from_eval(eval);
if(eval.space.kind == 0)
{
eval.space = rd_eval_space_from_ctrl_entity(ctrl_entity_from_handle(&d_state->ctrl_entity_store->ctx, rd_regs()->process), RD_EvalSpaceKind_CtrlEntity);
view_range = rd_whole_range_from_eval_space(eval.space);
}
if(eval.space.kind == RD_EvalSpaceKind_CtrlEntity && dim_1u64(view_range) == KB(16))
{
view_range = r1u64(0, 0x7FFFFFFFFFFFull);
}
U64 cursor_base_vaddr = rd_view_setting_u64_from_name(str8_lit("cursor"));
U64 mark_base_vaddr = rd_view_setting_u64_from_name(str8_lit("mark"));
U64 cursor_size = rd_view_setting_u64_from_name(str8_lit("cursor_size"));
@@ -3848,7 +3826,8 @@ RD_VIEW_UI_FUNCTION_DEF(bitmap)
break;
}
}
U64 base_offset = e_base_offset_from_eval(eval);
Rng1U64 eval_range = e_range_from_eval(eval);
U64 base_offset = eval_range.min;
U64 expected_size = dim.x*dim.y*r_tex2d_format_bytes_per_pixel_table[fmt];
Rng1U64 offset_range = r1u64(base_offset, base_offset + expected_size);
@@ -4361,7 +4340,8 @@ RD_VIEW_UI_FUNCTION_DEF(geo3d)
//////////////////////////////
//- rjf: evaluate & unpack expression
//
U64 base_offset = e_base_offset_from_eval(eval);
Rng1U64 eval_range = e_range_from_eval(eval);
U64 base_offset = eval_range.min;
Rng1U64 idxs_range = r1u64(base_offset, base_offset+count*sizeof(U32));
Rng1U64 vtxs_range = r1u64(vtx_base_off, vtx_base_off+vtx_size);
HS_Key idxs_key = rd_key_from_eval_space_range(eval.space, idxs_range, 0);