New UI system up and running
parent
c8a4b7e20a
commit
e307b67f4e
17
4ed.cpp
17
4ed.cpp
|
@ -339,6 +339,7 @@ App_Init_Sig(app_init){
|
|||
// NOTE(allen): live set
|
||||
Arena *arena = models->arena;
|
||||
{
|
||||
models->live_set.node_arena = reserve_arena(models->tctx);
|
||||
models->live_set.count = 0;
|
||||
models->live_set.max = MAX_VIEWS;
|
||||
models->live_set.views = push_array(arena, View, models->live_set.max);
|
||||
|
@ -848,8 +849,20 @@ App_Step_Sig(app_step){
|
|||
begin_render_section(target, models->frame_counter, literal_dt, animation_dt);
|
||||
models->in_render_mode = true;
|
||||
|
||||
if (models->render_caller != 0){
|
||||
models->render_caller(&models->app_links, frame);
|
||||
Live_Views *live_views = &models->live_set;
|
||||
Layout *layout = &models->layout;
|
||||
for (Node *node = layout->open_panels.next;
|
||||
node != &layout->open_panels;
|
||||
node = node->next){
|
||||
Panel *panel = CastFromMember(Panel, node, node);
|
||||
View *view = panel->view;
|
||||
View_Context_Node *ctx = view->ctx;
|
||||
if (ctx != 0){
|
||||
Render_Caller_Function *render_caller = ctx->ctx.render_caller;
|
||||
if (render_caller != 0){
|
||||
render_caller(&models->app_links, frame, view_get_id(live_views, view));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
models->in_render_mode = false;
|
||||
|
|
95
4ed_view.cpp
95
4ed_view.cpp
|
@ -445,6 +445,51 @@ view_set_file(Models *models, View *view, Editing_File *file){
|
|||
|
||||
////////////////////////////////
|
||||
|
||||
function View_Context_Node*
|
||||
view__alloc_context_node(Live_Views *views){
|
||||
View_Context_Node *node = views->free_nodes;
|
||||
if (node != 0){
|
||||
sll_stack_pop(views->free_nodes);
|
||||
}
|
||||
else{
|
||||
node = push_array(views->node_arena, View_Context_Node, 1);
|
||||
}
|
||||
return(node);
|
||||
}
|
||||
|
||||
function void
|
||||
view__free_context_node(Live_Views *views, View_Context_Node *node){
|
||||
sll_stack_push(views->free_nodes, node);
|
||||
}
|
||||
|
||||
function void
|
||||
view_push_context(Models *models, View *view, View_Context *ctx){
|
||||
View_Context_Node *node = view__alloc_context_node(&models->live_set);
|
||||
sll_stack_push(view->ctx, node);
|
||||
block_copy_struct(&node->ctx, ctx);
|
||||
}
|
||||
|
||||
function void
|
||||
view_pop_context(Models *models, View *view){
|
||||
View_Context_Node *node = view->ctx;
|
||||
if (node != 0){
|
||||
sll_stack_pop(view->ctx);
|
||||
view__free_context_node(&models->live_set, node);
|
||||
}
|
||||
}
|
||||
|
||||
function View_Context
|
||||
view_current_context(Models *models, View *view){
|
||||
View_Context ctx = {};
|
||||
View_Context_Node *node = view->ctx;
|
||||
if (node != 0){
|
||||
block_copy_struct(&ctx, &node->ctx);
|
||||
}
|
||||
return(ctx);
|
||||
}
|
||||
|
||||
////////////////////////////////
|
||||
|
||||
internal App_Coroutine_State
|
||||
get_co_state(Application_Links *app){
|
||||
App_Coroutine_State state = {};
|
||||
|
@ -512,6 +557,11 @@ function void
|
|||
view_init(Models *models, View *view, Editing_File *initial_buffer,
|
||||
Custom_Command_Function *event_context_base){
|
||||
view_set_file(models, view, initial_buffer);
|
||||
|
||||
View_Context first_ctx = {};
|
||||
first_ctx.render_caller = models->render_caller;
|
||||
view_push_context(models, view, &first_ctx);
|
||||
|
||||
view->co = coroutine_create(&models->coroutines, view_event_context_base__inner);
|
||||
Co_In in = {};
|
||||
in.models = models;
|
||||
|
@ -607,51 +657,6 @@ co_send_core_event(Models *models, View *view, Core_Code code){
|
|||
|
||||
////////////////////////////////
|
||||
|
||||
function View_Context_Node*
|
||||
view__alloc_context_node(Live_Views *views){
|
||||
View_Context_Node *node = views->free_nodes;
|
||||
if (node != 0){
|
||||
sll_stack_pop(views->free_nodes);
|
||||
}
|
||||
else{
|
||||
node = push_array(views->node_arena, View_Context_Node, 1);
|
||||
}
|
||||
return(node);
|
||||
}
|
||||
|
||||
function void
|
||||
view__free_context_node(Live_Views *views, View_Context_Node *node){
|
||||
sll_stack_push(views->free_nodes, node);
|
||||
}
|
||||
|
||||
function void
|
||||
view_push_context(Models *models, View *view, View_Context *ctx){
|
||||
View_Context_Node *node = view__alloc_context_node(&models->live_set);
|
||||
sll_stack_push(view->ctx, node);
|
||||
block_copy_struct(&node->ctx, ctx);
|
||||
}
|
||||
|
||||
function void
|
||||
view_pop_context(Models *models, View *view){
|
||||
View_Context_Node *node = view->ctx;
|
||||
if (node != 0){
|
||||
sll_stack_pop(view->ctx);
|
||||
view__free_context_node(&models->live_set, node);
|
||||
}
|
||||
}
|
||||
|
||||
function View_Context
|
||||
view_current_context(Models *models, View *view){
|
||||
View_Context ctx = {};
|
||||
View_Context_Node *node = view->ctx;
|
||||
if (node != 0){
|
||||
block_copy_struct(&ctx, &node->ctx);
|
||||
}
|
||||
return(ctx);
|
||||
}
|
||||
|
||||
////////////////////////////////
|
||||
|
||||
internal b32
|
||||
file_is_viewed(Layout *layout, Editing_File *file){
|
||||
b32 is_viewed = false;
|
||||
|
|
|
@ -325,202 +325,267 @@ get_token_color_cpp(Token token){
|
|||
}
|
||||
|
||||
internal void
|
||||
default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View_ID view_id, Rect_f32 view_inner_rect){
|
||||
Buffer_ID buffer = view_get_buffer(app, view_id, AccessAll);
|
||||
default_render_caller(Application_Links *app, Frame_Info frame_info, View_ID view_id){
|
||||
View_ID active_view = get_active_view(app, AccessAll);
|
||||
b32 is_active_view = (active_view == view_id);
|
||||
|
||||
Rect_f32 view_rect = view_get_screen_rect(app, view_id);
|
||||
Rect_f32 inner = rect_inner(view_rect, 3);
|
||||
draw_rectangle(app, view_rect, 0.f,
|
||||
get_margin_color(is_active_view?UIHighlight_Active:UIHighlight_None));
|
||||
draw_rectangle(app, inner, 0.f, Stag_Back);
|
||||
|
||||
Rect_f32 prev_clip = draw_set_clip(app, inner);
|
||||
|
||||
Buffer_ID buffer = view_get_buffer(app, view_id, AccessAll);
|
||||
Face_ID face_id = get_face_id(app, buffer);
|
||||
Face_Metrics face_metrics = get_face_metrics(app, face_id);
|
||||
|
||||
f32 line_height = face_metrics.line_height;
|
||||
|
||||
Rect_f32 sub_region = default_view_buffer_region(app, view_id, view_inner_rect);
|
||||
Rect_f32 buffer_rect = rect_intersect(sub_region, view_inner_rect);
|
||||
// NOTE(allen): Frame
|
||||
Rect_f32 r_cursor = inner;
|
||||
|
||||
// NOTE(allen): Filebar
|
||||
b64 showing_file_bar = false;
|
||||
if (view_get_setting(app, view_id, ViewSetting_ShowFileBar, &showing_file_bar) && showing_file_bar){
|
||||
Rect_f32 bar = r_cursor;
|
||||
bar.y1 = bar.y0 + line_height + 2.f;
|
||||
r_cursor.y0 = bar.y1;
|
||||
|
||||
draw_rectangle(app, bar, 0.f, Stag_Bar);
|
||||
|
||||
Fancy_Color base_color = fancy_id(Stag_Base);
|
||||
Fancy_Color pop2_color = fancy_id(Stag_Pop2);
|
||||
|
||||
Scratch_Block scratch(app);
|
||||
|
||||
i64 cursor_position = view_get_cursor_pos(app, view_id);
|
||||
Buffer_Cursor cursor = view_compute_cursor(app, view_id, seek_pos(cursor_position));
|
||||
|
||||
Fancy_String_List list = {};
|
||||
String_Const_u8 unique_name = push_buffer_unique_name(app, scratch, buffer);
|
||||
push_fancy_string(scratch, &list, base_color, unique_name);
|
||||
push_fancy_stringf(scratch, &list, base_color, " - Row: %3.lld Col: %3.lld -", cursor.line, cursor.col);
|
||||
|
||||
b64 is_dos_mode = false;
|
||||
if (buffer_get_setting(app, buffer, BufferSetting_Eol, &is_dos_mode)){
|
||||
if (is_dos_mode){
|
||||
push_fancy_string(scratch, &list, base_color, string_u8_litexpr(" dos"));
|
||||
}
|
||||
else{
|
||||
push_fancy_string(scratch, &list, base_color, string_u8_litexpr(" nix"));
|
||||
}
|
||||
}
|
||||
else{
|
||||
push_fancy_string(scratch, &list, base_color, string_u8_litexpr(" ???"));
|
||||
}
|
||||
|
||||
{
|
||||
Dirty_State dirty = buffer_get_dirty_state(app, buffer);
|
||||
u8 space[3];
|
||||
String_u8 str = Su8(space, 0, 3);
|
||||
if (dirty != 0){
|
||||
string_append(&str, string_u8_litexpr(" "));
|
||||
}
|
||||
if (HasFlag(dirty, DirtyState_UnsavedChanges)){
|
||||
string_append(&str, string_u8_litexpr("*"));
|
||||
}
|
||||
if (HasFlag(dirty, DirtyState_UnloadedChanges)){
|
||||
string_append(&str, string_u8_litexpr("!"));
|
||||
}
|
||||
push_fancy_string(scratch, &list, pop2_color, str.string);
|
||||
}
|
||||
|
||||
Vec2 p = bar.p0 + V2(0.f, 2.f);
|
||||
draw_fancy_string(app, face_id, list.first, p, Stag_Default, 0);
|
||||
}
|
||||
|
||||
Rect_f32 sub_region = default_view_buffer_region(app, view_id, inner);
|
||||
Rect_f32 buffer_rect = rect_intersect(sub_region, inner);
|
||||
|
||||
Buffer_Scroll scroll = view_get_buffer_scroll(app, view_id);
|
||||
Buffer_Point buffer_point = scroll.position;
|
||||
Text_Layout_ID text_layout_id = text_layout_create(app, buffer, buffer_rect, buffer_point);
|
||||
Interval_i64 visible_range = text_layout_get_visible_range(app, text_layout_id);
|
||||
|
||||
View_ID active_view = get_active_view(app, AccessAll);
|
||||
b32 is_active_view = (active_view == view_id);
|
||||
|
||||
Scratch_Block scratch(app);
|
||||
|
||||
// NOTE(allen): Token colorizing
|
||||
Token_Array token_array = get_token_array_from_buffer(app, buffer);
|
||||
if (token_array.tokens != 0){
|
||||
i64 first_index = token_index_from_pos(&token_array, visible_range.first);
|
||||
Token_Iterator_Array it = token_iterator_index(buffer, &token_array, first_index);
|
||||
for (;;){
|
||||
Token *token = token_it_read(&it);
|
||||
if (token->pos >= visible_range.one_past_last){
|
||||
break;
|
||||
}
|
||||
|
||||
int_color color = get_token_color_cpp(*token);
|
||||
paint_text_color(app, text_layout_id, Ii64_size(token->pos, token->size), color);
|
||||
|
||||
if (!token_it_inc_non_whitespace(&it)){
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// NOTE(allen): Scan for TODOs and NOTEs
|
||||
if (global_config.use_comment_keyword){
|
||||
Temp_Memory temp = begin_temp(scratch);
|
||||
String_Const_u8 tail = push_buffer_range(app, scratch, buffer, visible_range);
|
||||
i32 index = 0;
|
||||
for (;tail.size > 0; tail = string_skip(tail, 1), index += 1){
|
||||
if (string_match(string_prefix(tail, 4), string_u8_litexpr("NOTE"))){
|
||||
Interval_i64 range = Ii64_size(visible_range.first + index, 4);
|
||||
paint_text_color(app, text_layout_id, range, Stag_Text_Cycle_2);
|
||||
tail = string_skip(tail, 3);
|
||||
index += 3;
|
||||
}
|
||||
else if (string_match(string_prefix(tail, 4), string_u8_litexpr("TODO"))){
|
||||
Interval_i64 range = Ii64_size(visible_range.first + index, 4);
|
||||
paint_text_color(app, text_layout_id, range, Stag_Text_Cycle_1);
|
||||
tail = string_skip(tail, 3);
|
||||
index += 3;
|
||||
}
|
||||
}
|
||||
end_temp(temp);
|
||||
}
|
||||
|
||||
i64 cursor_pos = view_get_cursor_pos(app, view_id);
|
||||
i64 mark_pos = view_get_mark_pos(app, view_id);
|
||||
|
||||
// NOTE(allen): Scope highlight
|
||||
if (do_matching_enclosure_highlight){
|
||||
static const i32 color_count = 4;
|
||||
int_color colors[color_count];
|
||||
for (u16 i = 0; i < color_count; i += 1){
|
||||
colors[i] = Stag_Back_Cycle_1 + i;
|
||||
}
|
||||
draw_enclosures(app, text_layout_id, buffer,
|
||||
cursor_pos, FindNest_Scope, RangeHighlightKind_LineHighlight,
|
||||
colors, 0, color_count);
|
||||
}
|
||||
|
||||
// NOTE(allen): Error highlight
|
||||
{
|
||||
String_Const_u8 name = string_u8_litexpr("*compilation*");
|
||||
Buffer_ID compilation_buffer = get_buffer_by_name(app, name, AccessAll);
|
||||
if (compilation_buffer != 0){
|
||||
Managed_Scope scopes[2];
|
||||
scopes[0] = buffer_get_managed_scope(app, compilation_buffer);
|
||||
scopes[1] = buffer_get_managed_scope(app, buffer);
|
||||
Managed_Scope scope = get_managed_scope_with_multiple_dependencies(app, scopes, ArrayCount(scopes));
|
||||
Managed_Object *markers_object = scope_attachment(app, scope, sticky_jump_marker_handle, Managed_Object);
|
||||
Rect_f32 prev_clip_sub = draw_set_clip(app, buffer_rect);
|
||||
|
||||
// NOTE(allen): Token colorizing
|
||||
Token_Array token_array = get_token_array_from_buffer(app, buffer);
|
||||
if (token_array.tokens != 0){
|
||||
i64 first_index = token_index_from_pos(&token_array, visible_range.first);
|
||||
Token_Iterator_Array it = token_iterator_index(buffer, &token_array, first_index);
|
||||
for (;;){
|
||||
Token *token = token_it_read(&it);
|
||||
if (token->pos >= visible_range.one_past_last){
|
||||
break;
|
||||
}
|
||||
|
||||
int_color color = get_token_color_cpp(*token);
|
||||
paint_text_color(app, text_layout_id, Ii64_size(token->pos, token->size), color);
|
||||
|
||||
if (!token_it_inc_non_whitespace(&it)){
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// NOTE(allen): Scan for TODOs and NOTEs
|
||||
if (global_config.use_comment_keyword){
|
||||
Temp_Memory temp = begin_temp(scratch);
|
||||
i32 count = managed_object_get_item_count(app, *markers_object);
|
||||
Marker *markers = push_array(scratch, Marker, count);
|
||||
managed_object_load_data(app, *markers_object, 0, count, markers);
|
||||
for (i32 i = 0; i < count; i += 1){
|
||||
i64 line_number = get_line_number_from_pos(app, buffer, markers[i].pos);
|
||||
draw_line_highlight(app, text_layout_id, line_number,
|
||||
Stag_Highlight_Junk);
|
||||
String_Const_u8 tail = push_buffer_range(app, scratch, buffer, visible_range);
|
||||
i32 index = 0;
|
||||
for (;tail.size > 0; tail = string_skip(tail, 1), index += 1){
|
||||
if (string_match(string_prefix(tail, 4), string_u8_litexpr("NOTE"))){
|
||||
Interval_i64 range = Ii64_size(visible_range.first + index, 4);
|
||||
paint_text_color(app, text_layout_id, range, Stag_Text_Cycle_2);
|
||||
tail = string_skip(tail, 3);
|
||||
index += 3;
|
||||
}
|
||||
else if (string_match(string_prefix(tail, 4), string_u8_litexpr("TODO"))){
|
||||
Interval_i64 range = Ii64_size(visible_range.first + index, 4);
|
||||
paint_text_color(app, text_layout_id, range, Stag_Text_Cycle_1);
|
||||
tail = string_skip(tail, 3);
|
||||
index += 3;
|
||||
}
|
||||
}
|
||||
end_temp(temp);
|
||||
}
|
||||
}
|
||||
|
||||
// NOTE(allen): Color parens
|
||||
if (do_matching_paren_highlight){
|
||||
i64 pos = cursor_pos;
|
||||
if (buffer_get_char(app, buffer, pos) == '('){
|
||||
pos += 1;
|
||||
i64 cursor_pos = view_get_cursor_pos(app, view_id);
|
||||
i64 mark_pos = view_get_mark_pos(app, view_id);
|
||||
|
||||
// NOTE(allen): Scope highlight
|
||||
if (do_matching_enclosure_highlight){
|
||||
static const i32 color_count = 4;
|
||||
int_color colors[color_count];
|
||||
for (u16 i = 0; i < color_count; i += 1){
|
||||
colors[i] = Stag_Back_Cycle_1 + i;
|
||||
}
|
||||
draw_enclosures(app, text_layout_id, buffer,
|
||||
cursor_pos, FindNest_Scope, RangeHighlightKind_LineHighlight,
|
||||
colors, 0, color_count);
|
||||
}
|
||||
else if (pos > 0){
|
||||
if (buffer_get_char(app, buffer, pos - 1) == ')'){
|
||||
pos -= 1;
|
||||
|
||||
// NOTE(allen): Error highlight
|
||||
{
|
||||
String_Const_u8 name = string_u8_litexpr("*compilation*");
|
||||
Buffer_ID compilation_buffer = get_buffer_by_name(app, name, AccessAll);
|
||||
if (compilation_buffer != 0){
|
||||
Managed_Scope scopes[2];
|
||||
scopes[0] = buffer_get_managed_scope(app, compilation_buffer);
|
||||
scopes[1] = buffer_get_managed_scope(app, buffer);
|
||||
Managed_Scope comp_scope = get_managed_scope_with_multiple_dependencies(app, scopes, ArrayCount(scopes));
|
||||
Managed_Object *markers_object = scope_attachment(app, comp_scope, sticky_jump_marker_handle, Managed_Object);
|
||||
|
||||
Temp_Memory temp = begin_temp(scratch);
|
||||
i32 count = managed_object_get_item_count(app, *markers_object);
|
||||
Marker *markers = push_array(scratch, Marker, count);
|
||||
managed_object_load_data(app, *markers_object, 0, count, markers);
|
||||
for (i32 i = 0; i < count; i += 1){
|
||||
i64 line_number = get_line_number_from_pos(app, buffer, markers[i].pos);
|
||||
draw_line_highlight(app, text_layout_id, line_number,
|
||||
Stag_Highlight_Junk);
|
||||
}
|
||||
end_temp(temp);
|
||||
}
|
||||
}
|
||||
static const i32 color_count = 4;
|
||||
int_color colors[color_count];
|
||||
for (u16 i = 0; i < color_count; i += 1){
|
||||
colors[i] = Stag_Text_Cycle_1 + i;
|
||||
}
|
||||
draw_enclosures(app, text_layout_id, buffer,
|
||||
cursor_pos, FindNest_Paren, RangeHighlightKind_CharacterHighlight,
|
||||
0, colors, color_count);
|
||||
}
|
||||
|
||||
// NOTE(allen): Line highlight
|
||||
if (highlight_line_at_cursor && is_active_view){
|
||||
i64 line_number = get_line_number_from_pos(app, buffer, cursor_pos);
|
||||
draw_line_highlight(app, text_layout_id, line_number, Stag_Highlight_Cursor_Line);
|
||||
}
|
||||
|
||||
// NOTE(allen): Roundness
|
||||
f32 cursor_roundness = 4.f;
|
||||
f32 mark_thickness = 2.f;
|
||||
|
||||
// NOTE(allen): Highlight range
|
||||
b32 has_highlight_range = false;
|
||||
{
|
||||
Managed_Scope scope = view_get_managed_scope(app, view_id);
|
||||
Buffer_ID *highlight_buffer = scope_attachment(app, scope, view_highlight_buffer, Buffer_ID);
|
||||
if (*highlight_buffer != 0){
|
||||
if (*highlight_buffer != buffer){
|
||||
view_disable_highlight_range(app, view_id);
|
||||
// NOTE(allen): Color parens
|
||||
if (do_matching_paren_highlight){
|
||||
i64 pos = cursor_pos;
|
||||
if (buffer_get_char(app, buffer, pos) == '('){
|
||||
pos += 1;
|
||||
}
|
||||
else{
|
||||
has_highlight_range = true;
|
||||
Managed_Object *highlight = scope_attachment(app, scope, view_highlight_range, Managed_Object);
|
||||
Marker marker_range[2];
|
||||
if (managed_object_load_data(app, *highlight, 0, 2, marker_range)){
|
||||
Range_i64 range = Ii64(marker_range[0].pos, marker_range[1].pos);
|
||||
draw_character_block(app, text_layout_id, range, cursor_roundness, Stag_Highlight);
|
||||
paint_text_color(app, text_layout_id, range, Stag_At_Highlight);
|
||||
else if (pos > 0){
|
||||
if (buffer_get_char(app, buffer, pos - 1) == ')'){
|
||||
pos -= 1;
|
||||
}
|
||||
}
|
||||
static const i32 color_count = 4;
|
||||
int_color colors[color_count];
|
||||
for (u16 i = 0; i < color_count; i += 1){
|
||||
colors[i] = Stag_Text_Cycle_1 + i;
|
||||
}
|
||||
draw_enclosures(app, text_layout_id, buffer,
|
||||
cursor_pos, FindNest_Paren, RangeHighlightKind_CharacterHighlight,
|
||||
0, colors, color_count);
|
||||
}
|
||||
}
|
||||
|
||||
// NOTE(allen): Cursor and mark
|
||||
if (!has_highlight_range){
|
||||
switch (fcoder_mode){
|
||||
case FCoderMode_Original:
|
||||
{
|
||||
if (is_active_view){
|
||||
draw_character_block(app, text_layout_id, cursor_pos,
|
||||
cursor_roundness, Stag_Cursor);
|
||||
paint_text_color_pos(app, text_layout_id, cursor_pos,
|
||||
Stag_At_Cursor);
|
||||
draw_character_wire_frame(app, text_layout_id, mark_pos,
|
||||
cursor_roundness, mark_thickness,
|
||||
Stag_Mark);
|
||||
// NOTE(allen): Line highlight
|
||||
if (highlight_line_at_cursor && is_active_view){
|
||||
i64 line_number = get_line_number_from_pos(app, buffer, cursor_pos);
|
||||
draw_line_highlight(app, text_layout_id, line_number, Stag_Highlight_Cursor_Line);
|
||||
}
|
||||
|
||||
// NOTE(allen): Roundness
|
||||
f32 cursor_roundness = 4.f;
|
||||
f32 mark_thickness = 2.f;
|
||||
|
||||
// NOTE(allen): Highlight range
|
||||
b32 has_highlight_range = false;
|
||||
{
|
||||
Managed_Scope scope = view_get_managed_scope(app, view_id);
|
||||
Buffer_ID *highlight_buffer = scope_attachment(app, scope, view_highlight_buffer, Buffer_ID);
|
||||
if (*highlight_buffer != 0){
|
||||
if (*highlight_buffer != buffer){
|
||||
view_disable_highlight_range(app, view_id);
|
||||
}
|
||||
else{
|
||||
draw_character_wire_frame(app, text_layout_id, mark_pos,
|
||||
cursor_roundness, mark_thickness,
|
||||
Stag_Mark);
|
||||
draw_character_wire_frame(app, text_layout_id, cursor_pos,
|
||||
cursor_roundness, mark_thickness,
|
||||
Stag_Cursor);
|
||||
has_highlight_range = true;
|
||||
Managed_Object *highlight = scope_attachment(app, scope, view_highlight_range, Managed_Object);
|
||||
Marker marker_range[2];
|
||||
if (managed_object_load_data(app, *highlight, 0, 2, marker_range)){
|
||||
Range_i64 range = Ii64(marker_range[0].pos, marker_range[1].pos);
|
||||
draw_character_block(app, text_layout_id, range, cursor_roundness, Stag_Highlight);
|
||||
paint_text_color(app, text_layout_id, range, Stag_At_Highlight);
|
||||
}
|
||||
}
|
||||
}break;
|
||||
|
||||
case FCoderMode_NotepadLike:
|
||||
{
|
||||
if (cursor_pos != mark_pos){
|
||||
Range_i64 range = Ii64(cursor_pos, mark_pos);
|
||||
draw_character_block(app, text_layout_id, range,
|
||||
cursor_roundness, Stag_Highlight);
|
||||
paint_text_color(app, text_layout_id, range, Stag_At_Highlight);
|
||||
}
|
||||
draw_character_i_bar(app, text_layout_id, cursor_pos, Stag_Cursor);
|
||||
}break;
|
||||
}
|
||||
}
|
||||
|
||||
// NOTE(allen): Cursor and mark
|
||||
if (!has_highlight_range){
|
||||
switch (fcoder_mode){
|
||||
case FCoderMode_Original:
|
||||
{
|
||||
if (is_active_view){
|
||||
draw_character_block(app, text_layout_id, cursor_pos,
|
||||
cursor_roundness, Stag_Cursor);
|
||||
paint_text_color_pos(app, text_layout_id, cursor_pos,
|
||||
Stag_At_Cursor);
|
||||
draw_character_wire_frame(app, text_layout_id, mark_pos,
|
||||
cursor_roundness, mark_thickness,
|
||||
Stag_Mark);
|
||||
}
|
||||
else{
|
||||
draw_character_wire_frame(app, text_layout_id, mark_pos,
|
||||
cursor_roundness, mark_thickness,
|
||||
Stag_Mark);
|
||||
draw_character_wire_frame(app, text_layout_id, cursor_pos,
|
||||
cursor_roundness, mark_thickness,
|
||||
Stag_Cursor);
|
||||
}
|
||||
}break;
|
||||
|
||||
case FCoderMode_NotepadLike:
|
||||
{
|
||||
if (cursor_pos != mark_pos){
|
||||
Range_i64 range = Ii64(cursor_pos, mark_pos);
|
||||
draw_character_block(app, text_layout_id, range,
|
||||
cursor_roundness, Stag_Highlight);
|
||||
paint_text_color(app, text_layout_id, range, Stag_At_Highlight);
|
||||
}
|
||||
draw_character_i_bar(app, text_layout_id, cursor_pos, Stag_Cursor);
|
||||
}break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
{
|
||||
Rect_f32 prev_clip = draw_set_clip(app, buffer_rect);
|
||||
draw_text_layout(app, text_layout_id);
|
||||
draw_set_clip(app, prev_clip);
|
||||
draw_set_clip(app, prev_clip_sub);
|
||||
}
|
||||
|
||||
// NOTE(allen): FPS HUD
|
||||
|
@ -579,66 +644,6 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
|
|||
animate_in_n_milliseconds(app, 1000);
|
||||
}
|
||||
|
||||
// NOTE(allen): Frame
|
||||
Rect_f32 r_cursor = view_inner_rect;
|
||||
|
||||
// NOTE(allen): Filebar
|
||||
b64 showing_file_bar = false;
|
||||
if (view_get_setting(app, view_id, ViewSetting_ShowFileBar, &showing_file_bar) && showing_file_bar){
|
||||
Rect_f32 bar = r_cursor;
|
||||
bar.y1 = bar.y0 + line_height + 2.f;
|
||||
r_cursor.y0 = bar.y1;
|
||||
|
||||
draw_rectangle(app, bar, 0.f, Stag_Bar);
|
||||
|
||||
Fancy_Color base_color = fancy_id(Stag_Base);
|
||||
Fancy_Color pop2_color = fancy_id(Stag_Pop2);
|
||||
|
||||
Temp_Memory temp = begin_temp(scratch);
|
||||
|
||||
i64 cursor_position = view_get_cursor_pos(app, view_id);
|
||||
Buffer_Cursor cursor = view_compute_cursor(app, view_id, seek_pos(cursor_position));
|
||||
|
||||
Fancy_String_List list = {};
|
||||
String_Const_u8 unique_name = push_buffer_unique_name(app, scratch, buffer);
|
||||
push_fancy_string(scratch, &list, base_color, unique_name);
|
||||
push_fancy_stringf(scratch, &list, base_color, " - Row: %3.lld Col: %3.lld -", cursor.line, cursor.col);
|
||||
|
||||
b64 is_dos_mode = false;
|
||||
if (buffer_get_setting(app, buffer, BufferSetting_Eol, &is_dos_mode)){
|
||||
if (is_dos_mode){
|
||||
push_fancy_string(scratch, &list, base_color, string_u8_litexpr(" dos"));
|
||||
}
|
||||
else{
|
||||
push_fancy_string(scratch, &list, base_color, string_u8_litexpr(" nix"));
|
||||
}
|
||||
}
|
||||
else{
|
||||
push_fancy_string(scratch, &list, base_color, string_u8_litexpr(" ???"));
|
||||
}
|
||||
|
||||
{
|
||||
Dirty_State dirty = buffer_get_dirty_state(app, buffer);
|
||||
u8 space[3];
|
||||
String_u8 str = Su8(space, 0, 3);
|
||||
if (dirty != 0){
|
||||
string_append(&str, string_u8_litexpr(" "));
|
||||
}
|
||||
if (HasFlag(dirty, DirtyState_UnsavedChanges)){
|
||||
string_append(&str, string_u8_litexpr("*"));
|
||||
}
|
||||
if (HasFlag(dirty, DirtyState_UnloadedChanges)){
|
||||
string_append(&str, string_u8_litexpr("!"));
|
||||
}
|
||||
push_fancy_string(scratch, &list, pop2_color, str.string);
|
||||
}
|
||||
|
||||
Vec2 p = bar.p0 + V2(0.f, 2.f);
|
||||
draw_fancy_string(app, face_id, list.first, p, Stag_Default, 0);
|
||||
|
||||
end_temp(temp);
|
||||
}
|
||||
|
||||
// NOTE(allen): Query Bars
|
||||
{
|
||||
Query_Bar *space[32];
|
||||
|
@ -683,7 +688,7 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
|
|||
|
||||
draw_rectangle(app, left_margin, 0.f, Stag_Line_Numbers_Back);
|
||||
|
||||
Rect_f32 prev_clip = draw_set_clip(app, left_margin);
|
||||
Rect_f32 prev_clip_line_numbers = draw_set_clip(app, left_margin);
|
||||
|
||||
Fancy_Color line_color = fancy_id(Stag_Line_Numbers_Text);
|
||||
|
||||
|
@ -701,44 +706,14 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
|
|||
line_number += 1;
|
||||
}
|
||||
|
||||
draw_set_clip(app, prev_clip);
|
||||
draw_set_clip(app, prev_clip_line_numbers);
|
||||
}
|
||||
|
||||
text_layout_free(app, text_layout_id);
|
||||
}
|
||||
|
||||
internal void
|
||||
default_render_view(Application_Links *app, Frame_Info frame_info, View_ID view, b32 is_active){
|
||||
Rect_f32 view_rect = view_get_screen_rect(app, view);
|
||||
Rect_f32 inner = rect_inner(view_rect, 3);
|
||||
draw_rectangle(app, view_rect, 0.f,
|
||||
get_margin_color(is_active?UIHighlight_Active:UIHighlight_None));
|
||||
draw_rectangle(app, inner, 0.f, Stag_Back);
|
||||
Rect_f32 prev_clip = draw_set_clip(app, inner);
|
||||
|
||||
Managed_Scope scope = view_get_managed_scope(app, view);
|
||||
View_Render_Hook **hook_ptr = scope_attachment(app, scope, view_render_hook, View_Render_Hook*);
|
||||
|
||||
if (*hook_ptr == 0){
|
||||
default_buffer_render_caller(app, frame_info, view, inner);
|
||||
}
|
||||
else{
|
||||
View_Render_Hook *hook = *hook_ptr;
|
||||
hook(app, view, frame_info, inner);
|
||||
}
|
||||
|
||||
draw_set_clip(app, prev_clip);
|
||||
}
|
||||
|
||||
RENDER_CALLER_SIG(default_render_caller){
|
||||
View_ID active_view_id = get_active_view(app, AccessAll);
|
||||
for (View_ID view_id = get_view_next(app, 0, AccessAll);
|
||||
view_id != 0;
|
||||
view_id = get_view_next(app, view_id, AccessAll)){
|
||||
default_render_view(app, frame_info, view_id, (active_view_id == view_id));
|
||||
}
|
||||
}
|
||||
|
||||
HOOK_SIG(default_exit){
|
||||
// If this returns false it cancels the exit.
|
||||
b32 result = true;
|
||||
|
|
|
@ -69,7 +69,7 @@ begin_lister(Application_Links *app, Arena *arena, View_ID view, void *user_data
|
|||
}
|
||||
|
||||
function void
|
||||
lister_render(Application_Links *app, View_ID view, Frame_Info frame_info, Rect_f32 inner){
|
||||
lister_render(Application_Links *app, Frame_Info frame_info, View_ID view){
|
||||
Scratch_Block scratch(app);
|
||||
|
||||
Lister *lister = view_get_lister(view);
|
||||
|
@ -77,9 +77,20 @@ lister_render(Application_Links *app, View_ID view, Frame_Info frame_info, Rect_
|
|||
return;
|
||||
}
|
||||
|
||||
Rect_f32 region = view_get_screen_rect(app, view);
|
||||
// TODO(allen): eliminate this. bad bad bad bad :(
|
||||
region = rect_inner(region, 3.f);
|
||||
////////////////////////////////
|
||||
View_ID active_view = get_active_view(app, AccessAll);
|
||||
b32 is_active_view = (active_view == view);
|
||||
|
||||
Rect_f32 view_rect = view_get_screen_rect(app, view);
|
||||
Rect_f32 inner = rect_inner(view_rect, 3);
|
||||
draw_rectangle(app, view_rect, 0.f,
|
||||
get_margin_color(is_active_view?UIHighlight_Active:UIHighlight_None));
|
||||
draw_rectangle(app, inner, 0.f, Stag_Back);
|
||||
|
||||
Rect_f32 prev_clip = draw_set_clip(app, inner);
|
||||
////////////////////////////////
|
||||
|
||||
Rect_f32 region = inner;
|
||||
Mouse_State mouse = get_mouse_state(app);
|
||||
Vec2_f32 m_p = V2f32(mouse.p);
|
||||
|
||||
|
@ -104,7 +115,7 @@ lister_render(Application_Links *app, View_ID view, Frame_Info frame_info, Rect_
|
|||
}
|
||||
|
||||
Range_f32 x = rect_range_x(layout.list_rect);
|
||||
Rect_f32 prev_clip = draw_set_clip(app, layout.list_rect);
|
||||
draw_set_clip(app, layout.list_rect);
|
||||
|
||||
i32 count = lister->data.filtered.count;
|
||||
Range_f32 scroll_range = If32(0.f, clamp_bot(0.f, count*block_height - block_height));
|
||||
|
@ -341,9 +352,9 @@ lister_run(Application_Links *app, View_ID view, Lister *lister){
|
|||
lister->data.filter_restore_point = begin_temp(lister->arena);
|
||||
lister_update_filtered_list(app, view, lister);
|
||||
|
||||
Managed_Scope scope = view_get_managed_scope(app, view);
|
||||
View_Render_Hook **hook = scope_attachment(app, scope, view_render_hook, View_Render_Hook*);
|
||||
*hook = lister_render;
|
||||
View_Context ctx = view_current_context(app, view);
|
||||
ctx.render_caller = lister_render;
|
||||
view_push_context(app, view, &ctx);
|
||||
|
||||
for (;;){
|
||||
User_Input in = get_user_input(app, EventPropertyGroup_Any, EventProperty_Escape);
|
||||
|
@ -488,8 +499,7 @@ lister_run(Application_Links *app, View_ID view, Lister *lister){
|
|||
}
|
||||
}
|
||||
|
||||
hook = scope_attachment(app, scope, view_render_hook, View_Render_Hook*);
|
||||
*hook = 0;
|
||||
view_pop_context(app, view);
|
||||
}
|
||||
|
||||
function Lister_Prealloced_String
|
||||
|
|
|
@ -662,8 +662,21 @@ log_graph_render__tag(Arena *arena, Fancy_String_List *line, Log_Parse *log, Log
|
|||
}
|
||||
|
||||
internal void
|
||||
log_graph_render(Application_Links *app, View_ID view, Frame_Info frame_info, Rect_f32 inner){
|
||||
log_graph_render(Application_Links *app, Frame_Info frame_info, View_ID view){
|
||||
if (log_parse.arena != 0){
|
||||
////////////////////////////////
|
||||
View_ID active_view = get_active_view(app, AccessAll);
|
||||
b32 is_active_view = (active_view == view);
|
||||
|
||||
Rect_f32 view_rect = view_get_screen_rect(app, view);
|
||||
Rect_f32 inner = rect_inner(view_rect, 3);
|
||||
draw_rectangle(app, view_rect, 0.f,
|
||||
get_margin_color(is_active_view?UIHighlight_Active:UIHighlight_None));
|
||||
draw_rectangle(app, inner, 0.f, Stag_Back);
|
||||
|
||||
Rect_f32 prev_clip = draw_set_clip(app, inner);
|
||||
////////////////////////////////
|
||||
|
||||
Face_ID face_id = get_face_id(app, 0);
|
||||
f32 y_scroll = log_graph.y_scroll;
|
||||
Log_Event *selected_event = log_graph.selected_event;
|
||||
|
@ -900,6 +913,7 @@ log_graph_render(Application_Links *app, View_ID view, Frame_Info frame_info, Re
|
|||
}
|
||||
|
||||
log_graph.has_unused_click = false;
|
||||
draw_set_clip(app, prev_clip);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -972,21 +986,6 @@ log_graph__click_jump_to_event_source(Application_Links *app, Vec2_f32 m_p){
|
|||
}
|
||||
}
|
||||
|
||||
#if 0
|
||||
internal void
|
||||
fill_log_graph_command_map(Mapping *mapping){
|
||||
MappingScope();
|
||||
SelectMapping(mapping);
|
||||
SelectMap(default_log_graph_map);
|
||||
//Bind(log_graph__escape, KeyCode_Escape);
|
||||
//BindMouseWheel(log_graph__scroll_wheel);
|
||||
//BindMouse(log_graph__click_jump_to_event_source, MouseCode_Left);
|
||||
//BindMouse(log_graph__click_select_event, MouseCode_Right);
|
||||
Bind(log_graph__page_up, KeyCode_PageUp);
|
||||
Bind(log_graph__page_down, KeyCode_PageDown);
|
||||
}
|
||||
#endif
|
||||
|
||||
CUSTOM_COMMAND_SIG(show_the_log_graph)
|
||||
CUSTOM_DOC("Parses *log* and displays the 'log graph' UI")
|
||||
{
|
||||
|
@ -996,14 +995,14 @@ CUSTOM_DOC("Parses *log* and displays the 'log graph' UI")
|
|||
if (log_view == 0){
|
||||
log_view = get_active_view(app, AccessAll);
|
||||
}
|
||||
Managed_Scope scope = view_get_managed_scope(app, log_view);
|
||||
View_Render_Hook **hook = scope_attachment(app, scope, view_render_hook, View_Render_Hook*);
|
||||
*hook = log_graph_render;
|
||||
|
||||
View_ID view = log_view;
|
||||
View_Context ctx = view_current_context(app, log_view);
|
||||
ctx.render_caller = log_graph_render;
|
||||
view_push_context(app, log_view, &ctx);
|
||||
|
||||
for (;;){
|
||||
User_Input in = get_user_input(app,
|
||||
EventPropertyGroup_AnyUserInput,
|
||||
KeyCode_Escape);
|
||||
User_Input in = get_user_input(app, EventPropertyGroup_AnyUserInput, KeyCode_Escape);
|
||||
if (in.abort){
|
||||
log_view = 0;
|
||||
break;
|
||||
|
@ -1049,8 +1048,7 @@ CUSTOM_DOC("Parses *log* and displays the 'log graph' UI")
|
|||
}
|
||||
}
|
||||
|
||||
hook = scope_attachment(app, scope, view_render_hook, View_Render_Hook*);
|
||||
*hook = 0;
|
||||
view_pop_context(app, view);
|
||||
}
|
||||
|
||||
// BOTTOM
|
||||
|
|
|
@ -101,8 +101,17 @@ STRUCT Character_Predicate{
|
|||
u8 b[32];
|
||||
};
|
||||
|
||||
struct Frame_Info{
|
||||
i32 index;
|
||||
f32 literal_dt;
|
||||
f32 animation_dt;
|
||||
};
|
||||
|
||||
typedef void Render_Caller_Function(Application_Links *app, Frame_Info frame_info, View_ID view);
|
||||
#define RENDER_CALLER_SIG(name) void name(Application_Links *app, Frame_Info frame_info, View_ID view)
|
||||
|
||||
struct View_Context{
|
||||
Void_Func ctx_ptr;
|
||||
Render_Caller_Function *render_caller;
|
||||
b32 hides_buffer;
|
||||
};
|
||||
|
||||
|
@ -472,14 +481,6 @@ STRUCT User_Input{
|
|||
b32 abort;
|
||||
};
|
||||
|
||||
STRUCT Frame_Info{
|
||||
i32 index;
|
||||
f32 literal_dt;
|
||||
f32 animation_dt;
|
||||
};
|
||||
|
||||
TYPEDEF_FUNC void Render_Callback(struct Application_Links *app);
|
||||
|
||||
typedef i32 Hook_ID;
|
||||
enum{
|
||||
HookID_FileOutOfSync,
|
||||
|
@ -505,9 +506,6 @@ enum{
|
|||
TYPEDEF_FUNC i32 Hook_Function(struct Application_Links *app);
|
||||
#define HOOK_SIG(name) i32 name(struct Application_Links *app)
|
||||
|
||||
TYPEDEF_FUNC void Render_Caller_Function(struct Application_Links *app, Frame_Info frame_info);
|
||||
#define RENDER_CALLER_SIG(name) void name(struct Application_Links *app, Frame_Info frame_info)
|
||||
|
||||
TYPEDEF_FUNC i32 Buffer_Hook_Function(struct Application_Links *app, Buffer_ID buffer_id);
|
||||
#define BUFFER_HOOK_SIG(name) i32 name(struct Application_Links *app, Buffer_ID buffer_id)
|
||||
|
||||
|
|
|
@ -372,7 +372,7 @@ static Command_Metadata fcoder_metacmd_table[202] = {
|
|||
{ PROC_LINKS(if_read_only_goto_position, 0), "if_read_only_goto_position", 26, "If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor.", 106, "w:\\4ed\\code\\custom\\4coder_jump_sticky.cpp", 41, 562 },
|
||||
{ PROC_LINKS(if_read_only_goto_position_same_panel, 0), "if_read_only_goto_position_same_panel", 37, "If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor_same_panel.", 117, "w:\\4ed\\code\\custom\\4coder_jump_sticky.cpp", 41, 579 },
|
||||
{ PROC_LINKS(view_jump_list_with_lister, 0), "view_jump_list_with_lister", 26, "When executed on a buffer with jumps, creates a persistent lister for all the jumps", 83, "w:\\4ed\\code\\custom\\4coder_jump_lister.cpp", 41, 102 },
|
||||
{ PROC_LINKS(show_the_log_graph, 0), "show_the_log_graph", 18, "Parses *log* and displays the 'log graph' UI", 44, "w:\\4ed\\code\\custom\\4coder_log_parser.cpp", 40, 990 },
|
||||
{ PROC_LINKS(show_the_log_graph, 0), "show_the_log_graph", 18, "Parses *log* and displays the 'log graph' UI", 44, "w:\\4ed\\code\\custom\\4coder_log_parser.cpp", 40, 989 },
|
||||
{ PROC_LINKS(copy, 0), "copy", 4, "Copy the text in the range from the cursor to the mark onto the clipboard.", 74, "w:\\4ed\\code\\custom\\4coder_clipboard.cpp", 39, 19 },
|
||||
{ PROC_LINKS(cut, 0), "cut", 3, "Cut the text in the range from the cursor to the mark onto the clipboard.", 73, "w:\\4ed\\code\\custom\\4coder_clipboard.cpp", 39, 28 },
|
||||
{ PROC_LINKS(paste, 0), "paste", 5, "At the cursor, insert the text at the top of the clipboard.", 59, "w:\\4ed\\code\\custom\\4coder_clipboard.cpp", 39, 39 },
|
||||
|
|
Loading…
Reference in New Issue