Switching the API return method

master
Allen Webster 2019-06-18 19:31:59 -07:00
parent ef571b7f64
commit cf6c92fcbd
37 changed files with 1674 additions and 2329 deletions

View File

@ -1070,8 +1070,8 @@ ENUM(u32, Clipboard_Change_Flag){
TYPEDEF_FUNC void Clipboard_Change_Hook_Function(struct Application_Links *app, String_Const_u8 contents, Clipboard_Change_Flag flags); TYPEDEF_FUNC void Clipboard_Change_Hook_Function(struct Application_Links *app, String_Const_u8 contents, Clipboard_Change_Flag flags);
#define CLIPBOARD_CHANGE_HOOK_SIG(name) void name(struct Application_Links *app, String_Const_u8 contents, Clipboard_Change_Flag flags) #define CLIPBOARD_CHANGE_HOOK_SIG(name) void name(struct Application_Links *app, String_Const_u8 contents, Clipboard_Change_Flag flags)
TYPEDEF_FUNC Rect_i32 Get_View_Buffer_Region_Function(struct Application_Links *app, View_ID view_id, Rect_i32 sub_region); TYPEDEF_FUNC Rect_f32 Get_View_Buffer_Region_Function(struct Application_Links *app, View_ID view_id, Rect_f32 sub_region);
#define GET_VIEW_BUFFER_REGION_SIG(name) Rect_i32 name(struct Application_Links *app, View_ID view_id, Rect_i32 sub_region) #define GET_VIEW_BUFFER_REGION_SIG(name) Rect_f32 name(struct Application_Links *app, View_ID view_id, Rect_f32 sub_region)
STRUCT Buffer_Name_Conflict_Entry{ STRUCT Buffer_Name_Conflict_Entry{
Buffer_ID buffer_id; Buffer_ID buffer_id;
@ -1160,7 +1160,8 @@ STRUCT String_Match_List{
i32 count; i32 count;
}; };
STRUCT Process_State { STRUCT Process_State{
b32 valid;
b32 is_updating; b32 is_updating;
i64 return_code; i64 return_code;
}; };

View File

@ -27,37 +27,34 @@
typedef b32 bool32; typedef b32 bool32;
static b32 static b32
get_buffer_summary(Application_Links *app, Buffer_ID buffer_id, Access_Flag access, Buffer_Summary *buffer){ get_buffer_summary(Application_Links *app, Buffer_ID buffer, Access_Flag access, Buffer_Summary *summary){
b32 result = false; b32 result = false;
if (buffer_exists(app, buffer_id)){ if (buffer_exists(app, buffer)){
Scratch_Block scratch(app); Scratch_Block scratch(app);
Access_Flag buffer_access_flags = 0; Access_Flag buffer_access_flags = buffer_get_access_flags(app, buffer);
buffer_get_access_flags(app, buffer_id, &buffer_access_flags);
if ((buffer_access_flags & ~access) == 0){ if ((buffer_access_flags & ~access) == 0){
result = true; result = true;
buffer->exists = true; summary->exists = true;
buffer->ready = buffer_ready(app, buffer_id); summary->ready = buffer_ready(app, buffer);
buffer->buffer_id = buffer_id; summary->buffer_id = buffer;
buffer_get_size(app, buffer_id, &buffer->size); summary->size = (i32)buffer_get_size(app, buffer);
buffer_get_line_count(app, buffer_id, &buffer->line_count); summary->line_count = (i32)buffer_get_line_count(app, buffer);
String_Const_u8 file_name_get = {}; String_Const_u8 file_name_get = push_buffer_file_name(app, scratch, buffer);
buffer_get_file_name(app, buffer_id, scratch, &file_name_get); block_copy(summary->file_name, file_name_get.str, file_name_get.size);
block_copy(buffer->file_name, file_name_get.str, file_name_get.size); summary->file_name_len = (i32)file_name_get.size;
buffer->file_name_len = (i32)file_name_get.size;
String_Const_u8 buffer_name_get = {}; String_Const_u8 buffer_name_get = push_buffer_unique_name(app, scratch, buffer);
buffer_get_unique_buffer_name(app, buffer_id, scratch, &buffer_name_get); block_copy(summary->buffer_name, buffer_name_get.str, buffer_name_get.size);
block_copy(buffer->buffer_name, buffer_name_get.str, buffer_name_get.size); summary->buffer_name_len = (i32)buffer_name_get.size;
buffer->buffer_name_len = (i32)buffer_name_get.size;
buffer_get_dirty_state(app, buffer_id, &buffer->dirty); summary->dirty = buffer_get_dirty_state(app, buffer);
buffer_get_setting(app, buffer_id, BufferSetting_Lex, &buffer->is_lexed); buffer_get_setting(app, buffer, BufferSetting_Lex, &summary->is_lexed);
buffer->tokens_are_ready = buffer_tokens_are_ready(app, buffer_id); summary->tokens_are_ready = buffer_tokens_are_ready(app, buffer);
buffer_get_setting(app, buffer_id, BufferSetting_MapID, &buffer->map_id); buffer_get_setting(app, buffer, BufferSetting_MapID, &summary->map_id);
buffer_get_setting(app, buffer_id, BufferSetting_WrapLine, &buffer->unwrapped_lines); buffer_get_setting(app, buffer, BufferSetting_WrapLine, &summary->unwrapped_lines);
buffer->unwrapped_lines = !buffer->unwrapped_lines; summary->unwrapped_lines = !summary->unwrapped_lines;
buffer->lock_flags = buffer_access_flags; summary->lock_flags = buffer_access_flags;
} }
} }
return(result); return(result);
@ -67,8 +64,8 @@ static b32
get_view_summary(Application_Links *app, View_ID view_id, Access_Flag access, View_Summary *view){ get_view_summary(Application_Links *app, View_ID view_id, Access_Flag access, View_Summary *view){
b32 result = false; b32 result = false;
if (view_exists(app, view_id)){ if (view_exists(app, view_id)){
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view_id, access);
if (view_get_buffer(app, view_id, access, &buffer)){ if (buffer != 0){
result = true; result = true;
Face_ID face_id = 0; Face_ID face_id = 0;
@ -83,14 +80,12 @@ get_view_summary(Application_Links *app, View_ID view_id, Access_Flag access, Vi
view->unwrapped_lines = !view->unwrapped_lines; view->unwrapped_lines = !view->unwrapped_lines;
view_get_setting(app, view_id, ViewSetting_ShowWhitespace, &view->show_whitespace); view_get_setting(app, view_id, ViewSetting_ShowWhitespace, &view->show_whitespace);
view->buffer_id = buffer; view->buffer_id = buffer;
i32 pos = 0; i32 pos = view_get_mark_pos(app, view_id);
view_get_mark_pos(app, view_id, &pos);
view_compute_cursor(app, view_id, seek_pos(pos), &view->mark); view_compute_cursor(app, view_id, seek_pos(pos), &view->mark);
view_get_cursor_pos(app, view_id, &pos); pos = view_get_cursor_pos(app, view_id);
view_compute_cursor(app, view_id, seek_pos(pos), &view->cursor); view_compute_cursor(app, view_id, seek_pos(pos), &view->cursor);
view_get_preferred_x(app, view_id, &view->preferred_x); view->preferred_x = view_get_preferred_x(app, view_id);
Rect_f32 screen_rect = {}; Rect_f32 screen_rect = view_get_screen_rect(app, view_id);
view_get_screen_rect(app, view_id, &screen_rect);
view->view_region = screen_rect; view->view_region = screen_rect;
view->render_region = f32R(0.f, 0.f, rect_width(screen_rect), rect_height(screen_rect)); view->render_region = f32R(0.f, 0.f, rect_width(screen_rect), rect_height(screen_rect));
view_get_scroll_vars(app, view_id, &view->scroll_vars); view_get_scroll_vars(app, view_id, &view->scroll_vars);
@ -104,27 +99,19 @@ clipboard_post(Application_Links *app, i32 clipboard_id, char *str, i32 len){
return(clipboard_post(app, clipboard_id, SCu8(str, len))); return(clipboard_post(app, clipboard_id, SCu8(str, len)));
} }
static i32
clipboard_count(Application_Links *app, i32 clipboard_id){
i32 count = 0;
clipboard_count(app, clipboard_id, &count);
return(count);
}
static i32 static i32
clipboard_index(Application_Links *app, i32 clipboard_id, i32 item_index, char *out, i32 len){ clipboard_index(Application_Links *app, i32 clipboard_id, i32 item_index, char *out, i32 len){
Scratch_Block scratch(app); Scratch_Block scratch(app);
String_Const_u8 string = {}; String_Const_u8 string = push_clipboard_index(app, scratch, clipboard_id, item_index);
clipboard_index(app, clipboard_id, item_index, scratch, &string);
block_copy(out, string.str, clamp_top((i32)string.size, len)); block_copy(out, string.str, clamp_top((i32)string.size, len));
return((i32)string.size); return((i32)string.size);
} }
static Buffer_Summary static Buffer_Summary
get_buffer_first(Application_Links *app, Access_Flag access){ get_buffer_first(Application_Links *app, Access_Flag access){
Buffer_ID buffer_id = 0;
Buffer_Summary buffer = {}; Buffer_Summary buffer = {};
if (get_buffer_next(app, 0, access, &buffer_id)){ Buffer_ID buffer_id = get_buffer_next(app, 0, access);
if (buffer_id != 0){
get_buffer_summary(app, buffer_id, access, &buffer); get_buffer_summary(app, buffer_id, access, &buffer);
} }
return(buffer); return(buffer);
@ -133,12 +120,12 @@ get_buffer_first(Application_Links *app, Access_Flag access){
static void static void
get_buffer_next(Application_Links *app, Buffer_Summary *buffer, Access_Flag access){ get_buffer_next(Application_Links *app, Buffer_Summary *buffer, Access_Flag access){
if (buffer != 0 && buffer->exists){ if (buffer != 0 && buffer->exists){
Buffer_ID buffer_id = 0; Buffer_ID buffer_id = get_buffer_next(app, buffer->buffer_id, access);
if (get_buffer_next(app, buffer->buffer_id, access, &buffer_id)){ if (buffer_id != 0){
get_buffer_summary(app, buffer_id, access, buffer); get_buffer_summary(app, buffer_id, access, buffer);
} }
else{ else{
memset(buffer, 0, sizeof(*buffer)); block_zero_struct(buffer);
} }
} }
} }
@ -152,9 +139,9 @@ get_buffer(Application_Links *app, Buffer_ID buffer_id, Access_Flag access){
static Buffer_Summary static Buffer_Summary
get_buffer_by_name(Application_Links *app, char *name, i32 len, Access_Flag access){ get_buffer_by_name(Application_Links *app, char *name, i32 len, Access_Flag access){
Buffer_ID id = 0;
Buffer_Summary buffer = {}; Buffer_Summary buffer = {};
if (get_buffer_by_name(app, SCu8(name, len), access, &id)){ Buffer_ID id = get_buffer_by_name(app, SCu8(name, len), access);
if (id != 0){
get_buffer_summary(app, id, access, &buffer); get_buffer_summary(app, id, access, &buffer);
} }
return(buffer); return(buffer);
@ -162,9 +149,9 @@ get_buffer_by_name(Application_Links *app, char *name, i32 len, Access_Flag acce
static Buffer_Summary static Buffer_Summary
get_buffer_by_file_name(Application_Links *app, char *name, i32 len, Access_Flag access){ get_buffer_by_file_name(Application_Links *app, char *name, i32 len, Access_Flag access){
Buffer_ID id = 0;
Buffer_Summary buffer = {}; Buffer_Summary buffer = {};
if (get_buffer_by_file_name(app, SCu8(name, len), access, &id)){ Buffer_ID id = get_buffer_by_file_name(app, SCu8(name, len), access);
if (id != 0){
get_buffer_summary(app, id, access, &buffer); get_buffer_summary(app, id, access, &buffer);
} }
return(buffer); return(buffer);
@ -194,7 +181,8 @@ static b32
buffer_compute_cursor(Application_Links *app, Buffer_Summary *buffer, Buffer_Seek seek, Partial_Cursor *cursor_out){ buffer_compute_cursor(Application_Links *app, Buffer_Summary *buffer, Buffer_Seek seek, Partial_Cursor *cursor_out){
b32 result = false; b32 result = false;
if (buffer != 0 && buffer->exists){ if (buffer != 0 && buffer->exists){
result = buffer_compute_cursor(app, buffer->buffer_id, seek, cursor_out); *cursor_out = buffer_compute_cursor(app, buffer->buffer_id, seek);
result = (cursor_out->line > 0);
get_buffer_summary(app, buffer->buffer_id, AccessAll, buffer); get_buffer_summary(app, buffer->buffer_id, AccessAll, buffer);
} }
return(result); return(result);
@ -230,37 +218,48 @@ buffer_set_setting(Application_Links *app, Buffer_Summary *buffer, Buffer_Settin
return(result); return(result);
} }
static Managed_Scope
buffer_get_managed_scope(Application_Links *app, Buffer_ID buffer_id){
Managed_Scope scope = 0;
buffer_get_managed_scope(app, buffer_id, &scope);
return(scope);
}
static i32 static i32
buffer_token_count(Application_Links *app, Buffer_Summary *buffer){ buffer_token_count(Application_Links *app, Buffer_Summary *buffer){
i32 count = 0; i32 count = 0;
if (buffer != 0 && buffer->exists){ if (buffer != 0 && buffer->exists){
buffer_token_count(app, buffer->buffer_id, &count); count = buffer_get_token_array(app, buffer->buffer_id).count;
} }
return(count); return(count);
} }
static b32 static b32
buffer_read_tokens(Application_Links *app, Buffer_Summary *buffer, i32 start_token, i32 end_token, Cpp_Token *tokens_out){ buffer_read_tokens(Application_Links *app, Buffer_ID buffer, i32 start_token, i32 end_token, Cpp_Token *tokens_out){
b32 result = false; b32 result = false;
if (buffer != 0 && buffer->exists){ if (buffer != 0){
result = buffer_read_tokens(app, buffer->buffer_id, start_token, end_token, tokens_out); Cpp_Token_Array array = buffer_get_token_array(app, buffer);
get_buffer_summary(app, buffer->buffer_id, AccessAll, buffer); if (0 <= start_token && start_token <= end_token && end_token < array.count){
result = true;
block_copy_dynamic_array(tokens_out, array.tokens + start_token, end_token - start_token);
}
} }
return(result); return(result);
} }
static b32
buffer_read_tokens(Application_Links *app, Buffer_Summary *buffer, i32 start_token, i32 end_token, Cpp_Token *tokens_out){
Buffer_ID buffer_id = (buffer==0?0:buffer->buffer_id);
b32 result = buffer_read_tokens(app, buffer_id, start_token, end_token, tokens_out);
get_buffer_summary(app, buffer_id, AccessAll, buffer);
return(result);
}
static b32 static b32
buffer_get_token_range(Application_Links *app, Buffer_Summary *buffer, Cpp_Token **first_token_out, Cpp_Token **one_past_last_token_out){ buffer_get_token_range(Application_Links *app, Buffer_Summary *buffer, Cpp_Token **first_token_out, Cpp_Token **one_past_last_token_out){
b32 result = false; b32 result = false;
if (buffer != 0 && buffer->exists){ if (buffer != 0 && buffer->exists){
result = buffer_get_token_range(app, buffer->buffer_id, first_token_out, one_past_last_token_out); Cpp_Token_Array array = buffer_get_token_array(app, buffer->buffer_id);
result = true;
if (first_token_out != 0){
*first_token_out = array.tokens;
}
if (one_past_last_token_out != 0){
*one_past_last_token_out = array.tokens + array.count;
}
get_buffer_summary(app, buffer->buffer_id, AccessAll, buffer); get_buffer_summary(app, buffer->buffer_id, AccessAll, buffer);
} }
return(result); return(result);
@ -270,7 +269,9 @@ static b32
buffer_get_token_index(Application_Links *app, Buffer_Summary *buffer, i32 pos, Cpp_Get_Token_Result *get_result){ buffer_get_token_index(Application_Links *app, Buffer_Summary *buffer, i32 pos, Cpp_Get_Token_Result *get_result){
b32 result = false; b32 result = false;
if (buffer != 0 && buffer->exists){ if (buffer != 0 && buffer->exists){
result = buffer_get_token_index(app, buffer->buffer_id, pos, get_result); Cpp_Token_Array array = buffer_get_token_array(app, buffer->buffer_id);
result = true;
*get_result = cpp_get_token(array, pos);
get_buffer_summary(app, buffer->buffer_id, AccessAll, buffer); get_buffer_summary(app, buffer->buffer_id, AccessAll, buffer);
} }
return(result); return(result);
@ -289,8 +290,8 @@ buffer_send_end_signal(Application_Links *app, Buffer_Summary *buffer){
static Buffer_Summary static Buffer_Summary
create_buffer(Application_Links *app, char *filename, i32 filename_len, Buffer_Create_Flag flags){ create_buffer(Application_Links *app, char *filename, i32 filename_len, Buffer_Create_Flag flags){
Buffer_Summary buffer = {}; Buffer_Summary buffer = {};
Buffer_ID buffer_id = 0; Buffer_ID buffer_id = create_buffer(app, SCu8(filename, filename_len), flags);
if (create_buffer(app, SCu8(filename, filename_len), flags, &buffer_id)){ if (buffer_id != 0){
get_buffer_summary(app, buffer_id, AccessAll, &buffer); get_buffer_summary(app, buffer_id, AccessAll, &buffer);
} }
return(buffer); return(buffer);
@ -310,12 +311,12 @@ static Buffer_Kill_Result
kill_buffer(Application_Links *app, Buffer_Identifier buffer, Buffer_Kill_Flag flags){ kill_buffer(Application_Links *app, Buffer_Identifier buffer, Buffer_Kill_Flag flags){
Buffer_Kill_Result result = 0; Buffer_Kill_Result result = 0;
if (buffer.id != 0){ if (buffer.id != 0){
buffer_kill(app, buffer.id, flags, &result); result = buffer_kill(app, buffer.id, flags);
} }
else if (buffer.name != 0){ else if (buffer.name != 0){
Buffer_ID id = 0; Buffer_ID id = get_buffer_by_name(app, SCu8(buffer.name, buffer.name_len), AccessAll);
if (get_buffer_by_name(app, SCu8(buffer.name, buffer.name_len), AccessAll, &id)){ if (id != 0){
buffer_kill(app, id, flags, &result); result = buffer_kill(app, id, flags);
} }
} }
return(result); return(result);
@ -323,9 +324,9 @@ kill_buffer(Application_Links *app, Buffer_Identifier buffer, Buffer_Kill_Flag f
static Buffer_Reopen_Result static Buffer_Reopen_Result
reopen_buffer(Application_Links *app, Buffer_Summary *buffer, Buffer_Reopen_Flag flags){ reopen_buffer(Application_Links *app, Buffer_Summary *buffer, Buffer_Reopen_Flag flags){
Buffer_Kill_Result result = 0; Buffer_Reopen_Result result = 0;
if (buffer != 0 && buffer->exists){ if (buffer != 0 && buffer->exists){
buffer_reopen(app, buffer->buffer_id, flags, &result); result = buffer_reopen(app, buffer->buffer_id, flags);
} }
return(result); return(result);
} }
@ -333,8 +334,8 @@ reopen_buffer(Application_Links *app, Buffer_Summary *buffer, Buffer_Reopen_Flag
static View_Summary static View_Summary
get_view_first(Application_Links *app, Access_Flag access){ get_view_first(Application_Links *app, Access_Flag access){
View_Summary view = {}; View_Summary view = {};
View_ID view_id = 0; View_ID view_id = get_view_next(app, 0, access);
if (get_view_next(app, 0, access, &view_id)){ if (view_id != 0){
get_view_summary(app, view_id, access, &view); get_view_summary(app, view_id, access, &view);
} }
return(view); return(view);
@ -343,12 +344,12 @@ get_view_first(Application_Links *app, Access_Flag access){
static void static void
get_view_next(Application_Links *app, View_Summary *view, Access_Flag access){ get_view_next(Application_Links *app, View_Summary *view, Access_Flag access){
if (view != 0 && view->exists){ if (view != 0 && view->exists){
View_ID view_id = 0; View_ID view_id = get_view_next(app, view->view_id, access);
if (get_view_next(app, view->view_id, access, &view_id)){ if (view_id != 0){
get_view_summary(app, view_id, access, view); get_view_summary(app, view_id, access, view);
} }
else{ else{
memset(view, 0, sizeof(*view)); block_zero_struct(view);
} }
} }
} }
@ -361,10 +362,10 @@ get_view(Application_Links *app, View_ID view_id, Access_Flag access){
} }
static View_Summary static View_Summary
get_active_view(Application_Links *app, Access_Flag access){ get_active_view_DEP(Application_Links *app, Access_Flag access){
View_Summary view = {}; View_Summary view = {};
View_ID id = 0; View_ID id = get_active_view(app, access);
if (get_active_view(app, access, &id)){ if (id != 0){
get_view_summary(app, id, access, &view); get_view_summary(app, id, access, &view);
} }
return(view); return(view);
@ -374,15 +375,15 @@ static View_Summary
open_view(Application_Links *app, View_Summary *view_location, View_Split_Position position){ open_view(Application_Links *app, View_Summary *view_location, View_Split_Position position){
View_Summary view = {}; View_Summary view = {};
if (view_location != 0 && view_location->exists){ if (view_location != 0 && view_location->exists){
Panel_ID panel_id = 0; Panel_ID panel_id = view_get_panel(app, view_location->view_id);
if (view_get_panel(app, view_location->view_id, &panel_id)){ if (panel_id != 0){
b32 vertical = (position == ViewSplit_Left || position == ViewSplit_Right); b32 vertical = (position == ViewSplit_Left || position == ViewSplit_Right);
if (panel_split(app, panel_id, vertical?PanelSplit_LeftAndRight:PanelSplit_TopAndBottom)){ if (panel_split(app, panel_id, vertical?PanelSplit_LeftAndRight:PanelSplit_TopAndBottom)){
Panel_ID new_panel_id = 0;
Panel_Child child = (position == ViewSplit_Left || position == ViewSplit_Top)?PanelChild_Min:PanelChild_Max; Panel_Child child = (position == ViewSplit_Left || position == ViewSplit_Top)?PanelChild_Min:PanelChild_Max;
if (panel_get_child(app, panel_id, child, &new_panel_id)){ Panel_ID new_panel_id = panel_get_child(app, panel_id, child);
View_ID new_view_id = 0; if (new_panel_id != 0){
if (panel_get_view(app, new_panel_id, &new_view_id)){ View_ID new_view_id = panel_get_view(app, new_panel_id);
if (new_view_id != 0){
get_view_summary(app, new_view_id, AccessAll, &view); get_view_summary(app, new_view_id, AccessAll, &view);
get_view_summary(app, view_location->view_id, AccessAll, view_location); get_view_summary(app, view_location->view_id, AccessAll, view_location);
} }
@ -646,11 +647,11 @@ set_window_title(Application_Links *app, char *title){
} }
static Process_State static Process_State
get_process_state(Application_Links *app, Buffer_ID buffer_id){ get_process_state(Application_Links *app, Buffer_ID buffer){
Process_State state = {}; Process_State state = {};
Child_Process_ID child_process_id = 0; Child_Process_ID child_process = buffer_get_attached_child_process(app, buffer);
if (buffer_get_attached_child_process(app, buffer_id, &child_process_id)){ if (child_process != 0){
child_process_get_state(app, child_process_id, &state); state = child_process_get_state(app, child_process);
} }
return(state); return(state);
} }

View File

@ -112,6 +112,22 @@ enum{
BoundaryCamelCase = 0x8 BoundaryCamelCase = 0x8
}; };
// NOTE(allen|4.0.31): Stream_Tokens has been deprecated in favor of the Token_Iterator.
// For examples of usage: 4coder_function_list.cpp 4coder_scope_commands.cpp
// If you want to keep your code working easily uncomment the typedef for Stream_Tokens.
struct Stream_Tokens_DEP{
Application_Links *app;
Buffer_ID buffer_id;
Cpp_Token *base_tokens;
Cpp_Token *tokens;
i32 start;
i32 end;
i32 count;
i32 token_count;
};
//typedef Stream_Tokens_DEP Stream_Tokens;
#endif #endif
// BOTTOM // BOTTOM

View File

@ -145,7 +145,86 @@ init_stream_chunk(Stream_Chunk *chunk, Application_Links *app, Buffer_Summary *b
static b32 static b32
init_stream_tokens(Stream_Tokens_DEP *stream, Application_Links *app, Buffer_Summary *buffer, i32 pos, Cpp_Token *data, i32 count){ init_stream_tokens(Stream_Tokens_DEP *stream, Application_Links *app, Buffer_Summary *buffer, i32 pos, Cpp_Token *data, i32 count){
return(buffer==0?0:init_stream_tokens(stream, app, buffer->buffer_id, pos, data, count)); b32 result = false;
if (buffer != 0){
i32 token_count = buffer_token_count(app, buffer);
if (buffer_tokens_are_ready(app, buffer->buffer_id) &&
0 <= pos && pos < token_count && count > 0){
stream->app = app;
stream->buffer_id = buffer->buffer_id;
stream->base_tokens = data;
stream->count = count;
stream->start = round_down_i32(pos, count);
stream->end = round_up_i32(pos, count);
stream->token_count = token_count;
stream->start = clamp_bot(0, stream->start);
stream->end = clamp_top(stream->end, stream->token_count);
buffer_read_tokens(app, buffer, stream->start, stream->end, stream->base_tokens);
stream->tokens = stream->base_tokens - stream->start;
result = true;
}
}
return(result);
}
static Stream_Tokens_DEP
begin_temp_stream_token(Stream_Tokens_DEP *stream){
return(*stream);
}
static void
end_temp_stream_token(Stream_Tokens_DEP *stream, Stream_Tokens_DEP temp){
if (stream->start != temp.start || stream->end != temp.end){
Application_Links *app = stream->app;
buffer_read_tokens(app, temp.buffer_id, temp.start, temp.end, temp.base_tokens);
stream->tokens = stream->base_tokens - temp.start;
stream->start = temp.start;
stream->end = temp.end;
}
}
static b32
forward_stream_tokens(Stream_Tokens_DEP *stream){
Application_Links *app = stream->app;
Buffer_ID buffer_id = stream->buffer_id;
b32 result = false;
if (stream->end < stream->token_count){
stream->start = stream->end;
stream->end += stream->count;
if (stream->end > stream->token_count){
stream->end = stream->token_count;
}
if (stream->start < stream->end){
buffer_read_tokens(app, buffer_id, stream->start, stream->end, stream->base_tokens);
stream->tokens = stream->base_tokens - stream->start;
result = true;
}
}
return(result);
}
static b32
backward_stream_tokens(Stream_Tokens_DEP *stream){
Application_Links *app = stream->app;
Buffer_ID buffer_id = stream->buffer_id;
b32 result = false;
if (stream->start > 0){
stream->end = stream->start;
stream->start -= stream->count;
if (0 > stream->start){
stream->start = 0;
}
if (stream->start < stream->end){
buffer_read_tokens(app, buffer_id, stream->start, stream->end, stream->base_tokens);
stream->tokens = stream->base_tokens - stream->start;
result = true;
}
}
return(result);
} }
static String static String
@ -254,7 +333,7 @@ buffer_get_all_tokens(Application_Links *app, Arena *arena, Buffer_ID buffer_id)
b32 is_lexed = false; b32 is_lexed = false;
if (buffer_get_setting(app, buffer_id, BufferSetting_Lex, &is_lexed)){ if (buffer_get_setting(app, buffer_id, BufferSetting_Lex, &is_lexed)){
if (is_lexed){ if (is_lexed){
buffer_token_count(app, buffer_id, &array.count); array.count = buffer_get_token_array(app, buffer_id).count;
array.max_count = array.count; array.max_count = array.count;
array.tokens = push_array(arena, Cpp_Token, array.count); array.tokens = push_array(arena, Cpp_Token, array.count);
buffer_read_tokens(app, buffer_id, 0, array.count, array.tokens); buffer_read_tokens(app, buffer_id, 0, array.count, array.tokens);
@ -683,7 +762,7 @@ post_buffer_range_to_clipboard(Application_Links *app, i32 clipboard_index, Buff
static void static void
view_set_vertical_focus(Application_Links *app, View_Summary *view, i32 y_top, i32 y_bot){ view_set_vertical_focus(Application_Links *app, View_Summary *view, i32 y_top, i32 y_bot){
view_set_vertical_focus(app, view==0?0:view->view_id, y_top, y_bot); view_set_vertical_focus(app, view==0?0:view->view_id, (f32)y_top, (f32)y_bot);
} }
static b32 static b32
@ -738,8 +817,7 @@ isearch__update_highlight(Application_Links *app, View_Summary *view, Managed_Ob
static void static void
get_view_prev(Application_Links *app, View_Summary *view, Access_Flag access){ get_view_prev(Application_Links *app, View_Summary *view, Access_Flag access){
View_ID new_id = 0; View_ID new_id = get_view_prev(app, view->view_id, access);
get_view_prev(app, view->view_id, access, &new_id);
get_view_summary(app, new_id, access, view); get_view_summary(app, new_id, access, view);
} }
@ -1051,6 +1129,11 @@ current_view_boundary_seek_set_pos(Application_Links *app, Scan_Direction direct
current_view_scan_move(app, direction, boundary_list_from_old_flags(scratch, flags)); current_view_scan_move(app, direction, boundary_list_from_old_flags(scratch, flags));
} }
static Buffer_Kill_Result
kill_buffer(Application_Links *app, Buffer_Identifier identifier, View_ID gui_view_id, Buffer_Kill_Flag flags){
return(try_buffer_kill(app, buffer_identifier_to_id(app, identifier), gui_view_id, flags));
}
#endif #endif
// BOTTOM // BOTTOM

View File

@ -239,7 +239,7 @@ get_indentation_marks(Application_Links *app, Arena *arena, Buffer_ID buffer,
} }
else{ else{
token.type = CPP_TOKEN_EOF; token.type = CPP_TOKEN_EOF;
buffer_get_size(app, buffer, &token.start); token.start = (i32)buffer_get_size(app, buffer);
token.flags = 0; token.flags = 0;
} }
@ -475,8 +475,7 @@ get_indent_lines_whole_tokens(Application_Links *app, Buffer_ID buffer, Cpp_Toke
} }
} }
i32 line_count = 0; i32 line_count = (i32)buffer_get_line_count(app, buffer);
buffer_get_line_count(app, buffer, &line_count);
for (;line_end < line_count;){ for (;line_end < line_count;){
i32 next_line_start_pos = get_line_start_pos(app, buffer, line_end + 1); i32 next_line_start_pos = get_line_start_pos(app, buffer, line_end + 1);
@ -505,16 +504,12 @@ buffer_auto_indent(Application_Links *app, Arena *scratch, Buffer_ID buffer, i32
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
// Stage 1: Read the tokens to be used for indentation. // Stage 1: Read the tokens to be used for indentation.
Cpp_Token_Array tokens = {}; Cpp_Token_Array tokens = buffer_get_token_array(app, buffer);
buffer_token_count(app, buffer, &tokens.count);
tokens.max_count = tokens.count;
tokens.tokens = push_array(scratch, Cpp_Token, tokens.count);
buffer_read_tokens(app, buffer, 0, tokens.count, tokens.tokens);
// Stage 2: Decide where the first and last lines are. // Stage 2: Decide where the first and last lines are.
// The lines in the range [line_start,line_end) will be indented. // The lines in the range [line_start,line_end) will be indented.
i32 line_start = 0, line_end = 0; i32 line_start = 0, line_end = 0;
if (flags & AutoIndent_FullTokens){ if (HasFlag(flags, AutoIndent_FullTokens)){
get_indent_lines_whole_tokens(app, buffer, tokens, start, end, &line_start, &line_end); get_indent_lines_whole_tokens(app, buffer, tokens, start, end, &line_start, &line_end);
} }
else{ else{
@ -561,12 +556,9 @@ buffer_auto_indent(Application_Links *app, Buffer_ID buffer, i32 start, i32 end,
CUSTOM_COMMAND_SIG(auto_tab_whole_file) CUSTOM_COMMAND_SIG(auto_tab_whole_file)
CUSTOM_DOC("Audo-indents the entire current buffer.") CUSTOM_DOC("Audo-indents the entire current buffer.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer);
view_get_buffer(app, view, AccessOpen, &buffer);
i32 buffer_size = 0;
buffer_get_size(app, buffer, &buffer_size);
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
buffer_auto_indent(app, scratch, buffer, 0, buffer_size, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens); buffer_auto_indent(app, scratch, buffer, 0, buffer_size, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens);
} }
@ -574,12 +566,9 @@ CUSTOM_DOC("Audo-indents the entire current buffer.")
CUSTOM_COMMAND_SIG(auto_tab_line_at_cursor) CUSTOM_COMMAND_SIG(auto_tab_line_at_cursor)
CUSTOM_DOC("Auto-indents the line on which the cursor sits.") CUSTOM_DOC("Auto-indents the line on which the cursor sits.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessOpen, &buffer);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
buffer_auto_indent(app, scratch, buffer, pos, pos, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens); buffer_auto_indent(app, scratch, buffer, pos, pos, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens);
move_past_lead_whitespace(app, view, buffer); move_past_lead_whitespace(app, view, buffer);
@ -588,10 +577,8 @@ CUSTOM_DOC("Auto-indents the line on which the cursor sits.")
CUSTOM_COMMAND_SIG(auto_tab_range) CUSTOM_COMMAND_SIG(auto_tab_range)
CUSTOM_DOC("Auto-indents the range between the cursor and the mark.") CUSTOM_DOC("Auto-indents the range between the cursor and the mark.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
Range range = get_view_range(app, view); Range range = get_view_range(app, view);
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
buffer_auto_indent(app, scratch, buffer, range.min, range.max, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens); buffer_auto_indent(app, scratch, buffer, range.min, range.max, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens);
@ -602,17 +589,14 @@ CUSTOM_COMMAND_SIG(write_and_auto_tab)
CUSTOM_DOC("Inserts a character and auto-indents the line on which the cursor sits.") CUSTOM_DOC("Inserts a character and auto-indents the line on which the cursor sits.")
{ {
write_character(app); write_character(app);
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
u32 flags = DEFAULT_INDENT_FLAGS; u32 flags = DEFAULT_INDENT_FLAGS;
User_Input in = get_command_input(app); User_Input in = get_command_input(app);
if (in.key.character == '\n'){ if (in.key.character == '\n'){
flags |= AutoIndent_ExactAlignBlock; flags |= AutoIndent_ExactAlignBlock;
} }
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
buffer_auto_indent(app, scratch, buffer, pos, pos, DEF_TAB_WIDTH, flags); buffer_auto_indent(app, scratch, buffer, pos, pos, DEF_TAB_WIDTH, flags);
move_past_lead_whitespace(app, view, buffer); move_past_lead_whitespace(app, view, buffer);

File diff suppressed because it is too large Load Diff

View File

@ -1782,6 +1782,23 @@ range_is_valid(Interval_f32 a){
return(a.min <= a.max); return(a.min <= a.max);
} }
internal i32
range_side(Interval_i32 a, Side side){
return(side == Side_Min?a.min:a.max);
}
internal i64
range_side(Interval_i64 a, Side side){
return(side == Side_Min?a.min:a.max);
}
internal u64
range_side(Interval_u64 a, Side side){
return(side == Side_Min?a.min:a.max);
}
internal f32
range_side(Interval_f32 a, Side side){
return(side == Side_Min?a.min:a.max);
}
//////////////////////////////// ////////////////////////////////
internal i32 internal i32
@ -1835,12 +1852,12 @@ Rf32(Vec2_f32 p0, Vec2_f32 p1){
internal Rect_i32 internal Rect_i32
Ri32(Rect_f32 o){ Ri32(Rect_f32 o){
Rect_i32 rect = {(i32)(o.x0), (i32)(o.y0), (i32)(o.x0), (i32)(o.y1)}; Rect_i32 rect = {(i32)(o.x0), (i32)(o.y0), (i32)(o.x1), (i32)(o.y1)};
return(rect); return(rect);
} }
internal Rect_f32 internal Rect_f32
Rf32(Rect_i32 o){ Rf32(Rect_i32 o){
Rect_f32 rect = {(f32)(o.x0), (f32)(o.y0), (f32)(o.x0), (f32)(o.y1)}; Rect_f32 rect = {(f32)(o.x0), (f32)(o.y0), (f32)(o.x1), (f32)(o.y1)};
return(rect); return(rect);
} }

View File

@ -128,25 +128,22 @@ standard_search_and_build(Application_Links *app, View_ID view, Buffer_ID active
CUSTOM_COMMAND_SIG(build_search) CUSTOM_COMMAND_SIG(build_search)
CUSTOM_DOC("Looks for a build.bat, build.sh, or makefile in the current and parent directories. Runs the first that it finds and prints the output to *compilation*.") CUSTOM_DOC("Looks for a build.bat, build.sh, or makefile in the current and parent directories. Runs the first that it finds and prints the output to *compilation*.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessAll);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessAll, &buffer);
standard_search_and_build(app, view, buffer); standard_search_and_build(app, view, buffer);
memset(&prev_location, 0, sizeof(prev_location)); memset(&prev_location, 0, sizeof(prev_location));
lock_jump_buffer(string_u8_litexpr("*compilation*")); lock_jump_buffer(string_u8_litexpr("*compilation*"));
} }
static b32 static Buffer_ID
get_comp_buffer(Application_Links *app, Buffer_ID *id_out){ get_comp_buffer(Application_Links *app){
return(get_buffer_by_name(app, string_u8_litexpr("*compilation*"), AccessAll, id_out)); return(get_buffer_by_name(app, string_u8_litexpr("*compilation*"), AccessAll));
} }
static View_ID static View_ID
get_or_open_build_panel(Application_Links *app){ get_or_open_build_panel(Application_Links *app){
View_ID view = 0; View_ID view = 0;
Buffer_ID buffer = 0; Buffer_ID buffer = get_comp_buffer(app);
get_comp_buffer(app, &buffer);
if (buffer != 0){ if (buffer != 0){
view = get_first_view_with_buffer(app, buffer); view = get_first_view_with_buffer(app, buffer);
} }
@ -158,18 +155,15 @@ get_or_open_build_panel(Application_Links *app){
static void static void
set_fancy_compilation_buffer_font(Application_Links *app){ set_fancy_compilation_buffer_font(Application_Links *app){
Buffer_ID buffer = 0; Buffer_ID buffer = get_comp_buffer(app);
get_comp_buffer(app, &buffer);
set_buffer_face_by_name(app, buffer, string_u8_litexpr("Inconsolata")); set_buffer_face_by_name(app, buffer, string_u8_litexpr("Inconsolata"));
} }
CUSTOM_COMMAND_SIG(build_in_build_panel) CUSTOM_COMMAND_SIG(build_in_build_panel)
CUSTOM_DOC("Looks for a build.bat, build.sh, or makefile in the current and parent directories. Runs the first that it finds and prints the output to *compilation*. Puts the *compilation* buffer in a panel at the footer of the current view.") CUSTOM_DOC("Looks for a build.bat, build.sh, or makefile in the current and parent directories. Runs the first that it finds and prints the output to *compilation*. Puts the *compilation* buffer in a panel at the footer of the current view.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessAll);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessAll, &buffer);
View_ID build_view = get_or_open_build_panel(app); View_ID build_view = get_or_open_build_panel(app);

View File

@ -457,7 +457,7 @@ internal void
DeleteAfterMotion(struct Application_Links *app, Custom_Command_Function *motion) DeleteAfterMotion(struct Application_Links *app, Custom_Command_Function *motion)
{ {
unsigned int access = AccessOpen; unsigned int access = AccessOpen;
View_Summary view = get_active_view(app, access); View_Summary view = get_active_view_DEP(app, access);
int pos2 = view.cursor.pos; int pos2 = view.cursor.pos;
motion(app); motion(app);
@ -501,7 +501,7 @@ CUSTOM_COMMAND_SIG(casey_delete_token_right)
CUSTOM_COMMAND_SIG(casey_kill_to_end_of_line) CUSTOM_COMMAND_SIG(casey_kill_to_end_of_line)
{ {
unsigned int access = AccessOpen; unsigned int access = AccessOpen;
View_Summary view = get_active_view(app, access); View_Summary view = get_active_view_DEP(app, access);
int pos2 = view.cursor.pos; int pos2 = view.cursor.pos;
exec_command(app, seek_end_of_line); exec_command(app, seek_end_of_line);
@ -567,7 +567,7 @@ SwitchToOrLoadFile(struct Application_Links *app, String FileName, bool CreateIf
SanitizeSlashes(FileName); SanitizeSlashes(FileName);
unsigned int access = AccessAll; unsigned int access = AccessAll;
View_Summary view = get_active_view(app, access); View_Summary view = get_active_view_DEP(app, access);
Buffer_Summary buffer = get_buffer_by_name(app, FileName.str, FileName.size, access); Buffer_Summary buffer = get_buffer_by_name(app, FileName.str, FileName.size, access);
Result.view = view; Result.view = view;
@ -663,7 +663,7 @@ CUSTOM_COMMAND_SIG(casey_build_search)
CUSTOM_COMMAND_SIG(casey_find_corresponding_file) CUSTOM_COMMAND_SIG(casey_find_corresponding_file)
{ {
unsigned int access = AccessProtected; unsigned int access = AccessProtected;
View_Summary view = get_active_view(app, access); View_Summary view = get_active_view_DEP(app, access);
Buffer_Summary buffer = get_buffer(app, view.buffer_id, access); Buffer_Summary buffer = get_buffer(app, view.buffer_id, access);
String extension = file_extension(make_string(buffer.file_name, buffer.file_name_len)); String extension = file_extension(make_string(buffer.file_name, buffer.file_name_len));
@ -719,11 +719,11 @@ CUSTOM_COMMAND_SIG(casey_find_corresponding_file)
CUSTOM_COMMAND_SIG(casey_find_corresponding_file_other_window) CUSTOM_COMMAND_SIG(casey_find_corresponding_file_other_window)
{ {
unsigned int access = AccessProtected; unsigned int access = AccessProtected;
View_Summary old_view = get_active_view(app, access); View_Summary old_view = get_active_view_DEP(app, access);
Buffer_Summary buffer = get_buffer(app, old_view.buffer_id, access); Buffer_Summary buffer = get_buffer(app, old_view.buffer_id, access);
exec_command(app, change_active_panel); exec_command(app, change_active_panel);
View_Summary new_view = get_active_view(app, AccessAll); View_Summary new_view = get_active_view_DEP(app, AccessAll);
view_set_buffer(app, &new_view, buffer.buffer_id, 0); view_set_buffer(app, &new_view, buffer.buffer_id, 0);
// exec_command(app, casey_find_corresponding_file); // exec_command(app, casey_find_corresponding_file);
@ -771,7 +771,7 @@ CUSTOM_COMMAND_SIG(casey_save_and_make_without_asking)
if(append(&command, "build.bat")) if(append(&command, "build.bat"))
{ {
unsigned int access = AccessAll; unsigned int access = AccessAll;
View_Summary view = get_active_view(app, access); View_Summary view = get_active_view_DEP(app, access);
exec_system_command(app, &view, exec_system_command(app, &view,
buffer_identifier(GlobalCompilationBufferName, (int)strlen(GlobalCompilationBufferName)), buffer_identifier(GlobalCompilationBufferName, (int)strlen(GlobalCompilationBufferName)),
dir.str, dir.size, dir.str, dir.size,
@ -996,7 +996,7 @@ ParseCalc(tokenizer *Tokenizer)
CUSTOM_COMMAND_SIG(casey_quick_calc) CUSTOM_COMMAND_SIG(casey_quick_calc)
{ {
unsigned int access = AccessOpen; unsigned int access = AccessOpen;
View_Summary view = get_active_view(app, access); View_Summary view = get_active_view_DEP(app, access);
Range range = get_view_range(&view); Range range = get_view_range(&view);
@ -1130,7 +1130,7 @@ IsCodeLegal(int32_t Codepoint)
CUSTOM_COMMAND_SIG(casey_force_codelegal_characters) CUSTOM_COMMAND_SIG(casey_force_codelegal_characters)
{ {
View_Summary view = get_active_view(app, AccessOpen); View_Summary view = get_active_view_DEP(app, AccessOpen);
Buffer_Summary buffer = get_buffer(app, view.buffer_id, AccessOpen); Buffer_Summary buffer = get_buffer(app, view.buffer_id, AccessOpen);
int32_t line_count = buffer.line_count; int32_t line_count = buffer.line_count;
@ -1428,7 +1428,7 @@ casey_list_all_functions(Application_Links *app, Partition *part, Buffer_Summary
buffer_replace_range(app, decls_buffer, size, size, str, part_size); buffer_replace_range(app, decls_buffer, size, size, str, part_size);
View_Summary view = get_active_view(app, AccessAll); View_Summary view = get_active_view_DEP(app, AccessAll);
view_set_buffer(app, &view, decls_buffer->buffer_id, 0); view_set_buffer(app, &view, decls_buffer->buffer_id, 0);
lock_jump_buffer(decls_buffer->buffer_name, decls_buffer->buffer_name_len); lock_jump_buffer(decls_buffer->buffer_name, decls_buffer->buffer_name_len);
@ -1455,7 +1455,7 @@ ClearDeclsBuffer(Application_Links *app, Buffer_Summary *decls_buffer)
CUSTOM_COMMAND_SIG(casey_list_all_functions_current_buffer){ CUSTOM_COMMAND_SIG(casey_list_all_functions_current_buffer){
uint32_t access = AccessProtected; uint32_t access = AccessProtected;
View_Summary view = get_active_view(app, access); View_Summary view = get_active_view_DEP(app, access);
Buffer_Summary buffer = get_buffer(app, view.buffer_id, access); Buffer_Summary buffer = get_buffer(app, view.buffer_id, access);
Buffer_Summary decls_buffer; Buffer_Summary decls_buffer;

View File

@ -7,8 +7,7 @@
static b32 static b32
post_buffer_range_to_clipboard(Application_Links *app, i32 clipboard_index, Buffer_ID buffer, i32 first, i32 one_past_last){ post_buffer_range_to_clipboard(Application_Links *app, i32 clipboard_index, Buffer_ID buffer, i32 first, i32 one_past_last){
b32 success = false; b32 success = false;
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer);
buffer_get_size(app, buffer, &buffer_size);
if (buffer != 0 && 0 <= first && first < one_past_last && one_past_last <= buffer_size){ if (buffer != 0 && 0 <= first && first < one_past_last && one_past_last <= buffer_size){
Scratch_Block scratch(app); Scratch_Block scratch(app);
Range range = make_range(first, one_past_last); Range range = make_range(first, one_past_last);
@ -24,10 +23,8 @@ post_buffer_range_to_clipboard(Application_Links *app, i32 clipboard_index, Buff
CUSTOM_COMMAND_SIG(copy) CUSTOM_COMMAND_SIG(copy)
CUSTOM_DOC("Copy the text in the range from the cursor to the mark onto the clipboard.") CUSTOM_DOC("Copy the text in the range from the cursor to the mark onto the clipboard.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessProtected, &buffer);
Range range = get_view_range(app, view); Range range = get_view_range(app, view);
post_buffer_range_to_clipboard(app, 0, buffer, range.min, range.max); post_buffer_range_to_clipboard(app, 0, buffer, range.min, range.max);
} }
@ -35,10 +32,8 @@ CUSTOM_DOC("Copy the text in the range from the cursor to the mark onto the clip
CUSTOM_COMMAND_SIG(cut) CUSTOM_COMMAND_SIG(cut)
CUSTOM_DOC("Cut the text in the range from the cursor to the mark onto the clipboard.") CUSTOM_DOC("Cut the text in the range from the cursor to the mark onto the clipboard.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
Range range = get_view_range(app, view); Range range = get_view_range(app, view);
if (post_buffer_range_to_clipboard(app, 0, buffer, range.min, range.max)){ if (post_buffer_range_to_clipboard(app, 0, buffer, range.min, range.max)){
buffer_replace_range(app, buffer, range, string_u8_litexpr("")); buffer_replace_range(app, buffer, range, string_u8_litexpr(""));
@ -48,11 +43,9 @@ CUSTOM_DOC("Cut the text in the range from the cursor to the mark onto the clipb
CUSTOM_COMMAND_SIG(paste) CUSTOM_COMMAND_SIG(paste)
CUSTOM_DOC("At the cursor, insert the text at the top of the clipboard.") CUSTOM_DOC("At the cursor, insert the text at the top of the clipboard.")
{ {
i32 count = 0; i32 count = clipboard_count(app, 0);
clipboard_count(app, 0, &count);
if (count > 0){ if (count > 0){
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view);
if_view_has_highlighted_range_delete_range(app, view); if_view_has_highlighted_range_delete_range(app, view);
Managed_Scope scope = 0; Managed_Scope scope = 0;
@ -63,14 +56,11 @@ CUSTOM_DOC("At the cursor, insert the text at the top of the clipboard.")
Scratch_Block scratch(app); Scratch_Block scratch(app);
String_Const_u8 string = {}; String_Const_u8 string = push_clipboard_index(app, scratch, 0, paste_index);
clipboard_index(app, 0, paste_index, scratch, &string);
if (string.size > 0){ if (string.size > 0){
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
view_get_buffer(app, view, AccessOpen, &buffer);
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
buffer_replace_range(app, buffer, make_range(pos), string); buffer_replace_range(app, buffer, make_range(pos), string);
view_set_mark(app, view, seek_pos(pos)); view_set_mark(app, view, seek_pos(pos));
view_set_cursor(app, view, seek_pos(pos + (i32)string.size), true); view_set_cursor(app, view, seek_pos(pos + (i32)string.size), true);
@ -89,11 +79,9 @@ CUSTOM_DOC("If the previous command was paste or paste_next, replaces the paste
{ {
Scratch_Block scratch(app); Scratch_Block scratch(app);
i32 count = 0; i32 count = clipboard_count(app, 0);
clipboard_count(app, 0, &count);
if (count > 0){ if (count > 0){
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view);
Managed_Scope scope = 0; Managed_Scope scope = 0;
view_get_managed_scope(app, view, &scope); view_get_managed_scope(app, view, &scope);
no_mark_snap_to_cursor(app, scope); no_mark_snap_to_cursor(app, scope);
@ -107,11 +95,9 @@ CUSTOM_DOC("If the previous command was paste or paste_next, replaces the paste
i32 paste_index = (i32)prev_paste_index + 1; i32 paste_index = (i32)prev_paste_index + 1;
managed_variable_set(app, scope, view_paste_index_loc, paste_index); managed_variable_set(app, scope, view_paste_index_loc, paste_index);
String_Const_u8 string = {}; String_Const_u8 string = push_clipboard_index(app, scratch, 0, paste_index);
clipboard_index(app, 0, paste_index, scratch, &string);
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
view_get_buffer(app, view, AccessOpen, &buffer);
Range range = get_view_range(app, view); Range range = get_view_range(app, view);
i32 pos = range.min; i32 pos = range.min;

View File

@ -6,18 +6,15 @@
static void static void
write_string(Application_Links *app, View_ID view, Buffer_ID buffer, String_Const_u8 string){ write_string(Application_Links *app, View_ID view, Buffer_ID buffer, String_Const_u8 string){
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
buffer_replace_range(app, buffer, make_range(pos), string); buffer_replace_range(app, buffer, make_range(pos), string);
view_set_cursor(app, view, seek_pos(pos + (i32)string.size), 1); view_set_cursor(app, view, seek_pos(pos + (i32)string.size), 1);
} }
static void static void
write_string(Application_Links *app, String_Const_u8 string){ write_string(Application_Links *app, String_Const_u8 string){
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
write_string(app, view, buffer, string); write_string(app, view, buffer, string);
} }
@ -37,12 +34,9 @@ write_named_comment_string(Application_Links *app, char *type_string){
static void static void
long_braces(Application_Links *app, char *text, i32 size){ long_braces(Application_Links *app, char *text, i32 size){
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessOpen, &buffer);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
buffer_replace_range(app, buffer, make_range(pos), SCu8(text, size)); buffer_replace_range(app, buffer, make_range(pos), SCu8(text, size));
view_set_cursor(app, view, seek_pos(pos + 2), true); view_set_cursor(app, view, seek_pos(pos + 2), true);
buffer_auto_indent(app, buffer, pos, pos + size, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens); buffer_auto_indent(app, buffer, pos, pos + size, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens);
@ -111,8 +105,7 @@ CUSTOM_DOC("At the cursor, insert a ' = {};'.")
static i32 static i32
get_start_of_line_at_cursor(Application_Links *app, View_ID view, Buffer_ID buffer){ get_start_of_line_at_cursor(Application_Links *app, View_ID view, Buffer_ID buffer){
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
i32 line = get_line_number_from_pos(app, buffer, pos); i32 line = get_line_number_from_pos(app, buffer, pos);
pos = get_line_side_pos(app, buffer, line, Side_Min); pos = get_line_side_pos(app, buffer, line, Side_Min);
return(pos); return(pos);
@ -133,10 +126,8 @@ c_line_comment_starts_at_position(Application_Links *app, Buffer_ID buffer, i32
CUSTOM_COMMAND_SIG(comment_line) CUSTOM_COMMAND_SIG(comment_line)
CUSTOM_DOC("Insert '//' at the beginning of the line after leading whitespace.") CUSTOM_DOC("Insert '//' at the beginning of the line after leading whitespace.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
i32 pos = get_start_of_line_at_cursor(app, view, buffer); i32 pos = get_start_of_line_at_cursor(app, view, buffer);
b32 alread_has_comment = c_line_comment_starts_at_position(app, buffer, pos); b32 alread_has_comment = c_line_comment_starts_at_position(app, buffer, pos);
if (!alread_has_comment){ if (!alread_has_comment){
@ -147,10 +138,8 @@ CUSTOM_DOC("Insert '//' at the beginning of the line after leading whitespace.")
CUSTOM_COMMAND_SIG(uncomment_line) CUSTOM_COMMAND_SIG(uncomment_line)
CUSTOM_DOC("If present, delete '//' at the beginning of the line after leading whitespace.") CUSTOM_DOC("If present, delete '//' at the beginning of the line after leading whitespace.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
i32 pos = get_start_of_line_at_cursor(app, view, buffer); i32 pos = get_start_of_line_at_cursor(app, view, buffer);
b32 alread_has_comment = c_line_comment_starts_at_position(app, buffer, pos); b32 alread_has_comment = c_line_comment_starts_at_position(app, buffer, pos);
if (alread_has_comment){ if (alread_has_comment){
@ -161,10 +150,8 @@ CUSTOM_DOC("If present, delete '//' at the beginning of the line after leading w
CUSTOM_COMMAND_SIG(comment_line_toggle) CUSTOM_COMMAND_SIG(comment_line_toggle)
CUSTOM_DOC("Turns uncommented lines into commented lines and vice versa for comments starting with '//'.") CUSTOM_DOC("Turns uncommented lines into commented lines and vice versa for comments starting with '//'.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
i32 pos = get_start_of_line_at_cursor(app, view, buffer); i32 pos = get_start_of_line_at_cursor(app, view, buffer);
b32 alread_has_comment = c_line_comment_starts_at_position(app, buffer, pos); b32 alread_has_comment = c_line_comment_starts_at_position(app, buffer, pos);
if (alread_has_comment){ if (alread_has_comment){
@ -214,10 +201,8 @@ activate_snippet(Application_Links *app, Heap *heap, View_ID view, struct Lister
if (0 <= index && index < snippets.count){ if (0 <= index && index < snippets.count){
Snippet snippet = snippets.snippets[index]; Snippet snippet = snippets.snippets[index];
lister_default(app, heap, view, state, ListerActivation_Finished); lister_default(app, heap, view, state, ListerActivation_Finished);
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
view_get_buffer(app, view, AccessOpen, &buffer); i32 pos = view_get_cursor_pos(app, view);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
buffer_replace_range(app, buffer, make_range(pos), SCu8(snippet.text)); buffer_replace_range(app, buffer, make_range(pos), SCu8(snippet.text));
view_set_cursor(app, view, seek_pos(pos + snippet.cursor_offset), true); view_set_cursor(app, view, seek_pos(pos + snippet.cursor_offset), true);
view_set_mark(app, view, seek_pos(pos + snippet.mark_offset)); view_set_mark(app, view, seek_pos(pos + snippet.mark_offset));
@ -231,8 +216,7 @@ activate_snippet(Application_Links *app, Heap *heap, View_ID view, struct Lister
static void static void
snippet_lister__parameterized(Application_Links *app, Snippet_Array snippet_array){ snippet_lister__parameterized(Application_Links *app, Snippet_Array snippet_array){
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view_end_ui_mode(app, view); view_end_ui_mode(app, view);
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);

View File

@ -36,8 +36,7 @@ static View_ID
get_view_for_locked_jump_buffer(Application_Links *app){ get_view_for_locked_jump_buffer(Application_Links *app){
View_ID view = 0; View_ID view = 0;
if (locked_buffer.size > 0){ if (locked_buffer.size > 0){
Buffer_ID buffer = 0; Buffer_ID buffer = get_buffer_by_name(app, locked_buffer, AccessAll);
get_buffer_by_name(app, locked_buffer, AccessAll, &buffer);
if (buffer != 0){ if (buffer != 0){
view = get_first_view_with_buffer(app, buffer); view = get_first_view_with_buffer(app, buffer);
} }
@ -82,8 +81,7 @@ static View_ID
open_footer_panel(Application_Links *app, View_ID view){ open_footer_panel(Application_Links *app, View_ID view){
View_ID special_view = open_view(app, view, ViewSplit_Bottom); View_ID special_view = open_view(app, view, ViewSplit_Bottom);
new_view_settings(app, special_view); new_view_settings(app, special_view);
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, special_view, AccessAll);
view_get_buffer(app, special_view, AccessAll, &buffer);
Face_ID face_id = 0; Face_ID face_id = 0;
get_face_id(app, buffer, &face_id); get_face_id(app, buffer, &face_id);
Face_Metrics metrics = {}; Face_Metrics metrics = {};
@ -104,8 +102,7 @@ close_build_footer_panel(Application_Links *app){
static View_ID static View_ID
open_build_footer_panel(Application_Links *app){ open_build_footer_panel(Application_Links *app){
if (build_footer_panel_view_id == 0){ if (build_footer_panel_view_id == 0){
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
build_footer_panel_view_id = open_footer_panel(app, view); build_footer_panel_view_id = open_footer_panel(app, view);
view_set_active(app, view); view_set_active(app, view);
} }
@ -138,8 +135,7 @@ get_prev_view_looped_primary_panels(Application_Links *app, View_ID start_view_i
static View_ID static View_ID
get_next_view_after_active(Application_Links *app, Access_Flag access){ get_next_view_after_active(Application_Links *app, Access_Flag access){
View_ID view = 0; View_ID view = get_active_view(app, access);
get_active_view(app, access, &view);
if (view != 0){ if (view != 0){
view = get_next_view_looped_primary_panels(app, view, access); view = get_next_view_looped_primary_panels(app, view, access);
} }
@ -159,8 +155,7 @@ view_buffer_set(Application_Links *app, Buffer_ID *buffers, i32 *positions, i32
View_ID view_id; View_ID view_id;
}; };
View_ID active_view_id = 0; View_ID active_view_id = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &active_view_id);
View_ID first_view_id = active_view_id; View_ID first_view_id = active_view_id;
if (view_get_is_passive(app, active_view_id)){ if (view_get_is_passive(app, active_view_id)){
first_view_id = get_next_view_looped_primary_panels(app, active_view_id, AccessAll); first_view_id = get_next_view_looped_primary_panels(app, active_view_id, AccessAll);
@ -206,8 +201,7 @@ view_buffer_set(Application_Links *app, Buffer_ID *buffers, i32 *positions, i32
CUSTOM_COMMAND_SIG(change_active_panel) CUSTOM_COMMAND_SIG(change_active_panel)
CUSTOM_DOC("Change the currently active panel, moving to the panel with the next highest view_id.") CUSTOM_DOC("Change the currently active panel, moving to the panel with the next highest view_id.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view = get_next_view_looped_primary_panels(app, view, AccessAll); view = get_next_view_looped_primary_panels(app, view, AccessAll);
if (view != 0){ if (view != 0){
view_set_active(app, view); view_set_active(app, view);
@ -217,8 +211,7 @@ CUSTOM_DOC("Change the currently active panel, moving to the panel with the next
CUSTOM_COMMAND_SIG(change_active_panel_backwards) CUSTOM_COMMAND_SIG(change_active_panel_backwards)
CUSTOM_DOC("Change the currently active panel, moving to the panel with the next lowest view_id.") CUSTOM_DOC("Change the currently active panel, moving to the panel with the next lowest view_id.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view = get_prev_view_looped_primary_panels(app, view, AccessAll); view = get_prev_view_looped_primary_panels(app, view, AccessAll);
if (view != 0){ if (view != 0){
view_set_active(app, view); view_set_active(app, view);
@ -228,24 +221,20 @@ CUSTOM_DOC("Change the currently active panel, moving to the panel with the next
CUSTOM_COMMAND_SIG(open_panel_vsplit) CUSTOM_COMMAND_SIG(open_panel_vsplit)
CUSTOM_DOC("Create a new panel by vertically splitting the active panel.") CUSTOM_DOC("Create a new panel by vertically splitting the active panel.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
View_ID new_view = open_view(app, view, ViewSplit_Right); View_ID new_view = open_view(app, view, ViewSplit_Right);
new_view_settings(app, new_view); new_view_settings(app, new_view);
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessAll);
view_get_buffer(app, view, AccessAll, &buffer);
view_set_buffer(app, new_view, buffer, 0); view_set_buffer(app, new_view, buffer, 0);
} }
CUSTOM_COMMAND_SIG(open_panel_hsplit) CUSTOM_COMMAND_SIG(open_panel_hsplit)
CUSTOM_DOC("Create a new panel by horizontally splitting the active panel.") CUSTOM_DOC("Create a new panel by horizontally splitting the active panel.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
View_ID new_view = open_view(app, view, ViewSplit_Bottom); View_ID new_view = open_view(app, view, ViewSplit_Bottom);
new_view_settings(app, new_view); new_view_settings(app, new_view);
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessAll);
view_get_buffer(app, view, AccessAll, &buffer);
view_set_buffer(app, new_view, buffer, 0); view_set_buffer(app, new_view, buffer, 0);
} }
@ -255,8 +244,7 @@ CUSTOM_DOC("Create a new panel by horizontally splitting the active panel.")
static Buffer_ID static Buffer_ID
create_or_switch_to_buffer_and_clear_by_name(Application_Links *app, String_Const_u8 name_string, View_ID default_target_view){ create_or_switch_to_buffer_and_clear_by_name(Application_Links *app, String_Const_u8 name_string, View_ID default_target_view){
Buffer_ID search_buffer = 0; Buffer_ID search_buffer = get_buffer_by_name(app, name_string, AccessAll);
get_buffer_by_name(app, name_string, AccessAll, &search_buffer);
if (search_buffer != 0){ if (search_buffer != 0){
buffer_set_setting(app, search_buffer, BufferSetting_ReadOnly, true); buffer_set_setting(app, search_buffer, BufferSetting_ReadOnly, true);
@ -272,14 +260,13 @@ create_or_switch_to_buffer_and_clear_by_name(Application_Links *app, String_Cons
} }
view_set_active(app, target_view); view_set_active(app, target_view);
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, search_buffer);
buffer_get_size(app, search_buffer, &buffer_size);
buffer_send_end_signal(app, search_buffer); buffer_send_end_signal(app, search_buffer);
buffer_replace_range(app, search_buffer, make_range(0, buffer_size), string_u8_litexpr("")); buffer_replace_range(app, search_buffer, make_range(0, buffer_size), string_u8_litexpr(""));
} }
else{ else{
create_buffer(app, name_string, BufferCreate_AlwaysNew, &search_buffer); search_buffer = create_buffer(app, name_string, BufferCreate_AlwaysNew);
buffer_set_setting(app, search_buffer, BufferSetting_Unimportant, true); buffer_set_setting(app, search_buffer, BufferSetting_Unimportant, true);
buffer_set_setting(app, search_buffer, BufferSetting_ReadOnly, true); buffer_set_setting(app, search_buffer, BufferSetting_ReadOnly, true);
buffer_set_setting(app, search_buffer, BufferSetting_WrapLine, false); buffer_set_setting(app, search_buffer, BufferSetting_WrapLine, false);
@ -412,9 +399,9 @@ default_4coder_initialize(Application_Links *app, char **command_line_files, i32
Temp_Memory temp2 = begin_temp(scratch); Temp_Memory temp2 = begin_temp(scratch);
String_Const_u8 input_name = SCu8(command_line_files[i]); String_Const_u8 input_name = SCu8(command_line_files[i]);
String_Const_u8 file_name = push_u8_stringf(scratch, "%.*s/%.*s", string_expand(hot_directory), string_expand(input_name)); String_Const_u8 file_name = push_u8_stringf(scratch, "%.*s/%.*s", string_expand(hot_directory), string_expand(input_name));
Buffer_ID ignore = 0; Buffer_ID new_buffer = create_buffer(app, file_name, BufferCreate_NeverNew|BufferCreate_MustAttachToFile);
if (!create_buffer(app, file_name, BufferCreate_NeverNew|BufferCreate_MustAttachToFile, &ignore)){ if (new_buffer == 0){
create_buffer(app, input_name, 0, &ignore); create_buffer(app, input_name, 0);
} }
end_temp(temp2); end_temp(temp2);
} }
@ -444,15 +431,13 @@ default_4coder_side_by_side_panels(Application_Links *app, Buffer_Identifier lef
Buffer_ID right_id = buffer_identifier_to_id(app, right_buffer); Buffer_ID right_id = buffer_identifier_to_id(app, right_buffer);
// Left Panel // Left Panel
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
new_view_settings(app, view); new_view_settings(app, view);
view_set_buffer(app, view, left_id, 0); view_set_buffer(app, view, left_id, 0);
// Right Panel // Right Panel
open_panel_vsplit(app); open_panel_vsplit(app);
View_ID right_view = 0; View_ID right_view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &right_view);
view_set_buffer(app, right_view, right_id, 0); view_set_buffer(app, right_view, right_id, 0);
// Restore Active to Left // Restore Active to Left
@ -485,8 +470,7 @@ default_4coder_side_by_side_panels(Application_Links *app){
static void static void
default_4coder_one_panel(Application_Links *app, Buffer_Identifier buffer){ default_4coder_one_panel(Application_Links *app, Buffer_Identifier buffer){
Buffer_ID id = buffer_identifier_to_id(app, buffer); Buffer_ID id = buffer_identifier_to_id(app, buffer);
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
new_view_settings(app, view); new_view_settings(app, view);
view_set_buffer(app, view, id, 0); view_set_buffer(app, view, id, 0);
} }

View File

@ -29,14 +29,12 @@ START_HOOK_SIG(default_start){
#if 0 #if 0
default_4coder_one_panel(app, files, file_count); default_4coder_one_panel(app, files, file_count);
View_ID left_view = 0;
Panel_ID left = 0; Panel_ID left = 0;
Panel_ID right = 0; Panel_ID right = 0;
Panel_ID bottom = 0; Panel_ID bottom = 0;
Panel_ID header = 0; Panel_ID header = 0;
get_active_view(app, AccessAll, &left_view); View_ID left_view = get_active_view(app, AccessAll);
view_get_panel(app, left_view, &left); view_get_panel(app, left_view, &left);
@ -80,16 +78,14 @@ START_HOOK_SIG(default_start){
// NOTE(allen|a4.0.10): As of this version the word_complete command // NOTE(allen|a4.0.10): As of this version the word_complete command
// also relies on this particular command caller hook. // also relies on this particular command caller hook.
COMMAND_CALLER_HOOK(default_command_caller){ COMMAND_CALLER_HOOK(default_command_caller){
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Managed_Scope scope = 0; Managed_Scope scope = 0;
view_get_managed_scope(app, view, &scope); view_get_managed_scope(app, view, &scope);
managed_variable_set(app, scope, view_next_rewrite_loc, 0); managed_variable_set(app, scope, view_next_rewrite_loc, 0);
if (fcoder_mode == FCoderMode_NotepadLike){ if (fcoder_mode == FCoderMode_NotepadLike){
View_ID view_it = 0; for (View_ID view_it = get_view_next(app, 0, AccessAll);
for (get_view_next(app, 0, AccessAll, &view_it);
view_it != 0; view_it != 0;
get_view_next(app, view_it, AccessAll, &view_it)){ view_it = get_view_next(app, view_it, AccessAll)){
Managed_Scope scope_it = 0; Managed_Scope scope_it = 0;
view_get_managed_scope(app, view_it, &scope_it); view_get_managed_scope(app, view_it, &scope_it);
managed_variable_set(app, scope_it, view_snap_mark_to_cursor, true); managed_variable_set(app, scope_it, view_snap_mark_to_cursor, true);
@ -102,17 +98,15 @@ COMMAND_CALLER_HOOK(default_command_caller){
managed_variable_get(app, scope, view_next_rewrite_loc, &next_rewrite); managed_variable_get(app, scope, view_next_rewrite_loc, &next_rewrite);
managed_variable_set(app, scope, view_rewrite_loc, next_rewrite); managed_variable_set(app, scope, view_rewrite_loc, next_rewrite);
if (fcoder_mode == FCoderMode_NotepadLike){ if (fcoder_mode == FCoderMode_NotepadLike){
View_ID view_it = 0; for (View_ID view_it = get_view_next(app, 0, AccessAll);
for (get_view_next(app, 0, AccessAll, &view_it);
view_it != 0; view_it != 0;
get_view_next(app, view_it, AccessAll, &view_it)){ view_it = get_view_next(app, view_it, AccessAll)){
Managed_Scope scope_it = 0; Managed_Scope scope_it = 0;
view_get_managed_scope(app, view_it, &scope_it); view_get_managed_scope(app, view_it, &scope_it);
u64 val = 0; u64 val = 0;
if (managed_variable_get(app, scope_it, view_snap_mark_to_cursor, &val)){ if (managed_variable_get(app, scope_it, view_snap_mark_to_cursor, &val)){
if (val != 0){ if (val != 0){
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view_it);
view_get_cursor_pos(app, view_it, &pos);
view_set_mark(app, view_it, seek_pos(pos)); view_set_mark(app, view_it, seek_pos(pos));
} }
} }
@ -285,8 +279,7 @@ MODIFY_COLOR_TABLE_SIG(default_modify_color_table){
} }
GET_VIEW_BUFFER_REGION_SIG(default_view_buffer_region){ GET_VIEW_BUFFER_REGION_SIG(default_view_buffer_region){
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view_id, AccessAll);
view_get_buffer(app, view_id, AccessAll, &buffer);
Face_ID face_id = 0; Face_ID face_id = 0;
get_face_id(app, buffer, &face_id); get_face_id(app, buffer, &face_id);
Face_Metrics metrics = {}; Face_Metrics metrics = {};
@ -316,8 +309,7 @@ GET_VIEW_BUFFER_REGION_SIG(default_view_buffer_region){
// line number margins // line number margins
if (global_config.show_line_number_margins){ if (global_config.show_line_number_margins){
i32 line_count = 0; i32 line_count = (i32)buffer_get_line_count(app, buffer);
buffer_get_line_count(app, buffer, &line_count);
i32 line_count_digit_count = (i32)digit_count_from_integer(line_count, 10); i32 line_count_digit_count = (i32)digit_count_from_integer(line_count, 10);
i32 margin_width = ceil32((f32)line_count_digit_count*metrics.typical_character_width); i32 margin_width = ceil32((f32)line_count_digit_count*metrics.typical_character_width);
sub_region.x0 += margin_width + 2; sub_region.x0 += margin_width + 2;
@ -349,23 +341,21 @@ abs_position_from_buffer_point(Application_Links *app, View_ID view_id, Buffer_P
} }
static void static void
default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View_ID view_id, Rect_i32 view_inner_rect){ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View_ID view_id, Rect_f32 view_inner_rect){
Buffer_ID buffer_id = 0; Buffer_ID buffer = view_get_buffer(app, view_id, AccessAll);
view_get_buffer(app, view_id, AccessAll, &buffer_id);
Face_ID face_id = 0; Face_ID face_id = 0;
get_face_id(app, buffer_id, &face_id); get_face_id(app, buffer, &face_id);
Face_Metrics face_metrics = {}; Face_Metrics face_metrics = {};
get_face_metrics(app, face_id, &face_metrics); get_face_metrics(app, face_id, &face_metrics);
f32 line_height = face_metrics.line_height; f32 line_height = face_metrics.line_height;
Rect_i32 sub_region = i32R(0, 0, rect_width(view_inner_rect), rect_height(view_inner_rect)); Rect_f32 sub_region = Rf32(V2(0, 0), rect_dim(view_inner_rect));
sub_region = default_view_buffer_region(app, view_id, sub_region); sub_region = default_view_buffer_region(app, view_id, sub_region);
Rect_f32 buffer_rect = {}; Rect_f32 buffer_rect = Rf32(V2(view_inner_rect.p0 + sub_region.p0),
buffer_rect.p0 = V2(view_inner_rect.p0 + sub_region.p0); V2(view_inner_rect.p0 + sub_region.p1));
buffer_rect.p1 = V2(view_inner_rect.p0 + sub_region.p1); buffer_rect = rect_intersect(buffer_rect, view_inner_rect);
buffer_rect = intersection_of(buffer_rect, f32R(view_inner_rect));
GUI_Scroll_Vars scroll = {}; GUI_Scroll_Vars scroll = {};
view_get_scroll_vars(app, view_id, &scroll); view_get_scroll_vars(app, view_id, &scroll);
@ -373,14 +363,13 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
Buffer_Point buffer_point = buffer_position_from_scroll_position(app, view_id, scroll.scroll_p); Buffer_Point buffer_point = buffer_position_from_scroll_position(app, view_id, scroll.scroll_p);
Text_Layout_ID text_layout_id = 0; Text_Layout_ID text_layout_id = 0;
compute_render_layout(app, view_id, buffer_id, buffer_rect.p0, rect_dim(buffer_rect), buffer_point, compute_render_layout(app, view_id, buffer, buffer_rect.p0, rect_dim(buffer_rect), buffer_point,
max_i32, &text_layout_id); max_i32, &text_layout_id);
Range on_screen_range = {}; Range on_screen_range = {};
text_layout_get_on_screen_range(app, text_layout_id, &on_screen_range); text_layout_get_on_screen_range(app, text_layout_id, &on_screen_range);
text_layout_free(app, text_layout_id); text_layout_free(app, text_layout_id);
View_ID active_view = 0; View_ID active_view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &active_view);
b32 is_active_view = (active_view == view_id); b32 is_active_view = (active_view == view_id);
Scratch_Block scratch(app); Scratch_Block scratch(app);
@ -391,8 +380,7 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
} }
{ {
Rect_f32 r_cursor = {}; Rect_f32 r_cursor = view_get_screen_rect(app, view_id);
view_get_screen_rect(app, view_id, &r_cursor);
r_cursor.p1 -= r_cursor.p0; r_cursor.p1 -= r_cursor.p0;
r_cursor.p0 = V2(0.f,0.f); r_cursor.p0 = V2(0.f,0.f);
@ -412,18 +400,17 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
i32 cursor_position = 0; i32 cursor_position = view_get_cursor_pos(app, view_id);
view_get_cursor_pos(app, view_id, &cursor_position);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, view_id, seek_pos(cursor_position), &cursor); view_compute_cursor(app, view_id, seek_pos(cursor_position), &cursor);
Fancy_String_List list = {}; Fancy_String_List list = {};
String_Const_u8 unique_name = push_buffer_unique_name(app, scratch, buffer_id); String_Const_u8 unique_name = push_buffer_unique_name(app, scratch, buffer);
push_fancy_string(scratch, &list, base_color, unique_name); push_fancy_string(scratch, &list, base_color, unique_name);
push_fancy_stringf(scratch, &list, base_color, " - Row: %3.d Col: %3.d -", cursor.line, cursor.character); push_fancy_stringf(scratch, &list, base_color, " - Row: %3.d Col: %3.d -", cursor.line, cursor.character);
b32 is_dos_mode = false; b32 is_dos_mode = false;
if (buffer_get_setting(app, buffer_id, BufferSetting_Eol, &is_dos_mode)){ if (buffer_get_setting(app, buffer, BufferSetting_Eol, &is_dos_mode)){
if (is_dos_mode){ if (is_dos_mode){
push_fancy_string(scratch, &list, base_color, string_u8_litexpr(" dos")); push_fancy_string(scratch, &list, base_color, string_u8_litexpr(" dos"));
} }
@ -436,8 +423,7 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
} }
{ {
Dirty_State dirty = 0; Dirty_State dirty = buffer_get_dirty_state(app, buffer);
buffer_get_dirty_state(app, buffer_id, &dirty);
u8 space[3]; u8 space[3];
String_u8 str = Su8(space, 0, 3); String_u8 str = Su8(space, 0, 3);
if (dirty != 0){ if (dirty != 0){
@ -492,8 +478,7 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
// NOTE(allen): Line Numbers // NOTE(allen): Line Numbers
if (global_config.show_line_number_margins){ if (global_config.show_line_number_margins){
i32 line_count = 0; i32 line_count = (i32)buffer_get_line_count(app, buffer);
buffer_get_line_count(app, buffer_id, &line_count);
i32 line_count_digit_count = (i32)digit_count_from_integer(line_count, 10); i32 line_count_digit_count = (i32)digit_count_from_integer(line_count, 10);
// TODO(allen): I need a "digit width" // TODO(allen): I need a "digit width"
f32 zero = get_string_advance(app, face_id, string_u8_litexpr("0")); f32 zero = get_string_advance(app, face_id, string_u8_litexpr("0"));
@ -534,7 +519,7 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
// NOTE(allen): Scan for TODOs and NOTEs // NOTE(allen): Scan for TODOs and NOTEs
{ {
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
String_Const_u8 tail = push_buffer_range(app, scratch, buffer_id, on_screen_range); String_Const_u8 tail = push_buffer_range(app, scratch, buffer, on_screen_range);
Highlight_Record *record_first = 0; Highlight_Record *record_first = 0;
Highlight_Record *record_last = 0; Highlight_Record *record_last = 0;
@ -589,7 +574,7 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
b32 do_emit = (i == record_count || records[i].color != current_color); b32 do_emit = (i == record_count || records[i].color != current_color);
if (do_emit){ if (do_emit){
i32 marker_count = marker_index - marker_index_first; i32 marker_count = marker_index - marker_index_first;
Managed_Object o = alloc_buffer_markers_on_buffer(app, buffer_id, marker_count, &render_scope); Managed_Object o = alloc_buffer_markers_on_buffer(app, buffer, marker_count, &render_scope);
managed_object_store_data(app, o, 0, marker_count, markers + marker_index_first); managed_object_store_data(app, o, 0, marker_count, markers + marker_index_first);
Marker_Visual v = create_marker_visual(app, o); Marker_Visual v = create_marker_visual(app, o);
marker_visual_set_effect(app, v, VisualType_CharacterHighlightRanges, SymbolicColor_Default, current_color, 0); marker_visual_set_effect(app, v, VisualType_CharacterHighlightRanges, SymbolicColor_Default, current_color, 0);
@ -610,12 +595,10 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
} }
// NOTE(allen): Cursor and mark // NOTE(allen): Cursor and mark
i32 cursor_pos = 0; i32 cursor_pos = view_get_cursor_pos(app, view_id);
i32 mark_pos = 0; i32 mark_pos = view_get_mark_pos(app, view_id);
view_get_cursor_pos(app, view_id, &cursor_pos);
view_get_mark_pos(app, view_id, &mark_pos);
Managed_Object cursor_and_mark = alloc_buffer_markers_on_buffer(app, buffer_id, 2, &render_scope); Managed_Object cursor_and_mark = alloc_buffer_markers_on_buffer(app, buffer, 2, &render_scope);
Marker cm_markers[2] = {}; Marker cm_markers[2] = {};
cm_markers[0].pos = cursor_pos; cm_markers[0].pos = cursor_pos;
cm_markers[1].pos = mark_pos; cm_markers[1].pos = mark_pos;
@ -695,9 +678,9 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
Boundary_Function_List funcs = push_boundary_list(scratch, boundary_token, boundary_non_whitespace); Boundary_Function_List funcs = push_boundary_list(scratch, boundary_token, boundary_non_whitespace);
Range snipe_range = get_snipe_range(app, funcs, buffer_id, cursor_pos, Scan_Backward); Range snipe_range = get_snipe_range(app, funcs, buffer, cursor_pos, Scan_Backward);
if (range_size(snipe_range) > 0){ if (range_size(snipe_range) > 0){
Managed_Object token_highlight = alloc_buffer_markers_on_buffer(app, buffer_id, 2, &render_scope); Managed_Object token_highlight = alloc_buffer_markers_on_buffer(app, buffer, 2, &render_scope);
Marker range_markers[2] = {}; Marker range_markers[2] = {};
range_markers[0].pos = snipe_range.min; range_markers[0].pos = snipe_range.min;
range_markers[1].pos = snipe_range.max; range_markers[1].pos = snipe_range.max;
@ -715,15 +698,15 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
for (u16 i = 0; i < color_count; i += 1){ for (u16 i = 0; i < color_count; i += 1){
colors[i] = Stag_Back_Cycle_1 + i; colors[i] = Stag_Back_Cycle_1 + i;
} }
mark_enclosures(app, render_scope, buffer_id, cursor_pos, FindScope_Brace, VisualType_LineHighlightRanges, colors, 0, color_count); mark_enclosures(app, render_scope, buffer, cursor_pos, FindScope_Brace, VisualType_LineHighlightRanges, colors, 0, color_count);
} }
if (do_matching_paren_highlight){ if (do_matching_paren_highlight){
i32 pos = cursor_pos; i32 pos = cursor_pos;
if (buffer_get_char(app, buffer_id, pos) == '('){ if (buffer_get_char(app, buffer, pos) == '('){
pos += 1; pos += 1;
} }
else if (pos > 0){ else if (pos > 0){
if (buffer_get_char(app, buffer_id, pos - 1) == ')'){ if (buffer_get_char(app, buffer, pos - 1) == ')'){
pos -= 1; pos -= 1;
} }
} }
@ -731,7 +714,7 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
for (u16 i = 0; i < color_count; i += 1){ for (u16 i = 0; i < color_count; i += 1){
colors[i] = Stag_Text_Cycle_1 + i; colors[i] = Stag_Text_Cycle_1 + i;
} }
mark_enclosures(app, render_scope, buffer_id, pos, FindScope_Paren, VisualType_CharacterBlocks, 0, colors, color_count); mark_enclosures(app, render_scope, buffer, pos, FindScope_Paren, VisualType_CharacterBlocks, 0, colors, color_count);
} }
draw_clip_push(app, buffer_rect); draw_clip_push(app, buffer_rect);
@ -750,8 +733,7 @@ default_buffer_render_caller(Application_Links *app, Frame_Info frame_info, View
history_animation_dt[wrapped_index] = frame_info.animation_dt; history_animation_dt[wrapped_index] = frame_info.animation_dt;
history_frame_index[wrapped_index] = frame_info.index; history_frame_index[wrapped_index] = frame_info.index;
Rect_f32 hud_rect = {}; Rect_f32 hud_rect = view_get_screen_rect(app, view_id);
view_get_screen_rect(app, view_id, &hud_rect);
hud_rect.p1 -= hud_rect.p0; hud_rect.p1 -= hud_rect.p0;
hud_rect.p0 = V2(0.f, 0.f); hud_rect.p0 = V2(0.f, 0.f);
hud_rect.y0 = hud_rect.y1 - line_height*(f32)(history_depth); hud_rect.y0 = hud_rect.y1 - line_height*(f32)(history_depth);
@ -871,83 +853,74 @@ default_ui_render_caller(Application_Links *app, View_ID view_id, Rect_f32 rect_
} }
static void static void
default_ui_render_caller(Application_Links *app, View_ID view_id, Rect_f32 rect_f32){ default_ui_render_caller(Application_Links *app, View_ID view_id, Rect_f32 rect_f32){
Buffer_ID buffer_id = 0; Buffer_ID buffer = view_get_buffer(app, view_id, AccessAll);
view_get_buffer(app, view_id, AccessAll, &buffer_id);
Face_ID face_id = 0; Face_ID face_id = 0;
get_face_id(app, buffer_id, &face_id); get_face_id(app, buffer, &face_id);
default_ui_render_caller(app, view_id, rect_f32, face_id); default_ui_render_caller(app, view_id, rect_f32, face_id);
} }
static void static void
default_ui_render_caller(Application_Links *app, View_ID view_id, Face_ID face_id){ default_ui_render_caller(Application_Links *app, View_ID view_id, Face_ID face_id){
Rect_f32 rect = {}; Rect_f32 rect = view_get_screen_rect(app, view_id);
view_get_screen_rect(app, view_id, &rect);
rect.p1 -= rect.p0; rect.p1 -= rect.p0;
rect.p0 = V2(0.f,0.f); rect.p0 = V2(0.f,0.f);
default_ui_render_caller(app, view_id, rect, face_id); default_ui_render_caller(app, view_id, rect, face_id);
} }
static void static void
default_ui_render_caller(Application_Links *app, View_ID view_id){ default_ui_render_caller(Application_Links *app, View_ID view){
Rect_f32 rect = {}; Rect_f32 rect = view_get_screen_rect(app, view);
view_get_screen_rect(app, view_id, &rect);
rect.p1 -= rect.p0; rect.p1 -= rect.p0;
rect.p0 = V2(0.f,0.f); rect.p0 = V2(0.f,0.f);
Buffer_ID buffer_id = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessAll);
view_get_buffer(app, view_id, AccessAll, &buffer_id);
Face_ID face_id = 0; Face_ID face_id = 0;
get_face_id(app, buffer_id, &face_id); get_face_id(app, buffer, &face_id);
default_ui_render_caller(app, view_id, rect, face_id); default_ui_render_caller(app, view, rect, face_id);
} }
static void static void
default_render_view(Application_Links *app, Frame_Info frame_info, View_ID view_id, b32 is_active){ default_render_view(Application_Links *app, Frame_Info frame_info, View_ID view, b32 is_active){
Rect_i32 view_rect = {}; Rect_f32 view_rect = view_get_screen_rect(app, view);
view_get_region(app, view_id, &view_rect); Rect_f32 inner = rect_inner(view_rect, 3);
Rect_i32 inner = rect_inner(view_rect, 3); draw_rectangle(app, view_rect, get_margin_color(is_active?UIActivation_Active:UIActivation_None));
draw_rectangle(app, f32R(view_rect), get_margin_color(is_active?UIActivation_Active:UIActivation_None)); draw_rectangle(app, inner, Stag_Back);
draw_rectangle(app, f32R(inner), Stag_Back); draw_clip_push(app, inner);
draw_clip_push(app, f32R(inner)); draw_coordinate_center_push(app, inner.p0);
draw_coordinate_center_push(app, V2(inner.p0)); if (view_is_in_ui_mode(app, view)){
if (view_is_in_ui_mode(app, view_id)){ default_ui_render_caller(app, view);
default_ui_render_caller(app, view_id);
} }
else{ else{
default_buffer_render_caller(app, frame_info, view_id, inner); default_buffer_render_caller(app, frame_info, view, inner);
} }
draw_clip_pop(app); draw_clip_pop(app);
draw_coordinate_center_pop(app); draw_coordinate_center_pop(app);
} }
RENDER_CALLER_SIG(default_render_caller){ RENDER_CALLER_SIG(default_render_caller){
View_ID active_view_id = 0; View_ID active_view_id = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &active_view_id); for (View_ID view_id = get_view_next(app, 0, AccessAll);
View_ID view_id = 0;
for (get_view_next(app, 0, AccessAll, &view_id);
view_id != 0; view_id != 0;
get_view_next(app, view_id, AccessAll, &view_id)){ view_id = get_view_next(app, view_id, AccessAll)){
default_render_view(app, frame_info, view_id, (active_view_id == view_id)); default_render_view(app, frame_info, view_id, (active_view_id == view_id));
} }
} }
HOOK_SIG(default_exit){ HOOK_SIG(default_exit){
// If this returns zero it cancels the exit.
i32 result = 1; i32 result = 1;
// If this returns zero it cancels the exit.
if (!allow_immediate_close_without_checking_for_changes){ if (!allow_immediate_close_without_checking_for_changes){
b32 has_unsaved_changes = false; b32 has_unsaved_changes = false;
Buffer_ID buffer = 0; for (Buffer_ID buffer = get_buffer_next(app, 0, AccessAll);
for (get_buffer_next(app, 0, AccessAll, &buffer);
buffer != 0; buffer != 0;
get_buffer_next(app, buffer, AccessAll, &buffer)){ buffer = get_buffer_next(app, buffer, AccessAll)){
Dirty_State dirty = 0; Dirty_State dirty = buffer_get_dirty_state(app, buffer);
buffer_get_dirty_state(app, buffer, &dirty);
if (HasFlag(dirty, DirtyState_UnsavedChanges)){ if (HasFlag(dirty, DirtyState_UnsavedChanges)){
has_unsaved_changes = true; has_unsaved_changes = true;
break; break;
} }
} }
if (has_unsaved_changes){ if (has_unsaved_changes){
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
do_gui_sure_to_close_4coder(app, view); do_gui_sure_to_close_4coder(app, view);
result = 0; result = 0;
} }
@ -959,15 +932,12 @@ HOOK_SIG(default_exit){
// TODO(allen): how to deal with multiple sizes on a single view // TODO(allen): how to deal with multiple sizes on a single view
// TODO(allen): expected character advance. // TODO(allen): expected character advance.
HOOK_SIG(default_view_adjust){ HOOK_SIG(default_view_adjust){
View_ID view = 0; for (View_ID view = get_view_next(app, 0, AccessAll);
for (get_view_next(app, 0, AccessAll, &view);
view != 0; view != 0;
get_view_next(app, view, AccessAll, &view)){ view = get_view_next(app, view, AccessAll)){
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessAll);
view_get_buffer(app, view, AccessAll, &buffer);
Rect_f32 screen_rect = {}; Rect_f32 screen_rect = view_get_screen_rect(app, view);
view_get_screen_rect(app, view, &screen_rect);
f32 view_width = rect_width(screen_rect); f32 view_width = rect_width(screen_rect);
Face_ID face_id = 0; Face_ID face_id = 0;
@ -1111,8 +1081,7 @@ OPEN_FILE_HOOK_SIG(default_file_settings){
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
String_Const_u8 file_name = push_buffer_file_name(app, scratch, buffer_id); String_Const_u8 file_name = push_buffer_file_name(app, scratch, buffer_id);
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer_id);
buffer_get_size(app, buffer_id, &buffer_size);
if (file_name.size > 0 && buffer_size < MB(32)){ if (file_name.size > 0 && buffer_size < MB(32)){
String_Const_u8 ext = string_file_extension(file_name); String_Const_u8 ext = string_file_extension(file_name);
@ -1242,12 +1211,11 @@ OPEN_FILE_HOOK_SIG(default_new_file){
} }
OPEN_FILE_HOOK_SIG(default_file_save){ OPEN_FILE_HOOK_SIG(default_file_save){
i32 is_virtual = 0; b32 is_virtual = false;
if (global_config.automatically_indent_text_on_save && if (global_config.automatically_indent_text_on_save &&
buffer_get_setting(app, buffer_id, BufferSetting_VirtualWhitespace, &is_virtual)){ buffer_get_setting(app, buffer_id, BufferSetting_VirtualWhitespace, &is_virtual)){
if (is_virtual){ if (is_virtual){
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer_id);
buffer_get_size(app, buffer_id, &buffer_size);
buffer_auto_indent(app, buffer_id, 0, buffer_size, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens); buffer_auto_indent(app, buffer_id, 0, buffer_size, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens);
} }
} }

View File

@ -21,13 +21,10 @@ get_line_y(Application_Links *app, View_ID view, i32 line){
static Rect_i32 static Rect_i32
get_line_x_rect(Application_Links *app, View_ID view){ get_line_x_rect(Application_Links *app, View_ID view){
i32 cursor_pos = 0; i32 cursor_pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &cursor_pos);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, view, seek_pos(cursor_pos), &cursor); view_compute_cursor(app, view, seek_pos(cursor_pos), &cursor);
i32 mark_pos = view_get_mark_pos(app, view);
i32 mark_pos = 0;
view_get_mark_pos(app, view, &mark_pos);
Full_Cursor mark = {}; Full_Cursor mark = {};
view_compute_cursor(app, view, seek_pos(mark_pos), &mark); view_compute_cursor(app, view, seek_pos(mark_pos), &mark);
@ -50,10 +47,8 @@ get_line_x_rect(Application_Links *app, View_ID view){
CUSTOM_COMMAND_SIG(kill_rect) CUSTOM_COMMAND_SIG(kill_rect)
CUSTOM_DOC("Delete characters in a rectangular region. Range testing is done by unwrapped-xy coordinates.") CUSTOM_DOC("Delete characters in a rectangular region. Range testing is done by unwrapped-xy coordinates.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
i32_Rect rect = get_line_x_rect(app, view); i32_Rect rect = get_line_x_rect(app, view);
@ -72,21 +67,16 @@ CUSTOM_DOC("Delete characters in a rectangular region. Range testing is done by
static void static void
pad_buffer_line(Application_Links *app, Buffer_ID buffer, i32 line, char padchar, i32 target){ pad_buffer_line(Application_Links *app, Buffer_ID buffer, i32 line, char padchar, i32 target){
Partial_Cursor start = {}; Partial_Cursor start = buffer_compute_cursor(app, buffer, seek_line_char(line, 1));
Partial_Cursor end = {}; if (start.line == line){
Partial_Cursor end = buffer_compute_cursor(app, buffer, seek_line_char(line, 65536));
if (buffer_compute_cursor(app, buffer, seek_line_char(line, 1), &start)){ if (end.line == line){
if (buffer_compute_cursor(app, buffer, seek_line_char(line, 65536), &end)){ if (end.character - 1 < target){
if (start.line == line){ Scratch_Block scratch(app);
if (end.character-1 < target){ i32 size = target - (end.character - 1);
Arena *scratch = context_get_arena(app); char *str = push_array(scratch, char, size);
Temp_Memory temp = begin_temp(scratch); block_fill_u8(str, size, ' ');
i32 size = target - (end.character - 1); buffer_replace_range(app, buffer, make_range(end.pos), SCu8(str, size));
char *str = push_array(scratch, char, size);
block_fill_u8(str, size, ' ');
buffer_replace_range(app, buffer, make_range(end.pos), SCu8(str, size));
end_temp(temp);
}
} }
} }
} }
@ -137,17 +127,13 @@ struct Buffer_Rect{
CUSTOM_COMMAND_SIG(multi_line_edit) CUSTOM_COMMAND_SIG(multi_line_edit)
CUSTOM_DOC("Begin multi-line mode. In multi-line mode characters are inserted at every line between the mark and cursor. All characters are inserted at the same character offset into the line. This mode uses line_char coordinates.") CUSTOM_DOC("Begin multi-line mode. In multi-line mode characters are inserted at every line between the mark and cursor. All characters are inserted at the same character offset into the line. This mode uses line_char coordinates.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
i32 cursor_pos = 0; i32 cursor_pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &cursor_pos);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, view, seek_pos(cursor_pos), &cursor); view_compute_cursor(app, view, seek_pos(cursor_pos), &cursor);
i32 mark_pos = 0; i32 mark_pos = view_get_mark_pos(app, view);
view_get_mark_pos(app, view, &mark_pos);
Full_Cursor mark = {}; Full_Cursor mark = {};
view_compute_cursor(app, view, seek_pos(mark_pos), &mark); view_compute_cursor(app, view, seek_pos(mark_pos), &mark);
Buffer_Rect rect = {}; Buffer_Rect rect = {};
@ -178,18 +164,17 @@ CUSTOM_DOC("Begin multi-line mode. In multi-line mode characters are inserted a
if (in.key.character && key_is_unmodified(&in.key)){ if (in.key.character && key_is_unmodified(&in.key)){
char str = (char)in.key.character; char str = (char)in.key.character;
Arena *scratch = context_get_arena(app); Scratch_Block scratch(app);
Temp_Memory temp = begin_temp(scratch); Buffer_Edit *edits = push_array(scratch, Buffer_Edit, line_count);
Buffer_Edit *edit = push_array(scratch, Buffer_Edit, line_count); Buffer_Edit *edit = edits;
Buffer_Edit *edits = edit;
for (i32 i = rect.line0; i <= rect.line1; ++i){ for (i32 i = rect.line0; i <= rect.line1; ++i){
Partial_Cursor partial_cursor = {}; Partial_Cursor partial_cursor = buffer_compute_cursor(app, buffer, seek_line_char(i, pos + 1));
if (buffer_compute_cursor(app, buffer, seek_line_char(i, pos + 1), &partial_cursor)){ if (partial_cursor.line > 0){
edit->str_start = 0; edit->str_start = 0;
edit->len = 1; edit->len = 1;
edit->start = cursor.pos; edit->start = partial_cursor.pos;
edit->end = cursor.pos; edit->end = partial_cursor.pos;
++edit; ++edit;
} }
} }
@ -197,26 +182,23 @@ CUSTOM_DOC("Begin multi-line mode. In multi-line mode characters are inserted a
i32 edit_count = (int)(edit - edits); i32 edit_count = (int)(edit - edits);
buffer_batch_edit(app, buffer, &str, edits, edit_count); buffer_batch_edit(app, buffer, &str, edits, edit_count);
end_temp(temp);
++pos; ++pos;
view_set_cursor(app, view, seek_line_char(start_line, pos + 1), true); view_set_cursor(app, view, seek_line_char(start_line, pos + 1), true);
} }
else if (in.key.keycode == key_back){ else if (in.key.keycode == key_back){
if (pos > 0){ if (pos > 0){
Arena *scratch = context_get_arena(app); Scratch_Block scratch(app);
Temp_Memory temp = begin_temp(scratch); Buffer_Edit *edits = push_array(scratch, Buffer_Edit, line_count);
Buffer_Edit *edit = push_array(scratch, Buffer_Edit, line_count); Buffer_Edit *edit = edits;
Buffer_Edit *edits = edit;
for (i32 i = rect.line0; i <= rect.line1; ++i){ for (i32 i = rect.line0; i <= rect.line1; ++i){
Partial_Cursor partial_cursor = {}; Partial_Cursor partial_cursor = buffer_compute_cursor(app, buffer, seek_line_char(i, pos + 1));
if (buffer_compute_cursor(app, buffer, seek_line_char(i, pos + 1), &partial_cursor)){ if (partial_cursor.line > 0){
edit->str_start = 0; edit->str_start = 0;
edit->len = 0; edit->len = 0;
edit->start = cursor.pos-1; edit->start = partial_cursor.pos - 1;
edit->end = cursor.pos; edit->end = partial_cursor.pos;
++edit; ++edit;
} }
} }
@ -224,8 +206,6 @@ CUSTOM_DOC("Begin multi-line mode. In multi-line mode characters are inserted a
i32 edit_count = (int)(edit - edits); i32 edit_count = (int)(edit - edits);
buffer_batch_edit(app, buffer, 0, edits, edit_count); buffer_batch_edit(app, buffer, 0, edits, edit_count);
end_temp(temp);
--pos; --pos;
} }
} }
@ -240,11 +220,9 @@ CUSTOM_DOC("Begin multi-line mode. In multi-line mode characters are inserted a
CUSTOM_COMMAND_SIG(multi_paste){ CUSTOM_COMMAND_SIG(multi_paste){
Scratch_Block scratch(app); Scratch_Block scratch(app);
i32 count = 0; i32 count = clipboard_count(app, 0);
clipboard_count(app, 0, &count);
if (count > 0){ if (count > 0){
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view);
Managed_Scope scope = 0; Managed_Scope scope = 0;
view_get_managed_scope(app, view, &scope); view_get_managed_scope(app, view, &scope);
@ -257,13 +235,11 @@ CUSTOM_COMMAND_SIG(multi_paste){
i32 paste_index = (i32)prev_paste_index + 1; i32 paste_index = (i32)prev_paste_index + 1;
managed_variable_set(app, scope, view_paste_index_loc, paste_index); managed_variable_set(app, scope, view_paste_index_loc, paste_index);
String_Const_u8 string = {}; String_Const_u8 string = push_clipboard_index(app, scratch, 0, paste_index);
clipboard_index(app, 0, paste_index, scratch, &string);
String_Const_u8 insert_string = push_u8_stringf(scratch, "\n%.*s", string_expand(string)); String_Const_u8 insert_string = push_u8_stringf(scratch, "\n%.*s", string_expand(string));
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
view_get_buffer(app, view, AccessOpen, &buffer);
Range range = get_view_range(app, view); Range range = get_view_range(app, view);
buffer_replace_range(app, buffer, make_range(range.max), insert_string); buffer_replace_range(app, buffer, make_range(range.max), insert_string);
view_set_mark(app, view, seek_pos(range.max + 1)); view_set_mark(app, view, seek_pos(range.max + 1));
@ -287,8 +263,8 @@ multi_paste_range(Application_Links *app, View_ID view, Range range, i32 paste_c
Range finish_range = range; Range finish_range = range;
if (paste_count >= 1){ if (paste_count >= 1){
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
if (view_get_buffer(app, view, AccessOpen, &buffer)){ if (buffer != 0){
i32 total_size = 0; i32 total_size = 0;
for (i32 paste_index = 0; paste_index < paste_count; ++paste_index){ for (i32 paste_index = 0; paste_index < paste_count; ++paste_index){
total_size += 1 + clipboard_index(app, 0, paste_index, 0, 0); total_size += 1 + clipboard_index(app, 0, paste_index, 0, 0);
@ -311,8 +287,8 @@ multi_paste_range(Application_Links *app, View_ID view, Range range, i32 paste_c
if (paste_index != first){ if (paste_index != first){
string_list_push(scratch, &list, SCu8("\n", 1)); string_list_push(scratch, &list, SCu8("\n", 1));
} }
String_Const_u8 string = {}; String_Const_u8 string = push_clipboard_index(app, scratch, 0, paste_index);
if (clipboard_index(app, 0, paste_index, scratch, &string)){ if (string.size > 0){
string_list_push(scratch, &list, string); string_list_push(scratch, &list, string);
} }
} }
@ -339,10 +315,8 @@ multi_paste_range(Application_Links *app, View_ID view, Range range, i32 paste_c
static void static void
multi_paste_interactive_up_down(Application_Links *app, i32 paste_count, i32 clip_count){ multi_paste_interactive_up_down(Application_Links *app, i32 paste_count, i32 clip_count){
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); i32 pos = view_get_cursor_pos(app, view);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
Range range = make_range(pos);; Range range = make_range(pos);;
@ -386,23 +360,20 @@ multi_paste_interactive_up_down(Application_Links *app, i32 paste_count, i32 cli
} }
if (in.abort){ if (in.abort){
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
view_get_buffer(app, view, AccessOpen, &buffer);
buffer_replace_range(app, buffer, range, SCu8("")); buffer_replace_range(app, buffer, range, SCu8(""));
} }
} }
CUSTOM_COMMAND_SIG(multi_paste_interactive){ CUSTOM_COMMAND_SIG(multi_paste_interactive){
i32 clip_count = 0; i32 clip_count = clipboard_count(app, 0);
clipboard_count(app, 0, &clip_count);
if (clip_count > 0){ if (clip_count > 0){
multi_paste_interactive_up_down(app, 1, clip_count); multi_paste_interactive_up_down(app, 1, clip_count);
} }
} }
CUSTOM_COMMAND_SIG(multi_paste_interactive_quick){ CUSTOM_COMMAND_SIG(multi_paste_interactive_quick){
i32 clip_count = 0; i32 clip_count = clipboard_count(app, 0);
clipboard_count(app, 0, &clip_count);
if (clip_count > 0){ if (clip_count > 0){
u8 string_space[256]; u8 string_space[256];
Query_Bar bar = {}; Query_Bar bar = {};
@ -424,19 +395,17 @@ CUSTOM_COMMAND_SIG(multi_paste_interactive_quick){
CUSTOM_COMMAND_SIG(rename_parameter) CUSTOM_COMMAND_SIG(rename_parameter)
CUSTOM_DOC("If the cursor is found to be on the name of a function parameter in the signature of a function definition, all occurences within the scope of the function will be replaced with a new provided string.") CUSTOM_DOC("If the cursor is found to be on the name of a function parameter in the signature of a function definition, all occurences within the scope of the function will be replaced with a new provided string.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; i32 cursor_pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessOpen, &buffer);
i32 cursor_pos = 0;
view_get_cursor_pos(app, view, &cursor_pos);
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
Cpp_Get_Token_Result result; Cpp_Get_Token_Result result = {};
if (buffer_get_token_index(app, buffer, cursor_pos, &result)){ if (get_token_from_pos(app, buffer, cursor_pos, &result)){
if (!result.in_whitespace_after_token){ if (!result.in_whitespace_after_token){
#if 0
static const i32 stream_space_size = 512; static const i32 stream_space_size = 512;
Cpp_Token stream_space[stream_space_size]; Cpp_Token stream_space[stream_space_size];
Stream_Tokens_DEP stream = {}; Stream_Tokens_DEP stream = {};
@ -557,6 +526,7 @@ CUSTOM_DOC("If the cursor is found to be on the name of a function parameter in
} }
} }
} }
#endif
} }
} }
@ -571,20 +541,18 @@ enum{
static void static void
write_explicit_enum_values_parameters(Application_Links *app, Write_Explicit_Enum_Values_Mode mode){ write_explicit_enum_values_parameters(Application_Links *app, Write_Explicit_Enum_Values_Mode mode){
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
Cpp_Get_Token_Result result; Cpp_Get_Token_Result result = {};
if (buffer_get_token_index(app, buffer, pos, &result)){ if (get_token_from_pos(app, buffer, pos, &result)){
if (!result.in_whitespace_after_token){ if (!result.in_whitespace_after_token){
#if 0
Cpp_Token stream_space[32]; Cpp_Token stream_space[32];
Stream_Tokens_DEP stream = {}; Stream_Tokens_DEP stream = {};
@ -724,6 +692,7 @@ write_explicit_enum_values_parameters(Application_Links *app, Write_Explicit_Enu
} }
} }
} }
#endif
} }
} }

View File

@ -202,18 +202,16 @@ static void
list_all_functions(Application_Links *app, Buffer_ID optional_target_buffer){ list_all_functions(Application_Links *app, Buffer_ID optional_target_buffer){
// TODO(allen): Use create or switch to buffer and clear here? // TODO(allen): Use create or switch to buffer and clear here?
String_Const_u8 decls_name = string_u8_litexpr("*decls*"); String_Const_u8 decls_name = string_u8_litexpr("*decls*");
Buffer_ID decls_buffer = 0; Buffer_ID decls_buffer = get_buffer_by_name(app, decls_name, AccessAll);
get_buffer_by_name(app, decls_name, AccessAll, &decls_buffer);
if (!buffer_exists(app, decls_buffer)){ if (!buffer_exists(app, decls_buffer)){
create_buffer(app, decls_name, BufferCreate_AlwaysNew, &decls_buffer); decls_buffer = create_buffer(app, decls_name, BufferCreate_AlwaysNew);
buffer_set_setting(app, decls_buffer, BufferSetting_Unimportant, true); buffer_set_setting(app, decls_buffer, BufferSetting_Unimportant, true);
buffer_set_setting(app, decls_buffer, BufferSetting_ReadOnly, true); buffer_set_setting(app, decls_buffer, BufferSetting_ReadOnly, true);
buffer_set_setting(app, decls_buffer, BufferSetting_WrapLine, false); buffer_set_setting(app, decls_buffer, BufferSetting_WrapLine, false);
} }
else{ else{
buffer_send_end_signal(app, decls_buffer); buffer_send_end_signal(app, decls_buffer);
i32 size = 0; i32 size = (i32)buffer_get_size(app, decls_buffer);
buffer_get_size(app, decls_buffer, &size);
buffer_replace_range(app, decls_buffer, make_range(0, size), string_u8_litexpr("")); buffer_replace_range(app, decls_buffer, make_range(0, size), string_u8_litexpr(""));
} }
@ -227,10 +225,9 @@ list_all_functions(Application_Links *app, Buffer_ID optional_target_buffer){
Cursor insertion_cursor = make_cursor(push_array(scratch, u8, KB(256)), KB(256)); Cursor insertion_cursor = make_cursor(push_array(scratch, u8, KB(256)), KB(256));
Buffer_Insertion out = begin_buffer_insertion_at_buffered(app, decls_buffer, 0, &insertion_cursor); Buffer_Insertion out = begin_buffer_insertion_at_buffered(app, decls_buffer, 0, &insertion_cursor);
Buffer_ID buffer_it = 0; for (Buffer_ID buffer_it = get_buffer_next(app, 0, AccessAll);
for (get_buffer_next(app, 0, AccessAll, &buffer_it);
buffer_it != 0; buffer_it != 0;
get_buffer_next(app, buffer_it, AccessAll, &buffer_it)){ buffer_it = get_buffer_next(app, buffer_it, AccessAll)){
Buffer_ID buffer = buffer_it; Buffer_ID buffer = buffer_it;
if (optional_target_buffer != 0){ if (optional_target_buffer != 0){
buffer = optional_target_buffer; buffer = optional_target_buffer;
@ -260,8 +257,7 @@ list_all_functions(Application_Links *app, Buffer_ID optional_target_buffer){
end_buffer_insertion(&out); end_buffer_insertion(&out);
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view_set_buffer(app, view, decls_buffer, 0); view_set_buffer(app, view, decls_buffer, 0);
lock_jump_buffer(decls_name); lock_jump_buffer(decls_name);
@ -273,11 +269,9 @@ list_all_functions(Application_Links *app, Buffer_ID optional_target_buffer){
CUSTOM_COMMAND_SIG(list_all_functions_current_buffer) CUSTOM_COMMAND_SIG(list_all_functions_current_buffer)
CUSTOM_DOC("Creates a jump list of lines of the current buffer that appear to define or declare functions.") CUSTOM_DOC("Creates a jump list of lines of the current buffer that appear to define or declare functions.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0; if (buffer != 0){
view_get_buffer(app, view, AccessProtected, &buffer);
if (buffer_exists(app, buffer)){
list_all_functions(app, buffer); list_all_functions(app, buffer);
} }
} }
@ -285,13 +279,11 @@ CUSTOM_DOC("Creates a jump list of lines of the current buffer that appear to de
CUSTOM_COMMAND_SIG(list_all_functions_current_buffer_lister) CUSTOM_COMMAND_SIG(list_all_functions_current_buffer_lister)
CUSTOM_DOC("Creates a lister of locations that look like function definitions and declarations in the buffer.") CUSTOM_DOC("Creates a lister of locations that look like function definitions and declarations in the buffer.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0; if (buffer != 0){
view_get_buffer(app, view, AccessProtected, &buffer);
if (buffer_exists(app, buffer)){
list_all_functions(app, buffer); list_all_functions(app, buffer);
get_active_view(app, AccessAll, &view); view = get_active_view(app, AccessAll);
open_jump_lister(app, &global_heap, view, buffer, JumpListerActivation_OpenInUIView, 0); open_jump_lister(app, &global_heap, view, buffer, JumpListerActivation_OpenInUIView, 0);
} }
} }
@ -306,10 +298,8 @@ CUSTOM_COMMAND_SIG(list_all_functions_all_buffers_lister)
CUSTOM_DOC("Creates a lister of locations that look like function definitions and declarations all buffers.") CUSTOM_DOC("Creates a lister of locations that look like function definitions and declarations all buffers.")
{ {
list_all_functions(app, 0); list_all_functions(app, 0);
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessAll);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessAll, &buffer);
open_jump_lister(app, &global_heap, view, buffer, JumpListerActivation_OpenInUIView, 0); open_jump_lister(app, &global_heap, view, buffer, JumpListerActivation_OpenInUIView, 0);
} }

View File

@ -1,76 +1,72 @@
struct Application_Links; struct Application_Links;
#define GLOBAL_SET_SETTING_SIG(n) b32 n(Application_Links *app, Global_Setting_ID setting, i32 value) #define GLOBAL_SET_SETTING_SIG(n) b32 n(Application_Links *app, Global_Setting_ID setting, i32 value)
#define GLOBAL_SET_MAPPING_SIG(n) b32 n(Application_Links *app, void *data, i32 size) #define GLOBAL_SET_MAPPING_SIG(n) b32 n(Application_Links *app, void *data, i32 size)
#define GLOBAL_GET_SCREEN_RECTANGLE_SIG(n) b32 n(Application_Links *app, Rect_f32 *rect_out) #define GLOBAL_GET_SCREEN_RECTANGLE_SIG(n) Rect_f32 n(Application_Links *app)
#define CONTEXT_GET_ARENA_SIG(n) Arena* n(Application_Links *app) #define CONTEXT_GET_ARENA_SIG(n) Arena* n(Application_Links *app)
#define CONTEXT_GET_BASE_ALLOCATOR_SIG(n) Base_Allocator* n(Application_Links *app) #define CONTEXT_GET_BASE_ALLOCATOR_SIG(n) Base_Allocator* n(Application_Links *app)
#define CREATE_CHILD_PROCESS_SIG(n) b32 n(Application_Links *app, String_Const_u8 path, String_Const_u8 command, Child_Process_ID *child_process_id_out) #define CREATE_CHILD_PROCESS_SIG(n) b32 n(Application_Links *app, String_Const_u8 path, String_Const_u8 command, Child_Process_ID *child_process_id_out)
#define CHILD_PROCESS_SET_TARGET_BUFFER_SIG(n) b32 n(Application_Links *app, Child_Process_ID child_process_id, Buffer_ID buffer_id, Child_Process_Set_Target_Flags flags) #define CHILD_PROCESS_SET_TARGET_BUFFER_SIG(n) b32 n(Application_Links *app, Child_Process_ID child_process_id, Buffer_ID buffer_id, Child_Process_Set_Target_Flags flags)
#define BUFFER_GET_ATTACHED_CHILD_PROCESS_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Child_Process_ID *child_process_id_out) #define BUFFER_GET_ATTACHED_CHILD_PROCESS_SIG(n) Child_Process_ID n(Application_Links *app, Buffer_ID buffer_id)
#define CHILD_PROCESS_GET_ATTACHED_BUFFER_SIG(n) b32 n(Application_Links *app, Child_Process_ID child_process_id, Buffer_ID *buffer_id_out) #define CHILD_PROCESS_GET_ATTACHED_BUFFER_SIG(n) Buffer_ID n(Application_Links *app, Child_Process_ID child_process_id)
#define CHILD_PROCESS_GET_STATE_SIG(n) b32 n(Application_Links *app, Child_Process_ID child_process_id, Process_State *process_state_out) #define CHILD_PROCESS_GET_STATE_SIG(n) Process_State n(Application_Links *app, Child_Process_ID child_process_id)
#define CLIPBOARD_POST_SIG(n) b32 n(Application_Links *app, i32 clipboard_id, String_Const_u8 string) #define CLIPBOARD_POST_SIG(n) b32 n(Application_Links *app, i32 clipboard_id, String_Const_u8 string)
#define CLIPBOARD_COUNT_SIG(n) b32 n(Application_Links *app, i32 clipboard_id, i32 *count_out) #define CLIPBOARD_COUNT_SIG(n) i32 n(Application_Links *app, i32 clipboard_id)
#define CLIPBOARD_INDEX_SIG(n) b32 n(Application_Links *app, i32 clipboard_id, i32 item_index, Arena *out, String_Const_u8 *string_out) #define PUSH_CLIPBOARD_INDEX_SIG(n) String_Const_u8 n(Application_Links *app, Arena *arena, i32 clipboard_id, i32 item_index)
#define CREATE_PARSE_CONTEXT_SIG(n) Parse_Context_ID n(Application_Links *app, Parser_String_And_Type *kw, u32 kw_count, Parser_String_And_Type *pp, u32 pp_count) #define CREATE_PARSE_CONTEXT_SIG(n) Parse_Context_ID n(Application_Links *app, Parser_String_And_Type *kw, u32 kw_count, Parser_String_And_Type *pp, u32 pp_count)
#define GET_BUFFER_COUNT_SIG(n) i32 n(Application_Links *app) #define GET_BUFFER_COUNT_SIG(n) i32 n(Application_Links *app)
#define GET_BUFFER_NEXT_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Access_Flag access, Buffer_ID *buffer_id_out) #define GET_BUFFER_NEXT_SIG(n) Buffer_ID n(Application_Links *app, Buffer_ID buffer_id, Access_Flag access)
#define GET_BUFFER_BY_NAME_SIG(n) b32 n(Application_Links *app, String_Const_u8 name, Access_Flag access, Buffer_ID *buffer_id_out) #define GET_BUFFER_BY_NAME_SIG(n) Buffer_ID n(Application_Links *app, String_Const_u8 name, Access_Flag access)
#define GET_BUFFER_BY_FILE_NAME_SIG(n) b32 n(Application_Links *app, String_Const_u8 file_name, Access_Flag access, Buffer_ID *buffer_id_out) #define GET_BUFFER_BY_FILE_NAME_SIG(n) Buffer_ID n(Application_Links *app, String_Const_u8 file_name, Access_Flag access)
#define BUFFER_READ_RANGE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, i32 start, i32 one_past_last, char *out) #define BUFFER_READ_RANGE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, i32 start, i32 one_past_last, char *out)
#define BUFFER_REPLACE_RANGE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Range range, String_Const_u8 string) #define BUFFER_REPLACE_RANGE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Range range, String_Const_u8 string)
#define BUFFER_BATCH_EDIT_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, char *str, Buffer_Edit *edits, i32 edit_count) #define BUFFER_BATCH_EDIT_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, char *str, Buffer_Edit *edits, i32 edit_count)
#define BUFFER_SEEK_STRING_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer, String_Const_u8 needle, Scan_Direction direction, i32 start_pos, i32 *pos_out, b32 *case_sensitive_out) #define BUFFER_SEEK_STRING_SIG(n) String_Match n(Application_Links *app, Buffer_ID buffer, String_Const_u8 needle, Scan_Direction direction, i32 start_pos)
#define BUFFER_SEEK_CHARACTER_CLASS_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Character_Predicate *predicate, Scan_Direction direction, i32 start_pos, i32 *pos_out) #define BUFFER_SEEK_CHARACTER_CLASS_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Character_Predicate *predicate, Scan_Direction direction, i32 start_pos, i32 *pos_out)
#define BUFFER_COMPUTE_CURSOR_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Buffer_Seek seek, Partial_Cursor *cursor_out) #define BUFFER_COMPUTE_CURSOR_SIG(n) Partial_Cursor n(Application_Links *app, Buffer_ID buffer_id, Buffer_Seek seek)
#define BUFFER_EXISTS_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id) #define BUFFER_EXISTS_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id)
#define BUFFER_READY_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id) #define BUFFER_READY_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id)
#define BUFFER_GET_ACCESS_FLAGS_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Access_Flag *access_flags_out) #define BUFFER_GET_ACCESS_FLAGS_SIG(n) Access_Flag n(Application_Links *app, Buffer_ID buffer_id)
#define BUFFER_GET_SIZE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, i32 *size_out) #define BUFFER_GET_SIZE_SIG(n) u64 n(Application_Links *app, Buffer_ID buffer_id)
#define BUFFER_GET_LINE_COUNT_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, i32 *line_count_out) #define BUFFER_GET_LINE_COUNT_SIG(n) u64 n(Application_Links *app, Buffer_ID buffer_id)
#define BUFFER_GET_BASE_BUFFER_NAME_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Arena *out, String_Const_u8 *name_out) #define PUSH_BUFFER_BASE_NAME_SIG(n) String_Const_u8 n(Application_Links *app, Arena *arena, Buffer_ID buffer_id)
#define BUFFER_GET_UNIQUE_BUFFER_NAME_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Arena *out, String_Const_u8 *name_out) #define PUSH_BUFFER_UNIQUE_NAME_SIG(n) String_Const_u8 n(Application_Links *app, Arena *out, Buffer_ID buffer_id)
#define BUFFER_GET_FILE_NAME_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Arena *out, String_Const_u8 *name_out) #define PUSH_BUFFER_FILE_NAME_SIG(n) String_Const_u8 n(Application_Links *app, Arena *arena, Buffer_ID buffer_id)
#define BUFFER_GET_DIRTY_STATE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Dirty_State *dirty_state_out) #define BUFFER_GET_DIRTY_STATE_SIG(n) Dirty_State n(Application_Links *app, Buffer_ID buffer_id)
#define BUFFER_DIRECTLY_SET_DIRTY_STATE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Dirty_State dirty_state) #define BUFFER_SET_DIRTY_STATE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Dirty_State dirty_state)
#define BUFFER_TOKENS_ARE_READY_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id) #define BUFFER_TOKENS_ARE_READY_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id)
#define BUFFER_GET_SETTING_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 *value_out) #define BUFFER_GET_SETTING_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 *value_out)
#define BUFFER_SET_SETTING_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 value) #define BUFFER_SET_SETTING_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 value)
#define BUFFER_GET_MANAGED_SCOPE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Managed_Scope *scope_out) #define BUFFER_GET_MANAGED_SCOPE_SIG(n) Managed_Scope n(Application_Links *app, Buffer_ID buffer_id)
#define BUFFER_TOKEN_COUNT_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, i32 *count_out) #define BUFFER_GET_TOKEN_ARRAY_SIG(n) Cpp_Token_Array n(Application_Links *app, Buffer_ID buffer_id)
#define BUFFER_READ_TOKENS_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, i32 start_token, i32 end_token, Cpp_Token *tokens_out)
#define BUFFER_GET_TOKEN_RANGE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Cpp_Token **first_token_out, Cpp_Token **one_past_last_token_out)
#define BUFFER_GET_TOKEN_INDEX_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, i32 pos, Cpp_Get_Token_Result *get_result)
#define BUFFER_SEND_END_SIGNAL_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id) #define BUFFER_SEND_END_SIGNAL_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id)
#define CREATE_BUFFER_SIG(n) b32 n(Application_Links *app, String_Const_u8 file_name, Buffer_Create_Flag flags, Buffer_ID *new_buffer_id_out) #define CREATE_BUFFER_SIG(n) Buffer_ID n(Application_Links *app, String_Const_u8 file_name, Buffer_Create_Flag flags)
#define BUFFER_SAVE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, String_Const_u8 file_name, u32 flags) #define BUFFER_SAVE_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, String_Const_u8 file_name, Buffer_Save_Flag flags)
#define BUFFER_KILL_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Buffer_Kill_Flag flags, Buffer_Kill_Result *result_out) #define BUFFER_KILL_SIG(n) Buffer_Kill_Result n(Application_Links *app, Buffer_ID buffer_id, Buffer_Kill_Flag flags)
#define BUFFER_REOPEN_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, Buffer_Reopen_Flag flags, Buffer_Reopen_Result *result_out) #define BUFFER_REOPEN_SIG(n) Buffer_Reopen_Result n(Application_Links *app, Buffer_ID buffer_id, Buffer_Reopen_Flag flags)
#define BUFFER_GET_FILE_ATTRIBUTES_SIG(n) b32 n(Application_Links *app, Buffer_ID buffer_id, File_Attributes *attributes_out) #define BUFFER_GET_FILE_ATTRIBUTES_SIG(n) File_Attributes n(Application_Links *app, Buffer_ID buffer_id)
#define GET_VIEW_NEXT_SIG(n) b32 n(Application_Links *app, View_ID view_id, Access_Flag access, View_ID *view_id_out) #define GET_VIEW_NEXT_SIG(n) View_ID n(Application_Links *app, View_ID view_id, Access_Flag access)
#define GET_VIEW_PREV_SIG(n) b32 n(Application_Links *app, View_ID view_id, Access_Flag access, View_ID *view_id_out) #define GET_VIEW_PREV_SIG(n) View_ID n(Application_Links *app, View_ID view_id, Access_Flag access)
#define GET_ACTIVE_VIEW_SIG(n) b32 n(Application_Links *app, Access_Flag access, View_ID *view_id_out) #define GET_ACTIVE_VIEW_SIG(n) View_ID n(Application_Links *app, Access_Flag access)
#define GET_ACTIVE_PANEL_SIG(n) b32 n(Application_Links *app, Panel_ID *panel_id_out) #define GET_ACTIVE_PANEL_SIG(n) Panel_ID n(Application_Links *app)
#define VIEW_EXISTS_SIG(n) b32 n(Application_Links *app, View_ID view_id) #define VIEW_EXISTS_SIG(n) b32 n(Application_Links *app, View_ID view_id)
#define VIEW_GET_BUFFER_SIG(n) b32 n(Application_Links *app, View_ID view_id, Access_Flag access, Buffer_ID *buffer_id_out) #define VIEW_GET_BUFFER_SIG(n) Buffer_ID n(Application_Links *app, View_ID view_id, Access_Flag access)
#define VIEW_GET_CURSOR_POS_SIG(n) b32 n(Application_Links *app, View_ID view_id, i32 *pos_out) #define VIEW_GET_CURSOR_POS_SIG(n) i32 n(Application_Links *app, View_ID view_id)
#define VIEW_GET_MARK_POS_SIG(n) b32 n(Application_Links *app, View_ID view_id, i32 *pos_out) #define VIEW_GET_MARK_POS_SIG(n) i32 n(Application_Links *app, View_ID view_id)
#define VIEW_GET_PREFERRED_X_SIG(n) b32 n(Application_Links *app, View_ID view_id, f32 *preferred_x_out) #define VIEW_GET_PREFERRED_X_SIG(n) f32 n(Application_Links *app, View_ID view_id)
#define VIEW_GET_SCREEN_RECT_SIG(n) b32 n(Application_Links *app, View_ID view_id, Rect_f32 *rect_out) #define VIEW_GET_SCREEN_RECT_SIG(n) Rect_f32 n(Application_Links *app, View_ID view_id)
#define VIEW_GET_PANEL_SIG(n) b32 n(Application_Links *app, View_ID view_id, Panel_ID *panel_id_out) #define VIEW_GET_PANEL_SIG(n) Panel_ID n(Application_Links *app, View_ID view_id)
#define PANEL_GET_VIEW_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id, View_ID *view_id_out) #define PANEL_GET_VIEW_SIG(n) View_ID n(Application_Links *app, Panel_ID panel_id)
#define PANEL_IS_SPLIT_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id) #define PANEL_IS_SPLIT_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id)
#define PANEL_IS_LEAF_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id) #define PANEL_IS_LEAF_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id)
#define PANEL_SPLIT_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id, Panel_Split_Orientation orientation) #define PANEL_SPLIT_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id, Panel_Split_Orientation orientation)
#define PANEL_SET_SPLIT_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t) #define PANEL_SET_SPLIT_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t)
#define PANEL_SWAP_CHILDREN_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t) #define PANEL_SWAP_CHILDREN_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t)
#define PANEL_GET_PARENT_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id, Panel_ID *panel_id_out) #define PANEL_GET_PARENT_SIG(n) Panel_ID n(Application_Links *app, Panel_ID panel_id)
#define PANEL_GET_CHILD_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id, Panel_Child which_child, Panel_ID *panel_id_out) #define PANEL_GET_CHILD_SIG(n) Panel_ID n(Application_Links *app, Panel_ID panel_id, Panel_Child which_child)
#define PANEL_GET_MAX_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id, Panel_ID *panel_id_out) #define PANEL_GET_MAX_SIG(n) Panel_ID n(Application_Links *app, Panel_ID panel_id)
#define PANEL_GET_MARGIN_SIG(n) b32 n(Application_Links *app, Panel_ID panel_id, i32_Rect *margins_out) #define PANEL_GET_MARGIN_SIG(n) Rect_i32 n(Application_Links *app, Panel_ID panel_id)
#define VIEW_CLOSE_SIG(n) b32 n(Application_Links *app, View_ID view_id) #define VIEW_CLOSE_SIG(n) b32 n(Application_Links *app, View_ID view_id)
#define VIEW_GET_REGION_SIG(n) b32 n(Application_Links *app, View_ID view_id, Rect_i32 *region_out) #define VIEW_GET_BUFFER_REGION_SIG(n) Rect_f32 n(Application_Links *app, View_ID view_id)
#define VIEW_GET_BUFFER_REGION_SIG(n) b32 n(Application_Links *app, View_ID view_id, Rect_i32 *region_out)
#define VIEW_GET_SCROLL_VARS_SIG(n) b32 n(Application_Links *app, View_ID view_id, GUI_Scroll_Vars *scroll_vars_out) #define VIEW_GET_SCROLL_VARS_SIG(n) b32 n(Application_Links *app, View_ID view_id, GUI_Scroll_Vars *scroll_vars_out)
#define VIEW_SET_ACTIVE_SIG(n) b32 n(Application_Links *app, View_ID view_id) #define VIEW_SET_ACTIVE_SIG(n) b32 n(Application_Links *app, View_ID view_id)
#define VIEW_GET_SETTING_SIG(n) b32 n(Application_Links *app, View_ID view_id, View_Setting_ID setting, i32 *value_out) #define VIEW_GET_SETTING_SIG(n) b32 n(Application_Links *app, View_ID view_id, View_Setting_ID setting, i32 *value_out)
@ -196,7 +192,7 @@ typedef CHILD_PROCESS_GET_ATTACHED_BUFFER_SIG(Child_Process_Get_Attached_Buffer_
typedef CHILD_PROCESS_GET_STATE_SIG(Child_Process_Get_State_Function); typedef CHILD_PROCESS_GET_STATE_SIG(Child_Process_Get_State_Function);
typedef CLIPBOARD_POST_SIG(Clipboard_Post_Function); typedef CLIPBOARD_POST_SIG(Clipboard_Post_Function);
typedef CLIPBOARD_COUNT_SIG(Clipboard_Count_Function); typedef CLIPBOARD_COUNT_SIG(Clipboard_Count_Function);
typedef CLIPBOARD_INDEX_SIG(Clipboard_Index_Function); typedef PUSH_CLIPBOARD_INDEX_SIG(Push_Clipboard_Index_Function);
typedef CREATE_PARSE_CONTEXT_SIG(Create_Parse_Context_Function); typedef CREATE_PARSE_CONTEXT_SIG(Create_Parse_Context_Function);
typedef GET_BUFFER_COUNT_SIG(Get_Buffer_Count_Function); typedef GET_BUFFER_COUNT_SIG(Get_Buffer_Count_Function);
typedef GET_BUFFER_NEXT_SIG(Get_Buffer_Next_Function); typedef GET_BUFFER_NEXT_SIG(Get_Buffer_Next_Function);
@ -213,19 +209,16 @@ typedef BUFFER_READY_SIG(Buffer_Ready_Function);
typedef BUFFER_GET_ACCESS_FLAGS_SIG(Buffer_Get_Access_Flags_Function); typedef BUFFER_GET_ACCESS_FLAGS_SIG(Buffer_Get_Access_Flags_Function);
typedef BUFFER_GET_SIZE_SIG(Buffer_Get_Size_Function); typedef BUFFER_GET_SIZE_SIG(Buffer_Get_Size_Function);
typedef BUFFER_GET_LINE_COUNT_SIG(Buffer_Get_Line_Count_Function); typedef BUFFER_GET_LINE_COUNT_SIG(Buffer_Get_Line_Count_Function);
typedef BUFFER_GET_BASE_BUFFER_NAME_SIG(Buffer_Get_Base_Buffer_Name_Function); typedef PUSH_BUFFER_BASE_NAME_SIG(Push_Buffer_Base_Name_Function);
typedef BUFFER_GET_UNIQUE_BUFFER_NAME_SIG(Buffer_Get_Unique_Buffer_Name_Function); typedef PUSH_BUFFER_UNIQUE_NAME_SIG(Push_Buffer_Unique_Name_Function);
typedef BUFFER_GET_FILE_NAME_SIG(Buffer_Get_File_Name_Function); typedef PUSH_BUFFER_FILE_NAME_SIG(Push_Buffer_File_Name_Function);
typedef BUFFER_GET_DIRTY_STATE_SIG(Buffer_Get_Dirty_State_Function); typedef BUFFER_GET_DIRTY_STATE_SIG(Buffer_Get_Dirty_State_Function);
typedef BUFFER_DIRECTLY_SET_DIRTY_STATE_SIG(Buffer_Directly_Set_Dirty_State_Function); typedef BUFFER_SET_DIRTY_STATE_SIG(Buffer_Set_Dirty_State_Function);
typedef BUFFER_TOKENS_ARE_READY_SIG(Buffer_Tokens_Are_Ready_Function); typedef BUFFER_TOKENS_ARE_READY_SIG(Buffer_Tokens_Are_Ready_Function);
typedef BUFFER_GET_SETTING_SIG(Buffer_Get_Setting_Function); typedef BUFFER_GET_SETTING_SIG(Buffer_Get_Setting_Function);
typedef BUFFER_SET_SETTING_SIG(Buffer_Set_Setting_Function); typedef BUFFER_SET_SETTING_SIG(Buffer_Set_Setting_Function);
typedef BUFFER_GET_MANAGED_SCOPE_SIG(Buffer_Get_Managed_Scope_Function); typedef BUFFER_GET_MANAGED_SCOPE_SIG(Buffer_Get_Managed_Scope_Function);
typedef BUFFER_TOKEN_COUNT_SIG(Buffer_Token_Count_Function); typedef BUFFER_GET_TOKEN_ARRAY_SIG(Buffer_Get_Token_Array_Function);
typedef BUFFER_READ_TOKENS_SIG(Buffer_Read_Tokens_Function);
typedef BUFFER_GET_TOKEN_RANGE_SIG(Buffer_Get_Token_Range_Function);
typedef BUFFER_GET_TOKEN_INDEX_SIG(Buffer_Get_Token_Index_Function);
typedef BUFFER_SEND_END_SIGNAL_SIG(Buffer_Send_End_Signal_Function); typedef BUFFER_SEND_END_SIGNAL_SIG(Buffer_Send_End_Signal_Function);
typedef CREATE_BUFFER_SIG(Create_Buffer_Function); typedef CREATE_BUFFER_SIG(Create_Buffer_Function);
typedef BUFFER_SAVE_SIG(Buffer_Save_Function); typedef BUFFER_SAVE_SIG(Buffer_Save_Function);
@ -254,7 +247,6 @@ typedef PANEL_GET_CHILD_SIG(Panel_Get_Child_Function);
typedef PANEL_GET_MAX_SIG(Panel_Get_Max_Function); typedef PANEL_GET_MAX_SIG(Panel_Get_Max_Function);
typedef PANEL_GET_MARGIN_SIG(Panel_Get_Margin_Function); typedef PANEL_GET_MARGIN_SIG(Panel_Get_Margin_Function);
typedef VIEW_CLOSE_SIG(View_Close_Function); typedef VIEW_CLOSE_SIG(View_Close_Function);
typedef VIEW_GET_REGION_SIG(View_Get_Region_Function);
typedef VIEW_GET_BUFFER_REGION_SIG(View_Get_Buffer_Region_Function); typedef VIEW_GET_BUFFER_REGION_SIG(View_Get_Buffer_Region_Function);
typedef VIEW_GET_SCROLL_VARS_SIG(View_Get_Scroll_Vars_Function); typedef VIEW_GET_SCROLL_VARS_SIG(View_Get_Scroll_Vars_Function);
typedef VIEW_SET_ACTIVE_SIG(View_Set_Active_Function); typedef VIEW_SET_ACTIVE_SIG(View_Set_Active_Function);
@ -383,7 +375,7 @@ Child_Process_Get_Attached_Buffer_Function *child_process_get_attached_buffer;
Child_Process_Get_State_Function *child_process_get_state; Child_Process_Get_State_Function *child_process_get_state;
Clipboard_Post_Function *clipboard_post; Clipboard_Post_Function *clipboard_post;
Clipboard_Count_Function *clipboard_count; Clipboard_Count_Function *clipboard_count;
Clipboard_Index_Function *clipboard_index; Push_Clipboard_Index_Function *push_clipboard_index;
Create_Parse_Context_Function *create_parse_context; Create_Parse_Context_Function *create_parse_context;
Get_Buffer_Count_Function *get_buffer_count; Get_Buffer_Count_Function *get_buffer_count;
Get_Buffer_Next_Function *get_buffer_next; Get_Buffer_Next_Function *get_buffer_next;
@ -400,19 +392,16 @@ Buffer_Ready_Function *buffer_ready;
Buffer_Get_Access_Flags_Function *buffer_get_access_flags; Buffer_Get_Access_Flags_Function *buffer_get_access_flags;
Buffer_Get_Size_Function *buffer_get_size; Buffer_Get_Size_Function *buffer_get_size;
Buffer_Get_Line_Count_Function *buffer_get_line_count; Buffer_Get_Line_Count_Function *buffer_get_line_count;
Buffer_Get_Base_Buffer_Name_Function *buffer_get_base_buffer_name; Push_Buffer_Base_Name_Function *push_buffer_base_name;
Buffer_Get_Unique_Buffer_Name_Function *buffer_get_unique_buffer_name; Push_Buffer_Unique_Name_Function *push_buffer_unique_name;
Buffer_Get_File_Name_Function *buffer_get_file_name; Push_Buffer_File_Name_Function *push_buffer_file_name;
Buffer_Get_Dirty_State_Function *buffer_get_dirty_state; Buffer_Get_Dirty_State_Function *buffer_get_dirty_state;
Buffer_Directly_Set_Dirty_State_Function *buffer_directly_set_dirty_state; Buffer_Set_Dirty_State_Function *buffer_set_dirty_state;
Buffer_Tokens_Are_Ready_Function *buffer_tokens_are_ready; Buffer_Tokens_Are_Ready_Function *buffer_tokens_are_ready;
Buffer_Get_Setting_Function *buffer_get_setting; Buffer_Get_Setting_Function *buffer_get_setting;
Buffer_Set_Setting_Function *buffer_set_setting; Buffer_Set_Setting_Function *buffer_set_setting;
Buffer_Get_Managed_Scope_Function *buffer_get_managed_scope; Buffer_Get_Managed_Scope_Function *buffer_get_managed_scope;
Buffer_Token_Count_Function *buffer_token_count; Buffer_Get_Token_Array_Function *buffer_get_token_array;
Buffer_Read_Tokens_Function *buffer_read_tokens;
Buffer_Get_Token_Range_Function *buffer_get_token_range;
Buffer_Get_Token_Index_Function *buffer_get_token_index;
Buffer_Send_End_Signal_Function *buffer_send_end_signal; Buffer_Send_End_Signal_Function *buffer_send_end_signal;
Create_Buffer_Function *create_buffer; Create_Buffer_Function *create_buffer;
Buffer_Save_Function *buffer_save; Buffer_Save_Function *buffer_save;
@ -441,7 +430,6 @@ Panel_Get_Child_Function *panel_get_child;
Panel_Get_Max_Function *panel_get_max; Panel_Get_Max_Function *panel_get_max;
Panel_Get_Margin_Function *panel_get_margin; Panel_Get_Margin_Function *panel_get_margin;
View_Close_Function *view_close; View_Close_Function *view_close;
View_Get_Region_Function *view_get_region;
View_Get_Buffer_Region_Function *view_get_buffer_region; View_Get_Buffer_Region_Function *view_get_buffer_region;
View_Get_Scroll_Vars_Function *view_get_scroll_vars; View_Get_Scroll_Vars_Function *view_get_scroll_vars;
View_Set_Active_Function *view_set_active; View_Set_Active_Function *view_set_active;
@ -569,7 +557,7 @@ Child_Process_Get_Attached_Buffer_Function *child_process_get_attached_buffer_;
Child_Process_Get_State_Function *child_process_get_state_; Child_Process_Get_State_Function *child_process_get_state_;
Clipboard_Post_Function *clipboard_post_; Clipboard_Post_Function *clipboard_post_;
Clipboard_Count_Function *clipboard_count_; Clipboard_Count_Function *clipboard_count_;
Clipboard_Index_Function *clipboard_index_; Push_Clipboard_Index_Function *push_clipboard_index_;
Create_Parse_Context_Function *create_parse_context_; Create_Parse_Context_Function *create_parse_context_;
Get_Buffer_Count_Function *get_buffer_count_; Get_Buffer_Count_Function *get_buffer_count_;
Get_Buffer_Next_Function *get_buffer_next_; Get_Buffer_Next_Function *get_buffer_next_;
@ -586,19 +574,16 @@ Buffer_Ready_Function *buffer_ready_;
Buffer_Get_Access_Flags_Function *buffer_get_access_flags_; Buffer_Get_Access_Flags_Function *buffer_get_access_flags_;
Buffer_Get_Size_Function *buffer_get_size_; Buffer_Get_Size_Function *buffer_get_size_;
Buffer_Get_Line_Count_Function *buffer_get_line_count_; Buffer_Get_Line_Count_Function *buffer_get_line_count_;
Buffer_Get_Base_Buffer_Name_Function *buffer_get_base_buffer_name_; Push_Buffer_Base_Name_Function *push_buffer_base_name_;
Buffer_Get_Unique_Buffer_Name_Function *buffer_get_unique_buffer_name_; Push_Buffer_Unique_Name_Function *push_buffer_unique_name_;
Buffer_Get_File_Name_Function *buffer_get_file_name_; Push_Buffer_File_Name_Function *push_buffer_file_name_;
Buffer_Get_Dirty_State_Function *buffer_get_dirty_state_; Buffer_Get_Dirty_State_Function *buffer_get_dirty_state_;
Buffer_Directly_Set_Dirty_State_Function *buffer_directly_set_dirty_state_; Buffer_Set_Dirty_State_Function *buffer_set_dirty_state_;
Buffer_Tokens_Are_Ready_Function *buffer_tokens_are_ready_; Buffer_Tokens_Are_Ready_Function *buffer_tokens_are_ready_;
Buffer_Get_Setting_Function *buffer_get_setting_; Buffer_Get_Setting_Function *buffer_get_setting_;
Buffer_Set_Setting_Function *buffer_set_setting_; Buffer_Set_Setting_Function *buffer_set_setting_;
Buffer_Get_Managed_Scope_Function *buffer_get_managed_scope_; Buffer_Get_Managed_Scope_Function *buffer_get_managed_scope_;
Buffer_Token_Count_Function *buffer_token_count_; Buffer_Get_Token_Array_Function *buffer_get_token_array_;
Buffer_Read_Tokens_Function *buffer_read_tokens_;
Buffer_Get_Token_Range_Function *buffer_get_token_range_;
Buffer_Get_Token_Index_Function *buffer_get_token_index_;
Buffer_Send_End_Signal_Function *buffer_send_end_signal_; Buffer_Send_End_Signal_Function *buffer_send_end_signal_;
Create_Buffer_Function *create_buffer_; Create_Buffer_Function *create_buffer_;
Buffer_Save_Function *buffer_save_; Buffer_Save_Function *buffer_save_;
@ -627,7 +612,6 @@ Panel_Get_Child_Function *panel_get_child_;
Panel_Get_Max_Function *panel_get_max_; Panel_Get_Max_Function *panel_get_max_;
Panel_Get_Margin_Function *panel_get_margin_; Panel_Get_Margin_Function *panel_get_margin_;
View_Close_Function *view_close_; View_Close_Function *view_close_;
View_Get_Region_Function *view_get_region_;
View_Get_Buffer_Region_Function *view_get_buffer_region_; View_Get_Buffer_Region_Function *view_get_buffer_region_;
View_Get_Scroll_Vars_Function *view_get_scroll_vars_; View_Get_Scroll_Vars_Function *view_get_scroll_vars_;
View_Set_Active_Function *view_set_active_; View_Set_Active_Function *view_set_active_;
@ -763,7 +747,7 @@ app_links->child_process_get_attached_buffer_ = Child_Process_Get_Attached_Buffe
app_links->child_process_get_state_ = Child_Process_Get_State;\ app_links->child_process_get_state_ = Child_Process_Get_State;\
app_links->clipboard_post_ = Clipboard_Post;\ app_links->clipboard_post_ = Clipboard_Post;\
app_links->clipboard_count_ = Clipboard_Count;\ app_links->clipboard_count_ = Clipboard_Count;\
app_links->clipboard_index_ = Clipboard_Index;\ app_links->push_clipboard_index_ = Push_Clipboard_Index;\
app_links->create_parse_context_ = Create_Parse_Context;\ app_links->create_parse_context_ = Create_Parse_Context;\
app_links->get_buffer_count_ = Get_Buffer_Count;\ app_links->get_buffer_count_ = Get_Buffer_Count;\
app_links->get_buffer_next_ = Get_Buffer_Next;\ app_links->get_buffer_next_ = Get_Buffer_Next;\
@ -780,19 +764,16 @@ app_links->buffer_ready_ = Buffer_Ready;\
app_links->buffer_get_access_flags_ = Buffer_Get_Access_Flags;\ app_links->buffer_get_access_flags_ = Buffer_Get_Access_Flags;\
app_links->buffer_get_size_ = Buffer_Get_Size;\ app_links->buffer_get_size_ = Buffer_Get_Size;\
app_links->buffer_get_line_count_ = Buffer_Get_Line_Count;\ app_links->buffer_get_line_count_ = Buffer_Get_Line_Count;\
app_links->buffer_get_base_buffer_name_ = Buffer_Get_Base_Buffer_Name;\ app_links->push_buffer_base_name_ = Push_Buffer_Base_Name;\
app_links->buffer_get_unique_buffer_name_ = Buffer_Get_Unique_Buffer_Name;\ app_links->push_buffer_unique_name_ = Push_Buffer_Unique_Name;\
app_links->buffer_get_file_name_ = Buffer_Get_File_Name;\ app_links->push_buffer_file_name_ = Push_Buffer_File_Name;\
app_links->buffer_get_dirty_state_ = Buffer_Get_Dirty_State;\ app_links->buffer_get_dirty_state_ = Buffer_Get_Dirty_State;\
app_links->buffer_directly_set_dirty_state_ = Buffer_Directly_Set_Dirty_State;\ app_links->buffer_set_dirty_state_ = Buffer_Set_Dirty_State;\
app_links->buffer_tokens_are_ready_ = Buffer_Tokens_Are_Ready;\ app_links->buffer_tokens_are_ready_ = Buffer_Tokens_Are_Ready;\
app_links->buffer_get_setting_ = Buffer_Get_Setting;\ app_links->buffer_get_setting_ = Buffer_Get_Setting;\
app_links->buffer_set_setting_ = Buffer_Set_Setting;\ app_links->buffer_set_setting_ = Buffer_Set_Setting;\
app_links->buffer_get_managed_scope_ = Buffer_Get_Managed_Scope;\ app_links->buffer_get_managed_scope_ = Buffer_Get_Managed_Scope;\
app_links->buffer_token_count_ = Buffer_Token_Count;\ app_links->buffer_get_token_array_ = Buffer_Get_Token_Array;\
app_links->buffer_read_tokens_ = Buffer_Read_Tokens;\
app_links->buffer_get_token_range_ = Buffer_Get_Token_Range;\
app_links->buffer_get_token_index_ = Buffer_Get_Token_Index;\
app_links->buffer_send_end_signal_ = Buffer_Send_End_Signal;\ app_links->buffer_send_end_signal_ = Buffer_Send_End_Signal;\
app_links->create_buffer_ = Create_Buffer;\ app_links->create_buffer_ = Create_Buffer;\
app_links->buffer_save_ = Buffer_Save;\ app_links->buffer_save_ = Buffer_Save;\
@ -821,7 +802,6 @@ app_links->panel_get_child_ = Panel_Get_Child;\
app_links->panel_get_max_ = Panel_Get_Max;\ app_links->panel_get_max_ = Panel_Get_Max;\
app_links->panel_get_margin_ = Panel_Get_Margin;\ app_links->panel_get_margin_ = Panel_Get_Margin;\
app_links->view_close_ = View_Close;\ app_links->view_close_ = View_Close;\
app_links->view_get_region_ = View_Get_Region;\
app_links->view_get_buffer_region_ = View_Get_Buffer_Region;\ app_links->view_get_buffer_region_ = View_Get_Buffer_Region;\
app_links->view_get_scroll_vars_ = View_Get_Scroll_Vars;\ app_links->view_get_scroll_vars_ = View_Get_Scroll_Vars;\
app_links->view_set_active_ = View_Set_Active;\ app_links->view_set_active_ = View_Set_Active;\
@ -939,76 +919,72 @@ app_links->get_view_visible_range_ = Get_View_Visible_Range;} while(false)
#if defined(ALLOW_DEP_4CODER) #if defined(ALLOW_DEP_4CODER)
static b32 global_set_setting(Application_Links *app, Global_Setting_ID setting, i32 value){return(app->global_set_setting(app, setting, value));} static b32 global_set_setting(Application_Links *app, Global_Setting_ID setting, i32 value){return(app->global_set_setting(app, setting, value));}
static b32 global_set_mapping(Application_Links *app, void *data, i32 size){return(app->global_set_mapping(app, data, size));} static b32 global_set_mapping(Application_Links *app, void *data, i32 size){return(app->global_set_mapping(app, data, size));}
static b32 global_get_screen_rectangle(Application_Links *app, Rect_f32 *rect_out){return(app->global_get_screen_rectangle(app, rect_out));} static Rect_f32 global_get_screen_rectangle(Application_Links *app){return(app->global_get_screen_rectangle(app));}
static Arena* context_get_arena(Application_Links *app){return(app->context_get_arena(app));} static Arena* context_get_arena(Application_Links *app){return(app->context_get_arena(app));}
static Base_Allocator* context_get_base_allocator(Application_Links *app){return(app->context_get_base_allocator(app));} static Base_Allocator* context_get_base_allocator(Application_Links *app){return(app->context_get_base_allocator(app));}
static b32 create_child_process(Application_Links *app, String_Const_u8 path, String_Const_u8 command, Child_Process_ID *child_process_id_out){return(app->create_child_process(app, path, command, child_process_id_out));} static b32 create_child_process(Application_Links *app, String_Const_u8 path, String_Const_u8 command, Child_Process_ID *child_process_id_out){return(app->create_child_process(app, path, command, child_process_id_out));}
static b32 child_process_set_target_buffer(Application_Links *app, Child_Process_ID child_process_id, Buffer_ID buffer_id, Child_Process_Set_Target_Flags flags){return(app->child_process_set_target_buffer(app, child_process_id, buffer_id, flags));} static b32 child_process_set_target_buffer(Application_Links *app, Child_Process_ID child_process_id, Buffer_ID buffer_id, Child_Process_Set_Target_Flags flags){return(app->child_process_set_target_buffer(app, child_process_id, buffer_id, flags));}
static b32 buffer_get_attached_child_process(Application_Links *app, Buffer_ID buffer_id, Child_Process_ID *child_process_id_out){return(app->buffer_get_attached_child_process(app, buffer_id, child_process_id_out));} static Child_Process_ID buffer_get_attached_child_process(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_attached_child_process(app, buffer_id));}
static b32 child_process_get_attached_buffer(Application_Links *app, Child_Process_ID child_process_id, Buffer_ID *buffer_id_out){return(app->child_process_get_attached_buffer(app, child_process_id, buffer_id_out));} static Buffer_ID child_process_get_attached_buffer(Application_Links *app, Child_Process_ID child_process_id){return(app->child_process_get_attached_buffer(app, child_process_id));}
static b32 child_process_get_state(Application_Links *app, Child_Process_ID child_process_id, Process_State *process_state_out){return(app->child_process_get_state(app, child_process_id, process_state_out));} static Process_State child_process_get_state(Application_Links *app, Child_Process_ID child_process_id){return(app->child_process_get_state(app, child_process_id));}
static b32 clipboard_post(Application_Links *app, i32 clipboard_id, String_Const_u8 string){return(app->clipboard_post(app, clipboard_id, string));} static b32 clipboard_post(Application_Links *app, i32 clipboard_id, String_Const_u8 string){return(app->clipboard_post(app, clipboard_id, string));}
static b32 clipboard_count(Application_Links *app, i32 clipboard_id, i32 *count_out){return(app->clipboard_count(app, clipboard_id, count_out));} static i32 clipboard_count(Application_Links *app, i32 clipboard_id){return(app->clipboard_count(app, clipboard_id));}
static b32 clipboard_index(Application_Links *app, i32 clipboard_id, i32 item_index, Arena *out, String_Const_u8 *string_out){return(app->clipboard_index(app, clipboard_id, item_index, out, string_out));} static String_Const_u8 push_clipboard_index(Application_Links *app, Arena *arena, i32 clipboard_id, i32 item_index){return(app->push_clipboard_index(app, arena, clipboard_id, item_index));}
static Parse_Context_ID create_parse_context(Application_Links *app, Parser_String_And_Type *kw, u32 kw_count, Parser_String_And_Type *pp, u32 pp_count){return(app->create_parse_context(app, kw, kw_count, pp, pp_count));} static Parse_Context_ID create_parse_context(Application_Links *app, Parser_String_And_Type *kw, u32 kw_count, Parser_String_And_Type *pp, u32 pp_count){return(app->create_parse_context(app, kw, kw_count, pp, pp_count));}
static i32 get_buffer_count(Application_Links *app){return(app->get_buffer_count(app));} static i32 get_buffer_count(Application_Links *app){return(app->get_buffer_count(app));}
static b32 get_buffer_next(Application_Links *app, Buffer_ID buffer_id, Access_Flag access, Buffer_ID *buffer_id_out){return(app->get_buffer_next(app, buffer_id, access, buffer_id_out));} static Buffer_ID get_buffer_next(Application_Links *app, Buffer_ID buffer_id, Access_Flag access){return(app->get_buffer_next(app, buffer_id, access));}
static b32 get_buffer_by_name(Application_Links *app, String_Const_u8 name, Access_Flag access, Buffer_ID *buffer_id_out){return(app->get_buffer_by_name(app, name, access, buffer_id_out));} static Buffer_ID get_buffer_by_name(Application_Links *app, String_Const_u8 name, Access_Flag access){return(app->get_buffer_by_name(app, name, access));}
static b32 get_buffer_by_file_name(Application_Links *app, String_Const_u8 file_name, Access_Flag access, Buffer_ID *buffer_id_out){return(app->get_buffer_by_file_name(app, file_name, access, buffer_id_out));} static Buffer_ID get_buffer_by_file_name(Application_Links *app, String_Const_u8 file_name, Access_Flag access){return(app->get_buffer_by_file_name(app, file_name, access));}
static b32 buffer_read_range(Application_Links *app, Buffer_ID buffer_id, i32 start, i32 one_past_last, char *out){return(app->buffer_read_range(app, buffer_id, start, one_past_last, out));} static b32 buffer_read_range(Application_Links *app, Buffer_ID buffer_id, i32 start, i32 one_past_last, char *out){return(app->buffer_read_range(app, buffer_id, start, one_past_last, out));}
static b32 buffer_replace_range(Application_Links *app, Buffer_ID buffer_id, Range range, String_Const_u8 string){return(app->buffer_replace_range(app, buffer_id, range, string));} static b32 buffer_replace_range(Application_Links *app, Buffer_ID buffer_id, Range range, String_Const_u8 string){return(app->buffer_replace_range(app, buffer_id, range, string));}
static b32 buffer_batch_edit(Application_Links *app, Buffer_ID buffer_id, char *str, Buffer_Edit *edits, i32 edit_count){return(app->buffer_batch_edit(app, buffer_id, str, edits, edit_count));} static b32 buffer_batch_edit(Application_Links *app, Buffer_ID buffer_id, char *str, Buffer_Edit *edits, i32 edit_count){return(app->buffer_batch_edit(app, buffer_id, str, edits, edit_count));}
static b32 buffer_seek_string(Application_Links *app, Buffer_ID buffer, String_Const_u8 needle, Scan_Direction direction, i32 start_pos, i32 *pos_out, b32 *case_sensitive_out){return(app->buffer_seek_string(app, buffer, needle, direction, start_pos, pos_out, case_sensitive_out));} static String_Match buffer_seek_string(Application_Links *app, Buffer_ID buffer, String_Const_u8 needle, Scan_Direction direction, i32 start_pos){return(app->buffer_seek_string(app, buffer, needle, direction, start_pos));}
static b32 buffer_seek_character_class(Application_Links *app, Buffer_ID buffer_id, Character_Predicate *predicate, Scan_Direction direction, i32 start_pos, i32 *pos_out){return(app->buffer_seek_character_class(app, buffer_id, predicate, direction, start_pos, pos_out));} static b32 buffer_seek_character_class(Application_Links *app, Buffer_ID buffer_id, Character_Predicate *predicate, Scan_Direction direction, i32 start_pos, i32 *pos_out){return(app->buffer_seek_character_class(app, buffer_id, predicate, direction, start_pos, pos_out));}
static b32 buffer_compute_cursor(Application_Links *app, Buffer_ID buffer_id, Buffer_Seek seek, Partial_Cursor *cursor_out){return(app->buffer_compute_cursor(app, buffer_id, seek, cursor_out));} static Partial_Cursor buffer_compute_cursor(Application_Links *app, Buffer_ID buffer_id, Buffer_Seek seek){return(app->buffer_compute_cursor(app, buffer_id, seek));}
static b32 buffer_exists(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_exists(app, buffer_id));} static b32 buffer_exists(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_exists(app, buffer_id));}
static b32 buffer_ready(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_ready(app, buffer_id));} static b32 buffer_ready(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_ready(app, buffer_id));}
static b32 buffer_get_access_flags(Application_Links *app, Buffer_ID buffer_id, Access_Flag *access_flags_out){return(app->buffer_get_access_flags(app, buffer_id, access_flags_out));} static Access_Flag buffer_get_access_flags(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_access_flags(app, buffer_id));}
static b32 buffer_get_size(Application_Links *app, Buffer_ID buffer_id, i32 *size_out){return(app->buffer_get_size(app, buffer_id, size_out));} static u64 buffer_get_size(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_size(app, buffer_id));}
static b32 buffer_get_line_count(Application_Links *app, Buffer_ID buffer_id, i32 *line_count_out){return(app->buffer_get_line_count(app, buffer_id, line_count_out));} static u64 buffer_get_line_count(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_line_count(app, buffer_id));}
static b32 buffer_get_base_buffer_name(Application_Links *app, Buffer_ID buffer_id, Arena *out, String_Const_u8 *name_out){return(app->buffer_get_base_buffer_name(app, buffer_id, out, name_out));} static String_Const_u8 push_buffer_base_name(Application_Links *app, Arena *arena, Buffer_ID buffer_id){return(app->push_buffer_base_name(app, arena, buffer_id));}
static b32 buffer_get_unique_buffer_name(Application_Links *app, Buffer_ID buffer_id, Arena *out, String_Const_u8 *name_out){return(app->buffer_get_unique_buffer_name(app, buffer_id, out, name_out));} static String_Const_u8 push_buffer_unique_name(Application_Links *app, Arena *out, Buffer_ID buffer_id){return(app->push_buffer_unique_name(app, out, buffer_id));}
static b32 buffer_get_file_name(Application_Links *app, Buffer_ID buffer_id, Arena *out, String_Const_u8 *name_out){return(app->buffer_get_file_name(app, buffer_id, out, name_out));} static String_Const_u8 push_buffer_file_name(Application_Links *app, Arena *arena, Buffer_ID buffer_id){return(app->push_buffer_file_name(app, arena, buffer_id));}
static b32 buffer_get_dirty_state(Application_Links *app, Buffer_ID buffer_id, Dirty_State *dirty_state_out){return(app->buffer_get_dirty_state(app, buffer_id, dirty_state_out));} static Dirty_State buffer_get_dirty_state(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_dirty_state(app, buffer_id));}
static b32 buffer_directly_set_dirty_state(Application_Links *app, Buffer_ID buffer_id, Dirty_State dirty_state){return(app->buffer_directly_set_dirty_state(app, buffer_id, dirty_state));} static b32 buffer_set_dirty_state(Application_Links *app, Buffer_ID buffer_id, Dirty_State dirty_state){return(app->buffer_set_dirty_state(app, buffer_id, dirty_state));}
static b32 buffer_tokens_are_ready(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_tokens_are_ready(app, buffer_id));} static b32 buffer_tokens_are_ready(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_tokens_are_ready(app, buffer_id));}
static b32 buffer_get_setting(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 *value_out){return(app->buffer_get_setting(app, buffer_id, setting, value_out));} static b32 buffer_get_setting(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 *value_out){return(app->buffer_get_setting(app, buffer_id, setting, value_out));}
static b32 buffer_set_setting(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 value){return(app->buffer_set_setting(app, buffer_id, setting, value));} static b32 buffer_set_setting(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 value){return(app->buffer_set_setting(app, buffer_id, setting, value));}
static b32 buffer_get_managed_scope(Application_Links *app, Buffer_ID buffer_id, Managed_Scope *scope_out){return(app->buffer_get_managed_scope(app, buffer_id, scope_out));} static Managed_Scope buffer_get_managed_scope(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_managed_scope(app, buffer_id));}
static b32 buffer_token_count(Application_Links *app, Buffer_ID buffer_id, i32 *count_out){return(app->buffer_token_count(app, buffer_id, count_out));} static Cpp_Token_Array buffer_get_token_array(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_token_array(app, buffer_id));}
static b32 buffer_read_tokens(Application_Links *app, Buffer_ID buffer_id, i32 start_token, i32 end_token, Cpp_Token *tokens_out){return(app->buffer_read_tokens(app, buffer_id, start_token, end_token, tokens_out));}
static b32 buffer_get_token_range(Application_Links *app, Buffer_ID buffer_id, Cpp_Token **first_token_out, Cpp_Token **one_past_last_token_out){return(app->buffer_get_token_range(app, buffer_id, first_token_out, one_past_last_token_out));}
static b32 buffer_get_token_index(Application_Links *app, Buffer_ID buffer_id, i32 pos, Cpp_Get_Token_Result *get_result){return(app->buffer_get_token_index(app, buffer_id, pos, get_result));}
static b32 buffer_send_end_signal(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_send_end_signal(app, buffer_id));} static b32 buffer_send_end_signal(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_send_end_signal(app, buffer_id));}
static b32 create_buffer(Application_Links *app, String_Const_u8 file_name, Buffer_Create_Flag flags, Buffer_ID *new_buffer_id_out){return(app->create_buffer(app, file_name, flags, new_buffer_id_out));} static Buffer_ID create_buffer(Application_Links *app, String_Const_u8 file_name, Buffer_Create_Flag flags){return(app->create_buffer(app, file_name, flags));}
static b32 buffer_save(Application_Links *app, Buffer_ID buffer_id, String_Const_u8 file_name, u32 flags){return(app->buffer_save(app, buffer_id, file_name, flags));} static b32 buffer_save(Application_Links *app, Buffer_ID buffer_id, String_Const_u8 file_name, Buffer_Save_Flag flags){return(app->buffer_save(app, buffer_id, file_name, flags));}
static b32 buffer_kill(Application_Links *app, Buffer_ID buffer_id, Buffer_Kill_Flag flags, Buffer_Kill_Result *result_out){return(app->buffer_kill(app, buffer_id, flags, result_out));} static Buffer_Kill_Result buffer_kill(Application_Links *app, Buffer_ID buffer_id, Buffer_Kill_Flag flags){return(app->buffer_kill(app, buffer_id, flags));}
static b32 buffer_reopen(Application_Links *app, Buffer_ID buffer_id, Buffer_Reopen_Flag flags, Buffer_Reopen_Result *result_out){return(app->buffer_reopen(app, buffer_id, flags, result_out));} static Buffer_Reopen_Result buffer_reopen(Application_Links *app, Buffer_ID buffer_id, Buffer_Reopen_Flag flags){return(app->buffer_reopen(app, buffer_id, flags));}
static b32 buffer_get_file_attributes(Application_Links *app, Buffer_ID buffer_id, File_Attributes *attributes_out){return(app->buffer_get_file_attributes(app, buffer_id, attributes_out));} static File_Attributes buffer_get_file_attributes(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_file_attributes(app, buffer_id));}
static b32 get_view_next(Application_Links *app, View_ID view_id, Access_Flag access, View_ID *view_id_out){return(app->get_view_next(app, view_id, access, view_id_out));} static View_ID get_view_next(Application_Links *app, View_ID view_id, Access_Flag access){return(app->get_view_next(app, view_id, access));}
static b32 get_view_prev(Application_Links *app, View_ID view_id, Access_Flag access, View_ID *view_id_out){return(app->get_view_prev(app, view_id, access, view_id_out));} static View_ID get_view_prev(Application_Links *app, View_ID view_id, Access_Flag access){return(app->get_view_prev(app, view_id, access));}
static b32 get_active_view(Application_Links *app, Access_Flag access, View_ID *view_id_out){return(app->get_active_view(app, access, view_id_out));} static View_ID get_active_view(Application_Links *app, Access_Flag access){return(app->get_active_view(app, access));}
static b32 get_active_panel(Application_Links *app, Panel_ID *panel_id_out){return(app->get_active_panel(app, panel_id_out));} static Panel_ID get_active_panel(Application_Links *app){return(app->get_active_panel(app));}
static b32 view_exists(Application_Links *app, View_ID view_id){return(app->view_exists(app, view_id));} static b32 view_exists(Application_Links *app, View_ID view_id){return(app->view_exists(app, view_id));}
static b32 view_get_buffer(Application_Links *app, View_ID view_id, Access_Flag access, Buffer_ID *buffer_id_out){return(app->view_get_buffer(app, view_id, access, buffer_id_out));} static Buffer_ID view_get_buffer(Application_Links *app, View_ID view_id, Access_Flag access){return(app->view_get_buffer(app, view_id, access));}
static b32 view_get_cursor_pos(Application_Links *app, View_ID view_id, i32 *pos_out){return(app->view_get_cursor_pos(app, view_id, pos_out));} static i32 view_get_cursor_pos(Application_Links *app, View_ID view_id){return(app->view_get_cursor_pos(app, view_id));}
static b32 view_get_mark_pos(Application_Links *app, View_ID view_id, i32 *pos_out){return(app->view_get_mark_pos(app, view_id, pos_out));} static i32 view_get_mark_pos(Application_Links *app, View_ID view_id){return(app->view_get_mark_pos(app, view_id));}
static b32 view_get_preferred_x(Application_Links *app, View_ID view_id, f32 *preferred_x_out){return(app->view_get_preferred_x(app, view_id, preferred_x_out));} static f32 view_get_preferred_x(Application_Links *app, View_ID view_id){return(app->view_get_preferred_x(app, view_id));}
static b32 view_get_screen_rect(Application_Links *app, View_ID view_id, Rect_f32 *rect_out){return(app->view_get_screen_rect(app, view_id, rect_out));} static Rect_f32 view_get_screen_rect(Application_Links *app, View_ID view_id){return(app->view_get_screen_rect(app, view_id));}
static b32 view_get_panel(Application_Links *app, View_ID view_id, Panel_ID *panel_id_out){return(app->view_get_panel(app, view_id, panel_id_out));} static Panel_ID view_get_panel(Application_Links *app, View_ID view_id){return(app->view_get_panel(app, view_id));}
static b32 panel_get_view(Application_Links *app, Panel_ID panel_id, View_ID *view_id_out){return(app->panel_get_view(app, panel_id, view_id_out));} static View_ID panel_get_view(Application_Links *app, Panel_ID panel_id){return(app->panel_get_view(app, panel_id));}
static b32 panel_is_split(Application_Links *app, Panel_ID panel_id){return(app->panel_is_split(app, panel_id));} static b32 panel_is_split(Application_Links *app, Panel_ID panel_id){return(app->panel_is_split(app, panel_id));}
static b32 panel_is_leaf(Application_Links *app, Panel_ID panel_id){return(app->panel_is_leaf(app, panel_id));} static b32 panel_is_leaf(Application_Links *app, Panel_ID panel_id){return(app->panel_is_leaf(app, panel_id));}
static b32 panel_split(Application_Links *app, Panel_ID panel_id, Panel_Split_Orientation orientation){return(app->panel_split(app, panel_id, orientation));} static b32 panel_split(Application_Links *app, Panel_ID panel_id, Panel_Split_Orientation orientation){return(app->panel_split(app, panel_id, orientation));}
static b32 panel_set_split(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t){return(app->panel_set_split(app, panel_id, kind, t));} static b32 panel_set_split(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t){return(app->panel_set_split(app, panel_id, kind, t));}
static b32 panel_swap_children(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t){return(app->panel_swap_children(app, panel_id, kind, t));} static b32 panel_swap_children(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t){return(app->panel_swap_children(app, panel_id, kind, t));}
static b32 panel_get_parent(Application_Links *app, Panel_ID panel_id, Panel_ID *panel_id_out){return(app->panel_get_parent(app, panel_id, panel_id_out));} static Panel_ID panel_get_parent(Application_Links *app, Panel_ID panel_id){return(app->panel_get_parent(app, panel_id));}
static b32 panel_get_child(Application_Links *app, Panel_ID panel_id, Panel_Child which_child, Panel_ID *panel_id_out){return(app->panel_get_child(app, panel_id, which_child, panel_id_out));} static Panel_ID panel_get_child(Application_Links *app, Panel_ID panel_id, Panel_Child which_child){return(app->panel_get_child(app, panel_id, which_child));}
static b32 panel_get_max(Application_Links *app, Panel_ID panel_id, Panel_ID *panel_id_out){return(app->panel_get_max(app, panel_id, panel_id_out));} static Panel_ID panel_get_max(Application_Links *app, Panel_ID panel_id){return(app->panel_get_max(app, panel_id));}
static b32 panel_get_margin(Application_Links *app, Panel_ID panel_id, i32_Rect *margins_out){return(app->panel_get_margin(app, panel_id, margins_out));} static Rect_i32 panel_get_margin(Application_Links *app, Panel_ID panel_id){return(app->panel_get_margin(app, panel_id));}
static b32 view_close(Application_Links *app, View_ID view_id){return(app->view_close(app, view_id));} static b32 view_close(Application_Links *app, View_ID view_id){return(app->view_close(app, view_id));}
static b32 view_get_region(Application_Links *app, View_ID view_id, Rect_i32 *region_out){return(app->view_get_region(app, view_id, region_out));} static Rect_f32 view_get_buffer_region(Application_Links *app, View_ID view_id){return(app->view_get_buffer_region(app, view_id));}
static b32 view_get_buffer_region(Application_Links *app, View_ID view_id, Rect_i32 *region_out){return(app->view_get_buffer_region(app, view_id, region_out));}
static b32 view_get_scroll_vars(Application_Links *app, View_ID view_id, GUI_Scroll_Vars *scroll_vars_out){return(app->view_get_scroll_vars(app, view_id, scroll_vars_out));} static b32 view_get_scroll_vars(Application_Links *app, View_ID view_id, GUI_Scroll_Vars *scroll_vars_out){return(app->view_get_scroll_vars(app, view_id, scroll_vars_out));}
static b32 view_set_active(Application_Links *app, View_ID view_id){return(app->view_set_active(app, view_id));} static b32 view_set_active(Application_Links *app, View_ID view_id){return(app->view_set_active(app, view_id));}
static b32 view_get_setting(Application_Links *app, View_ID view_id, View_Setting_ID setting, i32 *value_out){return(app->view_get_setting(app, view_id, setting, value_out));} static b32 view_get_setting(Application_Links *app, View_ID view_id, View_Setting_ID setting, i32 *value_out){return(app->view_get_setting(app, view_id, setting, value_out));}
@ -1125,76 +1101,72 @@ static Range get_view_visible_range(Application_Links *app, View_ID view_id){ret
#else #else
static b32 global_set_setting(Application_Links *app, Global_Setting_ID setting, i32 value){return(app->global_set_setting_(app, setting, value));} static b32 global_set_setting(Application_Links *app, Global_Setting_ID setting, i32 value){return(app->global_set_setting_(app, setting, value));}
static b32 global_set_mapping(Application_Links *app, void *data, i32 size){return(app->global_set_mapping_(app, data, size));} static b32 global_set_mapping(Application_Links *app, void *data, i32 size){return(app->global_set_mapping_(app, data, size));}
static b32 global_get_screen_rectangle(Application_Links *app, Rect_f32 *rect_out){return(app->global_get_screen_rectangle_(app, rect_out));} static Rect_f32 global_get_screen_rectangle(Application_Links *app){return(app->global_get_screen_rectangle_(app));}
static Arena* context_get_arena(Application_Links *app){return(app->context_get_arena_(app));} static Arena* context_get_arena(Application_Links *app){return(app->context_get_arena_(app));}
static Base_Allocator* context_get_base_allocator(Application_Links *app){return(app->context_get_base_allocator_(app));} static Base_Allocator* context_get_base_allocator(Application_Links *app){return(app->context_get_base_allocator_(app));}
static b32 create_child_process(Application_Links *app, String_Const_u8 path, String_Const_u8 command, Child_Process_ID *child_process_id_out){return(app->create_child_process_(app, path, command, child_process_id_out));} static b32 create_child_process(Application_Links *app, String_Const_u8 path, String_Const_u8 command, Child_Process_ID *child_process_id_out){return(app->create_child_process_(app, path, command, child_process_id_out));}
static b32 child_process_set_target_buffer(Application_Links *app, Child_Process_ID child_process_id, Buffer_ID buffer_id, Child_Process_Set_Target_Flags flags){return(app->child_process_set_target_buffer_(app, child_process_id, buffer_id, flags));} static b32 child_process_set_target_buffer(Application_Links *app, Child_Process_ID child_process_id, Buffer_ID buffer_id, Child_Process_Set_Target_Flags flags){return(app->child_process_set_target_buffer_(app, child_process_id, buffer_id, flags));}
static b32 buffer_get_attached_child_process(Application_Links *app, Buffer_ID buffer_id, Child_Process_ID *child_process_id_out){return(app->buffer_get_attached_child_process_(app, buffer_id, child_process_id_out));} static Child_Process_ID buffer_get_attached_child_process(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_attached_child_process_(app, buffer_id));}
static b32 child_process_get_attached_buffer(Application_Links *app, Child_Process_ID child_process_id, Buffer_ID *buffer_id_out){return(app->child_process_get_attached_buffer_(app, child_process_id, buffer_id_out));} static Buffer_ID child_process_get_attached_buffer(Application_Links *app, Child_Process_ID child_process_id){return(app->child_process_get_attached_buffer_(app, child_process_id));}
static b32 child_process_get_state(Application_Links *app, Child_Process_ID child_process_id, Process_State *process_state_out){return(app->child_process_get_state_(app, child_process_id, process_state_out));} static Process_State child_process_get_state(Application_Links *app, Child_Process_ID child_process_id){return(app->child_process_get_state_(app, child_process_id));}
static b32 clipboard_post(Application_Links *app, i32 clipboard_id, String_Const_u8 string){return(app->clipboard_post_(app, clipboard_id, string));} static b32 clipboard_post(Application_Links *app, i32 clipboard_id, String_Const_u8 string){return(app->clipboard_post_(app, clipboard_id, string));}
static b32 clipboard_count(Application_Links *app, i32 clipboard_id, i32 *count_out){return(app->clipboard_count_(app, clipboard_id, count_out));} static i32 clipboard_count(Application_Links *app, i32 clipboard_id){return(app->clipboard_count_(app, clipboard_id));}
static b32 clipboard_index(Application_Links *app, i32 clipboard_id, i32 item_index, Arena *out, String_Const_u8 *string_out){return(app->clipboard_index_(app, clipboard_id, item_index, out, string_out));} static String_Const_u8 push_clipboard_index(Application_Links *app, Arena *arena, i32 clipboard_id, i32 item_index){return(app->push_clipboard_index_(app, arena, clipboard_id, item_index));}
static Parse_Context_ID create_parse_context(Application_Links *app, Parser_String_And_Type *kw, u32 kw_count, Parser_String_And_Type *pp, u32 pp_count){return(app->create_parse_context_(app, kw, kw_count, pp, pp_count));} static Parse_Context_ID create_parse_context(Application_Links *app, Parser_String_And_Type *kw, u32 kw_count, Parser_String_And_Type *pp, u32 pp_count){return(app->create_parse_context_(app, kw, kw_count, pp, pp_count));}
static i32 get_buffer_count(Application_Links *app){return(app->get_buffer_count_(app));} static i32 get_buffer_count(Application_Links *app){return(app->get_buffer_count_(app));}
static b32 get_buffer_next(Application_Links *app, Buffer_ID buffer_id, Access_Flag access, Buffer_ID *buffer_id_out){return(app->get_buffer_next_(app, buffer_id, access, buffer_id_out));} static Buffer_ID get_buffer_next(Application_Links *app, Buffer_ID buffer_id, Access_Flag access){return(app->get_buffer_next_(app, buffer_id, access));}
static b32 get_buffer_by_name(Application_Links *app, String_Const_u8 name, Access_Flag access, Buffer_ID *buffer_id_out){return(app->get_buffer_by_name_(app, name, access, buffer_id_out));} static Buffer_ID get_buffer_by_name(Application_Links *app, String_Const_u8 name, Access_Flag access){return(app->get_buffer_by_name_(app, name, access));}
static b32 get_buffer_by_file_name(Application_Links *app, String_Const_u8 file_name, Access_Flag access, Buffer_ID *buffer_id_out){return(app->get_buffer_by_file_name_(app, file_name, access, buffer_id_out));} static Buffer_ID get_buffer_by_file_name(Application_Links *app, String_Const_u8 file_name, Access_Flag access){return(app->get_buffer_by_file_name_(app, file_name, access));}
static b32 buffer_read_range(Application_Links *app, Buffer_ID buffer_id, i32 start, i32 one_past_last, char *out){return(app->buffer_read_range_(app, buffer_id, start, one_past_last, out));} static b32 buffer_read_range(Application_Links *app, Buffer_ID buffer_id, i32 start, i32 one_past_last, char *out){return(app->buffer_read_range_(app, buffer_id, start, one_past_last, out));}
static b32 buffer_replace_range(Application_Links *app, Buffer_ID buffer_id, Range range, String_Const_u8 string){return(app->buffer_replace_range_(app, buffer_id, range, string));} static b32 buffer_replace_range(Application_Links *app, Buffer_ID buffer_id, Range range, String_Const_u8 string){return(app->buffer_replace_range_(app, buffer_id, range, string));}
static b32 buffer_batch_edit(Application_Links *app, Buffer_ID buffer_id, char *str, Buffer_Edit *edits, i32 edit_count){return(app->buffer_batch_edit_(app, buffer_id, str, edits, edit_count));} static b32 buffer_batch_edit(Application_Links *app, Buffer_ID buffer_id, char *str, Buffer_Edit *edits, i32 edit_count){return(app->buffer_batch_edit_(app, buffer_id, str, edits, edit_count));}
static b32 buffer_seek_string(Application_Links *app, Buffer_ID buffer, String_Const_u8 needle, Scan_Direction direction, i32 start_pos, i32 *pos_out, b32 *case_sensitive_out){return(app->buffer_seek_string_(app, buffer, needle, direction, start_pos, pos_out, case_sensitive_out));} static String_Match buffer_seek_string(Application_Links *app, Buffer_ID buffer, String_Const_u8 needle, Scan_Direction direction, i32 start_pos){return(app->buffer_seek_string_(app, buffer, needle, direction, start_pos));}
static b32 buffer_seek_character_class(Application_Links *app, Buffer_ID buffer_id, Character_Predicate *predicate, Scan_Direction direction, i32 start_pos, i32 *pos_out){return(app->buffer_seek_character_class_(app, buffer_id, predicate, direction, start_pos, pos_out));} static b32 buffer_seek_character_class(Application_Links *app, Buffer_ID buffer_id, Character_Predicate *predicate, Scan_Direction direction, i32 start_pos, i32 *pos_out){return(app->buffer_seek_character_class_(app, buffer_id, predicate, direction, start_pos, pos_out));}
static b32 buffer_compute_cursor(Application_Links *app, Buffer_ID buffer_id, Buffer_Seek seek, Partial_Cursor *cursor_out){return(app->buffer_compute_cursor_(app, buffer_id, seek, cursor_out));} static Partial_Cursor buffer_compute_cursor(Application_Links *app, Buffer_ID buffer_id, Buffer_Seek seek){return(app->buffer_compute_cursor_(app, buffer_id, seek));}
static b32 buffer_exists(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_exists_(app, buffer_id));} static b32 buffer_exists(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_exists_(app, buffer_id));}
static b32 buffer_ready(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_ready_(app, buffer_id));} static b32 buffer_ready(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_ready_(app, buffer_id));}
static b32 buffer_get_access_flags(Application_Links *app, Buffer_ID buffer_id, Access_Flag *access_flags_out){return(app->buffer_get_access_flags_(app, buffer_id, access_flags_out));} static Access_Flag buffer_get_access_flags(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_access_flags_(app, buffer_id));}
static b32 buffer_get_size(Application_Links *app, Buffer_ID buffer_id, i32 *size_out){return(app->buffer_get_size_(app, buffer_id, size_out));} static u64 buffer_get_size(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_size_(app, buffer_id));}
static b32 buffer_get_line_count(Application_Links *app, Buffer_ID buffer_id, i32 *line_count_out){return(app->buffer_get_line_count_(app, buffer_id, line_count_out));} static u64 buffer_get_line_count(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_line_count_(app, buffer_id));}
static b32 buffer_get_base_buffer_name(Application_Links *app, Buffer_ID buffer_id, Arena *out, String_Const_u8 *name_out){return(app->buffer_get_base_buffer_name_(app, buffer_id, out, name_out));} static String_Const_u8 push_buffer_base_name(Application_Links *app, Arena *arena, Buffer_ID buffer_id){return(app->push_buffer_base_name_(app, arena, buffer_id));}
static b32 buffer_get_unique_buffer_name(Application_Links *app, Buffer_ID buffer_id, Arena *out, String_Const_u8 *name_out){return(app->buffer_get_unique_buffer_name_(app, buffer_id, out, name_out));} static String_Const_u8 push_buffer_unique_name(Application_Links *app, Arena *out, Buffer_ID buffer_id){return(app->push_buffer_unique_name_(app, out, buffer_id));}
static b32 buffer_get_file_name(Application_Links *app, Buffer_ID buffer_id, Arena *out, String_Const_u8 *name_out){return(app->buffer_get_file_name_(app, buffer_id, out, name_out));} static String_Const_u8 push_buffer_file_name(Application_Links *app, Arena *arena, Buffer_ID buffer_id){return(app->push_buffer_file_name_(app, arena, buffer_id));}
static b32 buffer_get_dirty_state(Application_Links *app, Buffer_ID buffer_id, Dirty_State *dirty_state_out){return(app->buffer_get_dirty_state_(app, buffer_id, dirty_state_out));} static Dirty_State buffer_get_dirty_state(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_dirty_state_(app, buffer_id));}
static b32 buffer_directly_set_dirty_state(Application_Links *app, Buffer_ID buffer_id, Dirty_State dirty_state){return(app->buffer_directly_set_dirty_state_(app, buffer_id, dirty_state));} static b32 buffer_set_dirty_state(Application_Links *app, Buffer_ID buffer_id, Dirty_State dirty_state){return(app->buffer_set_dirty_state_(app, buffer_id, dirty_state));}
static b32 buffer_tokens_are_ready(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_tokens_are_ready_(app, buffer_id));} static b32 buffer_tokens_are_ready(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_tokens_are_ready_(app, buffer_id));}
static b32 buffer_get_setting(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 *value_out){return(app->buffer_get_setting_(app, buffer_id, setting, value_out));} static b32 buffer_get_setting(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 *value_out){return(app->buffer_get_setting_(app, buffer_id, setting, value_out));}
static b32 buffer_set_setting(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 value){return(app->buffer_set_setting_(app, buffer_id, setting, value));} static b32 buffer_set_setting(Application_Links *app, Buffer_ID buffer_id, Buffer_Setting_ID setting, i32 value){return(app->buffer_set_setting_(app, buffer_id, setting, value));}
static b32 buffer_get_managed_scope(Application_Links *app, Buffer_ID buffer_id, Managed_Scope *scope_out){return(app->buffer_get_managed_scope_(app, buffer_id, scope_out));} static Managed_Scope buffer_get_managed_scope(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_managed_scope_(app, buffer_id));}
static b32 buffer_token_count(Application_Links *app, Buffer_ID buffer_id, i32 *count_out){return(app->buffer_token_count_(app, buffer_id, count_out));} static Cpp_Token_Array buffer_get_token_array(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_token_array_(app, buffer_id));}
static b32 buffer_read_tokens(Application_Links *app, Buffer_ID buffer_id, i32 start_token, i32 end_token, Cpp_Token *tokens_out){return(app->buffer_read_tokens_(app, buffer_id, start_token, end_token, tokens_out));}
static b32 buffer_get_token_range(Application_Links *app, Buffer_ID buffer_id, Cpp_Token **first_token_out, Cpp_Token **one_past_last_token_out){return(app->buffer_get_token_range_(app, buffer_id, first_token_out, one_past_last_token_out));}
static b32 buffer_get_token_index(Application_Links *app, Buffer_ID buffer_id, i32 pos, Cpp_Get_Token_Result *get_result){return(app->buffer_get_token_index_(app, buffer_id, pos, get_result));}
static b32 buffer_send_end_signal(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_send_end_signal_(app, buffer_id));} static b32 buffer_send_end_signal(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_send_end_signal_(app, buffer_id));}
static b32 create_buffer(Application_Links *app, String_Const_u8 file_name, Buffer_Create_Flag flags, Buffer_ID *new_buffer_id_out){return(app->create_buffer_(app, file_name, flags, new_buffer_id_out));} static Buffer_ID create_buffer(Application_Links *app, String_Const_u8 file_name, Buffer_Create_Flag flags){return(app->create_buffer_(app, file_name, flags));}
static b32 buffer_save(Application_Links *app, Buffer_ID buffer_id, String_Const_u8 file_name, u32 flags){return(app->buffer_save_(app, buffer_id, file_name, flags));} static b32 buffer_save(Application_Links *app, Buffer_ID buffer_id, String_Const_u8 file_name, Buffer_Save_Flag flags){return(app->buffer_save_(app, buffer_id, file_name, flags));}
static b32 buffer_kill(Application_Links *app, Buffer_ID buffer_id, Buffer_Kill_Flag flags, Buffer_Kill_Result *result_out){return(app->buffer_kill_(app, buffer_id, flags, result_out));} static Buffer_Kill_Result buffer_kill(Application_Links *app, Buffer_ID buffer_id, Buffer_Kill_Flag flags){return(app->buffer_kill_(app, buffer_id, flags));}
static b32 buffer_reopen(Application_Links *app, Buffer_ID buffer_id, Buffer_Reopen_Flag flags, Buffer_Reopen_Result *result_out){return(app->buffer_reopen_(app, buffer_id, flags, result_out));} static Buffer_Reopen_Result buffer_reopen(Application_Links *app, Buffer_ID buffer_id, Buffer_Reopen_Flag flags){return(app->buffer_reopen_(app, buffer_id, flags));}
static b32 buffer_get_file_attributes(Application_Links *app, Buffer_ID buffer_id, File_Attributes *attributes_out){return(app->buffer_get_file_attributes_(app, buffer_id, attributes_out));} static File_Attributes buffer_get_file_attributes(Application_Links *app, Buffer_ID buffer_id){return(app->buffer_get_file_attributes_(app, buffer_id));}
static b32 get_view_next(Application_Links *app, View_ID view_id, Access_Flag access, View_ID *view_id_out){return(app->get_view_next_(app, view_id, access, view_id_out));} static View_ID get_view_next(Application_Links *app, View_ID view_id, Access_Flag access){return(app->get_view_next_(app, view_id, access));}
static b32 get_view_prev(Application_Links *app, View_ID view_id, Access_Flag access, View_ID *view_id_out){return(app->get_view_prev_(app, view_id, access, view_id_out));} static View_ID get_view_prev(Application_Links *app, View_ID view_id, Access_Flag access){return(app->get_view_prev_(app, view_id, access));}
static b32 get_active_view(Application_Links *app, Access_Flag access, View_ID *view_id_out){return(app->get_active_view_(app, access, view_id_out));} static View_ID get_active_view(Application_Links *app, Access_Flag access){return(app->get_active_view_(app, access));}
static b32 get_active_panel(Application_Links *app, Panel_ID *panel_id_out){return(app->get_active_panel_(app, panel_id_out));} static Panel_ID get_active_panel(Application_Links *app){return(app->get_active_panel_(app));}
static b32 view_exists(Application_Links *app, View_ID view_id){return(app->view_exists_(app, view_id));} static b32 view_exists(Application_Links *app, View_ID view_id){return(app->view_exists_(app, view_id));}
static b32 view_get_buffer(Application_Links *app, View_ID view_id, Access_Flag access, Buffer_ID *buffer_id_out){return(app->view_get_buffer_(app, view_id, access, buffer_id_out));} static Buffer_ID view_get_buffer(Application_Links *app, View_ID view_id, Access_Flag access){return(app->view_get_buffer_(app, view_id, access));}
static b32 view_get_cursor_pos(Application_Links *app, View_ID view_id, i32 *pos_out){return(app->view_get_cursor_pos_(app, view_id, pos_out));} static i32 view_get_cursor_pos(Application_Links *app, View_ID view_id){return(app->view_get_cursor_pos_(app, view_id));}
static b32 view_get_mark_pos(Application_Links *app, View_ID view_id, i32 *pos_out){return(app->view_get_mark_pos_(app, view_id, pos_out));} static i32 view_get_mark_pos(Application_Links *app, View_ID view_id){return(app->view_get_mark_pos_(app, view_id));}
static b32 view_get_preferred_x(Application_Links *app, View_ID view_id, f32 *preferred_x_out){return(app->view_get_preferred_x_(app, view_id, preferred_x_out));} static f32 view_get_preferred_x(Application_Links *app, View_ID view_id){return(app->view_get_preferred_x_(app, view_id));}
static b32 view_get_screen_rect(Application_Links *app, View_ID view_id, Rect_f32 *rect_out){return(app->view_get_screen_rect_(app, view_id, rect_out));} static Rect_f32 view_get_screen_rect(Application_Links *app, View_ID view_id){return(app->view_get_screen_rect_(app, view_id));}
static b32 view_get_panel(Application_Links *app, View_ID view_id, Panel_ID *panel_id_out){return(app->view_get_panel_(app, view_id, panel_id_out));} static Panel_ID view_get_panel(Application_Links *app, View_ID view_id){return(app->view_get_panel_(app, view_id));}
static b32 panel_get_view(Application_Links *app, Panel_ID panel_id, View_ID *view_id_out){return(app->panel_get_view_(app, panel_id, view_id_out));} static View_ID panel_get_view(Application_Links *app, Panel_ID panel_id){return(app->panel_get_view_(app, panel_id));}
static b32 panel_is_split(Application_Links *app, Panel_ID panel_id){return(app->panel_is_split_(app, panel_id));} static b32 panel_is_split(Application_Links *app, Panel_ID panel_id){return(app->panel_is_split_(app, panel_id));}
static b32 panel_is_leaf(Application_Links *app, Panel_ID panel_id){return(app->panel_is_leaf_(app, panel_id));} static b32 panel_is_leaf(Application_Links *app, Panel_ID panel_id){return(app->panel_is_leaf_(app, panel_id));}
static b32 panel_split(Application_Links *app, Panel_ID panel_id, Panel_Split_Orientation orientation){return(app->panel_split_(app, panel_id, orientation));} static b32 panel_split(Application_Links *app, Panel_ID panel_id, Panel_Split_Orientation orientation){return(app->panel_split_(app, panel_id, orientation));}
static b32 panel_set_split(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t){return(app->panel_set_split_(app, panel_id, kind, t));} static b32 panel_set_split(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t){return(app->panel_set_split_(app, panel_id, kind, t));}
static b32 panel_swap_children(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t){return(app->panel_swap_children_(app, panel_id, kind, t));} static b32 panel_swap_children(Application_Links *app, Panel_ID panel_id, Panel_Split_Kind kind, float t){return(app->panel_swap_children_(app, panel_id, kind, t));}
static b32 panel_get_parent(Application_Links *app, Panel_ID panel_id, Panel_ID *panel_id_out){return(app->panel_get_parent_(app, panel_id, panel_id_out));} static Panel_ID panel_get_parent(Application_Links *app, Panel_ID panel_id){return(app->panel_get_parent_(app, panel_id));}
static b32 panel_get_child(Application_Links *app, Panel_ID panel_id, Panel_Child which_child, Panel_ID *panel_id_out){return(app->panel_get_child_(app, panel_id, which_child, panel_id_out));} static Panel_ID panel_get_child(Application_Links *app, Panel_ID panel_id, Panel_Child which_child){return(app->panel_get_child_(app, panel_id, which_child));}
static b32 panel_get_max(Application_Links *app, Panel_ID panel_id, Panel_ID *panel_id_out){return(app->panel_get_max_(app, panel_id, panel_id_out));} static Panel_ID panel_get_max(Application_Links *app, Panel_ID panel_id){return(app->panel_get_max_(app, panel_id));}
static b32 panel_get_margin(Application_Links *app, Panel_ID panel_id, i32_Rect *margins_out){return(app->panel_get_margin_(app, panel_id, margins_out));} static Rect_i32 panel_get_margin(Application_Links *app, Panel_ID panel_id){return(app->panel_get_margin_(app, panel_id));}
static b32 view_close(Application_Links *app, View_ID view_id){return(app->view_close_(app, view_id));} static b32 view_close(Application_Links *app, View_ID view_id){return(app->view_close_(app, view_id));}
static b32 view_get_region(Application_Links *app, View_ID view_id, Rect_i32 *region_out){return(app->view_get_region_(app, view_id, region_out));} static Rect_f32 view_get_buffer_region(Application_Links *app, View_ID view_id){return(app->view_get_buffer_region_(app, view_id));}
static b32 view_get_buffer_region(Application_Links *app, View_ID view_id, Rect_i32 *region_out){return(app->view_get_buffer_region_(app, view_id, region_out));}
static b32 view_get_scroll_vars(Application_Links *app, View_ID view_id, GUI_Scroll_Vars *scroll_vars_out){return(app->view_get_scroll_vars_(app, view_id, scroll_vars_out));} static b32 view_get_scroll_vars(Application_Links *app, View_ID view_id, GUI_Scroll_Vars *scroll_vars_out){return(app->view_get_scroll_vars_(app, view_id, scroll_vars_out));}
static b32 view_set_active(Application_Links *app, View_ID view_id){return(app->view_set_active_(app, view_id));} static b32 view_set_active(Application_Links *app, View_ID view_id){return(app->view_set_active_(app, view_id));}
static b32 view_get_setting(Application_Links *app, View_ID view_id, View_Setting_ID setting, i32 *value_out){return(app->view_get_setting_(app, view_id, setting, value_out));} static b32 view_get_setting(Application_Links *app, View_ID view_id, View_Setting_ID setting, i32 *value_out){return(app->view_get_setting_(app, view_id, setting, value_out));}

View File

@ -257,242 +257,242 @@ int32_t source_name_len;
int32_t line_number; int32_t line_number;
}; };
static Command_Metadata fcoder_metacmd_table[236] = { static Command_Metadata fcoder_metacmd_table[236] = {
{ PROC_LINKS(replace_all_occurrences, 0), "replace_all_occurrences", 23, "Queries the user for two strings, and replaces all occurrences of the first string with the second string in all open buffers.", 126, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 806 }, { PROC_LINKS(replace_all_occurrences, 0), "replace_all_occurrences", 23, "Queries the user for two strings, and replaces all occurrences of the first string with the second string in all open buffers.", 126, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 775 },
{ PROC_LINKS(seek_beginning_of_textual_line, 0), "seek_beginning_of_textual_line", 30, "Seeks the cursor to the beginning of the line across all text.", 62, "w:\\4ed\\code\\4coder_seek.cpp", 27, 34 }, { PROC_LINKS(seek_beginning_of_textual_line, 0), "seek_beginning_of_textual_line", 30, "Seeks the cursor to the beginning of the line across all text.", 62, "w:\\4ed\\code\\4coder_seek.cpp", 27, 29 },
{ PROC_LINKS(seek_end_of_textual_line, 0), "seek_end_of_textual_line", 24, "Seeks the cursor to the end of the line across all text.", 56, "w:\\4ed\\code\\4coder_seek.cpp", 27, 40 }, { PROC_LINKS(seek_end_of_textual_line, 0), "seek_end_of_textual_line", 24, "Seeks the cursor to the end of the line across all text.", 56, "w:\\4ed\\code\\4coder_seek.cpp", 27, 35 },
{ PROC_LINKS(seek_beginning_of_line, 0), "seek_beginning_of_line", 22, "Seeks the cursor to the beginning of the visual line.", 53, "w:\\4ed\\code\\4coder_seek.cpp", 27, 46 }, { PROC_LINKS(seek_beginning_of_line, 0), "seek_beginning_of_line", 22, "Seeks the cursor to the beginning of the visual line.", 53, "w:\\4ed\\code\\4coder_seek.cpp", 27, 41 },
{ PROC_LINKS(seek_end_of_line, 0), "seek_end_of_line", 16, "Seeks the cursor to the end of the visual line.", 47, "w:\\4ed\\code\\4coder_seek.cpp", 27, 52 }, { PROC_LINKS(seek_end_of_line, 0), "seek_end_of_line", 16, "Seeks the cursor to the end of the visual line.", 47, "w:\\4ed\\code\\4coder_seek.cpp", 27, 47 },
{ PROC_LINKS(goto_beginning_of_file, 0), "goto_beginning_of_file", 22, "Sets the cursor to the beginning of the file.", 45, "w:\\4ed\\code\\4coder_seek.cpp", 27, 58 }, { PROC_LINKS(goto_beginning_of_file, 0), "goto_beginning_of_file", 22, "Sets the cursor to the beginning of the file.", 45, "w:\\4ed\\code\\4coder_seek.cpp", 27, 53 },
{ PROC_LINKS(goto_end_of_file, 0), "goto_end_of_file", 16, "Sets the cursor to the end of the file.", 39, "w:\\4ed\\code\\4coder_seek.cpp", 27, 67 }, { PROC_LINKS(goto_end_of_file, 0), "goto_end_of_file", 16, "Sets the cursor to the end of the file.", 39, "w:\\4ed\\code\\4coder_seek.cpp", 27, 61 },
{ PROC_LINKS(change_active_panel, 0), "change_active_panel", 19, "Change the currently active panel, moving to the panel with the next highest view_id.", 85, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 206 }, { PROC_LINKS(change_active_panel, 0), "change_active_panel", 19, "Change the currently active panel, moving to the panel with the next highest view_id.", 85, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 201 },
{ PROC_LINKS(change_active_panel_backwards, 0), "change_active_panel_backwards", 29, "Change the currently active panel, moving to the panel with the next lowest view_id.", 84, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 217 }, { PROC_LINKS(change_active_panel_backwards, 0), "change_active_panel_backwards", 29, "Change the currently active panel, moving to the panel with the next lowest view_id.", 84, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 211 },
{ PROC_LINKS(open_panel_vsplit, 0), "open_panel_vsplit", 17, "Create a new panel by vertically splitting the active panel.", 60, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 228 }, { PROC_LINKS(open_panel_vsplit, 0), "open_panel_vsplit", 17, "Create a new panel by vertically splitting the active panel.", 60, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 221 },
{ PROC_LINKS(open_panel_hsplit, 0), "open_panel_hsplit", 17, "Create a new panel by horizontally splitting the active panel.", 62, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 240 }, { PROC_LINKS(open_panel_hsplit, 0), "open_panel_hsplit", 17, "Create a new panel by horizontally splitting the active panel.", 62, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 231 },
{ PROC_LINKS(suppress_mouse, 0), "suppress_mouse", 14, "Hides the mouse and causes all mosue input (clicks, position, wheel) to be ignored.", 83, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 307 }, { PROC_LINKS(suppress_mouse, 0), "suppress_mouse", 14, "Hides the mouse and causes all mosue input (clicks, position, wheel) to be ignored.", 83, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 294 },
{ PROC_LINKS(allow_mouse, 0), "allow_mouse", 11, "Shows the mouse and causes all mouse input to be processed normally.", 68, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 313 }, { PROC_LINKS(allow_mouse, 0), "allow_mouse", 11, "Shows the mouse and causes all mouse input to be processed normally.", 68, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 300 },
{ PROC_LINKS(toggle_mouse, 0), "toggle_mouse", 12, "Toggles the mouse suppression mode, see suppress_mouse and allow_mouse.", 71, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 319 }, { PROC_LINKS(toggle_mouse, 0), "toggle_mouse", 12, "Toggles the mouse suppression mode, see suppress_mouse and allow_mouse.", 71, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 306 },
{ PROC_LINKS(set_mode_to_original, 0), "set_mode_to_original", 20, "Sets the edit mode to 4coder original.", 38, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 325 }, { PROC_LINKS(set_mode_to_original, 0), "set_mode_to_original", 20, "Sets the edit mode to 4coder original.", 38, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 312 },
{ PROC_LINKS(set_mode_to_notepad_like, 0), "set_mode_to_notepad_like", 24, "Sets the edit mode to Notepad like.", 35, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 331 }, { PROC_LINKS(set_mode_to_notepad_like, 0), "set_mode_to_notepad_like", 24, "Sets the edit mode to Notepad like.", 35, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 318 },
{ PROC_LINKS(toggle_highlight_line_at_cursor, 0), "toggle_highlight_line_at_cursor", 31, "Toggles the line highlight at the cursor.", 41, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 337 }, { PROC_LINKS(toggle_highlight_line_at_cursor, 0), "toggle_highlight_line_at_cursor", 31, "Toggles the line highlight at the cursor.", 41, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 324 },
{ PROC_LINKS(toggle_highlight_enclosing_scopes, 0), "toggle_highlight_enclosing_scopes", 33, "In code files scopes surrounding the cursor are highlighted with distinguishing colors.", 87, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 343 }, { PROC_LINKS(toggle_highlight_enclosing_scopes, 0), "toggle_highlight_enclosing_scopes", 33, "In code files scopes surrounding the cursor are highlighted with distinguishing colors.", 87, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 330 },
{ PROC_LINKS(toggle_paren_matching_helper, 0), "toggle_paren_matching_helper", 28, "In code files matching parentheses pairs are colored with distinguishing colors.", 80, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 349 }, { PROC_LINKS(toggle_paren_matching_helper, 0), "toggle_paren_matching_helper", 28, "In code files matching parentheses pairs are colored with distinguishing colors.", 80, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 336 },
{ PROC_LINKS(toggle_fullscreen, 0), "toggle_fullscreen", 17, "Toggle fullscreen mode on or off. The change(s) do not take effect until the next frame.", 89, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 355 }, { PROC_LINKS(toggle_fullscreen, 0), "toggle_fullscreen", 17, "Toggle fullscreen mode on or off. The change(s) do not take effect until the next frame.", 89, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 342 },
{ PROC_LINKS(remap_interactive, 0), "remap_interactive", 17, "Switch to a named key binding map.", 34, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 363 }, { PROC_LINKS(remap_interactive, 0), "remap_interactive", 17, "Switch to a named key binding map.", 34, "w:\\4ed\\code\\4coder_default_framework.cpp", 40, 350 },
{ PROC_LINKS(write_character, 0), "write_character", 15, "Inserts whatever character was used to trigger this command.", 60, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 72 }, { PROC_LINKS(write_character, 0), "write_character", 15, "Inserts whatever character was used to trigger this command.", 60, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 69 },
{ PROC_LINKS(write_underscore, 0), "write_underscore", 16, "Inserts an underscore.", 22, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 81 }, { PROC_LINKS(write_underscore, 0), "write_underscore", 16, "Inserts an underscore.", 22, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 78 },
{ PROC_LINKS(delete_char, 0), "delete_char", 11, "Deletes the character to the right of the cursor.", 49, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 88 }, { PROC_LINKS(delete_char, 0), "delete_char", 11, "Deletes the character to the right of the cursor.", 49, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 85 },
{ PROC_LINKS(backspace_char, 0), "backspace_char", 14, "Deletes the character to the left of the cursor.", 48, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 110 }, { PROC_LINKS(backspace_char, 0), "backspace_char", 14, "Deletes the character to the left of the cursor.", 48, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 103 },
{ PROC_LINKS(set_mark, 0), "set_mark", 8, "Sets the mark to the current position of the cursor.", 52, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 134 }, { PROC_LINKS(set_mark, 0), "set_mark", 8, "Sets the mark to the current position of the cursor.", 52, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 123 },
{ PROC_LINKS(cursor_mark_swap, 0), "cursor_mark_swap", 16, "Swaps the position of the cursor and the mark.", 46, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 145 }, { PROC_LINKS(cursor_mark_swap, 0), "cursor_mark_swap", 16, "Swaps the position of the cursor and the mark.", 46, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 132 },
{ PROC_LINKS(delete_range, 0), "delete_range", 12, "Deletes the text in the range between the cursor and the mark.", 62, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 158 }, { PROC_LINKS(delete_range, 0), "delete_range", 12, "Deletes the text in the range between the cursor and the mark.", 62, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 142 },
{ PROC_LINKS(backspace_alpha_numeric_boundary, 0), "backspace_alpha_numeric_boundary", 32, "Delete characters between the cursor position and the first alphanumeric boundary to the left.", 94, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 182 }, { PROC_LINKS(backspace_alpha_numeric_boundary, 0), "backspace_alpha_numeric_boundary", 32, "Delete characters between the cursor position and the first alphanumeric boundary to the left.", 94, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 162 },
{ PROC_LINKS(delete_alpha_numeric_boundary, 0), "delete_alpha_numeric_boundary", 29, "Delete characters between the cursor position and the first alphanumeric boundary to the right.", 95, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 190 }, { PROC_LINKS(delete_alpha_numeric_boundary, 0), "delete_alpha_numeric_boundary", 29, "Delete characters between the cursor position and the first alphanumeric boundary to the right.", 95, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 170 },
{ PROC_LINKS(snipe_backward_whitespace_or_token_boundary, 0), "snipe_backward_whitespace_or_token_boundary", 43, "Delete a single, whole token on or to the left of the cursor and post it to the clipboard.", 90, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 213 }, { PROC_LINKS(snipe_backward_whitespace_or_token_boundary, 0), "snipe_backward_whitespace_or_token_boundary", 43, "Delete a single, whole token on or to the left of the cursor and post it to the clipboard.", 90, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 190 },
{ PROC_LINKS(snipe_forward_whitespace_or_token_boundary, 0), "snipe_forward_whitespace_or_token_boundary", 42, "Delete a single, whole token on or to the right of the cursor and post it to the clipboard.", 91, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 221 }, { PROC_LINKS(snipe_forward_whitespace_or_token_boundary, 0), "snipe_forward_whitespace_or_token_boundary", 42, "Delete a single, whole token on or to the right of the cursor and post it to the clipboard.", 91, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 198 },
{ PROC_LINKS(center_view, 0), "center_view", 11, "Centers the view vertically on the line on which the cursor sits.", 65, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 234 }, { PROC_LINKS(center_view, 0), "center_view", 11, "Centers the view vertically on the line on which the cursor sits.", 65, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 211 },
{ PROC_LINKS(left_adjust_view, 0), "left_adjust_view", 16, "Sets the left size of the view near the x position of the cursor.", 65, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 252 }, { PROC_LINKS(left_adjust_view, 0), "left_adjust_view", 16, "Sets the left size of the view near the x position of the cursor.", 65, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 227 },
{ PROC_LINKS(click_set_cursor_and_mark, 0), "click_set_cursor_and_mark", 25, "Sets the cursor position and mark to the mouse position.", 56, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 277 }, { PROC_LINKS(click_set_cursor_and_mark, 0), "click_set_cursor_and_mark", 25, "Sets the cursor position and mark to the mouse position.", 56, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 251 },
{ PROC_LINKS(click_set_cursor, 0), "click_set_cursor", 16, "Sets the cursor position to the mouse position.", 47, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 296 }, { PROC_LINKS(click_set_cursor, 0), "click_set_cursor", 16, "Sets the cursor position to the mouse position.", 47, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 268 },
{ PROC_LINKS(click_set_cursor_if_lbutton, 0), "click_set_cursor_if_lbutton", 27, "If the mouse left button is pressed, sets the cursor position to the mouse position.", 84, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 313 }, { PROC_LINKS(click_set_cursor_if_lbutton, 0), "click_set_cursor_if_lbutton", 27, "If the mouse left button is pressed, sets the cursor position to the mouse position.", 84, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 283 },
{ PROC_LINKS(click_set_mark, 0), "click_set_mark", 14, "Sets the mark position to the mouse position.", 45, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 332 }, { PROC_LINKS(click_set_mark, 0), "click_set_mark", 14, "Sets the mark position to the mouse position.", 45, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 300 },
{ PROC_LINKS(mouse_wheel_scroll, 0), "mouse_wheel_scroll", 18, "Reads the scroll wheel value from the mouse state and scrolls accordingly.", 74, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 349 }, { PROC_LINKS(mouse_wheel_scroll, 0), "mouse_wheel_scroll", 18, "Reads the scroll wheel value from the mouse state and scrolls accordingly.", 74, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 315 },
{ PROC_LINKS(move_up, 0), "move_up", 7, "Moves the cursor up one line.", 29, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 425 }, { PROC_LINKS(move_up, 0), "move_up", 7, "Moves the cursor up one line.", 29, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 382 },
{ PROC_LINKS(move_down, 0), "move_down", 9, "Moves the cursor down one line.", 31, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 431 }, { PROC_LINKS(move_down, 0), "move_down", 9, "Moves the cursor down one line.", 31, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 388 },
{ PROC_LINKS(move_up_10, 0), "move_up_10", 10, "Moves the cursor up ten lines.", 30, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 437 }, { PROC_LINKS(move_up_10, 0), "move_up_10", 10, "Moves the cursor up ten lines.", 30, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 394 },
{ PROC_LINKS(move_down_10, 0), "move_down_10", 12, "Moves the cursor down ten lines.", 32, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 443 }, { PROC_LINKS(move_down_10, 0), "move_down_10", 12, "Moves the cursor down ten lines.", 32, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 400 },
{ PROC_LINKS(move_down_textual, 0), "move_down_textual", 17, "Moves down to the next line of actual text, regardless of line wrapping.", 72, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 449 }, { PROC_LINKS(move_down_textual, 0), "move_down_textual", 17, "Moves down to the next line of actual text, regardless of line wrapping.", 72, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 406 },
{ PROC_LINKS(page_up, 0), "page_up", 7, "Scrolls the view up one view height and moves the cursor up one view height.", 76, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 463 }, { PROC_LINKS(page_up, 0), "page_up", 7, "Scrolls the view up one view height and moves the cursor up one view height.", 76, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 417 },
{ PROC_LINKS(page_down, 0), "page_down", 9, "Scrolls the view down one view height and moves the cursor down one view height.", 80, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 472 }, { PROC_LINKS(page_down, 0), "page_down", 9, "Scrolls the view down one view height and moves the cursor down one view height.", 80, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 425 },
{ PROC_LINKS(move_up_to_blank_line, 0), "move_up_to_blank_line", 21, "Seeks the cursor up to the next blank line.", 43, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 505 }, { PROC_LINKS(move_up_to_blank_line, 0), "move_up_to_blank_line", 21, "Seeks the cursor up to the next blank line.", 43, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 454 },
{ PROC_LINKS(move_down_to_blank_line, 0), "move_down_to_blank_line", 23, "Seeks the cursor down to the next blank line.", 45, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 511 }, { PROC_LINKS(move_down_to_blank_line, 0), "move_down_to_blank_line", 23, "Seeks the cursor down to the next blank line.", 45, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 460 },
{ PROC_LINKS(move_up_to_blank_line_skip_whitespace, 0), "move_up_to_blank_line_skip_whitespace", 37, "Seeks the cursor up to the next blank line and places it at the end of the line.", 80, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 517 }, { PROC_LINKS(move_up_to_blank_line_skip_whitespace, 0), "move_up_to_blank_line_skip_whitespace", 37, "Seeks the cursor up to the next blank line and places it at the end of the line.", 80, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 466 },
{ PROC_LINKS(move_down_to_blank_line_skip_whitespace, 0), "move_down_to_blank_line_skip_whitespace", 39, "Seeks the cursor down to the next blank line and places it at the end of the line.", 82, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 523 }, { PROC_LINKS(move_down_to_blank_line_skip_whitespace, 0), "move_down_to_blank_line_skip_whitespace", 39, "Seeks the cursor down to the next blank line and places it at the end of the line.", 82, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 472 },
{ PROC_LINKS(move_up_to_blank_line_end, 0), "move_up_to_blank_line_end", 25, "Seeks the cursor up to the next blank line and places it at the end of the line.", 80, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 529 }, { PROC_LINKS(move_up_to_blank_line_end, 0), "move_up_to_blank_line_end", 25, "Seeks the cursor up to the next blank line and places it at the end of the line.", 80, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 478 },
{ PROC_LINKS(move_down_to_blank_line_end, 0), "move_down_to_blank_line_end", 27, "Seeks the cursor down to the next blank line and places it at the end of the line.", 82, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 535 }, { PROC_LINKS(move_down_to_blank_line_end, 0), "move_down_to_blank_line_end", 27, "Seeks the cursor down to the next blank line and places it at the end of the line.", 82, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 484 },
{ PROC_LINKS(move_left, 0), "move_left", 9, "Moves the cursor one character to the left.", 43, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 546 }, { PROC_LINKS(move_left, 0), "move_left", 9, "Moves the cursor one character to the left.", 43, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 495 },
{ PROC_LINKS(move_right, 0), "move_right", 10, "Moves the cursor one character to the right.", 44, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 560 }, { PROC_LINKS(move_right, 0), "move_right", 10, "Moves the cursor one character to the right.", 44, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 507 },
{ PROC_LINKS(move_right_whitespace_boundary, 0), "move_right_whitespace_boundary", 30, "Seek right for the next boundary between whitespace and non-whitespace.", 71, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 587 }, { PROC_LINKS(move_right_whitespace_boundary, 0), "move_right_whitespace_boundary", 30, "Seek right for the next boundary between whitespace and non-whitespace.", 71, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 529 },
{ PROC_LINKS(move_left_whitespace_boundary, 0), "move_left_whitespace_boundary", 29, "Seek left for the next boundary between whitespace and non-whitespace.", 70, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 595 }, { PROC_LINKS(move_left_whitespace_boundary, 0), "move_left_whitespace_boundary", 29, "Seek left for the next boundary between whitespace and non-whitespace.", 70, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 537 },
{ PROC_LINKS(move_right_token_boundary, 0), "move_right_token_boundary", 25, "Seek right for the next end of a token.", 39, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 603 }, { PROC_LINKS(move_right_token_boundary, 0), "move_right_token_boundary", 25, "Seek right for the next end of a token.", 39, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 545 },
{ PROC_LINKS(move_left_token_boundary, 0), "move_left_token_boundary", 24, "Seek left for the next beginning of a token.", 44, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 611 }, { PROC_LINKS(move_left_token_boundary, 0), "move_left_token_boundary", 24, "Seek left for the next beginning of a token.", 44, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 553 },
{ PROC_LINKS(move_right_whitespace_or_token_boundary, 0), "move_right_whitespace_or_token_boundary", 39, "Seek right for the next end of a token or boundary between whitespace and non-whitespace.", 89, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 619 }, { PROC_LINKS(move_right_whitespace_or_token_boundary, 0), "move_right_whitespace_or_token_boundary", 39, "Seek right for the next end of a token or boundary between whitespace and non-whitespace.", 89, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 561 },
{ PROC_LINKS(move_left_whitespace_or_token_boundary, 0), "move_left_whitespace_or_token_boundary", 38, "Seek left for the next end of a token or boundary between whitespace and non-whitespace.", 88, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 627 }, { PROC_LINKS(move_left_whitespace_or_token_boundary, 0), "move_left_whitespace_or_token_boundary", 38, "Seek left for the next end of a token or boundary between whitespace and non-whitespace.", 88, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 569 },
{ PROC_LINKS(move_right_alpha_numeric_boundary, 0), "move_right_alpha_numeric_boundary", 33, "Seek right for boundary between alphanumeric characters and non-alphanumeric characters.", 88, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 635 }, { PROC_LINKS(move_right_alpha_numeric_boundary, 0), "move_right_alpha_numeric_boundary", 33, "Seek right for boundary between alphanumeric characters and non-alphanumeric characters.", 88, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 577 },
{ PROC_LINKS(move_left_alpha_numeric_boundary, 0), "move_left_alpha_numeric_boundary", 32, "Seek left for boundary between alphanumeric characters and non-alphanumeric characters.", 87, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 643 }, { PROC_LINKS(move_left_alpha_numeric_boundary, 0), "move_left_alpha_numeric_boundary", 32, "Seek left for boundary between alphanumeric characters and non-alphanumeric characters.", 87, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 585 },
{ PROC_LINKS(move_right_alpha_numeric_or_camel_boundary, 0), "move_right_alpha_numeric_or_camel_boundary", 42, "Seek right for boundary between alphanumeric characters or camel case word and non-alphanumeric characters.", 107, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 651 }, { PROC_LINKS(move_right_alpha_numeric_or_camel_boundary, 0), "move_right_alpha_numeric_or_camel_boundary", 42, "Seek right for boundary between alphanumeric characters or camel case word and non-alphanumeric characters.", 107, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 593 },
{ PROC_LINKS(move_left_alpha_numeric_or_camel_boundary, 0), "move_left_alpha_numeric_or_camel_boundary", 41, "Seek left for boundary between alphanumeric characters or camel case word and non-alphanumeric characters.", 106, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 659 }, { PROC_LINKS(move_left_alpha_numeric_or_camel_boundary, 0), "move_left_alpha_numeric_or_camel_boundary", 41, "Seek left for boundary between alphanumeric characters or camel case word and non-alphanumeric characters.", 106, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 601 },
{ PROC_LINKS(select_all, 0), "select_all", 10, "Puts the cursor at the top of the file, and the mark at the bottom of the file.", 79, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 680 }, { PROC_LINKS(select_all, 0), "select_all", 10, "Puts the cursor at the top of the file, and the mark at the bottom of the file.", 79, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 622 },
{ PROC_LINKS(to_uppercase, 0), "to_uppercase", 12, "Converts all ascii text in the range between the cursor and the mark to uppercase.", 82, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 696 }, { PROC_LINKS(to_uppercase, 0), "to_uppercase", 12, "Converts all ascii text in the range between the cursor and the mark to uppercase.", 82, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 635 },
{ PROC_LINKS(to_lowercase, 0), "to_lowercase", 12, "Converts all ascii text in the range between the cursor and the mark to lowercase.", 82, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 711 }, { PROC_LINKS(to_lowercase, 0), "to_lowercase", 12, "Converts all ascii text in the range between the cursor and the mark to lowercase.", 82, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 648 },
{ PROC_LINKS(clean_all_lines, 0), "clean_all_lines", 15, "Removes trailing whitespace from all lines in the current buffer.", 65, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 726 }, { PROC_LINKS(clean_all_lines, 0), "clean_all_lines", 15, "Removes trailing whitespace from all lines in the current buffer.", 65, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 661 },
{ PROC_LINKS(basic_change_active_panel, 0), "basic_change_active_panel", 25, "Change the currently active panel, moving to the panel with the next highest view_id. Will not skipe the build panel if it is open.", 132, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 767 }, { PROC_LINKS(basic_change_active_panel, 0), "basic_change_active_panel", 25, "Change the currently active panel, moving to the panel with the next highest view_id. Will not skipe the build panel if it is open.", 132, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 699 },
{ PROC_LINKS(close_panel, 0), "close_panel", 11, "Closes the currently active panel if it is not the only panel open.", 67, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 776 }, { PROC_LINKS(close_panel, 0), "close_panel", 11, "Closes the currently active panel if it is not the only panel open.", 67, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 707 },
{ PROC_LINKS(show_scrollbar, 0), "show_scrollbar", 14, "Sets the current view to show it's scrollbar.", 45, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 786 }, { PROC_LINKS(show_scrollbar, 0), "show_scrollbar", 14, "Sets the current view to show it's scrollbar.", 45, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 716 },
{ PROC_LINKS(hide_scrollbar, 0), "hide_scrollbar", 14, "Sets the current view to hide it's scrollbar.", 45, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 794 }, { PROC_LINKS(hide_scrollbar, 0), "hide_scrollbar", 14, "Sets the current view to hide it's scrollbar.", 45, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 723 },
{ PROC_LINKS(show_filebar, 0), "show_filebar", 12, "Sets the current view to show it's filebar.", 43, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 802 }, { PROC_LINKS(show_filebar, 0), "show_filebar", 12, "Sets the current view to show it's filebar.", 43, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 730 },
{ PROC_LINKS(hide_filebar, 0), "hide_filebar", 12, "Sets the current view to hide it's filebar.", 43, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 810 }, { PROC_LINKS(hide_filebar, 0), "hide_filebar", 12, "Sets the current view to hide it's filebar.", 43, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 737 },
{ PROC_LINKS(toggle_filebar, 0), "toggle_filebar", 14, "Toggles the visibility status of the current view's filebar.", 60, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 818 }, { PROC_LINKS(toggle_filebar, 0), "toggle_filebar", 14, "Toggles the visibility status of the current view's filebar.", 60, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 744 },
{ PROC_LINKS(toggle_line_wrap, 0), "toggle_line_wrap", 16, "Toggles the current buffer's line wrapping status.", 50, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 828 }, { PROC_LINKS(toggle_line_wrap, 0), "toggle_line_wrap", 16, "Toggles the current buffer's line wrapping status.", 50, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 753 },
{ PROC_LINKS(toggle_fps_meter, 0), "toggle_fps_meter", 16, "Toggles the visibility of the FPS performance meter", 51, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 840 }, { PROC_LINKS(toggle_fps_meter, 0), "toggle_fps_meter", 16, "Toggles the visibility of the FPS performance meter", 51, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 763 },
{ PROC_LINKS(increase_line_wrap, 0), "increase_line_wrap", 18, "Increases the current buffer's width for line wrapping.", 55, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 846 }, { PROC_LINKS(increase_line_wrap, 0), "increase_line_wrap", 18, "Increases the current buffer's width for line wrapping.", 55, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 769 },
{ PROC_LINKS(decrease_line_wrap, 0), "decrease_line_wrap", 18, "Decrases the current buffer's width for line wrapping.", 54, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 858 }, { PROC_LINKS(decrease_line_wrap, 0), "decrease_line_wrap", 18, "Decrases the current buffer's width for line wrapping.", 54, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 779 },
{ PROC_LINKS(increase_face_size, 0), "increase_face_size", 18, "Increase the size of the face used by the current buffer.", 57, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 870 }, { PROC_LINKS(increase_face_size, 0), "increase_face_size", 18, "Increase the size of the face used by the current buffer.", 57, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 789 },
{ PROC_LINKS(decrease_face_size, 0), "decrease_face_size", 18, "Decrease the size of the face used by the current buffer.", 57, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 884 }, { PROC_LINKS(decrease_face_size, 0), "decrease_face_size", 18, "Decrease the size of the face used by the current buffer.", 57, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 801 },
{ PROC_LINKS(mouse_wheel_change_face_size, 0), "mouse_wheel_change_face_size", 28, "Reads the state of the mouse wheel and uses it to either increase or decrease the face size.", 92, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 898 }, { PROC_LINKS(mouse_wheel_change_face_size, 0), "mouse_wheel_change_face_size", 28, "Reads the state of the mouse wheel and uses it to either increase or decrease the face size.", 92, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 813 },
{ PROC_LINKS(toggle_virtual_whitespace, 0), "toggle_virtual_whitespace", 25, "Toggles the current buffer's virtual whitespace status.", 55, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 915 }, { PROC_LINKS(toggle_virtual_whitespace, 0), "toggle_virtual_whitespace", 25, "Toggles the current buffer's virtual whitespace status.", 55, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 830 },
{ PROC_LINKS(toggle_show_whitespace, 0), "toggle_show_whitespace", 22, "Toggles the current buffer's whitespace visibility status.", 58, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 927 }, { PROC_LINKS(toggle_show_whitespace, 0), "toggle_show_whitespace", 22, "Toggles the current buffer's whitespace visibility status.", 58, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 840 },
{ PROC_LINKS(toggle_line_numbers, 0), "toggle_line_numbers", 19, "Toggles the left margin line numbers.", 37, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 937 }, { PROC_LINKS(toggle_line_numbers, 0), "toggle_line_numbers", 19, "Toggles the left margin line numbers.", 37, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 849 },
{ PROC_LINKS(eol_dosify, 0), "eol_dosify", 10, "Puts the buffer in DOS line ending mode.", 40, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 943 }, { PROC_LINKS(eol_dosify, 0), "eol_dosify", 10, "Puts the buffer in DOS line ending mode.", 40, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 855 },
{ PROC_LINKS(eol_nixify, 0), "eol_nixify", 10, "Puts the buffer in NIX line ending mode.", 40, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 953 }, { PROC_LINKS(eol_nixify, 0), "eol_nixify", 10, "Puts the buffer in NIX line ending mode.", 40, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 863 },
{ PROC_LINKS(exit_4coder, 0), "exit_4coder", 11, "Attempts to close 4coder.", 25, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 963 }, { PROC_LINKS(exit_4coder, 0), "exit_4coder", 11, "Attempts to close 4coder.", 25, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 871 },
{ PROC_LINKS(goto_line, 0), "goto_line", 9, "Queries the user for a number, and jumps the cursor to the corresponding line.", 78, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 971 }, { PROC_LINKS(goto_line, 0), "goto_line", 9, "Queries the user for a number, and jumps the cursor to the corresponding line.", 78, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 879 },
{ PROC_LINKS(search, 0), "search", 6, "Begins an incremental search down through the current buffer for a user specified string.", 89, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1199 }, { PROC_LINKS(search, 0), "search", 6, "Begins an incremental search down through the current buffer for a user specified string.", 89, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1102 },
{ PROC_LINKS(reverse_search, 0), "reverse_search", 14, "Begins an incremental search up through the current buffer for a user specified string.", 87, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1205 }, { PROC_LINKS(reverse_search, 0), "reverse_search", 14, "Begins an incremental search up through the current buffer for a user specified string.", 87, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1108 },
{ PROC_LINKS(search_identifier, 0), "search_identifier", 17, "Begins an incremental search down through the current buffer for the word or token under the cursor.", 100, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1211 }, { PROC_LINKS(search_identifier, 0), "search_identifier", 17, "Begins an incremental search down through the current buffer for the word or token under the cursor.", 100, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1114 },
{ PROC_LINKS(reverse_search_identifier, 0), "reverse_search_identifier", 25, "Begins an incremental search up through the current buffer for the word or token under the cursor.", 98, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1226 }, { PROC_LINKS(reverse_search_identifier, 0), "reverse_search_identifier", 25, "Begins an incremental search up through the current buffer for the word or token under the cursor.", 98, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1126 },
{ PROC_LINKS(replace_in_range, 0), "replace_in_range", 16, "Queries the user for two strings, and replaces all occurences of the first string in the range between the cursor and the mark with the second string.", 150, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1241 }, { PROC_LINKS(replace_in_range, 0), "replace_in_range", 16, "Queries the user for two strings, and replaces all occurences of the first string in the range between the cursor and the mark with the second string.", 150, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1138 },
{ PROC_LINKS(query_replace, 0), "query_replace", 13, "Queries the user for two strings, and incrementally replaces every occurence of the first string with the second string.", 120, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1350 }, { PROC_LINKS(query_replace, 0), "query_replace", 13, "Queries the user for two strings, and incrementally replaces every occurence of the first string with the second string.", 120, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1240 },
{ PROC_LINKS(query_replace_identifier, 0), "query_replace_identifier", 24, "Queries the user for a string, and incrementally replace every occurence of the word or token found at the cursor with the specified string.", 140, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1373 }, { PROC_LINKS(query_replace_identifier, 0), "query_replace_identifier", 24, "Queries the user for a string, and incrementally replace every occurence of the word or token found at the cursor with the specified string.", 140, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1260 },
{ PROC_LINKS(query_replace_selection, 0), "query_replace_selection", 23, "Queries the user for a string, and incrementally replace every occurence of the string found in the selected range with the specified string.", 141, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1392 }, { PROC_LINKS(query_replace_selection, 0), "query_replace_selection", 23, "Queries the user for a string, and incrementally replace every occurence of the string found in the selected range with the specified string.", 141, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1276 },
{ PROC_LINKS(save_all_dirty_buffers, 0), "save_all_dirty_buffers", 22, "Saves all buffers marked dirty (showing the '*' indicator).", 59, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1436 }, { PROC_LINKS(save_all_dirty_buffers, 0), "save_all_dirty_buffers", 22, "Saves all buffers marked dirty (showing the '*' indicator).", 59, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1316 },
{ PROC_LINKS(delete_file_query, 0), "delete_file_query", 17, "Deletes the file of the current buffer if 4coder has the appropriate access rights. Will ask the user for confirmation first.", 125, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1461 }, { PROC_LINKS(delete_file_query, 0), "delete_file_query", 17, "Deletes the file of the current buffer if 4coder has the appropriate access rights. Will ask the user for confirmation first.", 125, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1341 },
{ PROC_LINKS(save_to_query, 0), "save_to_query", 13, "Queries the user for a file name and saves the contents of the current buffer, altering the buffer's name too.", 110, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1501 }, { PROC_LINKS(save_to_query, 0), "save_to_query", 13, "Queries the user for a file name and saves the contents of the current buffer, altering the buffer's name too.", 110, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1379 },
{ PROC_LINKS(rename_file_query, 0), "rename_file_query", 17, "Queries the user for a new name and renames the file of the current buffer, altering the buffer's name too.", 107, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1539 }, { PROC_LINKS(rename_file_query, 0), "rename_file_query", 17, "Queries the user for a new name and renames the file of the current buffer, altering the buffer's name too.", 107, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1414 },
{ PROC_LINKS(make_directory_query, 0), "make_directory_query", 20, "Queries the user for a name and creates a new directory with the given name.", 76, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1582 }, { PROC_LINKS(make_directory_query, 0), "make_directory_query", 20, "Queries the user for a name and creates a new directory with the given name.", 76, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1454 },
{ PROC_LINKS(move_line_up, 0), "move_line_up", 12, "Swaps the line under the cursor with the line above it, and moves the cursor up with it.", 88, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1618 }, { PROC_LINKS(move_line_up, 0), "move_line_up", 12, "Swaps the line under the cursor with the line above it, and moves the cursor up with it.", 88, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1487 },
{ PROC_LINKS(move_line_down, 0), "move_line_down", 14, "Swaps the line under the cursor with the line below it, and moves the cursor down with it.", 90, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1624 }, { PROC_LINKS(move_line_down, 0), "move_line_down", 14, "Swaps the line under the cursor with the line below it, and moves the cursor down with it.", 90, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1493 },
{ PROC_LINKS(duplicate_line, 0), "duplicate_line", 14, "Create a copy of the line on which the cursor sits.", 51, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1630 }, { PROC_LINKS(duplicate_line, 0), "duplicate_line", 14, "Create a copy of the line on which the cursor sits.", 51, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1499 },
{ PROC_LINKS(delete_line, 0), "delete_line", 11, "Delete the line the on which the cursor sits.", 45, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1647 }, { PROC_LINKS(delete_line, 0), "delete_line", 11, "Delete the line the on which the cursor sits.", 45, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1513 },
{ PROC_LINKS(open_file_in_quotes, 0), "open_file_in_quotes", 19, "Reads a filename from surrounding '\"' characters and attempts to open the corresponding file.", 94, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1716 }, { PROC_LINKS(open_file_in_quotes, 0), "open_file_in_quotes", 19, "Reads a filename from surrounding '\"' characters and attempts to open the corresponding file.", 94, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1578 },
{ PROC_LINKS(open_matching_file_cpp, 0), "open_matching_file_cpp", 22, "If the current file is a *.cpp or *.h, attempts to open the corresponding *.h or *.cpp file in the other view.", 110, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1754 }, { PROC_LINKS(open_matching_file_cpp, 0), "open_matching_file_cpp", 22, "If the current file is a *.cpp or *.h, attempts to open the corresponding *.h or *.cpp file in the other view.", 110, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1613 },
{ PROC_LINKS(view_buffer_other_panel, 0), "view_buffer_other_panel", 23, "Set the other non-active panel to view the buffer that the active panel views, and switch to that panel.", 104, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1769 }, { PROC_LINKS(view_buffer_other_panel, 0), "view_buffer_other_panel", 23, "Set the other non-active panel to view the buffer that the active panel views, and switch to that panel.", 104, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1626 },
{ PROC_LINKS(swap_buffers_between_panels, 0), "swap_buffers_between_panels", 27, "Set the other non-active panel to view the buffer that the active panel views, and switch to that panel.", 104, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1784 }, { PROC_LINKS(swap_buffers_between_panels, 0), "swap_buffers_between_panels", 27, "Set the other non-active panel to view the buffer that the active panel views, and switch to that panel.", 104, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1638 },
{ PROC_LINKS(kill_buffer, 0), "kill_buffer", 11, "Kills the current buffer.", 25, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1829 }, { PROC_LINKS(kill_buffer, 0), "kill_buffer", 11, "Kills the current buffer.", 25, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1675 },
{ PROC_LINKS(save, 0), "save", 4, "Saves the current buffer.", 25, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1839 }, { PROC_LINKS(save, 0), "save", 4, "Saves the current buffer.", 25, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1683 },
{ PROC_LINKS(reopen, 0), "reopen", 6, "Reopen the current buffer from the hard drive.", 46, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1853 }, { PROC_LINKS(reopen, 0), "reopen", 6, "Reopen the current buffer from the hard drive.", 46, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1695 },
{ PROC_LINKS(undo, 0), "undo", 4, "Advances backwards through the undo history of the current buffer.", 66, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1917 }, { PROC_LINKS(undo, 0), "undo", 4, "Advances backwards through the undo history of the current buffer.", 66, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1757 },
{ PROC_LINKS(redo, 0), "redo", 4, "Advances forwards through the undo history of the current buffer.", 65, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1933 }, { PROC_LINKS(redo, 0), "redo", 4, "Advances forwards through the undo history of the current buffer.", 65, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1771 },
{ PROC_LINKS(undo_all_buffers, 0), "undo_all_buffers", 16, "Advances backward through the undo history in the buffer containing the most recent regular edit.", 97, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1951 }, { PROC_LINKS(undo_all_buffers, 0), "undo_all_buffers", 16, "Advances backward through the undo history in the buffer containing the most recent regular edit.", 97, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1787 },
{ PROC_LINKS(redo_all_buffers, 0), "redo_all_buffers", 16, "Advances forward through the undo history in the buffer containing the most recent regular edit.", 96, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 2030 }, { PROC_LINKS(redo_all_buffers, 0), "redo_all_buffers", 16, "Advances forward through the undo history in the buffer containing the most recent regular edit.", 96, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1865 },
{ PROC_LINKS(open_in_other, 0), "open_in_other", 13, "Interactively opens a file in the other panel.", 46, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 2140 }, { PROC_LINKS(open_in_other, 0), "open_in_other", 13, "Interactively opens a file in the other panel.", 46, "w:\\4ed\\code\\4coder_base_commands.cpp", 36, 1974 },
{ PROC_LINKS(lister__quit, 0), "lister__quit", 12, "A lister mode command that quits the list without executing any actions.", 72, "w:\\4ed\\code\\4coder_lists.cpp", 28, 8 }, { PROC_LINKS(lister__quit, 0), "lister__quit", 12, "A lister mode command that quits the list without executing any actions.", 72, "w:\\4ed\\code\\4coder_lists.cpp", 28, 8 },
{ PROC_LINKS(lister__activate, 0), "lister__activate", 16, "A lister mode command that activates the list's action on the highlighted item.", 79, "w:\\4ed\\code\\4coder_lists.cpp", 28, 16 }, { PROC_LINKS(lister__activate, 0), "lister__activate", 16, "A lister mode command that activates the list's action on the highlighted item.", 79, "w:\\4ed\\code\\4coder_lists.cpp", 28, 15 },
{ PROC_LINKS(lister__write_character, 0), "lister__write_character", 23, "A lister mode command that dispatches to the lister's write character handler.", 78, "w:\\4ed\\code\\4coder_lists.cpp", 28, 32 }, { PROC_LINKS(lister__write_character, 0), "lister__write_character", 23, "A lister mode command that dispatches to the lister's write character handler.", 78, "w:\\4ed\\code\\4coder_lists.cpp", 28, 30 },
{ PROC_LINKS(lister__backspace_text_field, 0), "lister__backspace_text_field", 28, "A lister mode command that dispatches to the lister's backspace text field handler.", 83, "w:\\4ed\\code\\4coder_lists.cpp", 28, 43 }, { PROC_LINKS(lister__backspace_text_field, 0), "lister__backspace_text_field", 28, "A lister mode command that dispatches to the lister's backspace text field handler.", 83, "w:\\4ed\\code\\4coder_lists.cpp", 28, 40 },
{ PROC_LINKS(lister__move_up, 0), "lister__move_up", 15, "A lister mode command that dispatches to the lister's navigate up handler.", 74, "w:\\4ed\\code\\4coder_lists.cpp", 28, 54 }, { PROC_LINKS(lister__move_up, 0), "lister__move_up", 15, "A lister mode command that dispatches to the lister's navigate up handler.", 74, "w:\\4ed\\code\\4coder_lists.cpp", 28, 50 },
{ PROC_LINKS(lister__move_down, 0), "lister__move_down", 17, "A lister mode command that dispatches to the lister's navigate down handler.", 76, "w:\\4ed\\code\\4coder_lists.cpp", 28, 65 }, { PROC_LINKS(lister__move_down, 0), "lister__move_down", 17, "A lister mode command that dispatches to the lister's navigate down handler.", 76, "w:\\4ed\\code\\4coder_lists.cpp", 28, 60 },
{ PROC_LINKS(lister__wheel_scroll, 0), "lister__wheel_scroll", 20, "A lister mode command that scrolls the list in response to the mouse wheel.", 75, "w:\\4ed\\code\\4coder_lists.cpp", 28, 76 }, { PROC_LINKS(lister__wheel_scroll, 0), "lister__wheel_scroll", 20, "A lister mode command that scrolls the list in response to the mouse wheel.", 75, "w:\\4ed\\code\\4coder_lists.cpp", 28, 70 },
{ PROC_LINKS(lister__mouse_press, 0), "lister__mouse_press", 19, "A lister mode command that beings a click interaction with a list item under the mouse.", 87, "w:\\4ed\\code\\4coder_lists.cpp", 28, 92 }, { PROC_LINKS(lister__mouse_press, 0), "lister__mouse_press", 19, "A lister mode command that beings a click interaction with a list item under the mouse.", 87, "w:\\4ed\\code\\4coder_lists.cpp", 28, 85 },
{ PROC_LINKS(lister__mouse_release, 0), "lister__mouse_release", 21, "A lister mode command that ends a click interaction with a list item under the mouse, possibly activating it.", 109, "w:\\4ed\\code\\4coder_lists.cpp", 28, 104 }, { PROC_LINKS(lister__mouse_release, 0), "lister__mouse_release", 21, "A lister mode command that ends a click interaction with a list item under the mouse, possibly activating it.", 109, "w:\\4ed\\code\\4coder_lists.cpp", 28, 96 },
{ PROC_LINKS(lister__repaint, 0), "lister__repaint", 15, "A lister mode command that updates the lists UI data.", 53, "w:\\4ed\\code\\4coder_lists.cpp", 28, 120 }, { PROC_LINKS(lister__repaint, 0), "lister__repaint", 15, "A lister mode command that updates the lists UI data.", 53, "w:\\4ed\\code\\4coder_lists.cpp", 28, 111 },
{ PROC_LINKS(lister__write_character__default, 0), "lister__write_character__default", 32, "A lister mode command that inserts a new character to the text field.", 69, "w:\\4ed\\code\\4coder_lists.cpp", 28, 131 }, { PROC_LINKS(lister__write_character__default, 0), "lister__write_character__default", 32, "A lister mode command that inserts a new character to the text field.", 69, "w:\\4ed\\code\\4coder_lists.cpp", 28, 121 },
{ PROC_LINKS(lister__backspace_text_field__default, 0), "lister__backspace_text_field__default", 37, "A lister mode command that backspaces one character from the text field.", 72, "w:\\4ed\\code\\4coder_lists.cpp", 28, 151 }, { PROC_LINKS(lister__backspace_text_field__default, 0), "lister__backspace_text_field__default", 37, "A lister mode command that backspaces one character from the text field.", 72, "w:\\4ed\\code\\4coder_lists.cpp", 28, 140 },
{ PROC_LINKS(lister__move_up__default, 0), "lister__move_up__default", 24, "A lister mode command that moves the highlighted item one up in the list.", 73, "w:\\4ed\\code\\4coder_lists.cpp", 28, 166 }, { PROC_LINKS(lister__move_up__default, 0), "lister__move_up__default", 24, "A lister mode command that moves the highlighted item one up in the list.", 73, "w:\\4ed\\code\\4coder_lists.cpp", 28, 154 },
{ PROC_LINKS(lister__move_down__default, 0), "lister__move_down__default", 26, "A lister mode command that moves the highlighted item one down in the list.", 75, "w:\\4ed\\code\\4coder_lists.cpp", 28, 182 }, { PROC_LINKS(lister__move_down__default, 0), "lister__move_down__default", 26, "A lister mode command that moves the highlighted item one down in the list.", 75, "w:\\4ed\\code\\4coder_lists.cpp", 28, 169 },
{ PROC_LINKS(lister__write_character__file_path, 0), "lister__write_character__file_path", 34, "A lister mode command that inserts a character into the text field of a file system list.", 89, "w:\\4ed\\code\\4coder_lists.cpp", 28, 198 }, { PROC_LINKS(lister__write_character__file_path, 0), "lister__write_character__file_path", 34, "A lister mode command that inserts a character into the text field of a file system list.", 89, "w:\\4ed\\code\\4coder_lists.cpp", 28, 184 },
{ PROC_LINKS(lister__backspace_text_field__file_path, 0), "lister__backspace_text_field__file_path", 39, "A lister mode command that backspaces one character from the text field of a file system list.", 94, "w:\\4ed\\code\\4coder_lists.cpp", 28, 224 }, { PROC_LINKS(lister__backspace_text_field__file_path, 0), "lister__backspace_text_field__file_path", 39, "A lister mode command that backspaces one character from the text field of a file system list.", 94, "w:\\4ed\\code\\4coder_lists.cpp", 28, 209 },
{ PROC_LINKS(lister__write_character__fixed_list, 0), "lister__write_character__fixed_list", 35, "A lister mode command that handles input for the fixed sure to kill list.", 73, "w:\\4ed\\code\\4coder_lists.cpp", 28, 266 }, { PROC_LINKS(lister__write_character__fixed_list, 0), "lister__write_character__fixed_list", 35, "A lister mode command that handles input for the fixed sure to kill list.", 73, "w:\\4ed\\code\\4coder_lists.cpp", 28, 250 },
{ PROC_LINKS(interactive_switch_buffer, 0), "interactive_switch_buffer", 25, "Interactively switch to an open buffer.", 39, "w:\\4ed\\code\\4coder_lists.cpp", 28, 750 }, { PROC_LINKS(interactive_switch_buffer, 0), "interactive_switch_buffer", 25, "Interactively switch to an open buffer.", 39, "w:\\4ed\\code\\4coder_lists.cpp", 28, 726 },
{ PROC_LINKS(interactive_kill_buffer, 0), "interactive_kill_buffer", 23, "Interactively kill an open buffer.", 34, "w:\\4ed\\code\\4coder_lists.cpp", 28, 770 }, { PROC_LINKS(interactive_kill_buffer, 0), "interactive_kill_buffer", 23, "Interactively kill an open buffer.", 34, "w:\\4ed\\code\\4coder_lists.cpp", 28, 745 },
{ PROC_LINKS(interactive_open_or_new, 0), "interactive_open_or_new", 23, "Interactively open a file out of the file system.", 49, "w:\\4ed\\code\\4coder_lists.cpp", 28, 845 }, { PROC_LINKS(interactive_open_or_new, 0), "interactive_open_or_new", 23, "Interactively open a file out of the file system.", 49, "w:\\4ed\\code\\4coder_lists.cpp", 28, 818 },
{ PROC_LINKS(interactive_new, 0), "interactive_new", 15, "Interactively creates a new file.", 33, "w:\\4ed\\code\\4coder_lists.cpp", 28, 885 }, { PROC_LINKS(interactive_new, 0), "interactive_new", 15, "Interactively creates a new file.", 33, "w:\\4ed\\code\\4coder_lists.cpp", 28, 857 },
{ PROC_LINKS(interactive_open, 0), "interactive_open", 16, "Interactively opens a file.", 27, "w:\\4ed\\code\\4coder_lists.cpp", 28, 919 }, { PROC_LINKS(interactive_open, 0), "interactive_open", 16, "Interactively opens a file.", 27, "w:\\4ed\\code\\4coder_lists.cpp", 28, 890 },
{ PROC_LINKS(command_lister, 0), "command_lister", 14, "Opens an interactive list of all registered commands.", 53, "w:\\4ed\\code\\4coder_lists.cpp", 28, 1004 }, { PROC_LINKS(command_lister, 0), "command_lister", 14, "Opens an interactive list of all registered commands.", 53, "w:\\4ed\\code\\4coder_lists.cpp", 28, 972 },
{ PROC_LINKS(auto_tab_whole_file, 0), "auto_tab_whole_file", 19, "Audo-indents the entire current buffer.", 39, "w:\\4ed\\code\\4coder_auto_indent.cpp", 34, 561 }, { PROC_LINKS(auto_tab_whole_file, 0), "auto_tab_whole_file", 19, "Audo-indents the entire current buffer.", 39, "w:\\4ed\\code\\4coder_auto_indent.cpp", 34, 556 },
{ PROC_LINKS(auto_tab_line_at_cursor, 0), "auto_tab_line_at_cursor", 23, "Auto-indents the line on which the cursor sits.", 47, "w:\\4ed\\code\\4coder_auto_indent.cpp", 34, 574 }, { PROC_LINKS(auto_tab_line_at_cursor, 0), "auto_tab_line_at_cursor", 23, "Auto-indents the line on which the cursor sits.", 47, "w:\\4ed\\code\\4coder_auto_indent.cpp", 34, 566 },
{ PROC_LINKS(auto_tab_range, 0), "auto_tab_range", 14, "Auto-indents the range between the cursor and the mark.", 55, "w:\\4ed\\code\\4coder_auto_indent.cpp", 34, 588 }, { PROC_LINKS(auto_tab_range, 0), "auto_tab_range", 14, "Auto-indents the range between the cursor and the mark.", 55, "w:\\4ed\\code\\4coder_auto_indent.cpp", 34, 577 },
{ PROC_LINKS(write_and_auto_tab, 0), "write_and_auto_tab", 18, "Inserts a character and auto-indents the line on which the cursor sits.", 71, "w:\\4ed\\code\\4coder_auto_indent.cpp", 34, 601 }, { PROC_LINKS(write_and_auto_tab, 0), "write_and_auto_tab", 18, "Inserts a character and auto-indents the line on which the cursor sits.", 71, "w:\\4ed\\code\\4coder_auto_indent.cpp", 34, 588 },
{ PROC_LINKS(list_all_locations, 0), "list_all_locations", 18, "Queries the user for a string and lists all exact case-sensitive matches found in all open buffers.", 99, "w:\\4ed\\code\\4coder_search.cpp", 29, 705 }, { PROC_LINKS(list_all_locations, 0), "list_all_locations", 18, "Queries the user for a string and lists all exact case-sensitive matches found in all open buffers.", 99, "w:\\4ed\\code\\4coder_search.cpp", 29, 698 },
{ PROC_LINKS(list_all_substring_locations, 0), "list_all_substring_locations", 28, "Queries the user for a string and lists all case-sensitive substring matches found in all open buffers.", 103, "w:\\4ed\\code\\4coder_search.cpp", 29, 712 }, { PROC_LINKS(list_all_substring_locations, 0), "list_all_substring_locations", 28, "Queries the user for a string and lists all case-sensitive substring matches found in all open buffers.", 103, "w:\\4ed\\code\\4coder_search.cpp", 29, 705 },
{ PROC_LINKS(list_all_locations_case_insensitive, 0), "list_all_locations_case_insensitive", 35, "Queries the user for a string and lists all exact case-insensitive matches found in all open buffers.", 101, "w:\\4ed\\code\\4coder_search.cpp", 29, 719 }, { PROC_LINKS(list_all_locations_case_insensitive, 0), "list_all_locations_case_insensitive", 35, "Queries the user for a string and lists all exact case-insensitive matches found in all open buffers.", 101, "w:\\4ed\\code\\4coder_search.cpp", 29, 712 },
{ PROC_LINKS(list_all_substring_locations_case_insensitive, 0), "list_all_substring_locations_case_insensitive", 45, "Queries the user for a string and lists all case-insensitive substring matches found in all open buffers.", 105, "w:\\4ed\\code\\4coder_search.cpp", 29, 726 }, { PROC_LINKS(list_all_substring_locations_case_insensitive, 0), "list_all_substring_locations_case_insensitive", 45, "Queries the user for a string and lists all case-insensitive substring matches found in all open buffers.", 105, "w:\\4ed\\code\\4coder_search.cpp", 29, 719 },
{ PROC_LINKS(list_all_locations_of_identifier, 0), "list_all_locations_of_identifier", 32, "Reads a token or word under the cursor and lists all exact case-sensitive mathces in all open buffers.", 102, "w:\\4ed\\code\\4coder_search.cpp", 29, 733 }, { PROC_LINKS(list_all_locations_of_identifier, 0), "list_all_locations_of_identifier", 32, "Reads a token or word under the cursor and lists all exact case-sensitive mathces in all open buffers.", 102, "w:\\4ed\\code\\4coder_search.cpp", 29, 726 },
{ PROC_LINKS(list_all_locations_of_identifier_case_insensitive, 0), "list_all_locations_of_identifier_case_insensitive", 49, "Reads a token or word under the cursor and lists all exact case-insensitive mathces in all open buffers.", 104, "w:\\4ed\\code\\4coder_search.cpp", 29, 740 }, { PROC_LINKS(list_all_locations_of_identifier_case_insensitive, 0), "list_all_locations_of_identifier_case_insensitive", 49, "Reads a token or word under the cursor and lists all exact case-insensitive mathces in all open buffers.", 104, "w:\\4ed\\code\\4coder_search.cpp", 29, 733 },
{ PROC_LINKS(list_all_locations_of_selection, 0), "list_all_locations_of_selection", 31, "Reads the string in the selected range and lists all exact case-sensitive mathces in all open buffers.", 102, "w:\\4ed\\code\\4coder_search.cpp", 29, 747 }, { PROC_LINKS(list_all_locations_of_selection, 0), "list_all_locations_of_selection", 31, "Reads the string in the selected range and lists all exact case-sensitive mathces in all open buffers.", 102, "w:\\4ed\\code\\4coder_search.cpp", 29, 740 },
{ PROC_LINKS(list_all_locations_of_selection_case_insensitive, 0), "list_all_locations_of_selection_case_insensitive", 48, "Reads the string in the selected range and lists all exact case-insensitive mathces in all open buffers.", 104, "w:\\4ed\\code\\4coder_search.cpp", 29, 754 }, { PROC_LINKS(list_all_locations_of_selection_case_insensitive, 0), "list_all_locations_of_selection_case_insensitive", 48, "Reads the string in the selected range and lists all exact case-insensitive mathces in all open buffers.", 104, "w:\\4ed\\code\\4coder_search.cpp", 29, 747 },
{ PROC_LINKS(list_all_locations_of_type_definition, 0), "list_all_locations_of_type_definition", 37, "Queries user for string, lists all locations of strings that appear to define a type whose name matches the input string.", 121, "w:\\4ed\\code\\4coder_search.cpp", 29, 761 }, { PROC_LINKS(list_all_locations_of_type_definition, 0), "list_all_locations_of_type_definition", 37, "Queries user for string, lists all locations of strings that appear to define a type whose name matches the input string.", 121, "w:\\4ed\\code\\4coder_search.cpp", 29, 754 },
{ PROC_LINKS(list_all_locations_of_type_definition_of_identifier, 0), "list_all_locations_of_type_definition_of_identifier", 51, "Reads a token or word under the cursor and lists all locations of strings that appear to define a type whose name matches it.", 125, "w:\\4ed\\code\\4coder_search.cpp", 29, 772 }, { PROC_LINKS(list_all_locations_of_type_definition_of_identifier, 0), "list_all_locations_of_type_definition_of_identifier", 51, "Reads a token or word under the cursor and lists all locations of strings that appear to define a type whose name matches it.", 125, "w:\\4ed\\code\\4coder_search.cpp", 29, 765 },
{ PROC_LINKS(word_complete, 0), "word_complete", 13, "Iteratively tries completing the word to the left of the cursor with other words in open buffers that have the same prefix string.", 130, "w:\\4ed\\code\\4coder_search.cpp", 29, 796 }, { PROC_LINKS(word_complete, 0), "word_complete", 13, "Iteratively tries completing the word to the left of the cursor with other words in open buffers that have the same prefix string.", 130, "w:\\4ed\\code\\4coder_search.cpp", 29, 786 },
{ PROC_LINKS(goto_jump_at_cursor_direct, 0), "goto_jump_at_cursor_direct", 26, "If the cursor is found to be on a jump location, parses the jump location and brings up the file and position in another view and changes the active panel to the view containing the jump.", 187, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 8 }, { PROC_LINKS(goto_jump_at_cursor_direct, 0), "goto_jump_at_cursor_direct", 26, "If the cursor is found to be on a jump location, parses the jump location and brings up the file and position in another view and changes the active panel to the view containing the jump.", 187, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 8 },
{ PROC_LINKS(goto_jump_at_cursor_same_panel_direct, 0), "goto_jump_at_cursor_same_panel_direct", 37, "If the cursor is found to be on a jump location, parses the jump location and brings up the file and position in this view, losing the compilation output or jump list..", 168, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 36 }, { PROC_LINKS(goto_jump_at_cursor_same_panel_direct, 0), "goto_jump_at_cursor_same_panel_direct", 37, "If the cursor is found to be on a jump location, parses the jump location and brings up the file and position in this view, losing the compilation output or jump list..", 168, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 32 },
{ PROC_LINKS(goto_next_jump_direct, 0), "goto_next_jump_direct", 21, "If a buffer containing jump locations has been locked in, goes to the next jump in the buffer, skipping sub jump locations.", 123, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 61 }, { PROC_LINKS(goto_next_jump_direct, 0), "goto_next_jump_direct", 21, "If a buffer containing jump locations has been locked in, goes to the next jump in the buffer, skipping sub jump locations.", 123, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 54 },
{ PROC_LINKS(goto_prev_jump_direct, 0), "goto_prev_jump_direct", 21, "If a buffer containing jump locations has been locked in, goes to the previous jump in the buffer, skipping sub jump locations.", 127, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 70 }, { PROC_LINKS(goto_prev_jump_direct, 0), "goto_prev_jump_direct", 21, "If a buffer containing jump locations has been locked in, goes to the previous jump in the buffer, skipping sub jump locations.", 127, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 63 },
{ PROC_LINKS(goto_next_jump_no_skips_direct, 0), "goto_next_jump_no_skips_direct", 30, "If a buffer containing jump locations has been locked in, goes to the next jump in the buffer, and does not skip sub jump locations.", 132, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 79 }, { PROC_LINKS(goto_next_jump_no_skips_direct, 0), "goto_next_jump_no_skips_direct", 30, "If a buffer containing jump locations has been locked in, goes to the next jump in the buffer, and does not skip sub jump locations.", 132, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 72 },
{ PROC_LINKS(goto_prev_jump_no_skips_direct, 0), "goto_prev_jump_no_skips_direct", 30, "If a buffer containing jump locations has been locked in, goes to the previous jump in the buffer, and does not skip sub jump locations.", 136, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 88 }, { PROC_LINKS(goto_prev_jump_no_skips_direct, 0), "goto_prev_jump_no_skips_direct", 30, "If a buffer containing jump locations has been locked in, goes to the previous jump in the buffer, and does not skip sub jump locations.", 136, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 81 },
{ PROC_LINKS(goto_first_jump_direct, 0), "goto_first_jump_direct", 22, "If a buffer containing jump locations has been locked in, goes to the first jump in the buffer.", 95, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 97 }, { PROC_LINKS(goto_first_jump_direct, 0), "goto_first_jump_direct", 22, "If a buffer containing jump locations has been locked in, goes to the first jump in the buffer.", 95, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 90 },
{ PROC_LINKS(newline_or_goto_position_direct, 0), "newline_or_goto_position_direct", 31, "If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor.", 106, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 112 }, { PROC_LINKS(newline_or_goto_position_direct, 0), "newline_or_goto_position_direct", 31, "If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor.", 106, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 105 },
{ PROC_LINKS(newline_or_goto_position_same_panel_direct, 0), "newline_or_goto_position_same_panel_direct", 42, "If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor_same_panel.", 117, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 127 }, { PROC_LINKS(newline_or_goto_position_same_panel_direct, 0), "newline_or_goto_position_same_panel_direct", 42, "If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor_same_panel.", 117, "w:\\4ed\\code\\4coder_jump_direct.cpp", 34, 122 },
{ PROC_LINKS(goto_jump_at_cursor_sticky, 0), "goto_jump_at_cursor_sticky", 26, "If the cursor is found to be on a jump location, parses the jump location and brings up the file and position in another view and changes the active panel to the view containing the jump.", 187, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 366 }, { PROC_LINKS(goto_jump_at_cursor_sticky, 0), "goto_jump_at_cursor_sticky", 26, "If the cursor is found to be on a jump location, parses the jump location and brings up the file and position in another view and changes the active panel to the view containing the jump.", 187, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 365 },
{ PROC_LINKS(goto_jump_at_cursor_same_panel_sticky, 0), "goto_jump_at_cursor_same_panel_sticky", 37, "If the cursor is found to be on a jump location, parses the jump location and brings up the file and position in this view, losing the compilation output or jump list.", 167, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 398 }, { PROC_LINKS(goto_jump_at_cursor_same_panel_sticky, 0), "goto_jump_at_cursor_same_panel_sticky", 37, "If the cursor is found to be on a jump location, parses the jump location and brings up the file and position in this view, losing the compilation output or jump list.", 167, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 393 },
{ PROC_LINKS(goto_next_jump_sticky, 0), "goto_next_jump_sticky", 21, "If a buffer containing jump locations has been locked in, goes to the next jump in the buffer, skipping sub jump locations.", 123, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 505 }, { PROC_LINKS(goto_next_jump_sticky, 0), "goto_next_jump_sticky", 21, "If a buffer containing jump locations has been locked in, goes to the next jump in the buffer, skipping sub jump locations.", 123, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 494 },
{ PROC_LINKS(goto_prev_jump_sticky, 0), "goto_prev_jump_sticky", 21, "If a buffer containing jump locations has been locked in, goes to the previous jump in the buffer, skipping sub jump locations.", 127, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 524 }, { PROC_LINKS(goto_prev_jump_sticky, 0), "goto_prev_jump_sticky", 21, "If a buffer containing jump locations has been locked in, goes to the previous jump in the buffer, skipping sub jump locations.", 127, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 512 },
{ PROC_LINKS(goto_next_jump_no_skips_sticky, 0), "goto_next_jump_no_skips_sticky", 30, "If a buffer containing jump locations has been locked in, goes to the next jump in the buffer, and does not skip sub jump locations.", 132, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 537 }, { PROC_LINKS(goto_next_jump_no_skips_sticky, 0), "goto_next_jump_no_skips_sticky", 30, "If a buffer containing jump locations has been locked in, goes to the next jump in the buffer, and does not skip sub jump locations.", 132, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 525 },
{ PROC_LINKS(goto_prev_jump_no_skips_sticky, 0), "goto_prev_jump_no_skips_sticky", 30, "If a buffer containing jump locations has been locked in, goes to the previous jump in the buffer, and does not skip sub jump locations.", 136, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 556 }, { PROC_LINKS(goto_prev_jump_no_skips_sticky, 0), "goto_prev_jump_no_skips_sticky", 30, "If a buffer containing jump locations has been locked in, goes to the previous jump in the buffer, and does not skip sub jump locations.", 136, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 543 },
{ PROC_LINKS(goto_first_jump_sticky, 0), "goto_first_jump_sticky", 22, "If a buffer containing jump locations has been locked in, goes to the first jump in the buffer.", 95, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 570 }, { PROC_LINKS(goto_first_jump_sticky, 0), "goto_first_jump_sticky", 22, "If a buffer containing jump locations has been locked in, goes to the first jump in the buffer.", 95, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 557 },
{ PROC_LINKS(goto_first_jump_same_panel_sticky, 0), "goto_first_jump_same_panel_sticky", 33, "If a buffer containing jump locations has been locked in, goes to the first jump in the buffer and views the buffer in the panel where the jump list was.", 153, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 587 }, { PROC_LINKS(goto_first_jump_same_panel_sticky, 0), "goto_first_jump_same_panel_sticky", 33, "If a buffer containing jump locations has been locked in, goes to the first jump in the buffer and views the buffer in the panel where the jump list was.", 153, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 574 },
{ PROC_LINKS(newline_or_goto_position_sticky, 0), "newline_or_goto_position_sticky", 31, "If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor.", 106, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 609 }, { PROC_LINKS(newline_or_goto_position_sticky, 0), "newline_or_goto_position_sticky", 31, "If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor.", 106, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 596 },
{ PROC_LINKS(newline_or_goto_position_same_panel_sticky, 0), "newline_or_goto_position_same_panel_sticky", 42, "If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor_same_panel.", 117, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 624 }, { PROC_LINKS(newline_or_goto_position_same_panel_sticky, 0), "newline_or_goto_position_same_panel_sticky", 42, "If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor_same_panel.", 117, "w:\\4ed\\code\\4coder_jump_sticky.cpp", 34, 613 },
{ 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\\4coder_jump_lister.cpp", 34, 104 }, { 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\\4coder_jump_lister.cpp", 34, 104 },
{ 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\\4coder_clipboard.cpp", 32, 24 }, { 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\\4coder_clipboard.cpp", 32, 23 },
{ 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\\4coder_clipboard.cpp", 32, 35 }, { 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\\4coder_clipboard.cpp", 32, 32 },
{ PROC_LINKS(paste, 0), "paste", 5, "At the cursor, insert the text at the top of the clipboard.", 59, "w:\\4ed\\code\\4coder_clipboard.cpp", 32, 48 }, { PROC_LINKS(paste, 0), "paste", 5, "At the cursor, insert the text at the top of the clipboard.", 59, "w:\\4ed\\code\\4coder_clipboard.cpp", 32, 43 },
{ PROC_LINKS(paste_next, 0), "paste_next", 10, "If the previous command was paste or paste_next, replaces the paste range with the next text down on the clipboard, otherwise operates as the paste command.", 156, "w:\\4ed\\code\\4coder_clipboard.cpp", 32, 87 }, { PROC_LINKS(paste_next, 0), "paste_next", 10, "If the previous command was paste or paste_next, replaces the paste range with the next text down on the clipboard, otherwise operates as the paste command.", 156, "w:\\4ed\\code\\4coder_clipboard.cpp", 32, 77 },
{ PROC_LINKS(paste_and_indent, 0), "paste_and_indent", 16, "Paste from the top of clipboard and run auto-indent on the newly pasted text.", 77, "w:\\4ed\\code\\4coder_clipboard.cpp", 32, 135 }, { PROC_LINKS(paste_and_indent, 0), "paste_and_indent", 16, "Paste from the top of clipboard and run auto-indent on the newly pasted text.", 77, "w:\\4ed\\code\\4coder_clipboard.cpp", 32, 121 },
{ PROC_LINKS(paste_next_and_indent, 0), "paste_next_and_indent", 21, "Paste the next item on the clipboard and run auto-indent on the newly pasted text.", 82, "w:\\4ed\\code\\4coder_clipboard.cpp", 32, 142 }, { PROC_LINKS(paste_next_and_indent, 0), "paste_next_and_indent", 21, "Paste the next item on the clipboard and run auto-indent on the newly pasted text.", 82, "w:\\4ed\\code\\4coder_clipboard.cpp", 32, 128 },
{ PROC_LINKS(execute_previous_cli, 0), "execute_previous_cli", 20, "If the command execute_any_cli has already been used, this will execute a CLI reusing the most recent buffer name and command.", 126, "w:\\4ed\\code\\4coder_system_command.cpp", 37, 7 }, { PROC_LINKS(execute_previous_cli, 0), "execute_previous_cli", 20, "If the command execute_any_cli has already been used, this will execute a CLI reusing the most recent buffer name and command.", 126, "w:\\4ed\\code\\4coder_system_command.cpp", 37, 7 },
{ PROC_LINKS(execute_any_cli, 0), "execute_any_cli", 15, "Queries for an output buffer name and system command, runs the system command as a CLI and prints the output to the specified buffer.", 133, "w:\\4ed\\code\\4coder_system_command.cpp", 37, 23 }, { PROC_LINKS(execute_any_cli, 0), "execute_any_cli", 15, "Queries for an output buffer name and system command, runs the system command as a CLI and prints the output to the specified buffer.", 133, "w:\\4ed\\code\\4coder_system_command.cpp", 37, 22 },
{ PROC_LINKS(build_search, 0), "build_search", 12, "Looks for a build.bat, build.sh, or makefile in the current and parent directories. Runs the first that it finds and prints the output to *compilation*.", 153, "w:\\4ed\\code\\4coder_build_commands.cpp", 37, 128 }, { PROC_LINKS(build_search, 0), "build_search", 12, "Looks for a build.bat, build.sh, or makefile in the current and parent directories. Runs the first that it finds and prints the output to *compilation*.", 153, "w:\\4ed\\code\\4coder_build_commands.cpp", 37, 128 },
{ PROC_LINKS(build_in_build_panel, 0), "build_in_build_panel", 20, "Looks for a build.bat, build.sh, or makefile in the current and parent directories. Runs the first that it finds and prints the output to *compilation*. Puts the *compilation* buffer in a panel at the footer of the current view.", 230, "w:\\4ed\\code\\4coder_build_commands.cpp", 37, 166 }, { PROC_LINKS(build_in_build_panel, 0), "build_in_build_panel", 20, "Looks for a build.bat, build.sh, or makefile in the current and parent directories. Runs the first that it finds and prints the output to *compilation*. Puts the *compilation* buffer in a panel at the footer of the current view.", 230, "w:\\4ed\\code\\4coder_build_commands.cpp", 37, 162 },
{ PROC_LINKS(close_build_panel, 0), "close_build_panel", 17, "If the special build panel is open, closes it.", 46, "w:\\4ed\\code\\4coder_build_commands.cpp", 37, 183 }, { PROC_LINKS(close_build_panel, 0), "close_build_panel", 17, "If the special build panel is open, closes it.", 46, "w:\\4ed\\code\\4coder_build_commands.cpp", 37, 177 },
{ PROC_LINKS(change_to_build_panel, 0), "change_to_build_panel", 21, "If the special build panel is open, makes the build panel the active panel.", 75, "w:\\4ed\\code\\4coder_build_commands.cpp", 37, 189 }, { PROC_LINKS(change_to_build_panel, 0), "change_to_build_panel", 21, "If the special build panel is open, makes the build panel the active panel.", 75, "w:\\4ed\\code\\4coder_build_commands.cpp", 37, 183 },
{ PROC_LINKS(close_all_code, 0), "close_all_code", 14, "Closes any buffer with a filename ending with an extension configured to be recognized as a code file type.", 107, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 931 }, { PROC_LINKS(close_all_code, 0), "close_all_code", 14, "Closes any buffer with a filename ending with an extension configured to be recognized as a code file type.", 107, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 929 },
{ PROC_LINKS(open_all_code, 0), "open_all_code", 13, "Open all code in the current directory. File types are determined by extensions. An extension is considered code based on the extensions specified in 4coder.config.", 164, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 937 }, { PROC_LINKS(open_all_code, 0), "open_all_code", 13, "Open all code in the current directory. File types are determined by extensions. An extension is considered code based on the extensions specified in 4coder.config.", 164, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 935 },
{ PROC_LINKS(open_all_code_recursive, 0), "open_all_code_recursive", 23, "Works as open_all_code but also runs in all subdirectories.", 59, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 943 }, { PROC_LINKS(open_all_code_recursive, 0), "open_all_code_recursive", 23, "Works as open_all_code but also runs in all subdirectories.", 59, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 941 },
{ PROC_LINKS(load_project, 0), "load_project", 12, "Looks for a project.4coder file in the current directory and tries to load it. Looks in parent directories until a project file is found or there are no more parents.", 167, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 951 }, { PROC_LINKS(load_project, 0), "load_project", 12, "Looks for a project.4coder file in the current directory and tries to load it. Looks in parent directories until a project file is found or there are no more parents.", 167, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 949 },
{ PROC_LINKS(project_fkey_command, 0), "project_fkey_command", 20, "Run an 'fkey command' configured in a project.4coder file. Determines the index of the 'fkey command' by which function key or numeric key was pressed to trigger the command.", 175, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 958 }, { PROC_LINKS(project_fkey_command, 0), "project_fkey_command", 20, "Run an 'fkey command' configured in a project.4coder file. Determines the index of the 'fkey command' by which function key or numeric key was pressed to trigger the command.", 175, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 956 },
{ PROC_LINKS(project_go_to_root_directory, 0), "project_go_to_root_directory", 28, "Changes 4coder's hot directory to the root directory of the currently loaded project. With no loaded project nothing hapepns.", 125, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 981 }, { PROC_LINKS(project_go_to_root_directory, 0), "project_go_to_root_directory", 28, "Changes 4coder's hot directory to the root directory of the currently loaded project. With no loaded project nothing hapepns.", 125, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 979 },
{ PROC_LINKS(setup_new_project, 0), "setup_new_project", 17, "Queries the user for several configuration options and initializes a new 4coder project with build scripts for every OS.", 120, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 1316 }, { PROC_LINKS(setup_new_project, 0), "setup_new_project", 17, "Queries the user for several configuration options and initializes a new 4coder project with build scripts for every OS.", 120, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 1314 },
{ PROC_LINKS(setup_build_bat, 0), "setup_build_bat", 15, "Queries the user for several configuration options and initializes a new build batch script.", 92, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 1323 }, { PROC_LINKS(setup_build_bat, 0), "setup_build_bat", 15, "Queries the user for several configuration options and initializes a new build batch script.", 92, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 1321 },
{ PROC_LINKS(setup_build_sh, 0), "setup_build_sh", 14, "Queries the user for several configuration options and initializes a new build shell script.", 92, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 1329 }, { PROC_LINKS(setup_build_sh, 0), "setup_build_sh", 14, "Queries the user for several configuration options and initializes a new build shell script.", 92, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 1327 },
{ PROC_LINKS(setup_build_bat_and_sh, 0), "setup_build_bat_and_sh", 22, "Queries the user for several configuration options and initializes a new build batch script.", 92, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 1335 }, { PROC_LINKS(setup_build_bat_and_sh, 0), "setup_build_bat_and_sh", 22, "Queries the user for several configuration options and initializes a new build batch script.", 92, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 1333 },
{ PROC_LINKS(project_command_lister, 0), "project_command_lister", 22, "Open a lister of all commands in the currently loaded project.", 62, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 1350 }, { PROC_LINKS(project_command_lister, 0), "project_command_lister", 22, "Open a lister of all commands in the currently loaded project.", 62, "w:\\4ed\\code\\4coder_project_commands.cpp", 39, 1348 },
{ PROC_LINKS(list_all_functions_current_buffer, 0), "list_all_functions_current_buffer", 33, "Creates a jump list of lines of the current buffer that appear to define or declare functions.", 94, "w:\\4ed\\code\\4coder_function_list.cpp", 36, 273 }, { PROC_LINKS(list_all_functions_current_buffer, 0), "list_all_functions_current_buffer", 33, "Creates a jump list of lines of the current buffer that appear to define or declare functions.", 94, "w:\\4ed\\code\\4coder_function_list.cpp", 36, 269 },
{ PROC_LINKS(list_all_functions_current_buffer_lister, 0), "list_all_functions_current_buffer_lister", 40, "Creates a lister of locations that look like function definitions and declarations in the buffer.", 97, "w:\\4ed\\code\\4coder_function_list.cpp", 36, 285 }, { PROC_LINKS(list_all_functions_current_buffer_lister, 0), "list_all_functions_current_buffer_lister", 40, "Creates a lister of locations that look like function definitions and declarations in the buffer.", 97, "w:\\4ed\\code\\4coder_function_list.cpp", 36, 279 },
{ PROC_LINKS(list_all_functions_all_buffers, 0), "list_all_functions_all_buffers", 30, "Creates a jump list of lines from all buffers that appear to define or declare functions.", 89, "w:\\4ed\\code\\4coder_function_list.cpp", 36, 299 }, { PROC_LINKS(list_all_functions_all_buffers, 0), "list_all_functions_all_buffers", 30, "Creates a jump list of lines from all buffers that appear to define or declare functions.", 89, "w:\\4ed\\code\\4coder_function_list.cpp", 36, 291 },
{ PROC_LINKS(list_all_functions_all_buffers_lister, 0), "list_all_functions_all_buffers_lister", 37, "Creates a lister of locations that look like function definitions and declarations all buffers.", 95, "w:\\4ed\\code\\4coder_function_list.cpp", 36, 305 }, { PROC_LINKS(list_all_functions_all_buffers_lister, 0), "list_all_functions_all_buffers_lister", 37, "Creates a lister of locations that look like function definitions and declarations all buffers.", 95, "w:\\4ed\\code\\4coder_function_list.cpp", 36, 297 },
{ PROC_LINKS(select_surrounding_scope, 0), "select_surrounding_scope", 24, "Finds the scope enclosed by '{' '}' surrounding the cursor and puts the cursor and mark on the '{' and '}'.", 107, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 339 }, { PROC_LINKS(select_surrounding_scope, 0), "select_surrounding_scope", 24, "Finds the scope enclosed by '{' '}' surrounding the cursor and puts the cursor and mark on the '{' and '}'.", 107, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 338 },
{ PROC_LINKS(select_next_scope_absolute, 0), "select_next_scope_absolute", 26, "Finds the first scope started by '{' after the cursor and puts the cursor and mark on the '{' and '}'.", 102, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 357 }, { PROC_LINKS(select_next_scope_absolute, 0), "select_next_scope_absolute", 26, "Finds the first scope started by '{' after the cursor and puts the cursor and mark on the '{' and '}'.", 102, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 353 },
{ PROC_LINKS(select_prev_scope_absolute, 0), "select_prev_scope_absolute", 26, "Finds the first scope started by '{' before the cursor and puts the cursor and mark on the '{' and '}'.", 103, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 379 }, { PROC_LINKS(select_prev_scope_absolute, 0), "select_prev_scope_absolute", 26, "Finds the first scope started by '{' before the cursor and puts the cursor and mark on the '{' and '}'.", 103, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 372 },
{ PROC_LINKS(place_in_scope, 0), "place_in_scope", 14, "Wraps the code contained in the range between cursor and mark with a new curly brace scope.", 91, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 475 }, { PROC_LINKS(place_in_scope, 0), "place_in_scope", 14, "Wraps the code contained in the range between cursor and mark with a new curly brace scope.", 91, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 462 },
{ PROC_LINKS(delete_current_scope, 0), "delete_current_scope", 20, "Deletes the braces surrounding the currently selected scope. Leaves the contents within the scope.", 99, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 481 }, { PROC_LINKS(delete_current_scope, 0), "delete_current_scope", 20, "Deletes the braces surrounding the currently selected scope. Leaves the contents within the scope.", 99, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 468 },
{ PROC_LINKS(scope_absorb_down, 0), "scope_absorb_down", 17, "If a scope is currently selected, and a statement or block statement is present below the current scope, the statement is moved into the scope.", 143, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 715 }, { PROC_LINKS(scope_absorb_down, 0), "scope_absorb_down", 17, "If a scope is currently selected, and a statement or block statement is present below the current scope, the statement is moved into the scope.", 143, "w:\\4ed\\code\\4coder_scope_commands.cpp", 37, 691 },
{ PROC_LINKS(open_long_braces, 0), "open_long_braces", 16, "At the cursor, insert a '{' and '}' separated by a blank line.", 62, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 52 }, { PROC_LINKS(open_long_braces, 0), "open_long_braces", 16, "At the cursor, insert a '{' and '}' separated by a blank line.", 62, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 46 },
{ PROC_LINKS(open_long_braces_semicolon, 0), "open_long_braces_semicolon", 26, "At the cursor, insert a '{' and '};' separated by a blank line.", 63, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 60 }, { PROC_LINKS(open_long_braces_semicolon, 0), "open_long_braces_semicolon", 26, "At the cursor, insert a '{' and '};' separated by a blank line.", 63, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 54 },
{ PROC_LINKS(open_long_braces_break, 0), "open_long_braces_break", 22, "At the cursor, insert a '{' and '}break;' separated by a blank line.", 68, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 68 }, { PROC_LINKS(open_long_braces_break, 0), "open_long_braces_break", 22, "At the cursor, insert a '{' and '}break;' separated by a blank line.", 68, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 62 },
{ PROC_LINKS(if0_off, 0), "if0_off", 7, "Surround the range between the cursor and mark with an '#if 0' and an '#endif'", 78, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 76 }, { PROC_LINKS(if0_off, 0), "if0_off", 7, "Surround the range between the cursor and mark with an '#if 0' and an '#endif'", 78, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 70 },
{ PROC_LINKS(write_todo, 0), "write_todo", 10, "At the cursor, insert a '// TODO' comment, includes user name if it was specified in config.4coder.", 99, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 82 }, { PROC_LINKS(write_todo, 0), "write_todo", 10, "At the cursor, insert a '// TODO' comment, includes user name if it was specified in config.4coder.", 99, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 76 },
{ PROC_LINKS(write_hack, 0), "write_hack", 10, "At the cursor, insert a '// HACK' comment, includes user name if it was specified in config.4coder.", 99, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 88 }, { PROC_LINKS(write_hack, 0), "write_hack", 10, "At the cursor, insert a '// HACK' comment, includes user name if it was specified in config.4coder.", 99, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 82 },
{ PROC_LINKS(write_note, 0), "write_note", 10, "At the cursor, insert a '// NOTE' comment, includes user name if it was specified in config.4coder.", 99, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 94 }, { PROC_LINKS(write_note, 0), "write_note", 10, "At the cursor, insert a '// NOTE' comment, includes user name if it was specified in config.4coder.", 99, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 88 },
{ PROC_LINKS(write_block, 0), "write_block", 11, "At the cursor, insert a block comment.", 38, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 100 }, { PROC_LINKS(write_block, 0), "write_block", 11, "At the cursor, insert a block comment.", 38, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 94 },
{ PROC_LINKS(write_zero_struct, 0), "write_zero_struct", 17, "At the cursor, insert a ' = {};'.", 33, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 106 }, { PROC_LINKS(write_zero_struct, 0), "write_zero_struct", 17, "At the cursor, insert a ' = {};'.", 33, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 100 },
{ PROC_LINKS(comment_line, 0), "comment_line", 12, "Insert '//' at the beginning of the line after leading whitespace.", 66, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 133 }, { PROC_LINKS(comment_line, 0), "comment_line", 12, "Insert '//' at the beginning of the line after leading whitespace.", 66, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 126 },
{ PROC_LINKS(uncomment_line, 0), "uncomment_line", 14, "If present, delete '//' at the beginning of the line after leading whitespace.", 78, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 147 }, { PROC_LINKS(uncomment_line, 0), "uncomment_line", 14, "If present, delete '//' at the beginning of the line after leading whitespace.", 78, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 138 },
{ PROC_LINKS(comment_line_toggle, 0), "comment_line_toggle", 19, "Turns uncommented lines into commented lines and vice versa for comments starting with '//'.", 92, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 161 }, { PROC_LINKS(comment_line_toggle, 0), "comment_line_toggle", 19, "Turns uncommented lines into commented lines and vice versa for comments starting with '//'.", 92, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 150 },
{ PROC_LINKS(snippet_lister, 0), "snippet_lister", 14, "Opens a snippet lister for inserting whole pre-written snippets of text.", 72, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 250 }, { PROC_LINKS(snippet_lister, 0), "snippet_lister", 14, "Opens a snippet lister for inserting whole pre-written snippets of text.", 72, "w:\\4ed\\code\\4coder_combined_write_commands.cpp", 46, 234 },
{ PROC_LINKS(set_bindings_choose, 0), "set_bindings_choose", 19, "Remap keybindings using the 'choose' mapping rule.", 50, "w:\\4ed\\code\\4coder_remapping_commands.cpp", 41, 39 }, { PROC_LINKS(set_bindings_choose, 0), "set_bindings_choose", 19, "Remap keybindings using the 'choose' mapping rule.", 50, "w:\\4ed\\code\\4coder_remapping_commands.cpp", 41, 39 },
{ PROC_LINKS(set_bindings_default, 0), "set_bindings_default", 20, "Remap keybindings using the 'default' mapping rule.", 51, "w:\\4ed\\code\\4coder_remapping_commands.cpp", 41, 49 }, { PROC_LINKS(set_bindings_default, 0), "set_bindings_default", 20, "Remap keybindings using the 'default' mapping rule.", 51, "w:\\4ed\\code\\4coder_remapping_commands.cpp", 41, 49 },
{ PROC_LINKS(set_bindings_mac_default, 0), "set_bindings_mac_default", 24, "Remap keybindings using the 'mac-default' mapping rule.", 55, "w:\\4ed\\code\\4coder_remapping_commands.cpp", 41, 64 }, { PROC_LINKS(set_bindings_mac_default, 0), "set_bindings_mac_default", 24, "Remap keybindings using the 'mac-default' mapping rule.", 55, "w:\\4ed\\code\\4coder_remapping_commands.cpp", 41, 64 },
{ PROC_LINKS(miblo_increment_basic, 0), "miblo_increment_basic", 21, "Increment an integer under the cursor by one.", 45, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 95 }, { PROC_LINKS(miblo_increment_basic, 0), "miblo_increment_basic", 21, "Increment an integer under the cursor by one.", 45, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 95 },
{ PROC_LINKS(miblo_decrement_basic, 0), "miblo_decrement_basic", 21, "Decrement an integer under the cursor by one.", 45, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 113 }, { PROC_LINKS(miblo_decrement_basic, 0), "miblo_decrement_basic", 21, "Decrement an integer under the cursor by one.", 45, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 110 },
{ PROC_LINKS(miblo_increment_time_stamp, 0), "miblo_increment_time_stamp", 26, "Increment a time stamp under the cursor by one second. (format [m]m:ss or h:mm:ss", 81, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 383 }, { PROC_LINKS(miblo_increment_time_stamp, 0), "miblo_increment_time_stamp", 26, "Increment a time stamp under the cursor by one second. (format [m]m:ss or h:mm:ss", 81, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 374 },
{ PROC_LINKS(miblo_decrement_time_stamp, 0), "miblo_decrement_time_stamp", 26, "Decrement a time stamp under the cursor by one second. (format [m]m:ss or h:mm:ss", 81, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 389 }, { PROC_LINKS(miblo_decrement_time_stamp, 0), "miblo_decrement_time_stamp", 26, "Decrement a time stamp under the cursor by one second. (format [m]m:ss or h:mm:ss", 81, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 380 },
{ PROC_LINKS(miblo_increment_time_stamp_minute, 0), "miblo_increment_time_stamp_minute", 33, "Increment a time stamp under the cursor by one minute. (format [m]m:ss or h:mm:ss", 81, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 395 }, { PROC_LINKS(miblo_increment_time_stamp_minute, 0), "miblo_increment_time_stamp_minute", 33, "Increment a time stamp under the cursor by one minute. (format [m]m:ss or h:mm:ss", 81, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 386 },
{ PROC_LINKS(miblo_decrement_time_stamp_minute, 0), "miblo_decrement_time_stamp_minute", 33, "Decrement a time stamp under the cursor by one minute. (format [m]m:ss or h:mm:ss", 81, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 401 }, { PROC_LINKS(miblo_decrement_time_stamp_minute, 0), "miblo_decrement_time_stamp_minute", 33, "Decrement a time stamp under the cursor by one minute. (format [m]m:ss or h:mm:ss", 81, "w:\\4ed\\code\\4coder_miblo_numbers.cpp", 36, 392 },
{ PROC_LINKS(kill_rect, 0), "kill_rect", 9, "Delete characters in a rectangular region. Range testing is done by unwrapped-xy coordinates.", 93, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 50 }, { PROC_LINKS(kill_rect, 0), "kill_rect", 9, "Delete characters in a rectangular region. Range testing is done by unwrapped-xy coordinates.", 93, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 47 },
{ PROC_LINKS(multi_line_edit, 0), "multi_line_edit", 15, "Begin multi-line mode. In multi-line mode characters are inserted at every line between the mark and cursor. All characters are inserted at the same character offset into the line. This mode uses line_char coordinates.", 221, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 137 }, { PROC_LINKS(multi_line_edit, 0), "multi_line_edit", 15, "Begin multi-line mode. In multi-line mode characters are inserted at every line between the mark and cursor. All characters are inserted at the same character offset into the line. This mode uses line_char coordinates.", 221, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 127 },
{ PROC_LINKS(rename_parameter, 0), "rename_parameter", 16, "If the cursor is found to be on the name of a function parameter in the signature of a function definition, all occurences within the scope of the function will be replaced with a new provided string.", 200, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 424 }, { PROC_LINKS(rename_parameter, 0), "rename_parameter", 16, "If the cursor is found to be on the name of a function parameter in the signature of a function definition, all occurences within the scope of the function will be replaced with a new provided string.", 200, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 395 },
{ PROC_LINKS(write_explicit_enum_values, 0), "write_explicit_enum_values", 26, "If the cursor is found to be on the '{' of an enum definition, the values of the enum will be filled in sequentially starting from zero. Existing values are overwritten.", 170, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 733 }, { PROC_LINKS(write_explicit_enum_values, 0), "write_explicit_enum_values", 26, "If the cursor is found to be on the '{' of an enum definition, the values of the enum will be filled in sequentially starting from zero. Existing values are overwritten.", 170, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 702 },
{ PROC_LINKS(write_explicit_enum_flags, 0), "write_explicit_enum_flags", 25, "If the cursor is found to be on the '{' of an enum definition, the values of the enum will be filled in to give each a unique power of 2 value, starting from 1. Existing values are overwritten.", 194, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 739 }, { PROC_LINKS(write_explicit_enum_flags, 0), "write_explicit_enum_flags", 25, "If the cursor is found to be on the '{' of an enum definition, the values of the enum will be filled in to give each a unique power of 2 value, starting from 1. Existing values are overwritten.", 194, "w:\\4ed\\code\\4coder_experiments.cpp", 34, 708 },
}; };
static int32_t fcoder_metacmd_ID_replace_all_occurrences = 0; static int32_t fcoder_metacmd_ID_replace_all_occurrences = 0;
static int32_t fcoder_metacmd_ID_seek_beginning_of_textual_line = 1; static int32_t fcoder_metacmd_ID_seek_beginning_of_textual_line = 1;

View File

@ -279,6 +279,28 @@ get_key_code(char *buffer){
//////////////////////////////// ////////////////////////////////
static Buffer_Seek
seek_location(ID_Line_Column_Jump_Location location){
return(seek_line_char(location.line, location.column));
}
static Buffer_Seek
seek_location(ID_Pos_Jump_Location location){
return(seek_pos(location.pos));
}
static Buffer_Seek
seek_location(Name_Line_Column_Location location){
return(seek_line_char(location.line, location.column));
}
static Buffer_Seek
seek_jump(Parsed_Jump jump){
return(seek_location(jump.location));
}
////////////////////////////////
internal Character_Predicate internal Character_Predicate
character_predicate_from_function(Character_Predicate_Function *func){ character_predicate_from_function(Character_Predicate_Function *func){
Character_Predicate predicate = {}; Character_Predicate predicate = {};
@ -393,41 +415,28 @@ push_4ed_path(Application_Links *app, Arena *arena){
return(result); return(result);
} }
static String_Const_u8
push_buffer_base_name(Application_Links *app, Arena *arena, Buffer_ID buffer){
String_Const_u8 result = {};
buffer_get_base_buffer_name(app, buffer, arena, &result);
return(result);
}
static String_Const_u8
push_buffer_unique_name(Application_Links *app, Arena *arena, Buffer_ID buffer){
String_Const_u8 result = {};
buffer_get_unique_buffer_name(app, buffer, arena, &result);
return(result);
}
static String_Const_u8
push_buffer_file_name(Application_Links *app, Arena *arena, Buffer_ID buffer){
String_Const_u8 result = {};
buffer_get_file_name(app, buffer, arena, &result);
return(result);
}
//////////////////////////////// ////////////////////////////////
static Range_u64
buffer_range(Application_Links *app, Buffer_ID buffer){
Range_u64 range = {};
range.end = buffer_get_size(app, buffer);
return(range);
}
static u64
buffer_side(Application_Links *app, Buffer_ID buffer, Side side){
return(range_side(buffer_range(app, buffer), side));
}
static Range static Range
get_view_range(Application_Links *app, View_ID view){ get_view_range(Application_Links *app, View_ID view){
Range range = {}; return(make_range(view_get_cursor_pos(app, view), view_get_mark_pos(app, view)));
view_get_cursor_pos(app, view, &range.first);
view_get_mark_pos(app, view, &range.one_past_last);
return(rectify(range));
} }
static f32 static f32
get_view_y(Application_Links *app, View_ID view){ get_view_y(Application_Links *app, View_ID view){
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, view, seek_pos(pos), &cursor); view_compute_cursor(app, view, seek_pos(pos), &cursor);
return(cursor.wrapped_y); return(cursor.wrapped_y);
@ -435,8 +444,7 @@ get_view_y(Application_Links *app, View_ID view){
static f32 static f32
get_view_x(Application_Links *app, View_ID view){ get_view_x(Application_Links *app, View_ID view){
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, view, seek_pos(pos), &cursor); view_compute_cursor(app, view, seek_pos(pos), &cursor);
return(cursor.wrapped_x); return(cursor.wrapped_x);
@ -444,22 +452,19 @@ get_view_x(Application_Links *app, View_ID view){
static b32 static b32
is_valid_line(Application_Links *app, Buffer_ID buffer_id, i32 line){ is_valid_line(Application_Links *app, Buffer_ID buffer_id, i32 line){
i32 max_line = 0; i32 max_line = (i32)buffer_get_line_count(app, buffer_id);
buffer_get_line_count(app, buffer_id, &max_line);
return(1 <= line && line <= max_line); return(1 <= line && line <= max_line);
} }
static b32 static b32
is_valid_line_range(Application_Links *app, Buffer_ID buffer_id, Range range){ is_valid_line_range(Application_Links *app, Buffer_ID buffer_id, Range range){
i32 max_line = 0; i32 max_line = (i32)buffer_get_line_count(app, buffer_id);
buffer_get_line_count(app, buffer_id, &max_line);
return(1 <= range.first && range.first <= range.end && range.end <= max_line); return(1 <= range.first && range.first <= range.end && range.end <= max_line);
} }
static i32 static i32
get_line_number_from_pos(Application_Links *app, Buffer_ID buffer, i32 pos){ get_line_number_from_pos(Application_Links *app, Buffer_ID buffer, i32 pos){
Partial_Cursor partial_cursor = {}; Partial_Cursor partial_cursor = buffer_compute_cursor(app, buffer, seek_pos(pos));
buffer_compute_cursor(app, buffer, seek_pos(pos), &partial_cursor);
return(partial_cursor.line); return(partial_cursor.line);
} }
@ -475,22 +480,14 @@ character_pos_to_pos_view(Application_Links *app, View_ID view, i32 character_po
static i32 static i32
character_pos_to_pos_buffer(Application_Links *app, Buffer_ID buffer, i32 character_pos){ character_pos_to_pos_buffer(Application_Links *app, Buffer_ID buffer, i32 character_pos){
i32 result = 0; Partial_Cursor cursor = buffer_compute_cursor(app, buffer, seek_character_pos(character_pos));
Partial_Cursor cursor = {}; return(cursor.pos);
if (buffer_compute_cursor(app, buffer, seek_character_pos(character_pos), &cursor)){
result = cursor.pos;
}
return(result);
} }
static Partial_Cursor static Partial_Cursor
get_line_side(Application_Links *app, Buffer_ID buffer, i32 line_number, Side side){ get_line_side(Application_Links *app, Buffer_ID buffer, i32 line_number, Side side){
Partial_Cursor result = {};
i32 character_index = (side == Side_Min)?(1):(-1); i32 character_index = (side == Side_Min)?(1):(-1);
if (!buffer_compute_cursor(app, buffer, seek_line_char(line_number, character_index), &result)){ return(buffer_compute_cursor(app, buffer, seek_line_char(line_number, character_index)));
block_zero_struct(&result);
}
return(result);
} }
static i32 static i32
get_line_side_pos(Application_Links *app, Buffer_ID buffer, i32 line_number, Side side){ get_line_side_pos(Application_Links *app, Buffer_ID buffer, i32 line_number, Side side){
@ -626,8 +623,7 @@ static i32
scan(Application_Links *app, Boundary_Function_List funcs, Buffer_ID buffer, Scan_Direction direction, i32 start_pos){ scan(Application_Links *app, Boundary_Function_List funcs, Buffer_ID buffer, Scan_Direction direction, i32 start_pos){
i32 result = 0; i32 result = 0;
if (direction == Scan_Forward){ if (direction == Scan_Forward){
i32 size = 0; i32 size = (i32)buffer_get_size(app, buffer);
buffer_get_size(app, buffer, &size);
result = size + 1; result = size + 1;
for (Boundary_Function_Node *node = funcs.first; for (Boundary_Function_Node *node = funcs.first;
node != 0; node != 0;
@ -746,15 +742,11 @@ boundary_token(Application_Links *app, Buffer_ID buffer, Side side, Scan_Directi
result = boundary_non_whitespace(app, buffer, side, direction, pos); result = boundary_non_whitespace(app, buffer, side, direction, pos);
} }
else{ else{
Cpp_Token *first_token = 0; Cpp_Token_Array tokens = buffer_get_token_array(app, buffer);
Cpp_Token *last_token = 0;
buffer_get_token_range(app, buffer, &first_token, &last_token);
Cpp_Token_Array tokens = {first_token, (i32)(last_token - first_token)};
switch (direction){ switch (direction){
case Scan_Forward: case Scan_Forward:
{ {
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer);
buffer_get_size(app, buffer, &buffer_size);
if (tokens.count > 0){ if (tokens.count > 0){
Cpp_Token *token = get_first_token_from_pos(tokens, pos); Cpp_Token *token = get_first_token_from_pos(tokens, pos);
if (token != 0){ if (token != 0){
@ -853,7 +845,7 @@ boundary_line(Application_Links *app, Buffer_ID buffer, Side side, Scan_Directio
else if (direction == Scan_Forward && new_pos <= pos){ else if (direction == Scan_Forward && new_pos <= pos){
new_pos = get_line_side_pos(app, buffer, line_number + 1, side); new_pos = get_line_side_pos(app, buffer, line_number + 1, side);
if (new_pos <= pos){ if (new_pos <= pos){
buffer_get_size(app, buffer, &new_pos); new_pos = (i32)buffer_get_size(app, buffer);
} }
} }
return(new_pos); return(new_pos);
@ -873,35 +865,38 @@ buffer_seek_delimiter_backward(Application_Links *app, Buffer_ID buffer, i32 pos
buffer_seek_character_class(app, buffer, &predicate, Scan_Backward, pos, result); buffer_seek_character_class(app, buffer, &predicate, Scan_Backward, pos, result);
} }
// TODO(allen): these need a little more rewrite
static void static void
buffer_seek_string_forward(Application_Links *app, Buffer_ID buffer, i32 pos, i32 end, String_Const_u8 needle, i32 *result){ buffer_seek_string_forward(Application_Links *app, Buffer_ID buffer, i32 pos, i32 end, String_Const_u8 needle, i32 *result){
if (end == 0){ if (end == 0){
buffer_get_size(app, buffer, &end); end = (i32)buffer_get_size(app, buffer);
} }
b32 case_sensitive = false; String_Match match = {};
b32 finding_matches = false; match.range.first = pos;
do{ for (;;){
finding_matches = match = buffer_seek_string(app, buffer, needle, Scan_Forward, (i32)match.range.first);
buffer_seek_string(app, buffer, needle, Scan_Forward, pos, &pos, &case_sensitive); if (HasFlag(match.flags, StringMatch_CaseSensitive) ||
} while(!case_sensitive && pos < end && finding_matches); match.buffer != buffer || match.range.first >= end) break;
if (pos < end && finding_matches){ }
*result = pos; if (match.range.first < end && match.buffer == buffer){
*result = (i32)match.range.first;
} }
else{ else{
buffer_get_size(app, buffer, result); *result = (i32)buffer_get_size(app, buffer);
} }
} }
static void static void
buffer_seek_string_backward(Application_Links *app, Buffer_ID buffer, i32 pos, i32 min, String_Const_u8 needle, i32 *result){ buffer_seek_string_backward(Application_Links *app, Buffer_ID buffer, i32 pos, i32 min, String_Const_u8 needle, i32 *result){
b32 case_sensitive = false; String_Match match = {};
b32 finding_matches = false; match.range.first = pos;
do{ for (;;){
finding_matches = match = buffer_seek_string(app, buffer, needle, Scan_Backward, (i32)match.range.first);
buffer_seek_string(app, buffer, needle, Scan_Backward, pos, &pos, &case_sensitive); if (HasFlag(match.flags, StringMatch_CaseSensitive) ||
} while(!case_sensitive && pos >= min && finding_matches); match.buffer != buffer || match.range.first < min) break;
if (pos >= min && finding_matches){ }
*result = pos; if (match.range.first >= min && match.buffer != buffer){
*result = (i32)match.range.first;
} }
else{ else{
*result = -1; *result = -1;
@ -911,28 +906,22 @@ buffer_seek_string_backward(Application_Links *app, Buffer_ID buffer, i32 pos, i
static void static void
buffer_seek_string_insensitive_forward(Application_Links *app, Buffer_ID buffer, i32 pos, i32 end, String_Const_u8 needle, i32 *result){ buffer_seek_string_insensitive_forward(Application_Links *app, Buffer_ID buffer, i32 pos, i32 end, String_Const_u8 needle, i32 *result){
if (end == 0){ if (end == 0){
buffer_get_size(app, buffer, &end); end = (i32)buffer_get_size(app, buffer);
} }
b32 finding_matches = false; String_Match match = buffer_seek_string(app, buffer, needle, Scan_Forward, pos);
b32 case_sensitive = false; if (match.range.first < end && match.buffer == buffer){
finding_matches = *result = (i32)match.range.first;
buffer_seek_string(app, buffer, needle, Scan_Forward, pos, &pos, &case_sensitive);
if (pos < end && finding_matches){
*result = pos;
} }
else{ else{
buffer_get_size(app, buffer, result); *result = (i32)buffer_get_size(app, buffer);
} }
} }
static void static void
buffer_seek_string_insensitive_backward(Application_Links *app, Buffer_ID buffer, i32 pos, i32 min, String_Const_u8 needle, i32 *result){ buffer_seek_string_insensitive_backward(Application_Links *app, Buffer_ID buffer, i32 pos, i32 min, String_Const_u8 needle, i32 *result){
b32 finding_matches = false; String_Match match = buffer_seek_string(app, buffer, needle, Scan_Backward, pos);
b32 case_sensitive = false; if (match.range.first >= min && match.buffer != buffer){
finding_matches = *result = (i32)match.range.first;
buffer_seek_string(app, buffer, needle, Scan_Backward, pos, &pos, &case_sensitive);
if (pos >= min && finding_matches){
*result = pos;
} }
else{ else{
*result = -1; *result = -1;
@ -1046,8 +1035,7 @@ pos_range_enclose_whole_lines(Application_Links *app, Buffer_ID buffer, Range ra
static Range static Range
get_snipe_range(Application_Links *app, Boundary_Function_List funcs, Buffer_ID buffer, i32 pos, Scan_Direction direction){ get_snipe_range(Application_Links *app, Boundary_Function_List funcs, Buffer_ID buffer, i32 pos, Scan_Direction direction){
Range result = {}; Range result = {};
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer);
buffer_get_size(app, buffer, &buffer_size);
i32 pos0 = pos; i32 pos0 = pos;
i32 pos1 = scan(app, funcs, buffer, direction, pos0); i32 pos1 = scan(app, funcs, buffer, direction, pos0);
if (0 <= pos1 && pos1 <= buffer_size){ if (0 <= pos1 && pos1 <= buffer_size){
@ -1074,7 +1062,7 @@ get_snipe_range(Application_Links *app, Boundary_Function *func, Buffer_ID buffe
//////////////////////////////// ////////////////////////////////
static String_Const_u8 static String_Const_u8
push_buffer_range(Application_Links *app, Arena *arena, Buffer_ID buffer, umem first, umem one_past_last){ push_buffer_range(Application_Links *app, Arena *arena, Buffer_ID buffer, u64 first, u64 one_past_last){
String_Const_u8 result = {}; String_Const_u8 result = {};
if (first <= one_past_last){ if (first <= one_past_last){
umem length = one_past_last - first; umem length = one_past_last - first;
@ -1112,15 +1100,12 @@ push_buffer_line(Application_Links *app, Arena *arena, Buffer_ID buffer, i32 lin
static String_Const_u8 static String_Const_u8
push_whole_buffer(Application_Links *app, Arena *arena, Buffer_ID buffer){ push_whole_buffer(Application_Links *app, Arena *arena, Buffer_ID buffer){
i32 size = 0; return(push_buffer_range(app, arena, buffer, buffer_range(app, buffer)));
buffer_get_size(app, buffer, &size);
return(push_buffer_range(app, arena, buffer, 0, size));
} }
static String_Const_u8 static String_Const_u8
push_string_in_view_range(Application_Links *app, Arena *arena, View_ID view){ push_string_in_view_range(Application_Links *app, Arena *arena, View_ID view){
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
view_get_buffer(app, view, AccessProtected, &buffer);
return(push_buffer_range(app, arena, buffer, get_view_range(app, view))); return(push_buffer_range(app, arena, buffer, get_view_range(app, view)));
} }
@ -1141,8 +1126,7 @@ buffer_has_name_with_star(Application_Links *app, Buffer_ID buffer){
static char static char
buffer_get_char(Application_Links *app, Buffer_ID buffer_id, i32 pos){ buffer_get_char(Application_Links *app, Buffer_ID buffer_id, i32 pos){
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer_id);
buffer_get_size(app, buffer_id, &buffer_size);
char result = ' '; char result = ' ';
if (0 <= pos && pos < buffer_size){ if (0 <= pos && pos < buffer_size){
buffer_read_range(app, buffer_id, pos, pos + 1, &result); buffer_read_range(app, buffer_id, pos, pos + 1, &result);
@ -1194,16 +1178,14 @@ get_pos_past_lead_whitespace(Application_Links *app, Buffer_ID buffer, i32 pos){
static void static void
move_past_lead_whitespace(Application_Links *app, View_ID view, Buffer_ID buffer){ move_past_lead_whitespace(Application_Links *app, View_ID view, Buffer_ID buffer){
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
i32 new_pos = get_pos_past_lead_whitespace(app, buffer, pos); i32 new_pos = get_pos_past_lead_whitespace(app, buffer, pos);
view_set_cursor(app, view, seek_pos(new_pos), true); view_set_cursor(app, view, seek_pos(new_pos), true);
} }
static void static void
move_past_lead_whitespace(Application_Links *app, View_ID view){ move_past_lead_whitespace(Application_Links *app, View_ID view){
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
view_get_buffer(app, view, AccessProtected, &buffer);
move_past_lead_whitespace(app, view, buffer); move_past_lead_whitespace(app, view, buffer);
} }
@ -1223,8 +1205,7 @@ line_is_blank(Application_Links *app, Buffer_ID buffer, i32 line_number){
static i32 static i32
get_line_number_of__whitespace_status_line(Application_Links *app, Buffer_ID buffer, Scan_Direction direction, i32 line_number_start, b32 get_blank_line){ get_line_number_of__whitespace_status_line(Application_Links *app, Buffer_ID buffer, Scan_Direction direction, i32 line_number_start, b32 get_blank_line){
i32 line_count = 0; i32 line_count = (i32)buffer_get_line_count(app, buffer);
buffer_get_line_count(app, buffer, &line_count);
i32 line_number = line_number_start + direction; i32 line_number = line_number_start + direction;
for (;1 <= line_number && line_number <= line_count; line_number += direction){ for (;1 <= line_number && line_number <= line_count; line_number += direction){
b32 is_blank = line_is_blank(app, buffer, line_number); b32 is_blank = line_is_blank(app, buffer, line_number);
@ -1352,8 +1333,7 @@ replace_in_range(Application_Links *app, Buffer_ID buffer, Range range, String_C
internal Range internal Range
swap_lines(Application_Links *app, Buffer_ID buffer, i32 line_1, i32 line_2){ swap_lines(Application_Links *app, Buffer_ID buffer, i32 line_1, i32 line_2){
Range result = {}; Range result = {};
i32 line_count = 0; i32 line_count = (i32)buffer_get_line_count(app, buffer);
buffer_get_line_count(app, buffer, &line_count);
if (1 <= line_1 && line_2 <= line_count){ if (1 <= line_1 && line_2 <= line_count){
Range range_1 = get_line_pos_range(app, buffer, line_1); Range range_1 = get_line_pos_range(app, buffer, line_1);
Range range_2 = get_line_pos_range(app, buffer, line_2); Range range_2 = get_line_pos_range(app, buffer, line_2);
@ -1561,9 +1541,9 @@ buffer_identifier_to_id(Application_Links *app, Buffer_Identifier identifier){
} }
else{ else{
String_Const_u8 name = SCu8(identifier.name, identifier.name_len); String_Const_u8 name = SCu8(identifier.name, identifier.name_len);
get_buffer_by_name(app, name, AccessAll, &id); id = get_buffer_by_name(app, name, AccessAll);
if (id == 0){ if (id == 0){
get_buffer_by_file_name(app, name, AccessAll, &id); id = get_buffer_by_file_name(app, name, AccessAll);
} }
} }
return(id); return(id);
@ -1574,12 +1554,13 @@ buffer_identifier_to_id_create_out_buffer(Application_Links *app, Buffer_Identif
Buffer_ID result = 0; Buffer_ID result = 0;
if (buffer_id.name != 0 && buffer_id.name_len > 0){ if (buffer_id.name != 0 && buffer_id.name_len > 0){
String_Const_u8 buffer_name = SCu8(buffer_id.name, buffer_id.name_len); String_Const_u8 buffer_name = SCu8(buffer_id.name, buffer_id.name_len);
Buffer_ID buffer_attach_id = 0; Buffer_ID buffer_attach_id = get_buffer_by_name(app, buffer_name, AccessAll);
if (get_buffer_by_name(app, buffer_name, AccessAll, &buffer_attach_id)){ if (buffer_attach_id != 0){
result = buffer_attach_id; result = buffer_attach_id;
} }
else{ else{
if (create_buffer(app, buffer_name, BufferCreate_AlwaysNew|BufferCreate_NeverAttachToFile, &buffer_attach_id)){ buffer_attach_id = create_buffer(app, buffer_name, BufferCreate_AlwaysNew|BufferCreate_NeverAttachToFile);
if (buffer_attach_id != 0){
buffer_set_setting(app, buffer_attach_id, BufferSetting_ReadOnly, true); buffer_set_setting(app, buffer_attach_id, BufferSetting_ReadOnly, true);
buffer_set_setting(app, buffer_attach_id, BufferSetting_Unimportant, true); buffer_set_setting(app, buffer_attach_id, BufferSetting_Unimportant, true);
result = buffer_attach_id; result = buffer_attach_id;
@ -1596,10 +1577,9 @@ buffer_identifier_to_id_create_out_buffer(Application_Links *app, Buffer_Identif
static void static void
adjust_all_buffer_wrap_widths(Application_Links *app, i32 wrap_width, i32 min_base_width){ adjust_all_buffer_wrap_widths(Application_Links *app, i32 wrap_width, i32 min_base_width){
Buffer_ID buffer = 0; for (Buffer_ID buffer = get_buffer_next(app, 0, AccessAll);
for (get_buffer_next(app, 0, AccessAll, &buffer);
buffer != 0; buffer != 0;
get_buffer_next(app, buffer, AccessAll, &buffer)){ buffer = get_buffer_next(app, buffer, AccessAll)){
buffer_set_setting(app, buffer, BufferSetting_WrapPosition, wrap_width); buffer_set_setting(app, buffer, BufferSetting_WrapPosition, wrap_width);
buffer_set_setting(app, buffer, BufferSetting_MinimumBaseWrapPosition, min_base_width); buffer_set_setting(app, buffer, BufferSetting_MinimumBaseWrapPosition, min_base_width);
} }
@ -1609,15 +1589,15 @@ static View_ID
open_view(Application_Links *app, View_ID view_location, View_Split_Position position){ open_view(Application_Links *app, View_ID view_location, View_Split_Position position){
View_ID result = 0; View_ID result = 0;
if (view_location != 0 && view_exists(app, view_location)){ if (view_location != 0 && view_exists(app, view_location)){
Panel_ID panel_id = 0; Panel_ID panel_id = view_get_panel(app, view_location);
if (view_get_panel(app, view_location, &panel_id)){ if (panel_id != 0){
b32 vertical = (position == ViewSplit_Left || position == ViewSplit_Right); b32 vertical = (position == ViewSplit_Left || position == ViewSplit_Right);
if (panel_split(app, panel_id, vertical?PanelSplit_LeftAndRight:PanelSplit_TopAndBottom)){ if (panel_split(app, panel_id, vertical?PanelSplit_LeftAndRight:PanelSplit_TopAndBottom)){
Panel_ID new_panel_id = 0;
Panel_Child child = (position == ViewSplit_Left || position == ViewSplit_Top)?PanelChild_Min:PanelChild_Max; Panel_Child child = (position == ViewSplit_Left || position == ViewSplit_Top)?PanelChild_Min:PanelChild_Max;
if (panel_get_child(app, panel_id, child, &new_panel_id)){ Panel_ID new_panel_id = panel_get_child(app, panel_id, child);
View_ID new_view_id = 0; if (new_panel_id != 0){
if (panel_get_view(app, new_panel_id, &new_view_id)){ View_ID new_view_id = panel_get_view(app, new_panel_id);
if (new_view_id != 0){
result = new_view_id; result = new_view_id;
} }
} }
@ -1630,13 +1610,11 @@ open_view(Application_Links *app, View_ID view_location, View_Split_Position pos
static View_ID static View_ID
get_first_view_with_buffer(Application_Links *app, Buffer_ID buffer_id){ get_first_view_with_buffer(Application_Links *app, Buffer_ID buffer_id){
View_ID result = {}; View_ID result = {};
View_ID test = {};
if (buffer_id != 0){ if (buffer_id != 0){
for (get_view_next(app, 0, AccessAll, &test); for (View_ID test = get_view_next(app, 0, AccessAll);
test != 0; test != 0;
get_view_next(app, test, AccessAll, &test)){ test = get_view_next(app, test, AccessAll)){
Buffer_ID test_buffer = 0; Buffer_ID test_buffer = view_get_buffer(app, test, AccessAll);
view_get_buffer(app, test, AccessAll, &test_buffer);
if (test_buffer == buffer_id){ if (test_buffer == buffer_id){
result = test; result = test;
break; break;
@ -1649,8 +1627,7 @@ get_first_view_with_buffer(Application_Links *app, Buffer_ID buffer_id){
static b32 static b32
open_file(Application_Links *app, Buffer_ID *buffer_out, String_Const_u8 file_name, b32 background, b32 never_new){ open_file(Application_Links *app, Buffer_ID *buffer_out, String_Const_u8 file_name, b32 background, b32 never_new){
b32 result = false; b32 result = false;
Buffer_ID buffer = 0; Buffer_ID buffer = get_buffer_by_name(app, file_name, AccessProtected);
get_buffer_by_name(app, file_name, AccessProtected, &buffer);
b32 exists = buffer_exists(app, buffer); b32 exists = buffer_exists(app, buffer);
if (!exists){ if (!exists){
Buffer_Create_Flag flags = 0; Buffer_Create_Flag flags = 0;
@ -1660,7 +1637,7 @@ open_file(Application_Links *app, Buffer_ID *buffer_out, String_Const_u8 file_na
if (never_new){ if (never_new){
flags |= BufferCreate_NeverNew; flags |= BufferCreate_NeverNew;
} }
create_buffer(app, file_name, flags, &buffer); buffer = create_buffer(app, file_name, flags);
exists = buffer_exists(app, buffer); exists = buffer_exists(app, buffer);
} }
if (exists){ if (exists){
@ -1689,20 +1666,18 @@ view_open_file(Application_Links *app, View_ID view, String_Const_u8 file_name,
static View_ID static View_ID
get_next_view_looped_all_panels(Application_Links *app, View_ID view_id, Access_Flag access){ get_next_view_looped_all_panels(Application_Links *app, View_ID view_id, Access_Flag access){
if (!get_view_next(app, view_id, access, &view_id)){ view_id = get_view_next(app, view_id, access);
if (!get_view_next(app, 0, access, &view_id)){ if (view_id == 0){
view_id = 0; view_id = get_view_next(app, 0, access);
}
} }
return(view_id); return(view_id);
} }
static View_ID static View_ID
get_prev_view_looped_all_panels(Application_Links *app, View_ID view_id, Access_Flag access){ get_prev_view_looped_all_panels(Application_Links *app, View_ID view_id, Access_Flag access){
if (!get_view_prev(app, view_id, access, &view_id)){ view_id = get_view_prev(app, view_id, access);
if (!get_view_prev(app, 0, access, &view_id)){ if (view_id == 0){
view_id = 0; view_id = get_view_prev(app, 0, access);
}
} }
return(view_id); return(view_id);
} }
@ -1710,10 +1685,8 @@ get_prev_view_looped_all_panels(Application_Links *app, View_ID view_id, Access_
//////////////////////////////// ////////////////////////////////
static Buffer_Kill_Result static Buffer_Kill_Result
kill_buffer(Application_Links *app, Buffer_Identifier identifier, View_ID gui_view_id, Buffer_Kill_Flag flags){ try_buffer_kill(Application_Links *app, Buffer_ID buffer, View_ID gui_view_id, Buffer_Kill_Flag flags){
Buffer_ID buffer = buffer_identifier_to_id(app, identifier); Buffer_Kill_Result result = buffer_kill(app, buffer, flags);
Buffer_Kill_Result result = 0;
buffer_kill(app, buffer, flags, &result);
if (result == BufferKillResult_Dirty){ if (result == BufferKillResult_Dirty){
do_gui_sure_to_kill(app, buffer, gui_view_id); do_gui_sure_to_kill(app, buffer, gui_view_id);
} }
@ -1724,8 +1697,7 @@ kill_buffer(Application_Links *app, Buffer_Identifier identifier, View_ID gui_vi
static void static void
clear_buffer(Application_Links *app, Buffer_ID buffer_id){ clear_buffer(Application_Links *app, Buffer_ID buffer_id){
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer_id);
buffer_get_size(app, buffer_id, &buffer_size);
buffer_replace_range(app, buffer_id, make_range(0, buffer_size), string_u8_litexpr("")); buffer_replace_range(app, buffer_id, make_range(0, buffer_size), string_u8_litexpr(""));
} }
@ -1736,8 +1708,7 @@ init_stream_chunk(Stream_Chunk *chunk, Application_Links *app, Buffer_ID buffer_
i32 pos, char *data, u32 size){ i32 pos, char *data, u32 size){
b32 result = false; b32 result = false;
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer_id);
buffer_get_size(app, buffer_id, &buffer_size);
if (0 <= pos && pos < buffer_size && size > 0){ if (0 <= pos && pos < buffer_size && size > 0){
chunk->app = app; chunk->app = app;
chunk->buffer_id = buffer_id; chunk->buffer_id = buffer_id;
@ -1773,8 +1744,7 @@ forward_stream_chunk(Stream_Chunk *chunk){
Buffer_ID buffer_id = chunk->buffer_id; Buffer_ID buffer_id = chunk->buffer_id;
b32 result = 0; b32 result = 0;
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer_id);
buffer_get_size(app, buffer_id, &buffer_size);
if (chunk->end < buffer_size){ if (chunk->end < buffer_size){
chunk->start = chunk->end; chunk->start = chunk->end;
chunk->end += chunk->data_size; chunk->end += chunk->data_size;
@ -1841,94 +1811,12 @@ backward_stream_chunk(Stream_Chunk *chunk){
//////////////////////////////// ////////////////////////////////
static b32
init_stream_tokens(Stream_Tokens_DEP *stream, Application_Links *app, Buffer_ID buffer_id, i32 pos, Cpp_Token *data, i32 count){
b32 result = false;
i32 token_count = 0;
buffer_token_count(app, buffer_id, &token_count);
if (buffer_tokens_are_ready(app, buffer_id) && pos >= 0 && pos < token_count && count > 0){
stream->app = app;
stream->buffer_id = buffer_id;
stream->base_tokens = data;
stream->count = count;
stream->start = round_down_i32(pos, count);
stream->end = round_up_i32(pos, count);
stream->token_count = token_count;
stream->start = clamp_bot(0, stream->start);
stream->end = clamp_top(stream->end, stream->token_count);
buffer_read_tokens(app, buffer_id, stream->start, stream->end, stream->base_tokens);
stream->tokens = stream->base_tokens - stream->start;
result = true;
}
return(result);
}
static Stream_Tokens_DEP
begin_temp_stream_token(Stream_Tokens_DEP *stream){
return(*stream);
}
static void
end_temp_stream_token(Stream_Tokens_DEP *stream, Stream_Tokens_DEP temp){
if (stream->start != temp.start || stream->end != temp.end){
Application_Links *app = stream->app;
buffer_read_tokens(app, temp.buffer_id, temp.start, temp.end, temp.base_tokens);
stream->tokens = stream->base_tokens - temp.start;
stream->start = temp.start;
stream->end = temp.end;
}
}
static b32
forward_stream_tokens(Stream_Tokens_DEP *stream){
Application_Links *app = stream->app;
Buffer_ID buffer_id = stream->buffer_id;
b32 result = false;
if (stream->end < stream->token_count){
stream->start = stream->end;
stream->end += stream->count;
if (stream->end > stream->token_count){
stream->end = stream->token_count;
}
if (stream->start < stream->end){
buffer_read_tokens(app, buffer_id, stream->start, stream->end, stream->base_tokens);
stream->tokens = stream->base_tokens - stream->start;
result = true;
}
}
return(result);
}
static b32
backward_stream_tokens(Stream_Tokens_DEP *stream){
Application_Links *app = stream->app;
Buffer_ID buffer_id = stream->buffer_id;
b32 result = false;
if (stream->start > 0){
stream->end = stream->start;
stream->start -= stream->count;
if (0 > stream->start){
stream->start = 0;
}
if (stream->start < stream->end){
buffer_read_tokens(app, buffer_id, stream->start, stream->end, stream->base_tokens);
stream->tokens = stream->base_tokens - stream->start;
result = true;
}
}
return(result);
}
////////////////////////////////
static Token_Range static Token_Range
buffer_get_token_range(Application_Links *app, Buffer_ID buffer){ buffer_get_token_range(Application_Links *app, Buffer_ID buffer){
Cpp_Token_Array array = buffer_get_token_array(app, buffer);
Token_Range range = {}; Token_Range range = {};
buffer_get_token_range(app, buffer, &range.first, &range.one_past_last); range.first = array.tokens;
range.one_past_last = array.tokens + array.count;
return(range); return(range);
} }
@ -2037,11 +1925,22 @@ get_query_string(Application_Links *app, char *query_str, char *string_space, i3
return(bar.string); return(bar.string);
} }
static b32
get_token_from_pos(Application_Links *app, Buffer_ID buffer, u64 pos, Cpp_Get_Token_Result *result){
b32 success = false;
Cpp_Token_Array array = buffer_get_token_array(app, buffer);
if (array.count > 0){
success = true;
*result = cpp_get_token(array, (i32)pos);
}
return(success);
}
static String_Const_u8 static String_Const_u8
get_token_or_word_under_pos(Application_Links *app, Arena *arena, Buffer_ID buffer, umem pos){ get_token_or_word_under_pos(Application_Links *app, Arena *arena, Buffer_ID buffer, u64 pos){
String_Const_u8 result = {}; String_Const_u8 result = {};
Cpp_Get_Token_Result get_result = {}; Cpp_Get_Token_Result get_result = {};
b32 success = buffer_get_token_index(app, buffer, (i32)pos, &get_result); b32 success = get_token_from_pos(app, buffer, (i32)pos, &get_result);
if (success && !get_result.in_whitespace_after_token){ if (success && !get_result.in_whitespace_after_token){
umem size = get_result.token_one_past_last - get_result.token_start; umem size = get_result.token_one_past_last - get_result.token_start;
if (0 < size){ if (0 < size){
@ -2256,13 +2155,11 @@ no_mark_snap_to_cursor_if_shift(Application_Links *app, View_ID view_id){
} }
static b32 static b32
view_has_highlighted_range(Application_Links *app, View_ID view_id){ view_has_highlighted_range(Application_Links *app, View_ID view){
b32 result = false; b32 result = false;
if (fcoder_mode == FCoderMode_NotepadLike){ if (fcoder_mode == FCoderMode_NotepadLike){
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
i32 mark = 0; i32 mark = view_get_mark_pos(app, view);
view_get_cursor_pos(app, view_id, &pos);
view_get_mark_pos(app, view_id, &mark);
result = (pos != mark); result = (pos != mark);
} }
return(result); return(result);
@ -2273,8 +2170,7 @@ if_view_has_highlighted_range_delete_range(Application_Links *app, View_ID view_
b32 result = false; b32 result = false;
if (view_has_highlighted_range(app, view_id)){ if (view_has_highlighted_range(app, view_id)){
Range range = get_view_range(app, view_id); Range range = get_view_range(app, view_id);
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view_id, AccessOpen);
view_get_buffer(app, view_id, AccessOpen, &buffer);
buffer_replace_range(app, buffer, range, string_u8_litexpr("")); buffer_replace_range(app, buffer, range, string_u8_litexpr(""));
result = true; result = true;
} }
@ -2284,34 +2180,26 @@ if_view_has_highlighted_range_delete_range(Application_Links *app, View_ID view_
static void static void
begin_notepad_mode(Application_Links *app){ begin_notepad_mode(Application_Links *app){
fcoder_mode = FCoderMode_NotepadLike; fcoder_mode = FCoderMode_NotepadLike;
View_ID view = 0; for (View_ID view = get_view_next(app, 0, AccessAll);
for (get_view_next(app, 0, AccessAll, &view);
view != 0; view != 0;
get_view_next(app, view, AccessAll, &view)){ view = get_view_next(app, view, AccessAll)){
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
view_set_mark(app, view, seek_pos(pos)); view_set_mark(app, view, seek_pos(pos));
} }
} }
//////////////////////////////// ////////////////////////////////
typedef i32 View_Split_Kind;
enum{
ViewSplitKind_Ratio,
ViewSplitKind_FixedPixels,
};
static b32 static b32
view_set_split(Application_Links *app, View_ID view, View_Split_Kind kind, f32 t){ view_set_split(Application_Links *app, View_ID view, View_Split_Kind kind, f32 t){
b32 result = false; b32 result = false;
if (view != 0){ if (view != 0){
Panel_ID panel_id = 0; Panel_ID panel_id = view_get_panel(app, view);
if (view_get_panel(app, view, &panel_id)){ if (panel_id != 0){
Panel_ID parent_panel_id = 0; Panel_ID parent_panel_id = panel_get_parent(app, panel_id);
if (panel_get_parent(app, panel_id, &parent_panel_id)){ if (parent_panel_id != 0){
Panel_ID min_child_id = 0; Panel_ID min_child_id = panel_get_child(app, parent_panel_id, PanelChild_Min);
if (panel_get_child(app, parent_panel_id, PanelChild_Min, &min_child_id)){ if (min_child_id != 0){
b32 panel_is_min = (min_child_id == panel_id); b32 panel_is_min = (min_child_id == panel_id);
Panel_Split_Kind panel_kind = ((kind == ViewSplitKind_Ratio)? Panel_Split_Kind panel_kind = ((kind == ViewSplitKind_Ratio)?
(panel_is_min?PanelSplitKind_Ratio_Min:PanelSplitKind_Ratio_Max): (panel_is_min?PanelSplitKind_Ratio_Min:PanelSplitKind_Ratio_Max):
@ -2425,8 +2313,7 @@ set_buffer_system_command(Application_Links *app, Child_Process_ID process, Buff
b32 result = false; b32 result = false;
Child_Process_Set_Target_Flags set_buffer_flags = flags_system_command(flags); Child_Process_Set_Target_Flags set_buffer_flags = flags_system_command(flags);
if (child_process_set_target_buffer(app, process, buffer, set_buffer_flags)){ if (child_process_set_target_buffer(app, process, buffer, set_buffer_flags)){
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer);
buffer_get_size(app, buffer, &buffer_size);
buffer_replace_range(app, buffer, make_range(0, buffer_size), string_u8_litexpr("")); buffer_replace_range(app, buffer, make_range(0, buffer_size), string_u8_litexpr(""));
if (HasFlag(flags, CLI_SendEndSignal)){ if (HasFlag(flags, CLI_SendEndSignal)){
buffer_send_end_signal(app, buffer); buffer_send_end_signal(app, buffer);

View File

@ -159,22 +159,6 @@ struct Stream_Chunk{
char *data; char *data;
}; };
// NOTE(allen|4.0.31): Stream_Tokens has been deprecated in favor of the Token_Iterator below.
// For examples of usage: 4coder_function_list.cpp 4coder_scope_commands.cpp
// If you want to keep your code working easily uncomment the typedef for Stream_Tokens.
struct Stream_Tokens_DEP{
Application_Links *app;
Buffer_ID buffer_id;
Cpp_Token *base_tokens;
Cpp_Token *tokens;
i32 start;
i32 end;
i32 count;
i32 token_count;
};
//typedef Stream_Tokens_DEP Stream_Tokens;
struct Token_Range{ struct Token_Range{
Cpp_Token *first; Cpp_Token *first;
Cpp_Token *one_past_last; Cpp_Token *one_past_last;
@ -201,6 +185,14 @@ struct History_Group{
History_Record_Index first; History_Record_Index first;
}; };
////////////////////////////////
typedef i32 View_Split_Kind;
enum{
ViewSplitKind_Ratio,
ViewSplitKind_FixedPixels,
};
#endif #endif
// BOTTOM // BOTTOM

View File

@ -24,12 +24,9 @@ begin_buffer_insertion_at_buffered(Application_Links *app, Buffer_ID buffer_id,
static Buffer_Insertion static Buffer_Insertion
begin_buffer_insertion(Application_Links *app){ begin_buffer_insertion(Application_Links *app){
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessAll);
Buffer_ID buffer = 0; i32 cursor_pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessAll, &buffer);
i32 cursor_pos = 0;
view_get_cursor_pos(app, view, &cursor_pos);
Buffer_Insertion result = begin_buffer_insertion_at(app, buffer, cursor_pos); Buffer_Insertion result = begin_buffer_insertion_at(app, buffer, cursor_pos);
return(result); return(result);
} }

View File

@ -10,20 +10,16 @@ CUSTOM_DOC("If the cursor is found to be on a jump location, parses the jump loc
{ {
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessProtected, &buffer);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, view, seek_pos(pos), &cursor); view_compute_cursor(app, view, seek_pos(pos), &cursor);
Parsed_Jump jump = parse_jump_from_buffer_line(app, scratch, buffer, cursor.line, false); Parsed_Jump jump = parse_jump_from_buffer_line(app, scratch, buffer, cursor.line, false);
if (jump.success){ if (jump.success){
change_active_panel(app); change_active_panel(app);
View_ID target_view = 0; View_ID target_view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &target_view);
if (get_jump_buffer(app, &buffer, &jump.location)){ if (get_jump_buffer(app, &buffer, &jump.location)){
switch_to_existing_view(app, target_view, buffer); switch_to_existing_view(app, target_view, buffer);
jump_to_location(app, target_view, buffer, jump.location); jump_to_location(app, target_view, buffer, jump.location);
@ -38,12 +34,9 @@ CUSTOM_DOC("If the cursor is found to be on a jump location, parses the jump loc
{ {
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessProtected, &buffer);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, view, seek_pos(pos), &cursor); view_compute_cursor(app, view, seek_pos(pos), &cursor);
@ -112,30 +105,34 @@ CUSTOM_DOC("If a buffer containing jump locations has been locked in, goes to th
CUSTOM_COMMAND_SIG(newline_or_goto_position_direct) CUSTOM_COMMAND_SIG(newline_or_goto_position_direct)
CUSTOM_DOC("If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor.") CUSTOM_DOC("If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; if (buffer != 0){
if (view_get_buffer(app, view, AccessOpen, &buffer)){
write_character(app); write_character(app);
} }
else if (view_get_buffer(app, view, AccessProtected, &buffer)){ else{
goto_jump_at_cursor_direct(app); buffer = view_get_buffer(app, view, AccessProtected);
lock_jump_buffer(app, buffer); if (buffer != 0){
goto_jump_at_cursor_direct(app);
lock_jump_buffer(app, buffer);
}
} }
} }
CUSTOM_COMMAND_SIG(newline_or_goto_position_same_panel_direct) CUSTOM_COMMAND_SIG(newline_or_goto_position_same_panel_direct)
CUSTOM_DOC("If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor_same_panel.") CUSTOM_DOC("If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor_same_panel.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; if (buffer != 0){
if (view_get_buffer(app, view, AccessOpen, &buffer)){
write_character(app); write_character(app);
} }
else if (view_get_buffer(app, view, AccessProtected, &buffer)){ else{
goto_jump_at_cursor_same_panel_direct(app); buffer = view_get_buffer(app, view, AccessProtected);
lock_jump_buffer(app, buffer); if (buffer != 0){
goto_jump_at_cursor_same_panel_direct(app);
lock_jump_buffer(app, buffer);
}
} }
} }

View File

@ -104,10 +104,8 @@ open_jump_lister(Application_Links *app, Heap *heap, View_ID ui_view, Buffer_ID
CUSTOM_COMMAND_SIG(view_jump_list_with_lister) CUSTOM_COMMAND_SIG(view_jump_list_with_lister)
CUSTOM_DOC("When executed on a buffer with jumps, creates a persistent lister for all the jumps") CUSTOM_DOC("When executed on a buffer with jumps, creates a persistent lister for all the jumps")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessAll);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessAll, &buffer);
open_jump_lister(app, &global_heap, view, buffer, JumpListerActivation_OpenInNextViewKeepUI, 0); open_jump_lister(app, &global_heap, view, buffer, JumpListerActivation_OpenInNextViewKeepUI, 0);
} }

View File

@ -60,8 +60,8 @@ parse_buffer_to_jump_array(Application_Links *app, Arena *arena, Buffer_ID buffe
Buffer_ID jump_buffer = {}; Buffer_ID jump_buffer = {};
if (open_file(app, &jump_buffer, parsed_jump.location.file, false, true)){ if (open_file(app, &jump_buffer, parsed_jump.location.file, false, true)){
if (buffer_exists(app, jump_buffer)){ if (buffer_exists(app, jump_buffer)){
Partial_Cursor cursor = {}; Partial_Cursor cursor = buffer_compute_cursor(app, jump_buffer, seek_jump(parsed_jump));
if (buffer_compute_cursor(app, jump_buffer, seek_line_char(parsed_jump.location.line, parsed_jump.location.column), &cursor)){ if (cursor.line > 0){
out_buffer_id = jump_buffer; out_buffer_id = jump_buffer;
out_pos = cursor.pos; out_pos = cursor.pos;
output_jump = true; output_jump = true;
@ -128,7 +128,7 @@ init_marker_list(Application_Links *app, Heap *heap, Buffer_ID buffer, Marker_Li
Sticky_Jump_Stored *stored = push_array(scratch, Sticky_Jump_Stored, jumps.count); Sticky_Jump_Stored *stored = push_array(scratch, Sticky_Jump_Stored, jumps.count);
Managed_Scope scope_array[2] = {}; Managed_Scope scope_array[2] = {};
buffer_get_managed_scope(app, buffer, &scope_array[0]); scope_array[0] = buffer_get_managed_scope(app, buffer);
for (i32 i = 0; i < scoped_buffer_ranges.count; i += 1){ for (i32 i = 0; i < scoped_buffer_ranges.count; i += 1){
Range buffer_range_indices = scoped_buffer_ranges.ranges[i]; Range buffer_range_indices = scoped_buffer_ranges.ranges[i];
@ -166,7 +166,7 @@ init_marker_list(Application_Links *app, Heap *heap, Buffer_ID buffer, Marker_Li
} }
} }
buffer_get_managed_scope(app, target_buffer_id, &scope_array[1]); scope_array[1] = buffer_get_managed_scope(app, target_buffer_id);
Managed_Scope scope = get_managed_scope_with_multiple_dependencies(app, scope_array, ArrayCount(scope_array)); Managed_Scope scope = get_managed_scope_with_multiple_dependencies(app, scope_array, ArrayCount(scope_array));
Managed_Object marker_handle = alloc_buffer_markers_on_buffer(app, target_buffer_id, total_jump_count, &scope); Managed_Object marker_handle = alloc_buffer_markers_on_buffer(app, target_buffer_id, total_jump_count, &scope);
managed_object_store_data(app, marker_handle, 0, total_jump_count, markers); managed_object_store_data(app, marker_handle, 0, total_jump_count, markers);
@ -191,7 +191,7 @@ init_marker_list(Application_Links *app, Heap *heap, Buffer_ID buffer, Marker_Li
list->jump_array = stored_jump_array; list->jump_array = stored_jump_array;
list->jump_count = jumps.count; list->jump_count = jumps.count;
buffer_get_size(app, buffer, &list->previous_size); list->previous_size = (i32)buffer_get_size(app, buffer);
list->buffer_id = buffer; list->buffer_id = buffer;
end_temp(temp); end_temp(temp);
@ -233,8 +233,7 @@ static Marker_List*
get_or_make_list_for_buffer(Application_Links *app, Heap *heap, Buffer_ID buffer_id){ get_or_make_list_for_buffer(Application_Links *app, Heap *heap, Buffer_ID buffer_id){
Marker_List *result = get_marker_list_for_buffer(buffer_id); Marker_List *result = get_marker_list_for_buffer(buffer_id);
if (result != 0){ if (result != 0){
i32 buffer_size = 0; i32 buffer_size = (i32)buffer_get_size(app, buffer_id);
buffer_get_size(app, buffer_id, &buffer_size);
// TODO(allen): // TODO(allen): // TODO(allen): // TODO(allen): // TODO(allen): When buffers get an "edit sequence number" use that instead. // TODO(allen): // TODO(allen): // TODO(allen): // TODO(allen): // TODO(allen): When buffers get an "edit sequence number" use that instead.
if (result->previous_size != buffer_size){ if (result->previous_size != buffer_size){
delete_marker_list(result); delete_marker_list(result);
@ -289,8 +288,8 @@ get_jump_from_list(Application_Links *app, Marker_List *list, i32 index, ID_Pos_
Buffer_ID target_buffer_id = stored.jump_buffer_id; Buffer_ID target_buffer_id = stored.jump_buffer_id;
Managed_Scope scope_array[2] = {}; Managed_Scope scope_array[2] = {};
buffer_get_managed_scope(app, list->buffer_id, &scope_array[0]); scope_array[0] = buffer_get_managed_scope(app, list->buffer_id);
buffer_get_managed_scope(app, target_buffer_id, &scope_array[1]); scope_array[1] = buffer_get_managed_scope(app, target_buffer_id);
Managed_Scope scope = get_managed_scope_with_multiple_dependencies(app, scope_array, ArrayCount(scope_array)); Managed_Scope scope = get_managed_scope_with_multiple_dependencies(app, scope_array, ArrayCount(scope_array));
sticky_jump_marker_handle_loc = managed_variable_create_or_get_id(app, sticky_jump_marker_handle_var, 0); sticky_jump_marker_handle_loc = managed_variable_create_or_get_id(app, sticky_jump_marker_handle_var, 0);
@ -368,14 +367,11 @@ CUSTOM_DOC("If the cursor is found to be on a jump location, parses the jump loc
{ {
Heap *heap = &global_heap; Heap *heap = &global_heap;
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessProtected, &buffer);
Marker_List *list = get_or_make_list_for_buffer(app, heap, buffer); Marker_List *list = get_or_make_list_for_buffer(app, heap, buffer);
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, view, seek_pos(pos), &cursor); view_compute_cursor(app, view, seek_pos(pos), &cursor);
@ -386,8 +382,7 @@ CUSTOM_DOC("If the cursor is found to be on a jump location, parses the jump loc
if (get_jump_from_list(app, list, list_index, &location)){ if (get_jump_from_list(app, list, list_index, &location)){
if (get_jump_buffer(app, &buffer, &location)){ if (get_jump_buffer(app, &buffer, &location)){
change_active_panel(app); change_active_panel(app);
View_ID target_view = 0; View_ID target_view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &target_view);
switch_to_existing_view(app, target_view, buffer); switch_to_existing_view(app, target_view, buffer);
jump_to_location(app, target_view, buffer, location); jump_to_location(app, target_view, buffer, location);
} }
@ -400,15 +395,12 @@ CUSTOM_DOC("If the cursor is found to be on a jump location, parses the jump loc
{ {
Heap *heap = &global_heap; Heap *heap = &global_heap;
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessProtected, &buffer);
Marker_List *list = get_or_make_list_for_buffer(app, heap, buffer); Marker_List *list = get_or_make_list_for_buffer(app, heap, buffer);
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, view, seek_pos(pos), &cursor); view_compute_cursor(app, view, seek_pos(pos), &cursor);
@ -428,11 +420,10 @@ static void
goto_jump_in_order(Application_Links *app, Marker_List *list, View_ID jump_view, ID_Pos_Jump_Location location){ goto_jump_in_order(Application_Links *app, Marker_List *list, View_ID jump_view, ID_Pos_Jump_Location location){
Buffer_ID buffer = {}; Buffer_ID buffer = {};
if (get_jump_buffer(app, &buffer, &location)){ if (get_jump_buffer(app, &buffer, &location)){
View_ID target_view = 0; View_ID target_view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &target_view);
if (target_view == jump_view){ if (target_view == jump_view){
change_active_panel(app); change_active_panel(app);
get_active_view(app, AccessAll, &target_view); target_view = get_active_view(app, AccessAll);
} }
switch_to_existing_view(app, target_view, buffer); switch_to_existing_view(app, target_view, buffer);
jump_to_location(app, target_view, buffer, location); jump_to_location(app, target_view, buffer, location);
@ -489,12 +480,10 @@ get_locked_jump_state(Application_Links *app, Heap *heap){
Locked_Jump_State result = {}; Locked_Jump_State result = {};
result.view = get_view_for_locked_jump_buffer(app); result.view = get_view_for_locked_jump_buffer(app);
if (result.view != 0){ if (result.view != 0){
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, result.view, AccessAll);
view_get_buffer(app, result.view, AccessAll, &buffer);
result.list = get_or_make_list_for_buffer(app, heap, buffer); result.list = get_or_make_list_for_buffer(app, heap, buffer);
i32 cursor_position = 0; i32 cursor_position = view_get_cursor_pos(app, result.view);
view_get_cursor_pos(app, result.view, &cursor_position);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, result.view, seek_pos(cursor_position), &cursor); view_compute_cursor(app, result.view, seek_pos(cursor_position), &cursor);
result.list_index = get_index_nearest_from_list(app, result.list, cursor.line); result.list_index = get_index_nearest_from_list(app, result.list, cursor.line);
@ -509,8 +498,7 @@ CUSTOM_DOC("If a buffer containing jump locations has been locked in, goes to th
Locked_Jump_State jump_state = get_locked_jump_state(app, heap); Locked_Jump_State jump_state = get_locked_jump_state(app, heap);
if (jump_state.view != 0){ if (jump_state.view != 0){
i32 cursor_position = 0; i32 cursor_position = view_get_cursor_pos(app, jump_state.view);
view_get_cursor_pos(app, jump_state.view, &cursor_position);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, jump_state.view, seek_pos(cursor_position), &cursor); view_compute_cursor(app, jump_state.view, seek_pos(cursor_position), &cursor);
i32 line = get_line_from_list(app, jump_state.list, jump_state.list_index); i32 line = get_line_from_list(app, jump_state.list, jump_state.list_index);
@ -541,8 +529,7 @@ CUSTOM_DOC("If a buffer containing jump locations has been locked in, goes to th
Locked_Jump_State jump_state = get_locked_jump_state(app, heap); Locked_Jump_State jump_state = get_locked_jump_state(app, heap);
if (jump_state.view != 0){ if (jump_state.view != 0){
i32 cursor_position = 0; i32 cursor_position = view_get_cursor_pos(app, jump_state.view);
view_get_cursor_pos(app, jump_state.view, &cursor_position);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, jump_state.view, seek_pos(cursor_position), &cursor); view_compute_cursor(app, jump_state.view, seek_pos(cursor_position), &cursor);
i32 line = get_line_from_list(app, jump_state.list, jump_state.list_index); i32 line = get_line_from_list(app, jump_state.list, jump_state.list_index);
@ -609,30 +596,34 @@ CUSTOM_DOC("If a buffer containing jump locations has been locked in, goes to th
CUSTOM_COMMAND_SIG(newline_or_goto_position_sticky) CUSTOM_COMMAND_SIG(newline_or_goto_position_sticky)
CUSTOM_DOC("If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor.") CUSTOM_DOC("If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; if (buffer != 0){
if (view_get_buffer(app, view, AccessOpen, &buffer)){
write_character(app); write_character(app);
} }
else if (view_get_buffer(app, view, AccessProtected, &buffer)){ else{
goto_jump_at_cursor_sticky(app); buffer = view_get_buffer(app, view, AccessProtected);
lock_jump_buffer(app, buffer); if (buffer != 0){
goto_jump_at_cursor_sticky(app);
lock_jump_buffer(app, buffer);
}
} }
} }
CUSTOM_COMMAND_SIG(newline_or_goto_position_same_panel_sticky) CUSTOM_COMMAND_SIG(newline_or_goto_position_same_panel_sticky)
CUSTOM_DOC("If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor_same_panel.") CUSTOM_DOC("If the buffer in the active view is writable, inserts a character, otherwise performs goto_jump_at_cursor_same_panel.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; if (buffer != 0){
if (view_get_buffer(app, view, AccessOpen, &buffer)){
write_character(app); write_character(app);
} }
else if (view_get_buffer(app, view, AccessProtected, &buffer)){ else{
goto_jump_at_cursor_same_panel_sticky(app); buffer = view_get_buffer(app, view, AccessProtected);
lock_jump_buffer(app, buffer); if (buffer != 0){
goto_jump_at_cursor_same_panel_sticky(app);
lock_jump_buffer(app, buffer);
}
} }
} }

View File

@ -224,8 +224,7 @@ get_jump_buffer(Application_Links *app, Buffer_ID *buffer, ID_Pos_Jump_Location
static View_ID static View_ID
switch_to_existing_view(Application_Links *app, View_ID view, Buffer_ID buffer){ switch_to_existing_view(Application_Links *app, View_ID view, Buffer_ID buffer){
Buffer_ID current_buffer = 0; Buffer_ID current_buffer = view_get_buffer(app, view, AccessAll);
view_get_buffer(app, view, AccessAll, &current_buffer);
if (view != 0 || current_buffer != buffer){ if (view != 0 || current_buffer != buffer){
View_ID existing_view = get_first_view_with_buffer(app, buffer); View_ID existing_view = get_first_view_with_buffer(app, buffer);
if (existing_view != 0){ if (existing_view != 0){
@ -237,8 +236,7 @@ switch_to_existing_view(Application_Links *app, View_ID view, Buffer_ID buffer){
static void static void
set_view_to_location(Application_Links *app, View_ID view, Buffer_ID buffer, Buffer_Seek seek){ set_view_to_location(Application_Links *app, View_ID view, Buffer_ID buffer, Buffer_Seek seek){
Buffer_ID current_buffer = 0; Buffer_ID current_buffer = view_get_buffer(app, view, AccessAll);
view_get_buffer(app, view, AccessAll, &current_buffer);
if (current_buffer != buffer){ if (current_buffer != buffer){
view_set_buffer(app, view, buffer, 0); view_set_buffer(app, view, buffer, 0);
} }
@ -294,8 +292,7 @@ seek_next_jump_in_buffer(Application_Links *app, Arena *arena,
static ID_Line_Column_Jump_Location static ID_Line_Column_Jump_Location
convert_name_based_to_id_based(Application_Links *app, Name_Line_Column_Location loc){ convert_name_based_to_id_based(Application_Links *app, Name_Line_Column_Location loc){
ID_Line_Column_Jump_Location result = {}; ID_Line_Column_Jump_Location result = {};
Buffer_ID buffer = 0; Buffer_ID buffer = get_buffer_by_name(app, loc.file, AccessAll);
get_buffer_by_name(app, loc.file, AccessAll, &buffer);
if (buffer != 0){ if (buffer != 0){
result.buffer_id = buffer; result.buffer_id = buffer;
result.line = loc.line; result.line = loc.line;
@ -306,13 +303,11 @@ convert_name_based_to_id_based(Application_Links *app, Name_Line_Column_Location
static Parsed_Jump static Parsed_Jump
seek_next_jump_in_view(Application_Links *app, Arena *arena, View_ID view, i32 skip_sub_errors, i32 direction, i32 *line_out){ seek_next_jump_in_view(Application_Links *app, Arena *arena, View_ID view, i32 skip_sub_errors, i32 direction, i32 *line_out){
i32 cursor_position = 0; i32 cursor_position = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &cursor_position);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, view, seek_pos(cursor_position), &cursor); view_compute_cursor(app, view, seek_pos(cursor_position), &cursor);
i32 line = cursor.line; i32 line = cursor.line;
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessAll);
view_get_buffer(app, view, AccessAll, &buffer);
Parsed_Jump jump = seek_next_jump_in_buffer(app, arena, buffer, line + direction, skip_sub_errors, direction, &line); Parsed_Jump jump = seek_next_jump_in_buffer(app, arena, buffer, line + direction, skip_sub_errors, direction, &line);
if (jump.success){ if (jump.success){
*line_out = line; *line_out = line;
@ -374,11 +369,10 @@ seek_jump(Application_Links *app, b32 skip_repeats, b32 skip_sub_errors, i32 dir
if (advance_cursor_in_jump_view(app, view, skip_repeats, skip_sub_errors, direction, &location)){ if (advance_cursor_in_jump_view(app, view, skip_repeats, skip_sub_errors, direction, &location)){
Buffer_ID buffer = {}; Buffer_ID buffer = {};
if (get_jump_buffer(app, &buffer, &location)){ if (get_jump_buffer(app, &buffer, &location)){
View_ID target_view = 0; View_ID target_view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &target_view);
if (target_view == view){ if (target_view == view){
change_active_panel(app); change_active_panel(app);
get_active_view(app, AccessAll, &target_view); target_view = get_active_view(app, AccessAll);
} }
switch_to_existing_view(app, target_view, buffer); switch_to_existing_view(app, target_view, buffer);
jump_to_location(app, target_view, buffer, location); jump_to_location(app, target_view, buffer, location);

View File

@ -8,8 +8,7 @@ such as open file, switch buffer, or kill buffer.
CUSTOM_COMMAND_SIG(lister__quit) CUSTOM_COMMAND_SIG(lister__quit)
CUSTOM_DOC("A lister mode command that quits the list without executing any actions.") CUSTOM_DOC("A lister mode command that quits the list without executing any actions.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view_end_ui_mode(app, view); view_end_ui_mode(app, view);
} }
@ -17,8 +16,7 @@ CUSTOM_COMMAND_SIG(lister__activate)
CUSTOM_DOC("A lister mode command that activates the list's action on the highlighted item.") CUSTOM_DOC("A lister mode command that activates the list's action on the highlighted item.")
{ {
Heap *heap = &global_heap; Heap *heap = &global_heap;
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->initialized){ if (state->initialized){
void *user_data = 0; void *user_data = 0;
@ -32,8 +30,7 @@ CUSTOM_DOC("A lister mode command that activates the list's action on the highli
CUSTOM_COMMAND_SIG(lister__write_character) CUSTOM_COMMAND_SIG(lister__write_character)
CUSTOM_DOC("A lister mode command that dispatches to the lister's write character handler.") CUSTOM_DOC("A lister mode command that dispatches to the lister's write character handler.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->lister.data.handlers.write_character != 0){ if (state->lister.data.handlers.write_character != 0){
state->lister.data.handlers.write_character(app); state->lister.data.handlers.write_character(app);
@ -43,8 +40,7 @@ CUSTOM_DOC("A lister mode command that dispatches to the lister's write characte
CUSTOM_COMMAND_SIG(lister__backspace_text_field) CUSTOM_COMMAND_SIG(lister__backspace_text_field)
CUSTOM_DOC("A lister mode command that dispatches to the lister's backspace text field handler.") CUSTOM_DOC("A lister mode command that dispatches to the lister's backspace text field handler.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->lister.data.handlers.backspace != 0){ if (state->lister.data.handlers.backspace != 0){
state->lister.data.handlers.backspace(app); state->lister.data.handlers.backspace(app);
@ -54,8 +50,7 @@ CUSTOM_DOC("A lister mode command that dispatches to the lister's backspace text
CUSTOM_COMMAND_SIG(lister__move_up) CUSTOM_COMMAND_SIG(lister__move_up)
CUSTOM_DOC("A lister mode command that dispatches to the lister's navigate up handler.") CUSTOM_DOC("A lister mode command that dispatches to the lister's navigate up handler.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->lister.data.handlers.navigate_up != 0){ if (state->lister.data.handlers.navigate_up != 0){
state->lister.data.handlers.navigate_up(app); state->lister.data.handlers.navigate_up(app);
@ -65,8 +60,7 @@ CUSTOM_DOC("A lister mode command that dispatches to the lister's navigate up ha
CUSTOM_COMMAND_SIG(lister__move_down) CUSTOM_COMMAND_SIG(lister__move_down)
CUSTOM_DOC("A lister mode command that dispatches to the lister's navigate down handler.") CUSTOM_DOC("A lister mode command that dispatches to the lister's navigate down handler.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->lister.data.handlers.navigate_down != 0){ if (state->lister.data.handlers.navigate_down != 0){
state->lister.data.handlers.navigate_down(app); state->lister.data.handlers.navigate_down(app);
@ -76,8 +70,7 @@ CUSTOM_DOC("A lister mode command that dispatches to the lister's navigate down
CUSTOM_COMMAND_SIG(lister__wheel_scroll) CUSTOM_COMMAND_SIG(lister__wheel_scroll)
CUSTOM_DOC("A lister mode command that scrolls the list in response to the mouse wheel.") CUSTOM_DOC("A lister mode command that scrolls the list in response to the mouse wheel.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
GUI_Scroll_Vars scroll = {}; GUI_Scroll_Vars scroll = {};
view_get_scroll_vars(app, view, &scroll); view_get_scroll_vars(app, view, &scroll);
Mouse_State mouse = get_mouse_state(app); Mouse_State mouse = get_mouse_state(app);
@ -92,8 +85,7 @@ CUSTOM_DOC("A lister mode command that scrolls the list in response to the mouse
CUSTOM_COMMAND_SIG(lister__mouse_press) CUSTOM_COMMAND_SIG(lister__mouse_press)
CUSTOM_DOC("A lister mode command that beings a click interaction with a list item under the mouse.") CUSTOM_DOC("A lister mode command that beings a click interaction with a list item under the mouse.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->initialized){ if (state->initialized){
UI_Item clicked = lister_get_clicked_item(app, view); UI_Item clicked = lister_get_clicked_item(app, view);
@ -105,8 +97,7 @@ CUSTOM_COMMAND_SIG(lister__mouse_release)
CUSTOM_DOC("A lister mode command that ends a click interaction with a list item under the mouse, possibly activating it.") CUSTOM_DOC("A lister mode command that ends a click interaction with a list item under the mouse, possibly activating it.")
{ {
Heap *heap = &global_heap; Heap *heap = &global_heap;
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->initialized && state->hot_user_data != 0){ if (state->initialized && state->hot_user_data != 0){
UI_Item clicked = lister_get_clicked_item(app, view); UI_Item clicked = lister_get_clicked_item(app, view);
@ -120,8 +111,7 @@ CUSTOM_DOC("A lister mode command that ends a click interaction with a list item
CUSTOM_COMMAND_SIG(lister__repaint) CUSTOM_COMMAND_SIG(lister__repaint)
CUSTOM_DOC("A lister mode command that updates the lists UI data.") CUSTOM_DOC("A lister mode command that updates the lists UI data.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->initialized){ if (state->initialized){
lister_update_ui(app, view, state); lister_update_ui(app, view, state);
@ -131,8 +121,7 @@ CUSTOM_DOC("A lister mode command that updates the lists UI data.")
CUSTOM_COMMAND_SIG(lister__write_character__default) CUSTOM_COMMAND_SIG(lister__write_character__default)
CUSTOM_DOC("A lister mode command that inserts a new character to the text field.") CUSTOM_DOC("A lister mode command that inserts a new character to the text field.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->initialized){ if (state->initialized){
User_Input in = get_command_input(app); User_Input in = get_command_input(app);
@ -151,8 +140,7 @@ CUSTOM_DOC("A lister mode command that inserts a new character to the text field
CUSTOM_COMMAND_SIG(lister__backspace_text_field__default) CUSTOM_COMMAND_SIG(lister__backspace_text_field__default)
CUSTOM_DOC("A lister mode command that backspaces one character from the text field.") CUSTOM_DOC("A lister mode command that backspaces one character from the text field.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->initialized){ if (state->initialized){
state->lister.data.text_field.string = backspace_utf8(state->lister.data.text_field.string); state->lister.data.text_field.string = backspace_utf8(state->lister.data.text_field.string);
@ -166,8 +154,7 @@ CUSTOM_DOC("A lister mode command that backspaces one character from the text fi
CUSTOM_COMMAND_SIG(lister__move_up__default) CUSTOM_COMMAND_SIG(lister__move_up__default)
CUSTOM_DOC("A lister mode command that moves the highlighted item one up in the list.") CUSTOM_DOC("A lister mode command that moves the highlighted item one up in the list.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->initialized){ if (state->initialized){
state->item_index = state->item_index - 1; state->item_index = state->item_index - 1;
@ -182,8 +169,7 @@ CUSTOM_DOC("A lister mode command that moves the highlighted item one up in the
CUSTOM_COMMAND_SIG(lister__move_down__default) CUSTOM_COMMAND_SIG(lister__move_down__default)
CUSTOM_DOC("A lister mode command that moves the highlighted item one down in the list.") CUSTOM_DOC("A lister mode command that moves the highlighted item one down in the list.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->initialized){ if (state->initialized){
state->item_index = state->item_index + 1; state->item_index = state->item_index + 1;
@ -198,8 +184,7 @@ CUSTOM_DOC("A lister mode command that moves the highlighted item one down in th
CUSTOM_COMMAND_SIG(lister__write_character__file_path) CUSTOM_COMMAND_SIG(lister__write_character__file_path)
CUSTOM_DOC("A lister mode command that inserts a character into the text field of a file system list.") CUSTOM_DOC("A lister mode command that inserts a character into the text field of a file system list.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->initialized){ if (state->initialized){
User_Input in = get_command_input(app); User_Input in = get_command_input(app);
@ -224,8 +209,7 @@ CUSTOM_DOC("A lister mode command that inserts a character into the text field o
CUSTOM_COMMAND_SIG(lister__backspace_text_field__file_path) CUSTOM_COMMAND_SIG(lister__backspace_text_field__file_path)
CUSTOM_DOC("A lister mode command that backspaces one character from the text field of a file system list.") CUSTOM_DOC("A lister mode command that backspaces one character from the text field of a file system list.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->initialized){ if (state->initialized){
if (state->lister.data.text_field.size > 0){ if (state->lister.data.text_field.size > 0){
@ -267,8 +251,7 @@ CUSTOM_COMMAND_SIG(lister__write_character__fixed_list)
CUSTOM_DOC("A lister mode command that handles input for the fixed sure to kill list.") CUSTOM_DOC("A lister mode command that handles input for the fixed sure to kill list.")
{ {
Heap *heap = &global_heap; Heap *heap = &global_heap;
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Lister_State *state = view_get_lister_state(view); Lister_State *state = view_get_lister_state(view);
if (state->initialized){ if (state->initialized){
User_Input in = get_command_input(app); User_Input in = get_command_input(app);
@ -467,8 +450,7 @@ begin_integrated_lister__theme_list(Application_Links *app, char *query_string,
static void static void
generate_all_buffers_list__output_buffer(Application_Links *app, Lister *lister, Buffer_ID buffer){ generate_all_buffers_list__output_buffer(Application_Links *app, Lister *lister, Buffer_ID buffer){
Dirty_State dirty = 0; Dirty_State dirty = buffer_get_dirty_state(app, buffer);
buffer_get_dirty_state(app, buffer, &dirty);
String_Const_u8 status = {}; String_Const_u8 status = {};
switch (dirty){ switch (dirty){
case DirtyState_UnsavedChanges: status = string_u8_litexpr("*"); break; case DirtyState_UnsavedChanges: status = string_u8_litexpr("*"); break;
@ -491,12 +473,10 @@ generate_all_buffers_list(Application_Links *app, Lister *lister){
// List currently viewed buffers // List currently viewed buffers
{ {
View_ID view = 0; for (View_ID view = get_view_next(app, 0, AccessAll);
for (get_view_next(app, 0, AccessAll, &view);
view != 0; view != 0;
get_view_next(app, view, AccessAll, &view)){ view = get_view_next(app, view, AccessAll)){
Buffer_ID new_buffer_id = 0; Buffer_ID new_buffer_id = view_get_buffer(app, view, AccessAll);
view_get_buffer(app, view, AccessAll, &new_buffer_id);
for (i32 i = 0; i < currently_viewed_buffer_count; i += 1){ for (i32 i = 0; i < currently_viewed_buffer_count; i += 1){
if (new_buffer_id == buffers_currently_being_viewed[i]){ if (new_buffer_id == buffers_currently_being_viewed[i]){
goto skip0; goto skip0;
@ -509,10 +489,9 @@ generate_all_buffers_list(Application_Links *app, Lister *lister){
// Regular Buffers // Regular Buffers
{ {
Buffer_ID buffer = 0; for (Buffer_ID buffer = get_buffer_next(app, 0, AccessAll);
for (get_buffer_next(app, 0, AccessAll, &buffer);
buffer != 0; buffer != 0;
get_buffer_next(app, buffer, AccessAll, &buffer)){ buffer = get_buffer_next(app, buffer, AccessAll)){
for (i32 i = 0; i < currently_viewed_buffer_count; i += 1){ for (i32 i = 0; i < currently_viewed_buffer_count; i += 1){
if (buffer == buffers_currently_being_viewed[i]){ if (buffer == buffers_currently_being_viewed[i]){
goto skip1; goto skip1;
@ -526,10 +505,9 @@ generate_all_buffers_list(Application_Links *app, Lister *lister){
} }
// Buffers Starting with * // Buffers Starting with *
{ {
Buffer_ID buffer = 0; for (Buffer_ID buffer = get_buffer_next(app, 0, AccessAll);
for (get_buffer_next(app, 0, AccessAll, &buffer);
buffer != 0; buffer != 0;
get_buffer_next(app, buffer, AccessAll, &buffer)){ buffer = get_buffer_next(app, buffer, AccessAll)){
for (i32 i = 0; i < currently_viewed_buffer_count; i += 1){ for (i32 i = 0; i < currently_viewed_buffer_count; i += 1){
if (buffer == buffers_currently_being_viewed[i]){ if (buffer == buffers_currently_being_viewed[i]){
goto skip2; goto skip2;
@ -596,14 +574,13 @@ generate_hot_directory_file_list(Application_Links *app, Lister *lister){
string_list_push_overlap(&lister->arena, &list, '/', string_list_push_overlap(&lister->arena, &list, '/',
SCu8(info->filename, info->filename_len)); SCu8(info->filename, info->filename_len));
String_Const_u8 full_file_path = string_list_flatten(&lister->arena, list); String_Const_u8 full_file_path = string_list_flatten(&lister->arena, list);
get_buffer_by_file_name(app, full_file_path, AccessAll, &buffer); buffer = get_buffer_by_file_name(app, full_file_path, AccessAll);
end_temp(path_temp); end_temp(path_temp);
} }
if (buffer != 0){ if (buffer != 0){
is_loaded = "LOADED"; is_loaded = "LOADED";
Dirty_State dirty = 0; Dirty_State dirty = buffer_get_dirty_state(app, buffer);
buffer_get_dirty_state(app, buffer, &dirty);
switch (dirty){ switch (dirty){
case DirtyState_UnsavedChanges: status_flag = " *"; break; case DirtyState_UnsavedChanges: status_flag = " *"; break;
case DirtyState_UnloadedChanges: status_flag = " !"; break; case DirtyState_UnloadedChanges: status_flag = " !"; break;
@ -657,8 +634,7 @@ activate_confirm_kill(Application_Links *app, Heap *heap, View_ID view, Lister_S
case SureToKill_Yes: case SureToKill_Yes:
{ {
Buffer_Kill_Result ignore = 0; buffer_kill(app, buffer_id, BufferKill_AlwaysKill);
buffer_kill(app, buffer_id, BufferKill_AlwaysKill, &ignore);
}break; }break;
case SureToKill_Save: case SureToKill_Save:
@ -667,7 +643,7 @@ activate_confirm_kill(Application_Links *app, Heap *heap, View_ID view, Lister_S
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
String_Const_u8 file_name = push_buffer_file_name(app, scratch, buffer_id); String_Const_u8 file_name = push_buffer_file_name(app, scratch, buffer_id);
if (buffer_save(app, buffer_id, file_name, BufferSave_IgnoreDirtyFlag)){ if (buffer_save(app, buffer_id, file_name, BufferSave_IgnoreDirtyFlag)){
buffer_kill(app, buffer_id, BufferKill_AlwaysKill, 0); buffer_kill(app, buffer_id, BufferKill_AlwaysKill);
} }
else{ else{
String_Const_u8 str = push_u8_stringf(scratch, "Did not close '%.*s' because it did not successfully save.", String_Const_u8 str = push_u8_stringf(scratch, "Did not close '%.*s' because it did not successfully save.",
@ -750,8 +726,7 @@ activate_switch_buffer(Application_Links *app, Heap *heap,
CUSTOM_COMMAND_SIG(interactive_switch_buffer) CUSTOM_COMMAND_SIG(interactive_switch_buffer)
CUSTOM_DOC("Interactively switch to an open buffer.") CUSTOM_DOC("Interactively switch to an open buffer.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view_end_ui_mode(app, view); view_end_ui_mode(app, view);
begin_integrated_lister__buffer_list(app, "Switch:", activate_switch_buffer, 0, 0, view); begin_integrated_lister__buffer_list(app, "Switch:", activate_switch_buffer, 0, 0, view);
} }
@ -762,16 +737,15 @@ activate_kill_buffer(Application_Links *app, Heap *heap,
String_Const_u8 text_field, void *user_data, b32 activated_by_mouse){ String_Const_u8 text_field, void *user_data, b32 activated_by_mouse){
lister_default(app, heap, view, state, ListerActivation_Finished); lister_default(app, heap, view, state, ListerActivation_Finished);
if (user_data != 0){ if (user_data != 0){
Buffer_ID buffer_id = (Buffer_ID)(PtrAsInt(user_data)); Buffer_ID buffer = (Buffer_ID)(PtrAsInt(user_data));
kill_buffer(app, buffer_identifier(buffer_id), view, 0); try_buffer_kill(app, buffer, view, 0);
} }
} }
CUSTOM_COMMAND_SIG(interactive_kill_buffer) CUSTOM_COMMAND_SIG(interactive_kill_buffer)
CUSTOM_DOC("Interactively kill an open buffer.") CUSTOM_DOC("Interactively kill an open buffer.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view_end_ui_mode(app, view); view_end_ui_mode(app, view);
begin_integrated_lister__buffer_list(app, "Kill:", activate_kill_buffer, 0, 0, view); begin_integrated_lister__buffer_list(app, "Kill:", activate_kill_buffer, 0, 0, view);
} }
@ -801,8 +775,7 @@ activate_open_or_new__generic(Application_Links *app, View_ID view,
result = ListerActivation_ContinueAndRefresh; result = ListerActivation_ContinueAndRefresh;
} }
else{ else{
Buffer_ID buffer = 0; Buffer_ID buffer = create_buffer(app, full_file_name, flags);
create_buffer(app, full_file_name, flags, &buffer);
if (buffer != 0){ if (buffer != 0){
view_set_buffer(app, view, buffer, SetBuffer_KeepOriginalGUI); view_set_buffer(app, view, buffer, SetBuffer_KeepOriginalGUI);
} }
@ -845,8 +818,7 @@ activate_open_or_new(Application_Links *app, Heap *heap,
CUSTOM_COMMAND_SIG(interactive_open_or_new) CUSTOM_COMMAND_SIG(interactive_open_or_new)
CUSTOM_DOC("Interactively open a file out of the file system.") CUSTOM_DOC("Interactively open a file out of the file system.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view_end_ui_mode(app, view); view_end_ui_mode(app, view);
begin_integrated_lister__file_system_list(app, "Open:", activate_open_or_new, 0, 0, view); begin_integrated_lister__file_system_list(app, "Open:", activate_open_or_new, 0, 0, view);
} }
@ -885,8 +857,7 @@ activate_new(Application_Links *app, Heap *heap,
CUSTOM_COMMAND_SIG(interactive_new) CUSTOM_COMMAND_SIG(interactive_new)
CUSTOM_DOC("Interactively creates a new file.") CUSTOM_DOC("Interactively creates a new file.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view_end_ui_mode(app, view); view_end_ui_mode(app, view);
begin_integrated_lister__file_system_list(app, "New:", activate_new, 0, 0, view); begin_integrated_lister__file_system_list(app, "New:", activate_new, 0, 0, view);
} }
@ -919,8 +890,7 @@ activate_open(Application_Links *app, Heap *heap,
CUSTOM_COMMAND_SIG(interactive_open) CUSTOM_COMMAND_SIG(interactive_open)
CUSTOM_DOC("Interactively opens a file.") CUSTOM_DOC("Interactively opens a file.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view_end_ui_mode(app, view); view_end_ui_mode(app, view);
begin_integrated_lister__file_system_list(app, "Open:", activate_open, 0, 0, view); begin_integrated_lister__file_system_list(app, "Open:", activate_open, 0, 0, view);
} }
@ -940,8 +910,7 @@ CUSTOM_DOC("Opens the 4coder theme selector list.")
Partition *scratch = &global_part; Partition *scratch = &global_part;
Temp_Memory temp = begin_temp_memory(scratch); Temp_Memory temp = begin_temp_memory(scratch);
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view_end_ui_mode(app, view); view_end_ui_mode(app, view);
i32 theme_count = get_theme_count(app); i32 theme_count = get_theme_count(app);
Lister_UI_Option *options = push_array(scratch, Lister_UI_Option, theme_count); Lister_UI_Option *options = push_array(scratch, Lister_UI_Option, theme_count);
@ -982,8 +951,7 @@ launch_custom_command_lister(Application_Links *app, i32 *command_ids, i32 comma
} }
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view_end_ui_mode(app, view); view_end_ui_mode(app, view);
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
Lister_Option *options = push_array(scratch, Lister_Option, command_id_count); Lister_Option *options = push_array(scratch, Lister_Option, command_id_count);

View File

@ -95,12 +95,9 @@ get_numeric_at_cursor(Application_Links *app, Buffer_ID buffer, i32 pos, Miblo_N
CUSTOM_COMMAND_SIG(miblo_increment_basic) CUSTOM_COMMAND_SIG(miblo_increment_basic)
CUSTOM_DOC("Increment an integer under the cursor by one.") CUSTOM_DOC("Increment an integer under the cursor by one.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessOpen, &buffer);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
Miblo_Number_Info number = {}; Miblo_Number_Info number = {};
if (get_numeric_at_cursor(app, buffer, pos, &number)){ if (get_numeric_at_cursor(app, buffer, pos, &number)){
Scratch_Block scratch(app); Scratch_Block scratch(app);
@ -113,12 +110,9 @@ CUSTOM_DOC("Increment an integer under the cursor by one.")
CUSTOM_COMMAND_SIG(miblo_decrement_basic) CUSTOM_COMMAND_SIG(miblo_decrement_basic)
CUSTOM_DOC("Decrement an integer under the cursor by one.") CUSTOM_DOC("Decrement an integer under the cursor by one.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessOpen, &buffer);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
Miblo_Number_Info number = {}; Miblo_Number_Info number = {};
if (get_numeric_at_cursor(app, buffer, pos, &number)){ if (get_numeric_at_cursor(app, buffer, pos, &number)){
Scratch_Block scratch(app); Scratch_Block scratch(app);
@ -363,12 +357,9 @@ get_timestamp_at_cursor(Application_Links *app, Buffer_ID buffer, i32 pos, Miblo
static void static void
miblo_time_stamp_alter(Application_Links *app, i32 unit_type, i32 amt){ miblo_time_stamp_alter(Application_Links *app, i32 unit_type, i32 amt){
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessOpen, &buffer);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
Miblo_Timestamp_Info timestamp = {}; Miblo_Timestamp_Info timestamp = {};
if (get_timestamp_at_cursor(app, buffer, pos, &timestamp)){ if (get_timestamp_at_cursor(app, buffer, pos, &timestamp)){

View File

@ -35,10 +35,9 @@ close_all_files_with_extension(Application_Links *app, String_Const_u8_Array ext
i32 buffers_to_close_count = 0; i32 buffers_to_close_count = 0;
do_repeat = false; do_repeat = false;
Buffer_ID buffer = 0; for (Buffer_ID buffer = get_buffer_next(app, 0, AccessAll);
for (buffer = get_buffer_next(app, 0, AccessAll, &buffer);
buffer != 0; buffer != 0;
get_buffer_next(app, buffer, AccessAll, &buffer)){ buffer = get_buffer_next(app, buffer, AccessAll)){
b32 is_match = true; b32 is_match = true;
if (extension_array.count > 0){ if (extension_array.count > 0){
@ -67,7 +66,7 @@ close_all_files_with_extension(Application_Links *app, String_Const_u8_Array ext
} }
for (i32 i = 0; i < buffers_to_close_count; ++i){ for (i32 i = 0; i < buffers_to_close_count; ++i){
kill_buffer(app, buffer_identifier(buffers_to_close[i]), true, 0); buffer_kill(app, buffers_to_close[i], BufferKill_AlwaysKill);
} }
}while(do_repeat); }while(do_repeat);
} }
@ -124,8 +123,7 @@ open_all_files_in_directory_pattern_match__recursive(Application_Links *app,
String_Const_u8 full_path = push_u8_stringf(scratch, "%.*s%.*s", String_Const_u8 full_path = push_u8_stringf(scratch, "%.*s%.*s",
string_expand(path), string_expand(path),
string_expand(file_name)); string_expand(file_name));
Buffer_ID ignore = 0; create_buffer(app, full_path, 0);
create_buffer(app, full_path, 0, &ignore);
} }
} }
@ -861,7 +859,7 @@ exec_project_command(Application_Links *app, Project_Command *command){
Buffer_ID buffer = buffer_identifier_to_id(app, buffer_id); Buffer_ID buffer = buffer_identifier_to_id(app, buffer_id);
view = get_first_view_with_buffer(app, buffer); view = get_first_view_with_buffer(app, buffer);
if (view == 0){ if (view == 0){
get_active_view(app, AccessAll, &view); view = get_active_view(app, AccessAll);
} }
} }
@ -1353,8 +1351,7 @@ CUSTOM_DOC("Open a lister of all commands in the currently loaded project.")
if (current_project.loaded){ if (current_project.loaded){
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
view_end_ui_mode(app, view); view_end_ui_mode(app, view);
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
i32 option_count = current_project.command_array.count; i32 option_count = current_project.command_array.count;

View File

@ -44,9 +44,9 @@ find_scope_top(Application_Links *app, Buffer_ID buffer, i32 start_pos, u32 flag
Cpp_Get_Token_Result get_result = {}; Cpp_Get_Token_Result get_result = {};
b32 success = false; b32 success = false;
i32 position = 0; i32 position = 0;
if (buffer_get_token_index(app, buffer, start_pos, &get_result)){ if (get_token_from_pos(app, buffer, start_pos, &get_result)){
i32 token_index = get_result.token_index; i32 token_index = get_result.token_index;
if (flags & FindScope_Parent){ if (HasFlag(flags, FindScope_Parent)){
--token_index; --token_index;
if (get_result.in_whitespace_after_token){ if (get_result.in_whitespace_after_token){
++token_index; ++token_index;
@ -95,9 +95,9 @@ find_scope_bottom(Application_Links *app, Buffer_ID buffer, i32 start_pos, u32 f
Cpp_Get_Token_Result get_result = {}; Cpp_Get_Token_Result get_result = {};
b32 success = false; b32 success = false;
i32 position = 0; i32 position = 0;
if (buffer_get_token_index(app, buffer, start_pos, &get_result)){ if (get_token_from_pos(app, buffer, start_pos, &get_result)){
i32 token_index = get_result.token_index + 1; i32 token_index = get_result.token_index + 1;
if (flags & FindScope_Parent){ if (HasFlag(flags, FindScope_Parent)){
--token_index; --token_index;
if (get_result.in_whitespace_after_token){ if (get_result.in_whitespace_after_token){
++token_index; ++token_index;
@ -146,13 +146,13 @@ find_next_scope(Application_Links *app, Buffer_ID buffer, i32 start_pos, u32 fla
Cpp_Get_Token_Result get_result = {}; Cpp_Get_Token_Result get_result = {};
b32 success = 0; b32 success = 0;
i32 position = 0; i32 position = 0;
if (buffer_get_token_index(app, buffer, start_pos, &get_result)){ if (get_token_from_pos(app, buffer, start_pos, &get_result)){
i32 token_index = get_result.token_index + 1; i32 token_index = get_result.token_index + 1;
if (token_index >= 0){ if (token_index >= 0){
Token_Range token_range = buffer_get_token_range(app, buffer); Token_Range token_range = buffer_get_token_range(app, buffer);
if (token_range.first != 0){ if (token_range.first != 0){
Token_Iterator token_it = make_token_iterator(token_range, token_index); Token_Iterator token_it = make_token_iterator(token_range, token_index);
if ((flags & FindScope_NextSibling) != 0){ if (HasFlag(flags, FindScope_NextSibling)){
i32 nest_level = 1; i32 nest_level = 1;
for (Cpp_Token *token = token_iterator_current(&token_it); for (Cpp_Token *token = token_iterator_current(&token_it);
token != 0; token != 0;
@ -212,8 +212,8 @@ find_prev_scope(Application_Links *app, Buffer_ID buffer, i32 start_pos, u32 fla
Cpp_Get_Token_Result get_result = {}; Cpp_Get_Token_Result get_result = {};
b32 success = false; b32 success = false;
i32 position = 0; i32 position = 0;
if (buffer_get_token_index(app, buffer, start_pos, &get_result)){ if (get_token_from_pos(app, buffer, start_pos, &get_result)){
i32 token_index = get_result.token_index-1; i32 token_index = get_result.token_index - 1;
if (token_index >= 0){ if (token_index >= 0){
Token_Range token_range = buffer_get_token_range(app, buffer); Token_Range token_range = buffer_get_token_range(app, buffer);
if (token_range.first != 0){ if (token_range.first != 0){
@ -301,8 +301,7 @@ view_set_to_region(Application_Links *app, View_ID view, i32 major_pos, i32 mino
f32 top_y = top.wrapped_y; f32 top_y = top.wrapped_y;
f32 bottom_y = bottom.wrapped_y; f32 bottom_y = bottom.wrapped_y;
Rect_i32 region = {}; Rect_f32 region = view_get_buffer_region(app, view);
view_get_buffer_region(app, view, &region);
GUI_Scroll_Vars scroll = {}; GUI_Scroll_Vars scroll = {};
view_get_scroll_vars(app, view, &scroll); view_get_scroll_vars(app, view, &scroll);
@ -339,12 +338,9 @@ view_set_to_region(Application_Links *app, View_ID view, i32 major_pos, i32 mino
CUSTOM_COMMAND_SIG(select_surrounding_scope) CUSTOM_COMMAND_SIG(select_surrounding_scope)
CUSTOM_DOC("Finds the scope enclosed by '{' '}' surrounding the cursor and puts the cursor and mark on the '{' and '}'.") CUSTOM_DOC("Finds the scope enclosed by '{' '}' surrounding the cursor and puts the cursor and mark on the '{' and '}'.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessProtected, &buffer);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
Range range = {}; Range range = {};
if (find_scope_range(app, buffer, pos, &range, FindScope_Brace)){ if (find_scope_range(app, buffer, pos, &range, FindScope_Brace)){
view_set_cursor(app, view, seek_pos(range.first), true); view_set_cursor(app, view, seek_pos(range.first), true);
@ -357,12 +353,9 @@ CUSTOM_DOC("Finds the scope enclosed by '{' '}' surrounding the cursor and puts
CUSTOM_COMMAND_SIG(select_next_scope_absolute) CUSTOM_COMMAND_SIG(select_next_scope_absolute)
CUSTOM_DOC("Finds the first scope started by '{' after the cursor and puts the cursor and mark on the '{' and '}'.") CUSTOM_DOC("Finds the first scope started by '{' after the cursor and puts the cursor and mark on the '{' and '}'.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessProtected, &buffer);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
i32 start_pos = pos; i32 start_pos = pos;
i32 top = 0; i32 top = 0;
i32 bottom = 0; i32 bottom = 0;
@ -379,12 +372,9 @@ CUSTOM_DOC("Finds the first scope started by '{' after the cursor and puts the c
CUSTOM_COMMAND_SIG(select_prev_scope_absolute) CUSTOM_COMMAND_SIG(select_prev_scope_absolute)
CUSTOM_DOC("Finds the first scope started by '{' before the cursor and puts the cursor and mark on the '{' and '}'.") CUSTOM_DOC("Finds the first scope started by '{' before the cursor and puts the cursor and mark on the '{' and '}'.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessProtected, &buffer);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
i32 start_pos = pos; i32 start_pos = pos;
i32 top = 0; i32 top = 0;
i32 bottom = 0; i32 bottom = 0;
@ -400,10 +390,8 @@ CUSTOM_DOC("Finds the first scope started by '{' before the cursor and puts the
static void static void
place_begin_and_end_on_own_lines(Application_Links *app, char *begin, char *end){ place_begin_and_end_on_own_lines(Application_Links *app, char *begin, char *end){
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
Range lines = {}; Range lines = {};
Range range = get_view_range(app, view); Range range = get_view_range(app, view);
@ -442,9 +430,8 @@ place_begin_and_end_on_own_lines(Application_Links *app, char *begin, char *end)
max_adjustment += begin_str.size; max_adjustment += begin_str.size;
Range new_pos = make_range(range.min + (i32)min_adjustment, range.max + (i32)max_adjustment); Range new_pos = make_range(range.min + (i32)min_adjustment, range.max + (i32)max_adjustment);
i32 cursor_pos = 0; i32 cursor_pos = view_get_cursor_pos(app, view);
i32 mark_pos = 0; i32 mark_pos = 0;
view_get_cursor_pos(app, view, &cursor_pos);
if (cursor_pos == range.min){ if (cursor_pos == range.min){
cursor_pos = new_pos.min; cursor_pos = new_pos.min;
@ -481,45 +468,35 @@ CUSTOM_DOC("Wraps the code contained in the range between cursor and mark with a
CUSTOM_COMMAND_SIG(delete_current_scope) CUSTOM_COMMAND_SIG(delete_current_scope)
CUSTOM_DOC("Deletes the braces surrounding the currently selected scope. Leaves the contents within the scope.") CUSTOM_DOC("Deletes the braces surrounding the currently selected scope. Leaves the contents within the scope.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
i32 view_cursor_pos = 0; i32 view_cursor_pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &view_cursor_pos); i32 view_mark_pos = view_get_mark_pos(app, view);
i32 view_mark_pos = 0;
view_get_mark_pos(app, view, &view_mark_pos);
i32 top = view_cursor_pos; Range range = make_range(view_cursor_pos, view_mark_pos);
i32 bottom = view_mark_pos;
if (top > bottom){ if (buffer_get_char(app, buffer, range.min) == '{' &&
i32 x = top; buffer_get_char(app, buffer, range.max - 1) == '}'){
top = bottom;
bottom = x;
}
if (buffer_get_char(app, buffer, top) == '{' && buffer_get_char(app, buffer, bottom - 1) == '}'){
i32 top_len = 1; i32 top_len = 1;
i32 bottom_len = 1; i32 bot_len = 1;
if (buffer_get_char(app, buffer, top - 1) == '\n'){ if (buffer_get_char(app, buffer, range.min - 1) == '\n'){
top_len = 2; top_len = 2;
} }
if (buffer_get_char(app, buffer, bottom + 1) == '\n'){ if (buffer_get_char(app, buffer, range.max + 1) == '\n'){
bottom_len = 2; bot_len = 2;
} }
Buffer_Edit edits[2]; Buffer_Edit edits[2];
edits[0].str_start = 0; edits[0].str_start = 0;
edits[0].len = 0; edits[0].len = 0;
edits[0].start = top + 1 - top_len; edits[0].start = range.min + 1 - top_len;
edits[0].end = top + 1; edits[0].end = range.min + 1;
edits[1].str_start = 0; edits[1].str_start = 0;
edits[1].len = 0; edits[1].len = 0;
edits[1].start = bottom - 1; edits[1].start = range.max - 1;
edits[1].end = bottom - 1 + bottom_len; edits[1].end = range.max - 1 + bot_len;
buffer_batch_edit(app, buffer, 0, edits, 2); buffer_batch_edit(app, buffer, 0, edits, 2);
} }
@ -691,8 +668,7 @@ find_whole_statement_down(Application_Links *app, Buffer_ID buffer, i32 pos, i32
i32 end = start; i32 end = start;
Cpp_Get_Token_Result get_result = {}; Cpp_Get_Token_Result get_result = {};
if (get_token_from_pos(app, buffer, pos, &get_result)){
if (buffer_get_token_index(app, buffer, pos, &get_result)){
Statement_Parser parser = make_statement_parser(app, buffer, get_result.token_index); Statement_Parser parser = make_statement_parser(app, buffer, get_result.token_index);
if (parser.buffer != 0){ if (parser.buffer != 0){
if (get_result.in_whitespace_after_token){ if (get_result.in_whitespace_after_token){
@ -715,29 +691,19 @@ find_whole_statement_down(Application_Links *app, Buffer_ID buffer, i32 pos, i32
CUSTOM_COMMAND_SIG(scope_absorb_down) CUSTOM_COMMAND_SIG(scope_absorb_down)
CUSTOM_DOC("If a scope is currently selected, and a statement or block statement is present below the current scope, the statement is moved into the scope.") CUSTOM_DOC("If a scope is currently selected, and a statement or block statement is present below the current scope, the statement is moved into the scope.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessOpen, &buffer);
i32 view_cursor_pos = 0; i32 view_cursor_pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &view_cursor_pos); i32 view_mark_pos = view_get_mark_pos(app, view);
i32 view_mark_pos = 0;
view_get_mark_pos(app, view, &view_mark_pos);
i32 top = view_cursor_pos; Range range = make_range(view_cursor_pos, view_mark_pos);
i32 bottom = view_mark_pos;
if (top > bottom){ if (buffer_get_char(app, buffer, range.min) == '{' &&
i32 x = top; buffer_get_char(app, buffer, range.max - 1) == '}'){
top = bottom;
bottom = x;
}
if (buffer_get_char(app, buffer, top) == '{' && buffer_get_char(app, buffer, bottom - 1) == '}'){
Scratch_Block scratch(app); Scratch_Block scratch(app);
Range range = {}; Range range = {};
if (find_whole_statement_down(app, buffer, bottom, &range.start, &range.end)){ if (find_whole_statement_down(app, buffer, range.max, &range.start, &range.end)){
String_Const_u8 base_string = push_buffer_range(app, scratch, buffer, range); String_Const_u8 base_string = push_buffer_range(app, scratch, buffer, range);
String_Const_u8 string = string_skip_chop_whitespace(base_string); String_Const_u8 string = string_skip_chop_whitespace(base_string);
@ -764,8 +730,8 @@ CUSTOM_DOC("If a scope is currently selected, and a statement or block statement
Buffer_Edit edits[2]; Buffer_Edit edits[2];
edits[0].str_start = 0; edits[0].str_start = 0;
edits[0].len = (i32)edit_str.size; edits[0].len = (i32)edit_str.size;
edits[0].start = bottom - 1; edits[0].start = range.max - 1;
edits[0].end = bottom - 1; edits[0].end = range.max - 1;
edits[1].str_start = 0; edits[1].str_start = 0;
edits[1].len = 0; edits[1].len = 0;
edits[1].start = range.start; edits[1].start = range.start;

View File

@ -495,10 +495,8 @@ initialize_generic_search_all_buffers(Application_Links *app, Heap *heap, String
Search_Range *ranges = set->ranges; Search_Range *ranges = set->ranges;
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessProtected, &buffer);
i32 j = 0; i32 j = 0;
if (buffer_exists(app, buffer)){ if (buffer_exists(app, buffer)){
@ -515,15 +513,14 @@ initialize_generic_search_all_buffers(Application_Links *app, Heap *heap, String
ranges[j].flags = match_flags; ranges[j].flags = match_flags;
ranges[j].buffer = buffer; ranges[j].buffer = buffer;
ranges[j].start = 0; ranges[j].start = 0;
buffer_get_size(app, buffer, &ranges[j].size); ranges[j].size = (i32)buffer_get_size(app, buffer);
++j; ++j;
} }
} }
Buffer_ID buffer_it = 0; for (Buffer_ID buffer_it = get_buffer_next(app, 0, AccessAll);
for (get_buffer_next(app, 0, AccessAll, &buffer_it);
buffer_exists(app, buffer_it); buffer_exists(app, buffer_it);
get_buffer_next(app, buffer_it, AccessAll, &buffer_it)){ buffer_it = get_buffer_next(app, buffer_it, AccessAll)){
if (buffer_it == buffer){ if (buffer_it == buffer){
continue; continue;
} }
@ -542,7 +539,7 @@ initialize_generic_search_all_buffers(Application_Links *app, Heap *heap, String
ranges[j].flags = match_flags; ranges[j].flags = match_flags;
ranges[j].buffer = buffer_it; ranges[j].buffer = buffer_it;
ranges[j].start = 0; ranges[j].start = 0;
buffer_get_size(app, buffer_it, &ranges[j].size); ranges[j].size = (i32)buffer_get_size(app, buffer_it);
++j; ++j;
} }
} }
@ -583,8 +580,8 @@ list__parameters_buffer(Application_Links *app, Heap *heap,
for (Search_Match match = search_next_match(app, &set, &iter); for (Search_Match match = search_next_match(app, &set, &iter);
match.found_match; match.found_match;
match = search_next_match(app, &set, &iter)){ match = search_next_match(app, &set, &iter)){
Partial_Cursor word_pos = {}; Partial_Cursor word_pos = buffer_compute_cursor(app, match.buffer, seek_pos(match.start));
if (buffer_compute_cursor(app, match.buffer, seek_pos(match.start), &word_pos)){ if (word_pos.line > 0){
if (prev_match_id != match.buffer){ if (prev_match_id != match.buffer){
if (prev_match_id != 0){ if (prev_match_id != 0){
insertc(&out, '\n'); insertc(&out, '\n');
@ -650,13 +647,10 @@ list_query__parameters(Application_Links *app, Heap *heap, b32 substrings, b32 c
static void static void
list_identifier__parameters(Application_Links *app, Heap *heap, b32 substrings, b32 case_insensitive, View_ID default_target_view){ list_identifier__parameters(Application_Links *app, Heap *heap, b32 substrings, b32 case_insensitive, View_ID default_target_view){
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer = 0;
view_get_buffer(app, view, AccessProtected, &buffer);
if (buffer != 0){ if (buffer != 0){
i32 pos = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &pos);
Scratch_Block scratch(app); Scratch_Block scratch(app);
String_Const_u8 str = get_token_or_word_under_pos(app, scratch, buffer, pos); String_Const_u8 str = get_token_or_word_under_pos(app, scratch, buffer, pos);
if (str.size > 0){ if (str.size > 0){
@ -667,8 +661,7 @@ list_identifier__parameters(Application_Links *app, Heap *heap, b32 substrings,
static void static void
list_selected_range__parameters(Application_Links *app, Heap *heap, b32 substrings, b32 case_insensitive, View_ID default_target_view){ list_selected_range__parameters(Application_Links *app, Heap *heap, b32 substrings, b32 case_insensitive, View_ID default_target_view){
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view);
Arena *scratch = context_get_arena(app); Arena *scratch = context_get_arena(app);
Temp_Memory temp = begin_temp(scratch); Temp_Memory temp = begin_temp(scratch);
String_Const_u8 str = push_string_in_view_range(app, scratch, view); String_Const_u8 str = push_string_in_view_range(app, scratch, view);
@ -772,12 +765,9 @@ CUSTOM_DOC("Queries user for string, lists all locations of strings that appear
CUSTOM_COMMAND_SIG(list_all_locations_of_type_definition_of_identifier) CUSTOM_COMMAND_SIG(list_all_locations_of_type_definition_of_identifier)
CUSTOM_DOC("Reads a token or word under the cursor and lists all locations of strings that appear to define a type whose name matches it.") CUSTOM_DOC("Reads a token or word under the cursor and lists all locations of strings that appear to define a type whose name matches it.")
{ {
View_ID target_view = 0; View_ID target_view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &target_view); Buffer_ID buffer = view_get_buffer(app, target_view, AccessProtected);
Buffer_ID buffer = 0; i32 pos = view_get_cursor_pos(app, target_view);
view_get_buffer(app, target_view, AccessProtected, &buffer);
i32 pos = 0;
view_get_cursor_pos(app, target_view, &pos);
Scratch_Block scratch(app); Scratch_Block scratch(app);
String_Const_u8 str = get_token_or_word_under_pos(app, scratch, buffer, pos); String_Const_u8 str = get_token_or_word_under_pos(app, scratch, buffer, pos);
if (str.size > 0){ if (str.size > 0){
@ -796,10 +786,9 @@ static Word_Complete_State complete_state = {};
CUSTOM_COMMAND_SIG(word_complete) CUSTOM_COMMAND_SIG(word_complete)
CUSTOM_DOC("Iteratively tries completing the word to the left of the cursor with other words in open buffers that have the same prefix string.") CUSTOM_DOC("Iteratively tries completing the word to the left of the cursor with other words in open buffers that have the same prefix string.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessOpen);
get_active_view(app, AccessOpen, &view); Buffer_ID buffer = view_get_buffer(app, view, AccessOpen);
Buffer_ID buffer = 0; if (buffer != 0){
if (view_get_buffer(app, view, AccessOpen, &buffer)){
i32 do_init = false; i32 do_init = false;
Managed_Scope scope = 0; Managed_Scope scope = 0;
@ -823,8 +812,7 @@ CUSTOM_DOC("Iteratively tries completing the word to the left of the cursor with
if (do_init){ if (do_init){
// NOTE(allen): Get the range where the // NOTE(allen): Get the range where the
// partial word is written. // partial word is written.
word_end = 0; word_end = view_get_cursor_pos(app, view);
view_get_cursor_pos(app, view, &word_end);
word_start = word_end; word_start = word_end;
cursor_pos = word_end - 1; cursor_pos = word_end - 1;
@ -872,22 +860,22 @@ CUSTOM_DOC("Iteratively tries completing the word to the left of the cursor with
ranges[0].flags = SearchFlag_MatchWordPrefix; ranges[0].flags = SearchFlag_MatchWordPrefix;
ranges[0].buffer = buffer; ranges[0].buffer = buffer;
ranges[0].start = 0; ranges[0].start = 0;
buffer_get_size(app, buffer, &ranges[0].size); ranges[0].size = (i32)buffer_get_size(app, buffer);
ranges[0].mid_start = word_start; ranges[0].mid_start = word_start;
ranges[0].mid_size = (i32)size; ranges[0].mid_size = (i32)size;
Buffer_ID buffer_it = 0; Buffer_ID buffer_it = 0;
i32 j = 1; i32 j = 1;
for (get_buffer_next(app, 0, AccessAll, &buffer_it); for (buffer_it = get_buffer_next(app, 0, AccessAll);
buffer_it != 0; buffer_it != 0;
get_buffer_next(app, buffer_it, AccessAll, &buffer_it)){ buffer_it = get_buffer_next(app, buffer_it, AccessAll)){
if (buffer != buffer_it){ if (buffer != buffer_it){
ranges[j].type = SearchRange_FrontToBack; ranges[j].type = SearchRange_FrontToBack;
ranges[j].flags = SearchFlag_MatchWordPrefix; ranges[j].flags = SearchFlag_MatchWordPrefix;
ranges[j].buffer = buffer_it; ranges[j].buffer = buffer_it;
ranges[j].start = 0; ranges[j].start = 0;
buffer_get_size(app, buffer_it, &ranges[j].size); ranges[j].size = (i32)buffer_get_size(app, buffer_it);
++j; ++j;
} }
} }

View File

@ -6,12 +6,9 @@
internal void internal void
seek_pos_of_textual_line(Application_Links *app, Side side){ seek_pos_of_textual_line(Application_Links *app, Side side){
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer_id = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer_id = 0; i32 pos = view_get_cursor_pos(app, view);
view_get_buffer(app, view, AccessProtected, &buffer_id);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
i32 new_pos = get_line_side_pos_from_pos(app, buffer_id, pos, side); i32 new_pos = get_line_side_pos_from_pos(app, buffer_id, pos, side);
view_set_cursor(app, view, seek_pos(new_pos), true); view_set_cursor(app, view, seek_pos(new_pos), true);
no_mark_snap_to_cursor_if_shift(app, view); no_mark_snap_to_cursor_if_shift(app, view);
@ -19,10 +16,8 @@ seek_pos_of_textual_line(Application_Links *app, Side side){
internal void internal void
seek_pos_of_visual_line(Application_Links *app, Side side){ seek_pos_of_visual_line(Application_Links *app, Side side){
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); i32 pos = view_get_cursor_pos(app, view);
i32 pos = 0;
view_get_cursor_pos(app, view, &pos);
Full_Cursor cursor = {}; Full_Cursor cursor = {};
view_compute_cursor(app, view, seek_pos(pos), &cursor); view_compute_cursor(app, view, seek_pos(pos), &cursor);
f32 y = cursor.wrapped_y; f32 y = cursor.wrapped_y;
@ -58,8 +53,7 @@ CUSTOM_DOC("Seeks the cursor to the end of the visual line.")
CUSTOM_COMMAND_SIG(goto_beginning_of_file) CUSTOM_COMMAND_SIG(goto_beginning_of_file)
CUSTOM_DOC("Sets the cursor to the beginning of the file.") CUSTOM_DOC("Sets the cursor to the beginning of the file.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view);
view_set_cursor(app, view, seek_pos(0), true); view_set_cursor(app, view, seek_pos(0), true);
no_mark_snap_to_cursor_if_shift(app, view); no_mark_snap_to_cursor_if_shift(app, view);
} }
@ -67,12 +61,9 @@ CUSTOM_DOC("Sets the cursor to the beginning of the file.")
CUSTOM_COMMAND_SIG(goto_end_of_file) CUSTOM_COMMAND_SIG(goto_end_of_file)
CUSTOM_DOC("Sets the cursor to the end of the file.") CUSTOM_DOC("Sets the cursor to the end of the file.")
{ {
View_ID view = 0; View_ID view = get_active_view(app, AccessProtected);
get_active_view(app, AccessProtected, &view); Buffer_ID buffer_id = view_get_buffer(app, view, AccessProtected);
Buffer_ID buffer_id = 0; i32 size = (i32)buffer_get_size(app, buffer_id);
view_get_buffer(app, view, AccessProtected, &buffer_id);
i32 size = 0;
buffer_get_size(app, buffer_id, &size);
view_set_cursor(app, view, seek_pos(size), true); view_set_cursor(app, view, seek_pos(size), true);
no_mark_snap_to_cursor_if_shift(app, view); no_mark_snap_to_cursor_if_shift(app, view);
} }

View File

@ -12,8 +12,7 @@ CUSTOM_DOC("If the command execute_any_cli has already been used, this will exec
String_Const_u8 hot_directory = SCu8(hot_directory_space); String_Const_u8 hot_directory = SCu8(hot_directory_space);
if (out_buffer.size > 0 && cmd.size > 0 && hot_directory.size > 0){ if (out_buffer.size > 0 && cmd.size > 0 && hot_directory.size > 0){
View_ID view = 0; View_ID view = get_active_view(app, AccessAll);
get_active_view(app, AccessAll, &view);
Buffer_Identifier id = buffer_identifier(out_buffer); Buffer_Identifier id = buffer_identifier(out_buffer);
exec_system_command(app, view, id, hot_directory, cmd, CLI_OverlapWithConflict|CLI_CursorAtEnd|CLI_SendEndSignal); exec_system_command(app, view, id, hot_directory, cmd, CLI_OverlapWithConflict|CLI_CursorAtEnd|CLI_SendEndSignal);
lock_jump_buffer(out_buffer); lock_jump_buffer(out_buffer);

View File

@ -138,10 +138,10 @@ ui_control_set_bottom(UI_Data *data, i32 bottom_y){
} }
static UI_Item* static UI_Item*
ui_control_get_mouse_hit(UI_Data *data, Vec2_i32 view_p, Vec2_i32 panel_p){ ui_control_get_mouse_hit(UI_Data *data, Vec2_f32 view_p, Vec2_f32 panel_p){
UI_Item *result = 0; UI_Item *result = 0;
for (UI_Item *item = data->list.first; item != 0 && result == 0; item = item->next){ for (UI_Item *item = data->list.first; item != 0 && result == 0; item = item->next){
i32_Rect r = item->rect_outer; Rect_f32 r = Rf32(item->rect_outer);
switch (item->coordinates){ switch (item->coordinates){
case UICoordinates_ViewSpace: case UICoordinates_ViewSpace:
{ {
@ -160,10 +160,12 @@ ui_control_get_mouse_hit(UI_Data *data, Vec2_i32 view_p, Vec2_i32 panel_p){
return(result); return(result);
} }
#if 0
static UI_Item* static UI_Item*
ui_control_get_mouse_hit(UI_Data *data, i32 mx_scrolled, i32 my_scrolled, i32 mx_unscrolled, i32 my_unscrolled){ ui_control_get_mouse_hit(UI_Data *data, i32 mx_scrolled, i32 my_scrolled, i32 mx_unscrolled, i32 my_unscrolled){
return(ui_control_get_mouse_hit(data, V2i32(mx_scrolled, my_scrolled), V2i32(mx_unscrolled, my_unscrolled))); return(ui_control_get_mouse_hit(data, V2i32(mx_scrolled, my_scrolled), V2i32(mx_unscrolled, my_unscrolled)));
} }
#endif
//////////////////////////////// ////////////////////////////////
@ -174,86 +176,74 @@ view_zero_scroll(Application_Links *app, View_ID view){
} }
static void static void
view_set_vertical_focus(Application_Links *app, View_ID view, i32 y_top, i32 y_bot){ view_set_vertical_focus(Application_Links *app, View_ID view, f32 y_top, f32 y_bot){
Rect_i32 buffer_region = {}; Rect_f32 buffer_region = view_get_buffer_region(app, view);
view_get_buffer_region(app, view, &buffer_region);
GUI_Scroll_Vars scroll = {}; GUI_Scroll_Vars scroll = {};
view_get_scroll_vars(app, view, &scroll); view_get_scroll_vars(app, view, &scroll);
i32 view_y_top = scroll.target_y; f32 view_y_top = (f32)scroll.target_y;
i32 view_y_dim = rect_height(buffer_region); f32 view_y_dim = rect_height(buffer_region);
i32 view_y_bot = view_y_top + view_y_dim; f32 view_y_bot = view_y_top + view_y_dim;
Buffer_ID buffer = 0; Buffer_ID buffer = view_get_buffer(app, view, AccessAll);
view_get_buffer(app, view, AccessAll, &buffer);
Face_ID face_id = 0; Face_ID face_id = 0;
get_face_id(app, buffer, &face_id); get_face_id(app, buffer, &face_id);
Face_Metrics metrics = {}; Face_Metrics metrics = {};
get_face_metrics(app, face_id, &metrics); get_face_metrics(app, face_id, &metrics);
i32 line_dim = (i32)metrics.line_height; f32 line_dim = metrics.line_height;
i32 hot_y_top = view_y_top + line_dim*3; f32 hot_y_top = view_y_top + line_dim*3;
i32 hot_y_bot = view_y_bot - line_dim*3; f32 hot_y_bot = view_y_bot - line_dim*3;
if (hot_y_bot - hot_y_top < line_dim*6){ if (hot_y_bot - hot_y_top < line_dim*6){
i32 quarter_view_y_dim = view_y_dim/4; f32 quarter_view_y_dim = view_y_dim*.25f;
hot_y_top = view_y_top + quarter_view_y_dim; hot_y_top = view_y_top + quarter_view_y_dim;
hot_y_bot = view_y_bot - quarter_view_y_dim; hot_y_bot = view_y_bot - quarter_view_y_dim;
} }
i32 hot_y_dim = hot_y_bot - hot_y_top; f32 hot_y_dim = hot_y_bot - hot_y_top;
i32 skirt_dim = hot_y_top - view_y_top; f32 skirt_dim = hot_y_top - view_y_top;
i32 y_dim = y_bot - y_top; f32 y_dim = y_bot - y_top;
if (y_dim > hot_y_dim){ if (y_dim > hot_y_dim){
scroll.target_y = y_top - skirt_dim; scroll.target_y = (i32)(y_top - skirt_dim);
view_set_scroll(app, view, scroll); view_set_scroll(app, view, scroll);
} }
else{ else{
if (y_top < hot_y_top){ if (y_top < hot_y_top){
scroll.target_y = y_top - skirt_dim; scroll.target_y = (i32)(y_top - skirt_dim);
view_set_scroll(app, view, scroll); view_set_scroll(app, view, scroll);
} }
else if (y_bot > hot_y_bot){ else if (y_bot > hot_y_bot){
scroll.target_y = y_bot + skirt_dim - view_y_dim; scroll.target_y = (i32)(y_bot + skirt_dim - view_y_dim);
view_set_scroll(app, view, scroll); view_set_scroll(app, view, scroll);
} }
} }
} }
static Vec2 static Vec2_f32
view_space_from_screen_space(Vec2 p, Vec2 file_region_p0, Vec2 scroll_p){ view_space_from_screen_space(Vec2_f32 p, Vec2_f32 file_region_p0, Vec2_f32 scroll_p){
return(p - file_region_p0 + scroll_p); return(p - file_region_p0 + scroll_p);
} }
static Vec2_i32 static Vec2_f32
view_space_from_screen_space(Vec2_i32 p, Vec2_i32 file_region_p0, Vec2_i32 scroll_p){ get_mouse_position_in_view_space(Mouse_State mouse, Vec2_f32 file_region_p0, Vec2_f32 scroll_p){
return(p - file_region_p0 + scroll_p); return(view_space_from_screen_space(V2f32(mouse.p), file_region_p0, scroll_p));
} }
static Vec2_i32 static Vec2_f32
get_mouse_position_in_view_space(Mouse_State mouse, Vec2_i32 file_region_p0, Vec2_i32 scroll_p){ get_mouse_position_in_view_space(Application_Links *app, Vec2_f32 file_region_p0, Vec2_f32 scroll_p){
return(view_space_from_screen_space(mouse.p, file_region_p0, scroll_p));
}
static Vec2_i32
get_mouse_position_in_view_space(Application_Links *app, Vec2_i32 file_region_p0, Vec2_i32 scroll_p){
return(get_mouse_position_in_view_space(get_mouse_state(app), file_region_p0, scroll_p)); return(get_mouse_position_in_view_space(get_mouse_state(app), file_region_p0, scroll_p));
} }
static Vec2 static Vec2_f32
panel_space_from_screen_space(Vec2 p, Vec2 file_region_p0){ panel_space_from_screen_space(Vec2_f32 p, Vec2_f32 file_region_p0){
return(p - file_region_p0); return(p - file_region_p0);
} }
static Vec2_i32 static Vec2_f32
panel_space_from_screen_space(Vec2_i32 p, Vec2_i32 file_region_p0){ get_mouse_position_in_panel_space(Mouse_State mouse, Vec2_f32 file_region_p0){
return(p - file_region_p0); return(panel_space_from_screen_space(V2f32(mouse.p), file_region_p0));
} }
static Vec2_i32 static Vec2_f32
get_mouse_position_in_panel_space(Mouse_State mouse, Vec2_i32 file_region_p0){ get_mouse_position_in_panel_space(Application_Links *app, Vec2_f32 file_region_p0){
return(panel_space_from_screen_space(mouse.p, file_region_p0));
}
static Vec2_i32
get_mouse_position_in_panel_space(Application_Links *app, Vec2_i32 file_region_p0){
return(get_mouse_position_in_panel_space(get_mouse_state(app), file_region_p0)); return(get_mouse_position_in_panel_space(get_mouse_state(app), file_region_p0));
} }
@ -314,11 +304,10 @@ lister_get_clicked_item(Application_Links *app, View_ID view_id){
GUI_Scroll_Vars scroll_vars = {}; GUI_Scroll_Vars scroll_vars = {};
view_get_scroll_vars(app, view_id, &scroll_vars); view_get_scroll_vars(app, view_id, &scroll_vars);
Mouse_State mouse = get_mouse_state(app); Mouse_State mouse = get_mouse_state(app);
Rect_i32 buffer_region = {}; Rect_f32 buffer_region = view_get_buffer_region(app, view_id);
view_get_buffer_region(app, view_id, &buffer_region); Vec2_f32 region_p0 = buffer_region.p0;
Vec2_i32 region_p0 = buffer_region.p0; Vec2_f32 m_view_space = get_mouse_position_in_view_space(mouse, region_p0, scroll_vars.scroll_p);
Vec2_i32 m_view_space = get_mouse_position_in_view_space(mouse, region_p0, V2i32(scroll_vars.scroll_p)); Vec2_f32 m_panel_space = get_mouse_position_in_panel_space(mouse, region_p0);
Vec2_i32 m_panel_space = get_mouse_position_in_panel_space(mouse, region_p0);
UI_Item *clicked = ui_control_get_mouse_hit(ui_data, m_view_space, m_panel_space); UI_Item *clicked = ui_control_get_mouse_hit(ui_data, m_view_space, m_panel_space);
if (clicked != 0){ if (clicked != 0){
result = *clicked; result = *clicked;
@ -348,8 +337,7 @@ static void
lister_update_ui(Application_Links *app, View_ID view, Lister_State *state){ lister_update_ui(Application_Links *app, View_ID view, Lister_State *state){
b32 is_theme_list = state->lister.data.theme_list; b32 is_theme_list = state->lister.data.theme_list;
Rect_f32 screen_rect = {}; Rect_f32 screen_rect = view_get_screen_rect(app, view);
view_get_screen_rect(app, view, &screen_rect);
Face_ID face_id = 0; Face_ID face_id = 0;
get_face_id(app, 0, &face_id); get_face_id(app, 0, &face_id);
@ -369,9 +357,8 @@ lister_update_ui(Application_Links *app, View_ID view, Lister_State *state){
Temp_Memory full_temp = begin_temp(scratch); Temp_Memory full_temp = begin_temp(scratch);
// TODO(allen): switch to float // TODO(allen): switch to float
Rect_i32 buffer_region = {}; Rect_f32 buffer_region = view_get_buffer_region(app, view);
view_get_buffer_region(app, view, &buffer_region); Vec2_f32 view_m = get_mouse_position_in_view_space(app, buffer_region.p0, scroll_vars.scroll_p);
Vec2_i32 view_m = get_mouse_position_in_view_space(app, buffer_region.p0, V2i32(scroll_vars.scroll_p));
f32 y_pos = text_field_height; f32 y_pos = text_field_height;
@ -434,18 +421,13 @@ lister_update_ui(Application_Links *app, View_ID view, Lister_State *state){
for (i32 node_index = 0; node_index < node_ptr_array.count; node_index += 1){ for (i32 node_index = 0; node_index < node_ptr_array.count; node_index += 1){
Lister_Node *node = node_ptr_array.node_ptrs[node_index]; Lister_Node *node = node_ptr_array.node_ptrs[node_index];
// TODO(allen): switch to float Rect_f32 item_rect = Rf32(x0, y_pos, x1, y_pos + block_height);
i32_Rect item_rect = {}; y_pos = item_rect.y1;
item_rect.x0 = (i32)x0;
item_rect.y0 = (i32)y_pos;
item_rect.x1 = (i32)x1;
item_rect.y1 = (i32)y_pos + (i32)block_height;
y_pos = (f32)item_rect.y1;
UI_Item item = {}; UI_Item item = {};
item.activation_level = UIActivation_None; item.activation_level = UIActivation_None;
item.coordinates = UICoordinates_ViewSpace; item.coordinates = UICoordinates_ViewSpace;
item.rect_outer = item_rect; item.rect_outer = Ri32(item_rect);
item.inner_margin = 3; item.inner_margin = 3;
if (!is_theme_list){ if (!is_theme_list){
@ -477,7 +459,6 @@ lister_update_ui(Application_Links *app, View_ID view, Lister_State *state){
item.user_data = node->user_data; item.user_data = node->user_data;
UI_Item *item_ptr = ui_list_add_item(ui_arena, &ui_data->list, item); UI_Item *item_ptr = ui_list_add_item(ui_arena, &ui_data->list, item);
if (rect_contains_point(item_rect, view_m)){ if (rect_contains_point(item_rect, view_m)){
hovered_item = item_ptr; hovered_item = item_ptr;
@ -511,7 +492,9 @@ lister_update_ui(Application_Links *app, View_ID view, Lister_State *state){
if (state->set_view_vertical_focus_to_item){ if (state->set_view_vertical_focus_to_item){
if (highlighted_item != 0){ if (highlighted_item != 0){
view_set_vertical_focus(app, view, highlighted_item->rect_outer.y0, highlighted_item->rect_outer.y1); view_set_vertical_focus(app, view,
(f32)highlighted_item->rect_outer.y0,
(f32)highlighted_item->rect_outer.y1);
} }
state->set_view_vertical_focus_to_item = false; state->set_view_vertical_focus_to_item = false;
} }

File diff suppressed because it is too large Load Diff

View File

@ -133,5 +133,19 @@ child_process_set_target_buffer(Models *models, Child_Process *child_process, Ed
return(result); return(result);
} }
internal Process_State
child_process_get_state(Child_Process_Container *child_processes, Child_Process_ID child_process_id){
Child_Process *child_process = child_process_from_id(child_processes, child_process_id);
Process_State result = {};
if (child_processes != 0){
result.valid = true;
result.is_updating = true;
}
else if (child_process_lookup_return_code(child_processes, child_process_id, &result.return_code)){
result.valid = true;
}
return(result);
}
// BOTTOM // BOTTOM

View File

@ -219,26 +219,19 @@ save_file(System_Functions *system, Models *models, Editing_File *file){
//////////////////////////////// ////////////////////////////////
internal b32 internal Partial_Cursor
file_compute_partial_cursor(Editing_File *file, Buffer_Seek seek, Partial_Cursor *cursor){ file_compute_partial_cursor(Editing_File *file, Buffer_Seek seek){
b32 result = true; Partial_Cursor result = {};
switch (seek.type){ switch (seek.type){
case buffer_seek_pos: case buffer_seek_pos:
{ {
*cursor = buffer_partial_from_pos(&file->state.buffer, seek.pos); result = buffer_partial_from_pos(&file->state.buffer, seek.pos);
}break; }break;
case buffer_seek_line_char: case buffer_seek_line_char:
{ {
*cursor = buffer_partial_from_line_character(&file->state.buffer, seek.line, seek.character); result = buffer_partial_from_line_character(&file->state.buffer, seek.line, seek.character);
}break; }break;
// TODO(allen): do(support buffer_seek_character_pos and character_pos coordiantes in partial cursor system) // TODO(allen): do(support buffer_seek_character_pos and character_pos coordiantes in partial cursor system)
default:
{
result = false;
}break;
} }
return(result); return(result);
} }

View File

@ -86,12 +86,12 @@ view_set_edit_pos(View *view, File_Edit_Positions edit_pos){
//////////////////////////////// ////////////////////////////////
internal Rect_i32 internal Rect_f32
view_get_buffer_rect(Models *models, View *view){ view_get_buffer_rect(Models *models, View *view){
Rect_i32 region = {}; Rect_f32 region = {};
if (models->get_view_buffer_region != 0){ if (models->get_view_buffer_region != 0){
Rect_i32 rect = view->panel->rect_inner; Rect_f32 rect = Rf32(view->panel->rect_inner);
Rect_i32 sub_region = i32R(0, 0, rect_width(rect), rect_height(rect)); Rect_f32 sub_region = Rf32(V2(0, 0), rect_dim(rect));
sub_region = models->get_view_buffer_region(&models->app_links, view_get_id(&models->live_set, view), sub_region); sub_region = models->get_view_buffer_region(&models->app_links, view_get_id(&models->live_set, view), sub_region);
region.p0 = rect.p0 + sub_region.p0; region.p0 = rect.p0 + sub_region.p0;
region.p1 = rect.p0 + sub_region.p1; region.p1 = rect.p0 + sub_region.p1;
@ -101,17 +101,17 @@ view_get_buffer_rect(Models *models, View *view){
region.y0 = clamp_top(region.y0, region.y1); region.y0 = clamp_top(region.y0, region.y1);
} }
else{ else{
region = view->panel->rect_inner; region = Rf32(view->panel->rect_inner);
} }
return(region); return(region);
} }
internal i32 internal f32
view_width(Models *models, View *view){ view_width(Models *models, View *view){
return(rect_width(view_get_buffer_rect(models, view))); return(rect_width(view_get_buffer_rect(models, view)));
} }
internal i32 internal f32
view_height(Models *models, View *view){ view_height(Models *models, View *view){
return(rect_height(view_get_buffer_rect(models, view))); return(rect_height(view_get_buffer_rect(models, view)));
} }
@ -133,7 +133,7 @@ view_get_cursor_xy(System_Functions *system, View *view){
internal Cursor_Limits internal Cursor_Limits
view_cursor_limits(Models *models, View *view){ view_cursor_limits(Models *models, View *view){
i32 line_height = view->line_height; i32 line_height = view->line_height;
i32 visible_height = view_height(models, view); i32 visible_height = (i32)view_height(models, view);
Cursor_Limits limits = {}; Cursor_Limits limits = {};
limits.max = visible_height - line_height*3; limits.max = visible_height - line_height*3;
limits.min = line_height*2; limits.min = line_height*2;
@ -177,7 +177,7 @@ view_compute_max_target_y(Models *models, View *view){
internal b32 internal b32
view_move_view_to_cursor(System_Functions *system, Models *models, View *view, GUI_Scroll_Vars *scroll){ view_move_view_to_cursor(System_Functions *system, Models *models, View *view, GUI_Scroll_Vars *scroll){
b32 result = false; b32 result = false;
i32 max_x = view_width(models, view); i32 max_x = (i32)view_width(models, view);
i32 max_y = view_compute_max_target_y(models, view); i32 max_y = view_compute_max_target_y(models, view);
Vec2_i32 cursor = view_get_cursor_xy(system, view); Vec2_i32 cursor = view_get_cursor_xy(system, view);

View File

@ -29,4 +29,7 @@ view_buffer_boundary_range
view_buffer_snipe_range view_buffer_snipe_range
Hard_Start_Result -> Line_Indent_Info Hard_Start_Result -> Line_Indent_Info
buffer_find_hard_start -> get_line_indent_info buffer_find_hard_start -> get_line_indent_info
get_active_view -> get_active_view_DEP