Skip to content

Commit 59fe6c7

Browse files
committed
distinguish root block from non-root blocks; in root case, we do not want to do a lookup-range to generate the block's expression (but in all other cases we do)
1 parent 6f4533d commit 59fe6c7

File tree

4 files changed

+22
-5
lines changed

4 files changed

+22
-5
lines changed

src/eval/eval_ir.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -101,7 +101,7 @@ e_lookup_rule_map_insert(Arena *arena, E_LookupRuleMap *map, E_LookupRule *rule)
101101
internal E_LookupRule *
102102
e_lookup_rule_from_string(String8 string)
103103
{
104-
E_LookupRule *result = &e_lookup_rule__default;
104+
E_LookupRule *result = &e_lookup_rule__nil;
105105
if(e_ir_ctx->lookup_rule_map != 0 && e_ir_ctx->lookup_rule_map->slots_count != 0)
106106
{
107107
U64 hash = e_hash_from_string(5381, string);

src/eval/eval_ir.h

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -242,6 +242,15 @@ struct E_IRCtx
242242
////////////////////////////////
243243
//~ rjf: Globals
244244

245+
local_persist read_only E_LookupRule e_lookup_rule__nil =
246+
{
247+
str8_lit_comp("nil"),
248+
E_LOOKUP_INFO_FUNCTION_NAME(default),
249+
E_LOOKUP_ACCESS_FUNCTION_NAME(default),
250+
E_LOOKUP_RANGE_FUNCTION_NAME(default),
251+
E_LOOKUP_ID_FROM_NUM_FUNCTION_NAME(default),
252+
E_LOOKUP_NUM_FROM_ID_FUNCTION_NAME(default),
253+
};
245254
local_persist read_only E_LookupRule e_lookup_rule__default =
246255
{
247256
str8_lit_comp("default"),

src/eval_visualization/eval_visualization_core.c

Lines changed: 11 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -508,7 +508,7 @@ ev_block_tree_from_expr(Arena *arena, EV_View *view, String8 filter, String8 str
508508
{
509509
E_LookupRule *lookup_rule_candidate = e_lookup_rule_from_string(tag->first->string);
510510
EV_ViewRuleInfo *expand_rule_candidate = ev_view_rule_info_from_string(tag->first->string);
511-
if(lookup_rule_candidate != &e_lookup_rule__default)
511+
if(lookup_rule_candidate != &e_lookup_rule__nil)
512512
{
513513
lookup_rule = lookup_rule_candidate;
514514
lookup_rule_tag = tag;
@@ -946,17 +946,25 @@ ev_windowed_row_list_from_block_range_list(Arena *arena, EV_View *view, String8
946946
if(block_relative_range__windowed.max > block_relative_range__windowed.min)
947947
{
948948
// rjf: get info about expansion range
949+
B32 is_root = 0;
949950
U64 range_exprs_count = dim_1u64(block_relative_range__windowed);
950951
E_Expr **range_exprs = push_array(arena, E_Expr *, range_exprs_count);
951952
String8 *range_exprs_strings = push_array(arena, String8 ,range_exprs_count);
952953
for EachIndex(idx, range_exprs_count)
953954
{
954955
range_exprs[idx] = &e_expr_nil;
955956
}
956-
n->v.block->lookup_rule->range(arena, n->v.block->expr, block_relative_range__windowed, range_exprs, range_exprs_strings, n->v.block->lookup_rule_user_data);
957+
if(n->v.block->lookup_rule == &e_lookup_rule__nil)
958+
{
959+
is_root = 1;
960+
}
961+
else
962+
{
963+
n->v.block->lookup_rule->range(arena, n->v.block->expr, block_relative_range__windowed, range_exprs, range_exprs_strings, n->v.block->lookup_rule_user_data);
964+
}
957965

958966
// rjf: no expansion operator applied -> push row for block expression; pass through block info
959-
if(range_exprs_count == 0)
967+
if(is_root)
960968
{
961969
EV_WindowedRowNode *row_node = push_array(arena, EV_WindowedRowNode, 1);
962970
SLLQueuePush(rows.first, rows.last, row_node);

src/eval_visualization/eval_visualization_core.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -283,7 +283,7 @@ global read_only EV_ViewRuleInfo ev_nil_view_rule_info =
283283
};
284284
thread_static EV_ViewRuleInfoTable *ev_view_rule_info_table = 0;
285285
thread_static EV_AutoViewRuleTable *ev_auto_view_rule_table = 0;
286-
global read_only EV_Block ev_nil_block = {&ev_nil_block, &ev_nil_block, &ev_nil_block, &ev_nil_block, &ev_nil_block, {0}, 0, {0}, &e_expr_nil, &e_expr_nil, &e_expr_nil, &e_lookup_rule__default, &ev_nil_view_rule_info};
286+
global read_only EV_Block ev_nil_block = {&ev_nil_block, &ev_nil_block, &ev_nil_block, &ev_nil_block, &ev_nil_block, {0}, 0, {0}, &e_expr_nil, &e_expr_nil, &e_expr_nil, &e_lookup_rule__nil, &ev_nil_view_rule_info};
287287

288288
////////////////////////////////
289289
//~ rjf: Key Functions

0 commit comments

Comments
 (0)