From 7759f7e8ef3d5634d387cd609cedfc4aea6ad306 Mon Sep 17 00:00:00 2001 From: Allen Webster Date: Fri, 11 May 2018 13:46:26 -0700 Subject: [PATCH] finished reorganizing custom layer --- 4coder_API/custom.h | 17 +- 4coder_base_commands.cpp | 144 +++++++++- 4coder_combined_write_commands.cpp | 120 ++++++++ 4coder_default_framework.cpp | 48 ++-- 4coder_default_include.cpp | 412 +--------------------------- 4coder_generated/command_metadata.h | 388 +++++++++++++------------- 4coder_generated/remapping.h | 28 +- 4coder_helper.cpp | 165 ++++++++++- 4coder_long_command_switch.cpp | 62 +++++ 4coder_search.cpp | 244 ++++++++-------- 10 files changed, 842 insertions(+), 786 deletions(-) create mode 100644 4coder_combined_write_commands.cpp create mode 100644 4coder_long_command_switch.cpp diff --git a/4coder_API/custom.h b/4coder_API/custom.h index 7e77dc91..f7b258bf 100644 --- a/4coder_API/custom.h +++ b/4coder_API/custom.h @@ -1,3 +1,8 @@ +/* +custom.h +*/ + +// TOP #ifndef FCODER_CUSTOM_H #define FCODER_CUSTOM_H @@ -5,18 +10,18 @@ #include #include "version.h" -#include "4coder_generated/keycodes.h" -#include "4coder_generated/style.h" -// TODO(allen): I don't like having to pull in the types from my standalone libraries to define the API. -// What to do??? Hmmm.... #include "4coder_lib/4coder_string.h" #include "4coder_lib/4cpp_lexer_types.h" +#include "4coder_generated/keycodes.h" +#include "4coder_generated/style.h" #include "types.h" #include "4coder_generated/app_functions.h" extern "C" _GET_VERSION_SIG(get_alpha_4coder_version){ - int32_t result = (maj == MAJOR && min == MINOR && patch == PATCH); - return(result); + return((maj == MAJOR && min == MINOR && patch == PATCH)); } #endif + +// BOTTOM + diff --git a/4coder_base_commands.cpp b/4coder_base_commands.cpp index 77dc3af5..ba68152e 100644 --- a/4coder_base_commands.cpp +++ b/4coder_base_commands.cpp @@ -37,7 +37,7 @@ CUSTOM_DOC("Inserts whatever character was used to trigger this command.") uint8_t character[4]; uint32_t length = to_writable_character(in, character); write_character_parameter(app, character, length); -} + } CUSTOM_COMMAND_SIG(write_underscore) CUSTOM_DOC("Inserts an underscore.") @@ -606,11 +606,8 @@ CUSTOM_COMMAND_SIG(reverse_search); static void isearch(Application_Links *app, int32_t start_reversed, String query_init){ - uint32_t access = AccessProtected; - - View_Summary view = get_active_view(app, access); - Buffer_Summary buffer = get_buffer(app, view.buffer_id, access); - + View_Summary view = get_active_view(app, AccessProtected); + Buffer_Summary buffer = get_buffer(app, view.buffer_id, AccessProtected); if (!buffer.exists) return; Query_Bar bar = {0}; @@ -1271,6 +1268,132 @@ CUSTOM_DOC("Delete the line the on which the cursor sits.") //////////////////////////////// +static bool32 +get_cpp_matching_file(Application_Links *app, Buffer_Summary buffer, Buffer_Summary *buffer_out){ + bool32 result = false; + + if (buffer.file_name != 0){ + char space[512]; + String file_name = make_string_cap(space, 0, sizeof(space)); + append(&file_name, make_string(buffer.file_name, buffer.file_name_len)); + + String extension = file_extension(file_name); + String new_extensions[2] = {0}; + int32_t new_extensions_count = 0; + + if (match(extension, "cpp") || match(extension, "cc")){ + new_extensions[0] = make_lit_string("h"); + new_extensions[1] = make_lit_string("hpp"); + new_extensions_count = 2; + } + else if (match(extension, "c")){ + new_extensions[0] = make_lit_string("h"); + new_extensions_count = 1; + } + else if (match(extension, "h")){ + new_extensions[0] = make_lit_string("c"); + new_extensions[1] = make_lit_string("cpp"); + new_extensions_count = 2; + } + else if (match(extension, "hpp")){ + new_extensions[0] = make_lit_string("cpp"); + new_extensions_count = 1; + } + + remove_extension(&file_name); + int32_t base_pos = file_name.size; + for (int32_t i = 0; i < new_extensions_count; ++i){ + String ext = new_extensions[i]; + file_name.size = base_pos; + append(&file_name, ext); + + if (open_file(app, buffer_out, file_name.str, file_name.size, false, true)){ + result = true; + break; + } + } + } + + return(result); +} + +CUSTOM_COMMAND_SIG(open_file_in_quotes) +CUSTOM_DOC("Reads a filename from surrounding '\"' characters and attempts to open the corresponding file.") +{ + View_Summary view = get_active_view(app, AccessProtected); + Buffer_Summary buffer = get_buffer(app, view.buffer_id, AccessProtected); + if (!buffer.exists) return; + + char file_name_[256]; + String file_name = make_fixed_width_string(file_name_); + + int32_t pos = view.cursor.pos; + int32_t start = 0; + int32_t end = 0; + buffer_seek_delimiter_forward(app, &buffer, pos, '"', &end); + buffer_seek_delimiter_backward(app, &buffer, pos, '"', &start); + ++start; + + int32_t size = end - start; + + char short_file_name[128]; + if (size < sizeof(short_file_name)){ + if (buffer_read_range(app, &buffer, start, end, short_file_name)){ + copy(&file_name, make_string(buffer.file_name, buffer.file_name_len)); + remove_last_folder(&file_name); + append(&file_name, make_string(short_file_name, size)); + + view = get_next_active_panel(app, &view); + if (view.exists){ + if (view_open_file(app, &view, file_name.str, file_name.size, true)){ + set_active_view(app, &view); + } + } + } + } +} + +CUSTOM_COMMAND_SIG(open_matching_file_cpp) +CUSTOM_DOC("If the current file is a *.cpp or *.h, attempts to open the corresponding *.h or *.cpp file in the other view.") +{ + View_Summary view = get_active_view(app, AccessAll); + Buffer_Summary buffer = get_buffer(app, view.buffer_id, AccessAll); + + Buffer_Summary new_buffer = {0}; + if (get_cpp_matching_file(app, buffer, &new_buffer)){ + get_view_next_looped(app, &view, AccessAll); + view_set_buffer(app, &view, new_buffer.buffer_id, 0); + set_active_view(app, &view); + } +} + +CUSTOM_COMMAND_SIG(view_buffer_other_panel) +CUSTOM_DOC("Set the other non-active panel to view the buffer that the active panel views, and switch to that panel.") +{ + View_Summary view = get_active_view(app, AccessAll); + int32_t buffer_id = view.buffer_id; + change_active_panel(app); + view = get_active_view(app, AccessAll); + view_set_buffer(app, &view, buffer_id, 0); +} + +CUSTOM_COMMAND_SIG(swap_buffers_between_panels) +CUSTOM_DOC("Set the other non-active panel to view the buffer that the active panel views, and switch to that panel.") +{ + View_Summary view1 = get_active_view(app, AccessAll); + change_active_panel(app); + View_Summary view2 = get_active_view(app, AccessAll); + + if (view1.view_id != view2.view_id){ + int32_t buffer_id1 = view1.buffer_id; + int32_t buffer_id2 = view2.buffer_id; + view_set_buffer(app, &view1, buffer_id2, 0); + view_set_buffer(app, &view2, buffer_id1, 0); + } +} + +//////////////////////////////// + CUSTOM_COMMAND_SIG(undo) CUSTOM_DOC("Advances backwards through the undo history.") { @@ -1337,5 +1460,14 @@ CUSTOM_DOC("Opens the 4coder colors and fonts selector menu.") exec_command(app, cmdid_open_color_tweaker); } +//////////////////////////////// + +CUSTOM_COMMAND_SIG(open_in_other) +CUSTOM_DOC("Switches to the next active panel and begins an open file dialogue.") +{ + change_active_panel(app); + interactive_open_or_new(app); +} + // BOTTOM diff --git a/4coder_combined_write_commands.cpp b/4coder_combined_write_commands.cpp new file mode 100644 index 00000000..ae7c595b --- /dev/null +++ b/4coder_combined_write_commands.cpp @@ -0,0 +1,120 @@ +/* +4coder_combined_write_commands.cpp - Commands for writing text specialized for particular +contexts. +*/ + +// TOP + +static void +write_string(Application_Links *app, View_Summary *view, Buffer_Summary *buffer, String string){ + buffer_replace_range(app, buffer, view->cursor.pos, view->cursor.pos, string.str, string.size); + view_set_cursor(app, view, seek_pos(view->cursor.pos + string.size), 1); +} + +static void +write_string(Application_Links *app, String string){ + uint32_t access = AccessOpen; + View_Summary view = get_active_view(app, access); + Buffer_Summary buffer = get_buffer(app, view.buffer_id, access); + write_string(app, &view, &buffer, string); +} + +static void +write_named_comment_string(Application_Links *app, char *type_string){ + char space[512]; + String str = make_fixed_width_string(space); + + char *name = 0; + int32_t name_len = 0; + if (get_current_name(&name, &name_len)){ + append(&str, "// "); + append(&str, type_string); + append(&str, "("); + append(&str, make_string(name, name_len)); + append(&str, "): "); + } + else{ + append(&str, "// "); + append(&str, type_string); + append(&str, ": "); + } + + write_string(app, str); +} + +static void +long_braces(Application_Links *app, char *text, int32_t size){ + uint32_t access = AccessOpen; + View_Summary view = get_active_view(app, access); + Buffer_Summary buffer = get_buffer(app, view.buffer_id, access); + int32_t pos = view.cursor.pos; + + buffer_replace_range(app, &buffer, pos, pos, text, size); + view_set_cursor(app, &view, seek_pos(pos + 2), true); + + buffer_auto_indent(app, &global_part, &buffer, pos, pos + size, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens); + move_past_lead_whitespace(app, &view, &buffer); +} + +CUSTOM_COMMAND_SIG(open_long_braces) +CUSTOM_DOC("At the cursor, insert a '{' and '}' separated by a blank line.") +{ + char text[] = "{\n\n}"; + int32_t size = sizeof(text) - 1; + long_braces(app, text, size); +} + +CUSTOM_COMMAND_SIG(open_long_braces_semicolon) +CUSTOM_DOC("At the cursor, insert a '{' and '};' separated by a blank line.") +{ + char text[] = "{\n\n};"; + int32_t size = sizeof(text) - 1; + long_braces(app, text, size); +} + +CUSTOM_COMMAND_SIG(open_long_braces_break) +CUSTOM_DOC("At the cursor, insert a '{' and '}break;' separated by a blank line.") +{ + char text[] = "{\n\n}break;"; + int32_t size = sizeof(text) - 1; + long_braces(app, text, size); +} + +CUSTOM_COMMAND_SIG(if0_off) +CUSTOM_DOC("Surround the range between the cursor and mark with an '#if 0' and an '#endif'") +{ + place_begin_and_end_on_own_lines(app, &global_part, "#if 0", "#endif"); +} + +CUSTOM_COMMAND_SIG(write_todo) +CUSTOM_DOC("At the cursor, insert a '// TODO' comment, includes user name if it was specified in config.4coder.") +{ + write_named_comment_string(app, "TODO"); +} + +CUSTOM_COMMAND_SIG(write_hack) +CUSTOM_DOC("At the cursor, insert a '// HACK' comment, includes user name if it was specified in config.4coder.") +{ + write_named_comment_string(app, "HACK"); +} + +CUSTOM_COMMAND_SIG(write_note) +CUSTOM_DOC("At the cursor, insert a '// NOTE' comment, includes user name if it was specified in config.4coder.") +{ + write_named_comment_string(app, "NOTE"); +} + +CUSTOM_COMMAND_SIG(write_block) +CUSTOM_DOC("At the cursor, insert a block comment.") +{ + write_string(app, make_lit_string("/* */")); +} + +CUSTOM_COMMAND_SIG(write_zero_struct) +CUSTOM_DOC("At the cursor, insert a ' = {0};'.") +{ + write_string(app, make_lit_string(" = {0};")); +} + +// BOTTOM + diff --git a/4coder_default_framework.cpp b/4coder_default_framework.cpp index 3019ac23..cda3c7af 100644 --- a/4coder_default_framework.cpp +++ b/4coder_default_framework.cpp @@ -144,19 +144,43 @@ open_special_note_view(Application_Links *app, bool32 create_if_not_exist = true return(special_view); } -CUSTOM_COMMAND_SIG(change_active_panel) -CUSTOM_DOC("Change the currently active panel, moving to the panel with the next highest view_id.") -{ - View_Summary view = get_active_view(app, AccessAll); - View_ID original_view_id = view.view_id; - +static View_Summary +get_next_active_panel(Application_Links *app, View_Summary *view_start){ + View_ID original_view_id = view_start->view_id; + View_Summary view = *view_start; do{ get_view_next_looped(app, &view, AccessAll); if (view.view_id != special_note_view_id){ break; } }while(view.view_id != original_view_id); - + if (!view.exists){ + memset(&view, 0, sizeof(view)); + } + return(view); +} + +static View_Summary +get_prev_active_panel(Application_Links *app, View_Summary *view_start){ + View_ID original_view_id = view_start->view_id; + View_Summary view = *view_start; + do{ + get_view_prev_looped(app, &view, AccessAll); + if (view.view_id != special_note_view_id){ + break; + } + }while(view.view_id != original_view_id); + if (!view.exists){ + memset(&view, 0, sizeof(view)); + } + return(view); +} + +CUSTOM_COMMAND_SIG(change_active_panel) +CUSTOM_DOC("Change the currently active panel, moving to the panel with the next highest view_id.") +{ + View_Summary view = get_active_view(app, AccessAll); + view = get_next_active_panel(app, &view); if (view.exists){ set_active_view(app, &view); } @@ -166,15 +190,7 @@ CUSTOM_COMMAND_SIG(change_active_panel_backwards) CUSTOM_DOC("Change the currently active panel, moving to the panel with the next lowest view_id.") { View_Summary view = get_active_view(app, AccessAll); - View_ID original_view_id = view.view_id; - - do{ - get_view_prev_looped(app, &view, AccessAll); - if (view.view_id != special_note_view_id){ - break; - } - }while(view.view_id != original_view_id); - + view = get_prev_active_panel(app, &view); if (view.exists){ set_active_view(app, &view); } diff --git a/4coder_default_include.cpp b/4coder_default_include.cpp index 49564837..a4486429 100644 --- a/4coder_default_include.cpp +++ b/4coder_default_include.cpp @@ -48,418 +48,10 @@ #include "4coder_project_commands.cpp" #include "4coder_function_list.cpp" #include "4coder_scope_commands.cpp" +#include "4coder_combined_write_commands.cpp" +#include "4coder_long_command_switch.cpp" #include "4coder_default_hooks.cpp" - -// -// Approximate Definition Search -// - -static void -get_search_definition(Application_Links *app, Query_Bar *bar, char *string_space, int32_t space_size){ - bar->prompt = make_lit_string("List Definitions For: "); - bar->string = make_string_cap(string_space, 0, space_size); - - if (!query_user_string(app, bar)){ - bar->string.size = 0; - } -} - -static String -build_string(Partition *part, char *s1, char *s2, char *s3){ - String sr = {0}; - sr.memory_size = str_size(s1) + str_size(s2) + str_size(s3); - sr.str = push_array(part, char, sr.memory_size); - append(&sr, s1); - append(&sr, s2); - append(&sr, s3); - return(sr); -} - -static void -list_all_locations_of_type_definition_parameters(Application_Links *app, char *str){ - Partition *part = &global_part; - Temp_Memory temp = begin_temp_memory(part); - - String match_strings[6]; - match_strings[0] = build_string(part, "struct ", str, "{"); - match_strings[1] = build_string(part, "struct ", str, "\n{"); - match_strings[2] = build_string(part, "union " , str, "{"); - match_strings[3] = build_string(part, "union " , str, "\n{"); - match_strings[4] = build_string(part, "enum " , str, "{"); - match_strings[5] = build_string(part, "enum " , str, "\n{"); - - list_all_locations_parameters(app, &global_general, part, match_strings, ArrayCount(match_strings), 0); - - end_temp_memory(temp); - - Buffer_Summary buffer = get_buffer_by_name(app, literal("*search*"), AccessAll); - if (buffer.line_count == 2){ - goto_first_jump_same_panel_sticky(app); - } -} - -CUSTOM_COMMAND_SIG(list_all_locations_of_type_definition) -CUSTOM_DOC("Queries user for string, lists all locations of strings that appear to define a type whose name matches the input string.") -{ - char string_space[1024]; - Query_Bar bar; - get_search_definition(app, &bar, string_space, sizeof(string_space)); - if (bar.string.size == 0) return; - if (!terminate_with_null(&bar.string)) return; - - list_all_locations_of_type_definition_parameters(app, bar.string.str); -} - -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.") -{ - View_Summary view = get_active_view(app, AccessProtected); - Buffer_Summary buffer = get_buffer(app, view.buffer_id, AccessProtected); - - char space[512]; - String str = get_token_or_word_under_pos(app, &buffer, view.cursor.pos, space, sizeof(space) - 1); - if (str.size > 0){ - str.str[str.size] = 0; - - change_active_panel(app); - list_all_locations_of_type_definition_parameters(app, str.str); - } -} - - -// -// Combined Write Commands -// - -static void -write_string(Application_Links *app, View_Summary *view, Buffer_Summary *buffer, String string){ - buffer_replace_range(app, buffer, view->cursor.pos, view->cursor.pos, string.str, string.size); - view_set_cursor(app, view, seek_pos(view->cursor.pos + string.size), 1); -} - -static void -write_string(Application_Links *app, String string){ - uint32_t access = AccessOpen; - View_Summary view = get_active_view(app, access); - Buffer_Summary buffer = get_buffer(app, view.buffer_id, access); - write_string(app, &view, &buffer, string); -} - -static void -long_braces(Application_Links *app, char *text, int32_t size){ - uint32_t access = AccessOpen; - View_Summary view = get_active_view(app, access); - Buffer_Summary buffer = get_buffer(app, view.buffer_id, access); - int32_t pos = view.cursor.pos; - - buffer_replace_range(app, &buffer, pos, pos, text, size); - view_set_cursor(app, &view, seek_pos(pos + 2), true); - - buffer_auto_indent(app, &global_part, &buffer, pos, pos + size, DEF_TAB_WIDTH, DEFAULT_INDENT_FLAGS | AutoIndent_FullTokens); - move_past_lead_whitespace(app, &view, &buffer); -} - -CUSTOM_COMMAND_SIG(open_long_braces) -CUSTOM_DOC("At the cursor, insert a '{' and '}' separated by a blank line.") -{ - char text[] = "{\n\n}"; - int32_t size = sizeof(text) - 1; - long_braces(app, text, size); -} - -CUSTOM_COMMAND_SIG(open_long_braces_semicolon) -CUSTOM_DOC("At the cursor, insert a '{' and '};' separated by a blank line.") -{ - char text[] = "{\n\n};"; - int32_t size = sizeof(text) - 1; - long_braces(app, text, size); -} - -CUSTOM_COMMAND_SIG(open_long_braces_break) -CUSTOM_DOC("At the cursor, insert a '{' and '}break;' separated by a blank line.") -{ - char text[] = "{\n\n}break;"; - int32_t size = sizeof(text) - 1; - long_braces(app, text, size); -} - -CUSTOM_COMMAND_SIG(if0_off) -CUSTOM_DOC("Surround the range between the cursor and mark with an '#if 0' and an '#endif'") -{ - place_begin_and_end_on_own_lines(app, &global_part, "#if 0", "#endif"); -} - -static void -write_named_comment_string(Application_Links *app, char *type_string){ - char space[512]; - String str = make_fixed_width_string(space); - - char *name = 0; - int32_t name_len = 0; - if (get_current_name(&name, &name_len)){ - append(&str, "// "); - append(&str, type_string); - append(&str, "("); - append(&str, make_string(name, name_len)); - append(&str, "): "); - } - else{ - append(&str, "// "); - append(&str, type_string); - append(&str, ": "); - } - - write_string(app, str); -} - -CUSTOM_COMMAND_SIG(write_todo) -CUSTOM_DOC("At the cursor, insert a '// TODO' comment, includes user name if it was specified in config.4coder.") -{ - write_named_comment_string(app, "TODO"); -} - -CUSTOM_COMMAND_SIG(write_hack) -CUSTOM_DOC("At the cursor, insert a '// HACK' comment, includes user name if it was specified in config.4coder.") -{ - write_named_comment_string(app, "HACK"); -} - -CUSTOM_COMMAND_SIG(write_note) -CUSTOM_DOC("At the cursor, insert a '// NOTE' comment, includes user name if it was specified in config.4coder.") -{ - write_named_comment_string(app, "NOTE"); -} - -CUSTOM_COMMAND_SIG(write_block) -CUSTOM_DOC("At the cursor, insert a block comment.") -{ - write_string(app, make_lit_string("/* */")); -} - -CUSTOM_COMMAND_SIG(write_zero_struct) -CUSTOM_DOC("At the cursor, insert a ' = {0};'.") -{ - write_string(app, make_lit_string(" = {0};")); -} - - -// -// Open File In Quotes -// - -static bool32 -file_name_in_quotes(Application_Links *app, String *file_name){ - bool32 result = false; - uint32_t access = AccessProtected; - - View_Summary view = get_active_view(app, access); - Buffer_Summary buffer = get_buffer(app, view.buffer_id, access); - - if (buffer.file_name != 0){ - int32_t pos = view.cursor.pos; - int32_t start = 0, end = 0; - buffer_seek_delimiter_forward(app, &buffer, pos, '"', &end); - buffer_seek_delimiter_backward(app, &buffer, pos, '"', &start); - ++start; - - int32_t size = end - start; - - char short_file_name[128]; - // NOTE(allen): This check is necessary because buffer_read_range - // requiers that the output buffer you provide is at least (end - start) bytes long. - if (size < sizeof(short_file_name)){ - if (buffer_read_range(app, &buffer, start, end, short_file_name)){ - result = true; - copy_ss(file_name, make_string(buffer.file_name, buffer.file_name_len)); - remove_last_folder(file_name); - append_ss(file_name, make_string(short_file_name, size)); - } - } - } - - return(result); -} - -CUSTOM_COMMAND_SIG(open_file_in_quotes) -CUSTOM_DOC("Reads a filename from surrounding '\"' characters and attempts to open the corresponding file.") -{ - char file_name_[256]; - String file_name = make_fixed_width_string(file_name_); - - if (file_name_in_quotes(app, &file_name)){ - exec_command(app, change_active_panel); - View_Summary view = get_active_view(app, AccessAll); - view_open_file(app, &view, expand_str(file_name), true); - } -} - -// -// File Navigating -// - -CUSTOM_COMMAND_SIG(open_in_other) -CUSTOM_DOC("Reads a filename from surrounding '\"' characters and attempts to open the corresponding file, displaying it in the other view.") -{ - exec_command(app, change_active_panel); - exec_command(app, interactive_open_or_new); -} - -static bool32 -get_cpp_matching_file(Application_Links *app, Buffer_Summary buffer, Buffer_Summary *buffer_out){ - bool32 result = false; - - if (buffer.file_name != 0){ - char space[512]; - String file_name = make_string_cap(space, 0, sizeof(space)); - append(&file_name, make_string(buffer.file_name, buffer.file_name_len)); - - String extension = file_extension(file_name); - String new_extensions[2] = {0}; - int32_t new_extensions_count = 0; - - if (match(extension, "cpp") || match(extension, "cc")){ - new_extensions[0] = make_lit_string("h"); - new_extensions[1] = make_lit_string("hpp"); - new_extensions_count = 2; - } - else if (match(extension, "c")){ - new_extensions[0] = make_lit_string("h"); - new_extensions_count = 1; - } - else if (match(extension, "h")){ - new_extensions[0] = make_lit_string("c"); - new_extensions[1] = make_lit_string("cpp"); - new_extensions_count = 2; - } - else if (match(extension, "hpp")){ - new_extensions[0] = make_lit_string("cpp"); - new_extensions_count = 1; - } - - remove_extension(&file_name); - int32_t base_pos = file_name.size; - for (int32_t i = 0; i < new_extensions_count; ++i){ - String ext = new_extensions[i]; - file_name.size = base_pos; - append(&file_name, ext); - - if (open_file(app, buffer_out, file_name.str, file_name.size, false, true)){ - result = true; - break; - } - } - } - - return(result); -} - -CUSTOM_COMMAND_SIG(open_matching_file_cpp) -CUSTOM_DOC("If the current file is a *.cpp or *.h, attempts to open the corresponding *.h or *.cpp file in the other view.") -{ - View_Summary view = get_active_view(app, AccessAll); - Buffer_Summary buffer = get_buffer(app, view.buffer_id, AccessAll); - - Buffer_Summary new_buffer = {0}; - if (get_cpp_matching_file(app, buffer, &new_buffer)){ - get_view_next_looped(app, &view, AccessAll); - view_set_buffer(app, &view, new_buffer.buffer_id, 0); - set_active_view(app, &view); - } -} - -CUSTOM_COMMAND_SIG(view_buffer_other_panel) -CUSTOM_DOC("Set the other non-active panel to view the buffer that the active panel views, and switch to that panel.") -{ - View_Summary view = get_active_view(app, AccessAll); - int32_t buffer_id = view.buffer_id; - change_active_panel(app); - view = get_active_view(app, AccessAll); - view_set_buffer(app, &view, buffer_id, 0); -} - -CUSTOM_COMMAND_SIG(swap_buffers_between_panels) -CUSTOM_DOC("Set the other non-active panel to view the buffer that the active panel views, and switch to that panel.") -{ - View_Summary view1 = get_active_view(app, AccessAll); - change_active_panel(app); - View_Summary view2 = get_active_view(app, AccessAll); - - if (view1.view_id != view2.view_id){ - int32_t buffer_id1 = view1.buffer_id; - int32_t buffer_id2 = view2.buffer_id; - view_set_buffer(app, &view1, buffer_id2, 0); - view_set_buffer(app, &view2, buffer_id1, 0); - } -} - -// -// Execute Arbitrary Command -// - -CUSTOM_COMMAND_SIG(execute_arbitrary_command) -CUSTOM_DOC("Execute a 'long form' command.") -{ - // NOTE(allen): This isn't a super powerful version of this command, I will expand - // upon it so that it has all the cmdid_* commands by default. However, with this - // as an example you have everything you need to make it work already. You could - // even use app->memory to create a hash table in the start hook. - Query_Bar bar = {0}; - char space[1024]; - bar.prompt = make_lit_string("Command: "); - bar.string = make_fixed_width_string(space); - - if (!query_user_string(app, &bar)) return; - - // NOTE(allen): Here I chose to end this query bar because when I call another - // command it might ALSO have query bars and I don't want this one hanging - // around at that point. Since the bar exists on my stack the result of the query - // is still available in bar.string though. - end_query_bar(app, &bar, 0); - - if (match(bar.string, make_lit_string("toggle fullscreen"))){ - toggle_fullscreen(app); - } - else if (match(bar.string, make_lit_string("load project"))){ - load_project(app); - } - else if (match(bar.string, make_lit_string("open all code"))){ - open_all_code(app); - } - else if (match(bar.string, make_lit_string("open all code recursive"))){ - open_all_code_recursive(app); - } - else if(match(bar.string, make_lit_string("close all code"))){ - close_all_code(app); - } - else if (match(bar.string, make_lit_string("dos lines")) || - match(bar.string, make_lit_string("dosify"))){ - eol_dosify(app); - } - else if (match(bar.string, make_lit_string("nix lines")) || - match(bar.string, make_lit_string("nixify"))){ - eol_nixify(app); - } - else if (match(bar.string, make_lit_string("remap"))){ - remap_interactive(app); - } - else if (match(bar.string, make_lit_string("new project"))){ - setup_new_project(app); - } - else if (match(bar.string, make_lit_string("delete file"))){ - delete_file_query(app); - } - else if (match(bar.string, make_lit_string("rename file"))){ - rename_file_query(app); - } - else if (match(bar.string, make_lit_string("mkdir"))){ - make_directory_query(app); - } - else{ - print_message(app, literal("unrecognized command\n")); - } -} - #include "4coder_remapping_commands.cpp" #endif diff --git a/4coder_generated/command_metadata.h b/4coder_generated/command_metadata.h index 1c99a5c0..679a019e 100644 --- a/4coder_generated/command_metadata.h +++ b/4coder_generated/command_metadata.h @@ -214,200 +214,200 @@ int32_t source_name_len; int32_t line_number; }; static Command_Metadata fcoder_metacmd_table[194] = { -{ PROC_LINKS(allow_mouse, 0), "allow_mouse", 11, "Shows the mouse and causes all mouse input to be processed normally.", 68, "C:\\4ed\\code\\4coder_default_framework.cpp", 43, 221 }, -{ PROC_LINKS(auto_tab_line_at_cursor, 0), "auto_tab_line_at_cursor", 23, "Auto-indents the line on which the cursor sits.", 47, "C:\\4ed\\code\\4coder_auto_indent.cpp", 37, 722 }, -{ PROC_LINKS(auto_tab_range, 0), "auto_tab_range", 14, "Auto-indents the range between the cursor and the mark.", 55, "C:\\4ed\\code\\4coder_auto_indent.cpp", 37, 733 }, -{ PROC_LINKS(auto_tab_whole_file, 0), "auto_tab_whole_file", 19, "Audo-indents the entire current buffer.", 39, "C:\\4ed\\code\\4coder_auto_indent.cpp", 37, 712 }, -{ PROC_LINKS(backspace_char, 0), "backspace_char", 14, "Deletes the character to the left of the cursor.", 48, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 67 }, -{ PROC_LINKS(backspace_word, 0), "backspace_word", 14, "Delete characters between the cursor position and the first alphanumeric boundary to the left.", 94, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1247 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 433 }, -{ 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, "C:\\4ed\\code\\4coder_build_commands.cpp", 40, 188 }, -{ 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, "C:\\4ed\\code\\4coder_build_commands.cpp", 40, 154 }, -{ PROC_LINKS(center_view, 0), "center_view", 11, "Centers the view vertically on the line on which the cursor sits.", 65, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 120 }, -{ 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, "C:\\4ed\\code\\4coder_default_framework.cpp", 43, 147 }, -{ 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, "C:\\4ed\\code\\4coder_default_framework.cpp", 43, 165 }, -{ 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, "C:\\4ed\\code\\4coder_build_commands.cpp", 40, 210 }, -{ PROC_LINKS(clean_all_lines, 0), "clean_all_lines", 15, "Removes trailing whitespace from all lines in the current buffer.", 65, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 368 }, -{ PROC_LINKS(click_set_cursor, 0), "click_set_cursor", 16, "Sets the cursor position to the mouse position.", 47, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 174 }, -{ PROC_LINKS(click_set_mark, 0), "click_set_mark", 14, "Sets the mark position to the mouse position.", 45, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 187 }, -{ 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, "C:\\4ed\\code\\4coder_project_commands.cpp", 42, 403 }, -{ PROC_LINKS(close_build_panel, 0), "close_build_panel", 17, "If the special build panel is open, closes it.", 46, "C:\\4ed\\code\\4coder_build_commands.cpp", 40, 204 }, -{ PROC_LINKS(close_panel, 0), "close_panel", 11, "Closes the currently active panel if it is not the only panel open.", 67, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 441 }, -{ PROC_LINKS(copy, 0), "copy", 4, "Copy the text in the range from the cursor to the mark onto the clipboard.", 74, "C:\\4ed\\code\\4coder_clipboard.cpp", 35, 26 }, -{ PROC_LINKS(cursor_mark_swap, 0), "cursor_mark_swap", 16, "Swaps the position of the cursor and the mark.", 46, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 95 }, -{ PROC_LINKS(cut, 0), "cut", 3, "Cut the text in the range from the cursor to the mark onto the clipboard.", 73, "C:\\4ed\\code\\4coder_clipboard.cpp", 35, 35 }, -{ PROC_LINKS(decrease_face_size, 0), "decrease_face_size", 18, "Decrease the size of the face used by the current buffer.", 57, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 531 }, -{ PROC_LINKS(decrease_line_wrap, 0), "decrease_line_wrap", 18, "Decrases the current buffer's width for line wrapping.", 54, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 508 }, -{ PROC_LINKS(delete_char, 0), "delete_char", 11, "Deletes the character to the right of the cursor.", 49, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 49 }, -{ 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, "C:\\4ed\\code\\4coder_scope_commands.cpp", 40, 487 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 996 }, -{ PROC_LINKS(delete_line, 0), "delete_line", 11, "Delete the line the on which the cursor sits.", 45, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1246 }, -{ PROC_LINKS(delete_range, 0), "delete_range", 12, "Deletes the text in the range between the cursor and the mark.", 62, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 107 }, -{ PROC_LINKS(delete_word, 0), "delete_word", 11, "Delete characters between the cursor position and the first alphanumeric boundary to the right.", 95, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1253 }, -{ PROC_LINKS(duplicate_line, 0), "duplicate_line", 14, "Create a copy of the line on which the cursor sits.", 51, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1224 }, -{ PROC_LINKS(eol_dosify, 0), "eol_dosify", 10, "Puts the buffer in DOS line ending mode.", 40, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 561 }, -{ PROC_LINKS(eol_nixify, 0), "eol_nixify", 10, "Puts the buffer in NIX line ending mode.", 40, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 569 }, -{ 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, "C:\\4ed\\code\\4coder_system_command.cpp", 40, 23 }, -{ PROC_LINKS(execute_arbitrary_command, 0), "execute_arbitrary_command", 25, "Execute a 'long form' command.", 30, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 400 }, -{ 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, "C:\\4ed\\code\\4coder_system_command.cpp", 40, 7 }, -{ PROC_LINKS(exit_4coder, 0), "exit_4coder", 11, "Attempts to close 4coder.", 25, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 577 }, -{ PROC_LINKS(goto_beginning_of_file, 0), "goto_beginning_of_file", 22, "Sets the cursor to the beginning of the file.", 45, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1168 }, -{ PROC_LINKS(goto_end_of_file, 0), "goto_end_of_file", 16, "Sets the cursor to the end of the file.", 39, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1175 }, -{ 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, "C:\\4ed\\code\\4coder_jump_direct.cpp", 37, 84 }, -{ 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, "C:\\4ed\\code\\4coder_jump_sticky.cpp", 37, 533 }, -{ 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, "C:\\4ed\\code\\4coder_jump_sticky.cpp", 37, 515 }, -{ 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, "C:\\4ed\\code\\4coder_jump_direct.cpp", 37, 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, "C:\\4ed\\code\\4coder_jump_direct.cpp", 37, 29 }, -{ 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, "C:\\4ed\\code\\4coder_jump_sticky.cpp", 37, 365 }, -{ 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, "C:\\4ed\\code\\4coder_jump_sticky.cpp", 37, 337 }, -{ PROC_LINKS(goto_line, 0), "goto_line", 9, "Queries the user for a number, and jumps the cursor to the corresponding line.", 78, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 585 }, -{ 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, "C:\\4ed\\code\\4coder_jump_direct.cpp", 37, 48 }, -{ 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, "C:\\4ed\\code\\4coder_jump_direct.cpp", 37, 66 }, -{ 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, "C:\\4ed\\code\\4coder_jump_sticky.cpp", 37, 484 }, -{ 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, "C:\\4ed\\code\\4coder_jump_sticky.cpp", 37, 454 }, -{ 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, "C:\\4ed\\code\\4coder_jump_direct.cpp", 37, 57 }, -{ 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, "C:\\4ed\\code\\4coder_jump_direct.cpp", 37, 75 }, -{ 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, "C:\\4ed\\code\\4coder_jump_sticky.cpp", 37, 500 }, -{ 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, "C:\\4ed\\code\\4coder_jump_sticky.cpp", 37, 470 }, -{ PROC_LINKS(hide_filebar, 0), "hide_filebar", 12, "Sets the current view to hide it's filebar.", 43, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 471 }, -{ PROC_LINKS(hide_scrollbar, 0), "hide_scrollbar", 14, "Sets the current view to hide it's scrollbar.", 45, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 457 }, -{ PROC_LINKS(highlight_next_scope_absolute, 0), "highlight_next_scope_absolute", 29, "Finds the first scope started by '{' after the cursor and puts the cursor and mark on the '{' and '}'.", 102, "C:\\4ed\\code\\4coder_scope_commands.cpp", 40, 363 }, -{ PROC_LINKS(highlight_prev_scope_absolute, 0), "highlight_prev_scope_absolute", 29, "Finds the first scope started by '{' before the cursor and puts the cursor and mark on the '{' and '}'.", 103, "C:\\4ed\\code\\4coder_scope_commands.cpp", 40, 382 }, -{ PROC_LINKS(highlight_surrounding_scope, 0), "highlight_surrounding_scope", 27, "Finds the scope enclosed by '{' '}' surrounding the cursor and puts the cursor and mark on the '{' and '}'.", 107, "C:\\4ed\\code\\4coder_scope_commands.cpp", 40, 341 }, -{ PROC_LINKS(if0_off, 0), "if0_off", 7, "Surround the range between the cursor and mark with an '#if 0' and an '#endif'", 78, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 187 }, -{ PROC_LINKS(increase_face_size, 0), "increase_face_size", 18, "Increase the size of the face used by the current buffer.", 57, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 519 }, -{ PROC_LINKS(increase_line_wrap, 0), "increase_line_wrap", 18, "Increases the current buffer's width for line wrapping.", 55, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 497 }, -{ PROC_LINKS(interactive_kill_buffer, 0), "interactive_kill_buffer", 23, "Interactively kill an open buffer.", 34, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1310 }, -{ PROC_LINKS(interactive_new, 0), "interactive_new", 15, "Interactively creates a new file.", 33, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1286 }, -{ PROC_LINKS(interactive_open, 0), "interactive_open", 16, "Interactively opens a file.", 27, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1292 }, -{ PROC_LINKS(interactive_open_or_new, 0), "interactive_open_or_new", 23, "Interactively opens or creates a new file.", 42, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1298 }, -{ PROC_LINKS(interactive_switch_buffer, 0), "interactive_switch_buffer", 25, "Interactively switch to an open buffer.", 39, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1304 }, -{ PROC_LINKS(kill_buffer, 0), "kill_buffer", 11, "Kills the current buffer.", 25, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1328 }, -{ PROC_LINKS(kill_rect, 0), "kill_rect", 9, "Delete characters in a rectangular region. Range testing is done by unwrapped-xy coordinates.", 93, "C:\\4ed\\code\\4coder_experiments.cpp", 37, 29 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 135 }, -{ 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, "C:\\4ed\\code\\4coder_function_list.cpp", 39, 318 }, -{ 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, "C:\\4ed\\code\\4coder_search.cpp", 32, 675 }, -{ 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, "C:\\4ed\\code\\4coder_search.cpp", 32, 695 }, -{ 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, "C:\\4ed\\code\\4coder_search.cpp", 32, 759 }, -{ 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, "C:\\4ed\\code\\4coder_search.cpp", 32, 765 }, -{ 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, "C:\\4ed\\code\\4coder_search.cpp", 32, 807 }, -{ 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, "C:\\4ed\\code\\4coder_search.cpp", 32, 813 }, -{ 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, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 102 }, -{ 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, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 114 }, -{ 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, "C:\\4ed\\code\\4coder_search.cpp", 32, 685 }, -{ 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, "C:\\4ed\\code\\4coder_search.cpp", 32, 705 }, -{ 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, "C:\\4ed\\code\\4coder_project_commands.cpp", 42, 426 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1104 }, -{ PROC_LINKS(miblo_decrement_basic, 0), "miblo_decrement_basic", 21, "Decrement an integer under the cursor by one.", 45, "C:\\4ed\\code\\4coder_miblo_numbers.cpp", 39, 110 }, -{ 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, "C:\\4ed\\code\\4coder_miblo_numbers.cpp", 39, 383 }, -{ 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, "C:\\4ed\\code\\4coder_miblo_numbers.cpp", 39, 395 }, -{ PROC_LINKS(miblo_increment_basic, 0), "miblo_increment_basic", 21, "Increment an integer under the cursor by one.", 45, "C:\\4ed\\code\\4coder_miblo_numbers.cpp", 39, 94 }, -{ 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, "C:\\4ed\\code\\4coder_miblo_numbers.cpp", 39, 377 }, -{ 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, "C:\\4ed\\code\\4coder_miblo_numbers.cpp", 39, 389 }, -{ PROC_LINKS(move_down, 0), "move_down", 9, "Moves the cursor down one line.", 31, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 250 }, -{ PROC_LINKS(move_down_10, 0), "move_down_10", 12, "Moves the cursor down ten lines.", 32, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 262 }, -{ PROC_LINKS(move_down_textual, 0), "move_down_textual", 17, "Moves down to the next line of actual text, regardless of line wrapping.", 72, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 268 }, -{ PROC_LINKS(move_left, 0), "move_left", 9, "Moves the cursor one character to the left.", 43, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 299 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1201 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1137 }, -{ PROC_LINKS(move_right, 0), "move_right", 10, "Moves the cursor one character to the right.", 44, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 308 }, -{ PROC_LINKS(move_up, 0), "move_up", 7, "Moves the cursor up one line.", 29, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 244 }, -{ PROC_LINKS(move_up_10, 0), "move_up_10", 10, "Moves the cursor up ten lines.", 30, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 256 }, -{ 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, "C:\\4ed\\code\\4coder_experiments.cpp", 37, 120 }, -{ 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, "C:\\4ed\\code\\4coder_jump_direct.cpp", 37, 101 }, -{ 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, "C:\\4ed\\code\\4coder_jump_direct.cpp", 37, 116 }, -{ 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, "C:\\4ed\\code\\4coder_jump_sticky.cpp", 37, 571 }, -{ 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, "C:\\4ed\\code\\4coder_jump_sticky.cpp", 37, 556 }, -{ 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, "C:\\4ed\\code\\4coder_project_commands.cpp", 42, 410 }, -{ PROC_LINKS(open_all_code_recursive, 0), "open_all_code_recursive", 23, "Works as open_all_code but also runs in all subdirectories.", 59, "C:\\4ed\\code\\4coder_project_commands.cpp", 42, 417 }, -{ PROC_LINKS(open_color_tweaker, 0), "open_color_tweaker", 18, "Opens the 4coder colors and fonts selector menu.", 48, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1334 }, -{ 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, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 284 }, -{ PROC_LINKS(open_in_other, 0), "open_in_other", 13, "Reads a filename from surrounding '\"' characters and attempts to open the corresponding file, displaying it in the other view.", 127, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 301 }, -{ PROC_LINKS(open_long_braces, 0), "open_long_braces", 16, "At the cursor, insert a '{' and '}' separated by a blank line.", 62, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 163 }, -{ 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, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 179 }, -{ PROC_LINKS(open_long_braces_semicolon, 0), "open_long_braces_semicolon", 26, "At the cursor, insert a '{' and '};' separated by a blank line.", 63, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 171 }, -{ 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, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 357 }, -{ PROC_LINKS(open_panel_hsplit, 0), "open_panel_hsplit", 17, "Create a new panel by horizontally splitting the active panel.", 62, "C:\\4ed\\code\\4coder_default_framework.cpp", 43, 192 }, -{ PROC_LINKS(open_panel_vsplit, 0), "open_panel_vsplit", 17, "Create a new panel by vertically splitting the active panel.", 60, "C:\\4ed\\code\\4coder_default_framework.cpp", 43, 183 }, -{ PROC_LINKS(page_down, 0), "page_down", 9, "Scrolls the view down one view height and moves the cursor down one view height.", 80, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 288 }, -{ PROC_LINKS(page_up, 0), "page_up", 7, "Scrolls the view up one view height and moves the cursor up one view height.", 76, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 279 }, -{ PROC_LINKS(paste, 0), "paste", 5, "At the cursor, insert the text at the top of the clipboard.", 59, "C:\\4ed\\code\\4coder_clipboard.cpp", 35, 46 }, -{ 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, "C:\\4ed\\code\\4coder_clipboard.cpp", 35, 128 }, -{ 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, "C:\\4ed\\code\\4coder_clipboard.cpp", 35, 84 }, -{ 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, "C:\\4ed\\code\\4coder_clipboard.cpp", 35, 135 }, -{ 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, "C:\\4ed\\code\\4coder_scope_commands.cpp", 40, 481 }, -{ 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, "C:\\4ed\\code\\4coder_project_commands.cpp", 42, 497 }, -{ 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, "C:\\4ed\\code\\4coder_project_commands.cpp", 42, 522 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 896 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 916 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 934 }, -{ PROC_LINKS(redo, 0), "redo", 4, "Advances forewards through the undo history.", 44, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1280 }, -{ PROC_LINKS(reload_current_project, 0), "reload_current_project", 22, "If a project file has already been loaded, reloads the same file. Useful for when the project configuration is changed.", 120, "C:\\4ed\\code\\4coder_project_commands.cpp", 42, 465 }, -{ PROC_LINKS(remap_interactive, 0), "remap_interactive", 17, "Switch to a named key binding map.", 34, "C:\\4ed\\code\\4coder_default_framework.cpp", 43, 578 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1062 }, -{ 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, "C:\\4ed\\code\\4coder_experiments.cpp", 37, 385 }, -{ PROC_LINKS(reopen, 0), "reopen", 6, "Reopen the current buffer from the hard drive.", 46, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1316 }, -{ 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, "C:\\4ed\\code\\4coder_experiments.cpp", 37, 771 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 794 }, -{ PROC_LINKS(reverse_search, 0), "reverse_search", 14, "Begins an incremental search up through the current buffer for a user specified string.", 87, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 765 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 783 }, -{ PROC_LINKS(save, 0), "save", 4, "Saves the current buffer.", 25, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1322 }, -{ PROC_LINKS(save_all_dirty_buffers, 0), "save_all_dirty_buffers", 22, "Saves all buffers marked dirty (showing the '*' indicator).", 59, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 961 }, -{ PROC_LINKS(save_to_query, 0), "save_to_query", 13, "Queries the user for a name and saves the contents of the current buffer, altering the buffer's name too.", 105, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1022 }, -{ 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, "C:\\4ed\\code\\4coder_scope_commands.cpp", 40, 738 }, -{ PROC_LINKS(search, 0), "search", 6, "Begins an incremental search down through the current buffer for a user specified string.", 89, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 758 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 772 }, -{ PROC_LINKS(seek_alphanumeric_left, 0), "seek_alphanumeric_left", 22, "Seek left for boundary between alphanumeric characters and non-alphanumeric characters.", 87, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1227 }, -{ PROC_LINKS(seek_alphanumeric_or_camel_left, 0), "seek_alphanumeric_or_camel_left", 31, "Seek left for boundary between alphanumeric characters or camel case word and non-alphanumeric characters.", 106, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1239 }, -{ PROC_LINKS(seek_alphanumeric_or_camel_right, 0), "seek_alphanumeric_or_camel_right", 32, "Seek right for boundary between alphanumeric characters or camel case word and non-alphanumeric characters.", 107, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1233 }, -{ PROC_LINKS(seek_alphanumeric_right, 0), "seek_alphanumeric_right", 23, "Seek right for boundary between alphanumeric characters and non-alphanumeric characters.", 88, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1221 }, -{ PROC_LINKS(seek_beginning_of_line, 0), "seek_beginning_of_line", 22, "Seeks the cursor to the beginning of the visual line.", 53, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1126 }, -{ 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, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1108 }, -{ PROC_LINKS(seek_end_of_line, 0), "seek_end_of_line", 16, "Seeks the cursor to the end of the visual line.", 47, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1137 }, -{ 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, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1117 }, -{ PROC_LINKS(seek_token_left, 0), "seek_token_left", 15, "Seek left for the next beginning of a token.", 44, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1203 }, -{ PROC_LINKS(seek_token_right, 0), "seek_token_right", 16, "Seek right for the next end of a token.", 39, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1197 }, -{ PROC_LINKS(seek_white_or_token_left, 0), "seek_white_or_token_left", 24, "Seek left for the next end of a token or boundary between whitespace and non-whitespace.", 88, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1215 }, -{ PROC_LINKS(seek_white_or_token_right, 0), "seek_white_or_token_right", 25, "Seek right for the next end of a token or boundary between whitespace and non-whitespace.", 89, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1209 }, -{ PROC_LINKS(seek_whitespace_down, 0), "seek_whitespace_down", 20, "Seeks the cursor down to the next blank line.", 45, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1099 }, -{ PROC_LINKS(seek_whitespace_down_end_line, 0), "seek_whitespace_down_end_line", 29, "Seeks the cursor down to the next blank line and places it at the end of the line.", 82, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1158 }, -{ PROC_LINKS(seek_whitespace_left, 0), "seek_whitespace_left", 20, "Seek left for the next boundary between whitespace and non-whitespace.", 70, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1191 }, -{ PROC_LINKS(seek_whitespace_right, 0), "seek_whitespace_right", 21, "Seek right for the next boundary between whitespace and non-whitespace.", 71, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1185 }, -{ PROC_LINKS(seek_whitespace_up, 0), "seek_whitespace_up", 18, "Seeks the cursor up to the next blank line.", 43, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1090 }, -{ PROC_LINKS(seek_whitespace_up_end_line, 0), "seek_whitespace_up_end_line", 27, "Seeks the cursor up to the next blank line and places it at the end of the line.", 80, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1148 }, -{ 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, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 317 }, -{ PROC_LINKS(set_bindings_choose, 0), "set_bindings_choose", 19, "Remap keybindings using the 'choose' mapping rule.", 50, "C:\\4ed\\code\\4coder_remapping_commands.cpp", 44, 47 }, -{ PROC_LINKS(set_bindings_default, 0), "set_bindings_default", 20, "Remap keybindings using the 'default' mapping rule.", 51, "C:\\4ed\\code\\4coder_remapping_commands.cpp", 44, 61 }, -{ PROC_LINKS(set_bindings_mac_default, 0), "set_bindings_mac_default", 24, "Remap keybindings using the 'mac-default' mapping rule.", 55, "C:\\4ed\\code\\4coder_remapping_commands.cpp", 44, 75 }, -{ PROC_LINKS(set_mark, 0), "set_mark", 8, "Sets the mark to the current position of the cursor.", 52, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 86 }, -{ 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, "C:\\4ed\\code\\4coder_project_commands.cpp", 42, 569 }, -{ PROC_LINKS(show_filebar, 0), "show_filebar", 12, "Sets the current view to show it's filebar.", 43, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 464 }, -{ PROC_LINKS(show_scrollbar, 0), "show_scrollbar", 14, "Sets the current view to show it's scrollbar.", 45, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 450 }, -{ PROC_LINKS(snipe_token_or_word, 0), "snipe_token_or_word", 19, "Delete a single, whole token on or to the left of the cursor and post it to the clipboard.", 90, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1259 }, -{ PROC_LINKS(snipe_token_or_word_right, 0), "snipe_token_or_word_right", 25, "Delete a single, whole token on or to the right of the cursor and post it to the clipboard.", 91, "C:\\4ed\\code\\4coder_seek.cpp", 30, 1265 }, -{ PROC_LINKS(suppress_mouse, 0), "suppress_mouse", 14, "Hides the mouse and causes all mosue input (clicks, position, wheel) to be ignored.", 83, "C:\\4ed\\code\\4coder_default_framework.cpp", 43, 215 }, -{ 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, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 381 }, -{ PROC_LINKS(to_lowercase, 0), "to_lowercase", 12, "Converts all ascii text in the range between the cursor and the mark to lowercase.", 82, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 348 }, -{ PROC_LINKS(to_uppercase, 0), "to_uppercase", 12, "Converts all ascii text in the range between the cursor and the mark to uppercase.", 82, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 328 }, -{ PROC_LINKS(toggle_filebar, 0), "toggle_filebar", 14, "Toggles the visibility status of the current view's filebar.", 60, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 478 }, -{ 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, "C:\\4ed\\code\\4coder_default_framework.cpp", 43, 233 }, -{ PROC_LINKS(toggle_line_wrap, 0), "toggle_line_wrap", 16, "Toggles the current buffer's line wrapping status.", 50, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 487 }, -{ PROC_LINKS(toggle_mouse, 0), "toggle_mouse", 12, "Toggles the mouse suppression mode, see suppress_mouse and allow_mouse.", 71, "C:\\4ed\\code\\4coder_default_framework.cpp", 43, 227 }, -{ PROC_LINKS(toggle_show_whitespace, 0), "toggle_show_whitespace", 22, "Toggles the current buffer's whitespace visibility status.", 58, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 554 }, -{ PROC_LINKS(toggle_virtual_whitespace, 0), "toggle_virtual_whitespace", 25, "Toggles the current buffer's virtual whitespace status.", 55, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 543 }, -{ PROC_LINKS(undo, 0), "undo", 4, "Advances backwards through the undo history.", 44, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 1274 }, -{ 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, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 371 }, -{ 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, "C:\\4ed\\code\\4coder_search.cpp", 32, 826 }, -{ 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, "C:\\4ed\\code\\4coder_auto_indent.cpp", 37, 745 }, -{ PROC_LINKS(write_block, 0), "write_block", 11, "At the cursor, insert a block comment.", 38, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 234 }, -{ PROC_LINKS(write_character, 0), "write_character", 15, "Inserts whatever character was used to trigger this command.", 60, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 33 }, -{ 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, "C:\\4ed\\code\\4coder_experiments.cpp", 37, 707 }, -{ 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, "C:\\4ed\\code\\4coder_experiments.cpp", 37, 701 }, -{ 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, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 222 }, -{ 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, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 228 }, -{ 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, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 216 }, -{ PROC_LINKS(write_underscore, 0), "write_underscore", 16, "Inserts an underscore.", 22, "C:\\4ed\\code\\4coder_base_commands.cpp", 39, 42 }, -{ PROC_LINKS(write_zero_struct, 0), "write_zero_struct", 17, "At the cursor, insert a ' = {0};'.", 34, "C:\\4ed\\code\\4coder_default_include.cpp", 41, 240 }, +{ PROC_LINKS(allow_mouse, 0), "allow_mouse", 11, "Shows the mouse and causes all mouse input to be processed normally.", 68, "C:\\work\\4ed\\code\\4coder_default_framework.cpp", 49, 237 }, +{ PROC_LINKS(auto_tab_line_at_cursor, 0), "auto_tab_line_at_cursor", 23, "Auto-indents the line on which the cursor sits.", 47, "C:\\work\\4ed\\code\\4coder_auto_indent.cpp", 43, 722 }, +{ PROC_LINKS(auto_tab_range, 0), "auto_tab_range", 14, "Auto-indents the range between the cursor and the mark.", 55, "C:\\work\\4ed\\code\\4coder_auto_indent.cpp", 43, 733 }, +{ PROC_LINKS(auto_tab_whole_file, 0), "auto_tab_whole_file", 19, "Audo-indents the entire current buffer.", 39, "C:\\work\\4ed\\code\\4coder_auto_indent.cpp", 43, 712 }, +{ PROC_LINKS(backspace_char, 0), "backspace_char", 14, "Deletes the character to the left of the cursor.", 48, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 74 }, +{ PROC_LINKS(backspace_word, 0), "backspace_word", 14, "Delete characters between the cursor position and the first alphanumeric boundary to the left.", 94, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1247 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 440 }, +{ 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, "C:\\work\\4ed\\code\\4coder_build_commands.cpp", 46, 188 }, +{ 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, "C:\\work\\4ed\\code\\4coder_build_commands.cpp", 46, 154 }, +{ PROC_LINKS(center_view, 0), "center_view", 11, "Centers the view vertically on the line on which the cursor sits.", 65, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 127 }, +{ 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, "C:\\work\\4ed\\code\\4coder_default_framework.cpp", 49, 179 }, +{ 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, "C:\\work\\4ed\\code\\4coder_default_framework.cpp", 49, 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, "C:\\work\\4ed\\code\\4coder_build_commands.cpp", 46, 210 }, +{ PROC_LINKS(clean_all_lines, 0), "clean_all_lines", 15, "Removes trailing whitespace from all lines in the current buffer.", 65, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 375 }, +{ PROC_LINKS(click_set_cursor, 0), "click_set_cursor", 16, "Sets the cursor position to the mouse position.", 47, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 181 }, +{ PROC_LINKS(click_set_mark, 0), "click_set_mark", 14, "Sets the mark position to the mouse position.", 45, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 194 }, +{ 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, "C:\\work\\4ed\\code\\4coder_project_commands.cpp", 48, 403 }, +{ PROC_LINKS(close_build_panel, 0), "close_build_panel", 17, "If the special build panel is open, closes it.", 46, "C:\\work\\4ed\\code\\4coder_build_commands.cpp", 46, 204 }, +{ PROC_LINKS(close_panel, 0), "close_panel", 11, "Closes the currently active panel if it is not the only panel open.", 67, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 448 }, +{ PROC_LINKS(copy, 0), "copy", 4, "Copy the text in the range from the cursor to the mark onto the clipboard.", 74, "C:\\work\\4ed\\code\\4coder_clipboard.cpp", 41, 26 }, +{ PROC_LINKS(cursor_mark_swap, 0), "cursor_mark_swap", 16, "Swaps the position of the cursor and the mark.", 46, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 102 }, +{ PROC_LINKS(cut, 0), "cut", 3, "Cut the text in the range from the cursor to the mark onto the clipboard.", 73, "C:\\work\\4ed\\code\\4coder_clipboard.cpp", 41, 35 }, +{ PROC_LINKS(decrease_face_size, 0), "decrease_face_size", 18, "Decrease the size of the face used by the current buffer.", 57, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 538 }, +{ PROC_LINKS(decrease_line_wrap, 0), "decrease_line_wrap", 18, "Decrases the current buffer's width for line wrapping.", 54, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 515 }, +{ PROC_LINKS(delete_char, 0), "delete_char", 11, "Deletes the character to the right of the cursor.", 49, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 56 }, +{ 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, "C:\\work\\4ed\\code\\4coder_scope_commands.cpp", 46, 487 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1000 }, +{ PROC_LINKS(delete_line, 0), "delete_line", 11, "Delete the line the on which the cursor sits.", 45, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1250 }, +{ PROC_LINKS(delete_range, 0), "delete_range", 12, "Deletes the text in the range between the cursor and the mark.", 62, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 114 }, +{ PROC_LINKS(delete_word, 0), "delete_word", 11, "Delete characters between the cursor position and the first alphanumeric boundary to the right.", 95, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1253 }, +{ PROC_LINKS(duplicate_line, 0), "duplicate_line", 14, "Create a copy of the line on which the cursor sits.", 51, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1228 }, +{ PROC_LINKS(eol_dosify, 0), "eol_dosify", 10, "Puts the buffer in DOS line ending mode.", 40, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 568 }, +{ PROC_LINKS(eol_nixify, 0), "eol_nixify", 10, "Puts the buffer in NIX line ending mode.", 40, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 576 }, +{ 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, "C:\\work\\4ed\\code\\4coder_system_command.cpp", 46, 23 }, +{ PROC_LINKS(execute_arbitrary_command, 0), "execute_arbitrary_command", 25, "Execute a 'long form' command.", 30, "C:\\work\\4ed\\code\\4coder_long_command_switch.cpp", 51, 8 }, +{ 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, "C:\\work\\4ed\\code\\4coder_system_command.cpp", 46, 7 }, +{ PROC_LINKS(exit_4coder, 0), "exit_4coder", 11, "Attempts to close 4coder.", 25, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 584 }, +{ PROC_LINKS(goto_beginning_of_file, 0), "goto_beginning_of_file", 22, "Sets the cursor to the beginning of the file.", 45, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1168 }, +{ PROC_LINKS(goto_end_of_file, 0), "goto_end_of_file", 16, "Sets the cursor to the end of the file.", 39, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1175 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_direct.cpp", 43, 84 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_sticky.cpp", 43, 533 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_sticky.cpp", 43, 515 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_direct.cpp", 43, 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, "C:\\work\\4ed\\code\\4coder_jump_direct.cpp", 43, 29 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_sticky.cpp", 43, 365 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_sticky.cpp", 43, 337 }, +{ PROC_LINKS(goto_line, 0), "goto_line", 9, "Queries the user for a number, and jumps the cursor to the corresponding line.", 78, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 592 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_direct.cpp", 43, 48 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_direct.cpp", 43, 66 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_sticky.cpp", 43, 484 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_sticky.cpp", 43, 454 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_direct.cpp", 43, 57 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_direct.cpp", 43, 75 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_sticky.cpp", 43, 500 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_sticky.cpp", 43, 470 }, +{ PROC_LINKS(hide_filebar, 0), "hide_filebar", 12, "Sets the current view to hide it's filebar.", 43, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 478 }, +{ PROC_LINKS(hide_scrollbar, 0), "hide_scrollbar", 14, "Sets the current view to hide it's scrollbar.", 45, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 464 }, +{ PROC_LINKS(highlight_next_scope_absolute, 0), "highlight_next_scope_absolute", 29, "Finds the first scope started by '{' after the cursor and puts the cursor and mark on the '{' and '}'.", 102, "C:\\work\\4ed\\code\\4coder_scope_commands.cpp", 46, 363 }, +{ PROC_LINKS(highlight_prev_scope_absolute, 0), "highlight_prev_scope_absolute", 29, "Finds the first scope started by '{' before the cursor and puts the cursor and mark on the '{' and '}'.", 103, "C:\\work\\4ed\\code\\4coder_scope_commands.cpp", 46, 382 }, +{ PROC_LINKS(highlight_surrounding_scope, 0), "highlight_surrounding_scope", 27, "Finds the scope enclosed by '{' '}' surrounding the cursor and puts the cursor and mark on the '{' and '}'.", 107, "C:\\work\\4ed\\code\\4coder_scope_commands.cpp", 46, 341 }, +{ PROC_LINKS(if0_off, 0), "if0_off", 7, "Surround the range between the cursor and mark with an '#if 0' and an '#endif'", 78, "C:\\work\\4ed\\code\\4coder_combined_write_commands.cpp", 55, 83 }, +{ PROC_LINKS(increase_face_size, 0), "increase_face_size", 18, "Increase the size of the face used by the current buffer.", 57, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 526 }, +{ PROC_LINKS(increase_line_wrap, 0), "increase_line_wrap", 18, "Increases the current buffer's width for line wrapping.", 55, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 504 }, +{ PROC_LINKS(interactive_kill_buffer, 0), "interactive_kill_buffer", 23, "Interactively kill an open buffer.", 34, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1440 }, +{ PROC_LINKS(interactive_new, 0), "interactive_new", 15, "Interactively creates a new file.", 33, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1416 }, +{ PROC_LINKS(interactive_open, 0), "interactive_open", 16, "Interactively opens a file.", 27, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1422 }, +{ PROC_LINKS(interactive_open_or_new, 0), "interactive_open_or_new", 23, "Interactively opens or creates a new file.", 42, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1428 }, +{ PROC_LINKS(interactive_switch_buffer, 0), "interactive_switch_buffer", 25, "Interactively switch to an open buffer.", 39, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1434 }, +{ PROC_LINKS(kill_buffer, 0), "kill_buffer", 11, "Kills the current buffer.", 25, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1458 }, +{ PROC_LINKS(kill_rect, 0), "kill_rect", 9, "Delete characters in a rectangular region. Range testing is done by unwrapped-xy coordinates.", 93, "C:\\work\\4ed\\code\\4coder_experiments.cpp", 43, 29 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 142 }, +{ 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, "C:\\work\\4ed\\code\\4coder_function_list.cpp", 45, 318 }, +{ 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, "C:\\work\\4ed\\code\\4coder_search.cpp", 38, 741 }, +{ 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, "C:\\work\\4ed\\code\\4coder_search.cpp", 38, 753 }, +{ 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, "C:\\work\\4ed\\code\\4coder_search.cpp", 38, 765 }, +{ 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, "C:\\work\\4ed\\code\\4coder_search.cpp", 38, 771 }, +{ 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, "C:\\work\\4ed\\code\\4coder_search.cpp", 38, 777 }, +{ 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, "C:\\work\\4ed\\code\\4coder_search.cpp", 38, 783 }, +{ 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, "C:\\work\\4ed\\code\\4coder_search.cpp", 38, 789 }, +{ 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, "C:\\work\\4ed\\code\\4coder_search.cpp", 38, 800 }, +{ 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, "C:\\work\\4ed\\code\\4coder_search.cpp", 38, 747 }, +{ 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, "C:\\work\\4ed\\code\\4coder_search.cpp", 38, 759 }, +{ 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, "C:\\work\\4ed\\code\\4coder_project_commands.cpp", 48, 426 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1108 }, +{ PROC_LINKS(miblo_decrement_basic, 0), "miblo_decrement_basic", 21, "Decrement an integer under the cursor by one.", 45, "C:\\work\\4ed\\code\\4coder_miblo_numbers.cpp", 45, 110 }, +{ 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, "C:\\work\\4ed\\code\\4coder_miblo_numbers.cpp", 45, 383 }, +{ 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, "C:\\work\\4ed\\code\\4coder_miblo_numbers.cpp", 45, 395 }, +{ PROC_LINKS(miblo_increment_basic, 0), "miblo_increment_basic", 21, "Increment an integer under the cursor by one.", 45, "C:\\work\\4ed\\code\\4coder_miblo_numbers.cpp", 45, 94 }, +{ 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, "C:\\work\\4ed\\code\\4coder_miblo_numbers.cpp", 45, 377 }, +{ 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, "C:\\work\\4ed\\code\\4coder_miblo_numbers.cpp", 45, 389 }, +{ PROC_LINKS(move_down, 0), "move_down", 9, "Moves the cursor down one line.", 31, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 257 }, +{ PROC_LINKS(move_down_10, 0), "move_down_10", 12, "Moves the cursor down ten lines.", 32, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 269 }, +{ PROC_LINKS(move_down_textual, 0), "move_down_textual", 17, "Moves down to the next line of actual text, regardless of line wrapping.", 72, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 275 }, +{ PROC_LINKS(move_left, 0), "move_left", 9, "Moves the cursor one character to the left.", 43, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 306 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1205 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1141 }, +{ PROC_LINKS(move_right, 0), "move_right", 10, "Moves the cursor one character to the right.", 44, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 315 }, +{ PROC_LINKS(move_up, 0), "move_up", 7, "Moves the cursor up one line.", 29, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 251 }, +{ PROC_LINKS(move_up_10, 0), "move_up_10", 10, "Moves the cursor up ten lines.", 30, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 263 }, +{ 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, "C:\\work\\4ed\\code\\4coder_experiments.cpp", 43, 120 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_direct.cpp", 43, 101 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_direct.cpp", 43, 116 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_sticky.cpp", 43, 571 }, +{ 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, "C:\\work\\4ed\\code\\4coder_jump_sticky.cpp", 43, 556 }, +{ 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, "C:\\work\\4ed\\code\\4coder_project_commands.cpp", 48, 410 }, +{ PROC_LINKS(open_all_code_recursive, 0), "open_all_code_recursive", 23, "Works as open_all_code but also runs in all subdirectories.", 59, "C:\\work\\4ed\\code\\4coder_project_commands.cpp", 48, 417 }, +{ PROC_LINKS(open_color_tweaker, 0), "open_color_tweaker", 18, "Opens the 4coder colors and fonts selector menu.", 48, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1464 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1327 }, +{ PROC_LINKS(open_in_other, 0), "open_in_other", 13, "Switches to the next active panel and begins an open file dialogue.", 67, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1472 }, +{ PROC_LINKS(open_long_braces, 0), "open_long_braces", 16, "At the cursor, insert a '{' and '}' separated by a blank line.", 62, "C:\\work\\4ed\\code\\4coder_combined_write_commands.cpp", 55, 59 }, +{ 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, "C:\\work\\4ed\\code\\4coder_combined_write_commands.cpp", 55, 75 }, +{ PROC_LINKS(open_long_braces_semicolon, 0), "open_long_braces_semicolon", 26, "At the cursor, insert a '{' and '};' separated by a blank line.", 63, "C:\\work\\4ed\\code\\4coder_combined_write_commands.cpp", 55, 67 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1363 }, +{ PROC_LINKS(open_panel_hsplit, 0), "open_panel_hsplit", 17, "Create a new panel by horizontally splitting the active panel.", 62, "C:\\work\\4ed\\code\\4coder_default_framework.cpp", 49, 208 }, +{ PROC_LINKS(open_panel_vsplit, 0), "open_panel_vsplit", 17, "Create a new panel by vertically splitting the active panel.", 60, "C:\\work\\4ed\\code\\4coder_default_framework.cpp", 49, 199 }, +{ PROC_LINKS(page_down, 0), "page_down", 9, "Scrolls the view down one view height and moves the cursor down one view height.", 80, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 295 }, +{ PROC_LINKS(page_up, 0), "page_up", 7, "Scrolls the view up one view height and moves the cursor up one view height.", 76, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 286 }, +{ PROC_LINKS(paste, 0), "paste", 5, "At the cursor, insert the text at the top of the clipboard.", 59, "C:\\work\\4ed\\code\\4coder_clipboard.cpp", 41, 46 }, +{ 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, "C:\\work\\4ed\\code\\4coder_clipboard.cpp", 41, 128 }, +{ 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, "C:\\work\\4ed\\code\\4coder_clipboard.cpp", 41, 84 }, +{ 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, "C:\\work\\4ed\\code\\4coder_clipboard.cpp", 41, 135 }, +{ 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, "C:\\work\\4ed\\code\\4coder_scope_commands.cpp", 46, 481 }, +{ 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, "C:\\work\\4ed\\code\\4coder_project_commands.cpp", 48, 497 }, +{ 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, "C:\\work\\4ed\\code\\4coder_project_commands.cpp", 48, 522 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 900 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 920 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 938 }, +{ PROC_LINKS(redo, 0), "redo", 4, "Advances forewards through the undo history.", 44, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1410 }, +{ PROC_LINKS(reload_current_project, 0), "reload_current_project", 22, "If a project file has already been loaded, reloads the same file. Useful for when the project configuration is changed.", 120, "C:\\work\\4ed\\code\\4coder_project_commands.cpp", 48, 465 }, +{ PROC_LINKS(remap_interactive, 0), "remap_interactive", 17, "Switch to a named key binding map.", 34, "C:\\work\\4ed\\code\\4coder_default_framework.cpp", 49, 594 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1066 }, +{ 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, "C:\\work\\4ed\\code\\4coder_experiments.cpp", 43, 385 }, +{ PROC_LINKS(reopen, 0), "reopen", 6, "Reopen the current buffer from the hard drive.", 46, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1446 }, +{ 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, "C:\\work\\4ed\\code\\4coder_experiments.cpp", 43, 771 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 798 }, +{ PROC_LINKS(reverse_search, 0), "reverse_search", 14, "Begins an incremental search up through the current buffer for a user specified string.", 87, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 769 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 787 }, +{ PROC_LINKS(save, 0), "save", 4, "Saves the current buffer.", 25, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1452 }, +{ PROC_LINKS(save_all_dirty_buffers, 0), "save_all_dirty_buffers", 22, "Saves all buffers marked dirty (showing the '*' indicator).", 59, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 965 }, +{ PROC_LINKS(save_to_query, 0), "save_to_query", 13, "Queries the user for a name and saves the contents of the current buffer, altering the buffer's name too.", 105, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1026 }, +{ 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, "C:\\work\\4ed\\code\\4coder_scope_commands.cpp", 46, 738 }, +{ PROC_LINKS(search, 0), "search", 6, "Begins an incremental search down through the current buffer for a user specified string.", 89, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 762 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 776 }, +{ PROC_LINKS(seek_alphanumeric_left, 0), "seek_alphanumeric_left", 22, "Seek left for boundary between alphanumeric characters and non-alphanumeric characters.", 87, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1227 }, +{ PROC_LINKS(seek_alphanumeric_or_camel_left, 0), "seek_alphanumeric_or_camel_left", 31, "Seek left for boundary between alphanumeric characters or camel case word and non-alphanumeric characters.", 106, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1239 }, +{ PROC_LINKS(seek_alphanumeric_or_camel_right, 0), "seek_alphanumeric_or_camel_right", 32, "Seek right for boundary between alphanumeric characters or camel case word and non-alphanumeric characters.", 107, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1233 }, +{ PROC_LINKS(seek_alphanumeric_right, 0), "seek_alphanumeric_right", 23, "Seek right for boundary between alphanumeric characters and non-alphanumeric characters.", 88, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1221 }, +{ PROC_LINKS(seek_beginning_of_line, 0), "seek_beginning_of_line", 22, "Seeks the cursor to the beginning of the visual line.", 53, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1126 }, +{ 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, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1108 }, +{ PROC_LINKS(seek_end_of_line, 0), "seek_end_of_line", 16, "Seeks the cursor to the end of the visual line.", 47, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1137 }, +{ 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, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1117 }, +{ PROC_LINKS(seek_token_left, 0), "seek_token_left", 15, "Seek left for the next beginning of a token.", 44, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1203 }, +{ PROC_LINKS(seek_token_right, 0), "seek_token_right", 16, "Seek right for the next end of a token.", 39, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1197 }, +{ PROC_LINKS(seek_white_or_token_left, 0), "seek_white_or_token_left", 24, "Seek left for the next end of a token or boundary between whitespace and non-whitespace.", 88, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1215 }, +{ PROC_LINKS(seek_white_or_token_right, 0), "seek_white_or_token_right", 25, "Seek right for the next end of a token or boundary between whitespace and non-whitespace.", 89, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1209 }, +{ PROC_LINKS(seek_whitespace_down, 0), "seek_whitespace_down", 20, "Seeks the cursor down to the next blank line.", 45, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1099 }, +{ PROC_LINKS(seek_whitespace_down_end_line, 0), "seek_whitespace_down_end_line", 29, "Seeks the cursor down to the next blank line and places it at the end of the line.", 82, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1158 }, +{ PROC_LINKS(seek_whitespace_left, 0), "seek_whitespace_left", 20, "Seek left for the next boundary between whitespace and non-whitespace.", 70, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1191 }, +{ PROC_LINKS(seek_whitespace_right, 0), "seek_whitespace_right", 21, "Seek right for the next boundary between whitespace and non-whitespace.", 71, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1185 }, +{ PROC_LINKS(seek_whitespace_up, 0), "seek_whitespace_up", 18, "Seeks the cursor up to the next blank line.", 43, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1090 }, +{ PROC_LINKS(seek_whitespace_up_end_line, 0), "seek_whitespace_up_end_line", 27, "Seeks the cursor up to the next blank line and places it at the end of the line.", 80, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1148 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 324 }, +{ PROC_LINKS(set_bindings_choose, 0), "set_bindings_choose", 19, "Remap keybindings using the 'choose' mapping rule.", 50, "C:\\work\\4ed\\code\\4coder_remapping_commands.cpp", 50, 47 }, +{ PROC_LINKS(set_bindings_default, 0), "set_bindings_default", 20, "Remap keybindings using the 'default' mapping rule.", 51, "C:\\work\\4ed\\code\\4coder_remapping_commands.cpp", 50, 61 }, +{ PROC_LINKS(set_bindings_mac_default, 0), "set_bindings_mac_default", 24, "Remap keybindings using the 'mac-default' mapping rule.", 55, "C:\\work\\4ed\\code\\4coder_remapping_commands.cpp", 50, 75 }, +{ PROC_LINKS(set_mark, 0), "set_mark", 8, "Sets the mark to the current position of the cursor.", 52, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 93 }, +{ 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, "C:\\work\\4ed\\code\\4coder_project_commands.cpp", 48, 569 }, +{ PROC_LINKS(show_filebar, 0), "show_filebar", 12, "Sets the current view to show it's filebar.", 43, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 471 }, +{ PROC_LINKS(show_scrollbar, 0), "show_scrollbar", 14, "Sets the current view to show it's scrollbar.", 45, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 457 }, +{ PROC_LINKS(snipe_token_or_word, 0), "snipe_token_or_word", 19, "Delete a single, whole token on or to the left of the cursor and post it to the clipboard.", 90, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1259 }, +{ PROC_LINKS(snipe_token_or_word_right, 0), "snipe_token_or_word_right", 25, "Delete a single, whole token on or to the right of the cursor and post it to the clipboard.", 91, "C:\\work\\4ed\\code\\4coder_seek.cpp", 36, 1265 }, +{ PROC_LINKS(suppress_mouse, 0), "suppress_mouse", 14, "Hides the mouse and causes all mosue input (clicks, position, wheel) to be ignored.", 83, "C:\\work\\4ed\\code\\4coder_default_framework.cpp", 49, 231 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1387 }, +{ PROC_LINKS(to_lowercase, 0), "to_lowercase", 12, "Converts all ascii text in the range between the cursor and the mark to lowercase.", 82, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 355 }, +{ PROC_LINKS(to_uppercase, 0), "to_uppercase", 12, "Converts all ascii text in the range between the cursor and the mark to uppercase.", 82, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 335 }, +{ PROC_LINKS(toggle_filebar, 0), "toggle_filebar", 14, "Toggles the visibility status of the current view's filebar.", 60, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 485 }, +{ 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, "C:\\work\\4ed\\code\\4coder_default_framework.cpp", 49, 249 }, +{ PROC_LINKS(toggle_line_wrap, 0), "toggle_line_wrap", 16, "Toggles the current buffer's line wrapping status.", 50, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 494 }, +{ PROC_LINKS(toggle_mouse, 0), "toggle_mouse", 12, "Toggles the mouse suppression mode, see suppress_mouse and allow_mouse.", 71, "C:\\work\\4ed\\code\\4coder_default_framework.cpp", 49, 243 }, +{ PROC_LINKS(toggle_show_whitespace, 0), "toggle_show_whitespace", 22, "Toggles the current buffer's whitespace visibility status.", 58, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 561 }, +{ PROC_LINKS(toggle_virtual_whitespace, 0), "toggle_virtual_whitespace", 25, "Toggles the current buffer's virtual whitespace status.", 55, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 550 }, +{ PROC_LINKS(undo, 0), "undo", 4, "Advances backwards through the undo history.", 44, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1404 }, +{ 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, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1377 }, +{ 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, "C:\\work\\4ed\\code\\4coder_search.cpp", 38, 820 }, +{ 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, "C:\\work\\4ed\\code\\4coder_auto_indent.cpp", 43, 745 }, +{ PROC_LINKS(write_block, 0), "write_block", 11, "At the cursor, insert a block comment.", 38, "C:\\work\\4ed\\code\\4coder_combined_write_commands.cpp", 55, 107 }, +{ PROC_LINKS(write_character, 0), "write_character", 15, "Inserts whatever character was used to trigger this command.", 60, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 33 }, +{ 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, "C:\\work\\4ed\\code\\4coder_experiments.cpp", 43, 707 }, +{ 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, "C:\\work\\4ed\\code\\4coder_experiments.cpp", 43, 701 }, +{ 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, "C:\\work\\4ed\\code\\4coder_combined_write_commands.cpp", 55, 95 }, +{ 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, "C:\\work\\4ed\\code\\4coder_combined_write_commands.cpp", 55, 101 }, +{ 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, "C:\\work\\4ed\\code\\4coder_combined_write_commands.cpp", 55, 89 }, +{ PROC_LINKS(write_underscore, 0), "write_underscore", 16, "Inserts an underscore.", 22, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 49 }, +{ PROC_LINKS(write_zero_struct, 0), "write_zero_struct", 17, "At the cursor, insert a ' = {0};'.", 34, "C:\\work\\4ed\\code\\4coder_combined_write_commands.cpp", 55, 113 }, }; static int32_t fcoder_metacmd_ID_allow_mouse = 0; static int32_t fcoder_metacmd_ID_auto_tab_line_at_cursor = 1; diff --git a/4coder_generated/remapping.h b/4coder_generated/remapping.h index 07f40c19..fc4d1d74 100644 --- a/4coder_generated/remapping.h +++ b/4coder_generated/remapping.h @@ -28,7 +28,6 @@ bind(context, 'W', MDFR_ALT, show_scrollbar); bind(context, 'w', MDFR_ALT, hide_scrollbar); bind(context, 'b', MDFR_ALT, toggle_filebar); bind(context, '@', MDFR_ALT, toggle_mouse); -bind(context, key_page_up, MDFR_CTRL, toggle_fullscreen); bind(context, 'E', MDFR_ALT, exit_4coder); bind(context, '+', MDFR_CTRL, increase_face_size); bind(context, '-', MDFR_CTRL, decrease_face_size); @@ -90,7 +89,6 @@ bind(context, 'F', MDFR_CTRL, list_all_locations); bind(context, 'F', MDFR_ALT, list_all_substring_locations_case_insensitive); bind(context, 'g', MDFR_CTRL, goto_line); bind(context, 'G', MDFR_CTRL, list_all_locations_of_selection); -bind(context, 'j', MDFR_CTRL, to_lowercase); bind(context, 'K', MDFR_CTRL, kill_buffer); bind(context, 'l', MDFR_CTRL, toggle_line_wrap); bind(context, 'L', MDFR_CTRL, duplicate_line); @@ -104,7 +102,6 @@ bind(context, 's', MDFR_CTRL, save); bind(context, 's', MDFR_ALT, save_to_query); bind(context, 't', MDFR_CTRL, search_identifier); bind(context, 'T', MDFR_CTRL, list_all_locations_of_identifier); -bind(context, 'u', MDFR_CTRL, to_uppercase); bind(context, 'v', MDFR_CTRL, paste_and_indent); bind(context, 'v', MDFR_ALT, toggle_virtual_whitespace); bind(context, 'V', MDFR_CTRL, paste_next_and_indent); @@ -184,7 +181,6 @@ bind(context, 'W', MDFR_CTRL, show_scrollbar); bind(context, 'w', MDFR_CTRL, hide_scrollbar); bind(context, 'b', MDFR_CTRL, toggle_filebar); bind(context, '@', MDFR_CTRL, toggle_mouse); -bind(context, key_page_up, MDFR_CMND, toggle_fullscreen); bind(context, 'E', MDFR_CTRL, exit_4coder); bind(context, '+', MDFR_CTRL, increase_face_size); bind(context, '-', MDFR_CTRL, decrease_face_size); @@ -245,7 +241,6 @@ bind(context, 'F', MDFR_CMND, list_all_locations); bind(context, 'F', MDFR_CTRL, list_all_substring_locations_case_insensitive); bind(context, 'g', MDFR_CMND, goto_line); bind(context, 'G', MDFR_CMND, list_all_locations_of_selection); -bind(context, 'j', MDFR_CMND, to_lowercase); bind(context, 'K', MDFR_CMND, kill_buffer); bind(context, 'l', MDFR_CMND, toggle_line_wrap); bind(context, 'L', MDFR_CMND, duplicate_line); @@ -258,7 +253,6 @@ bind(context, 's', MDFR_CMND, save); bind(context, 's', MDFR_CTRL, save_to_query); bind(context, 't', MDFR_CMND, search_identifier); bind(context, 'T', MDFR_CMND, list_all_locations_of_identifier); -bind(context, 'u', MDFR_CMND, to_uppercase); bind(context, 'v', MDFR_CMND, paste_and_indent); bind(context, 'v', MDFR_CTRL, toggle_virtual_whitespace); bind(context, 'V', MDFR_CMND, paste_next_and_indent); @@ -342,7 +336,7 @@ Meta_Sub_Map *sub_maps; int32_t sub_map_count; LINK_PROCS(void (*fill_keys_proc)(Bind_Helper *context);) }; -static Meta_Key_Bind fcoder_binds_for_default_mapid_global[47] = { +static Meta_Key_Bind fcoder_binds_for_default_mapid_global[46] = { {0, 112, 1, "open_panel_vsplit", 17, LINK_PROCS(open_panel_vsplit)}, {0, 95, 1, "open_panel_hsplit", 17, LINK_PROCS(open_panel_hsplit)}, {0, 80, 1, "close_panel", 11, LINK_PROCS(close_panel)}, @@ -370,7 +364,6 @@ static Meta_Key_Bind fcoder_binds_for_default_mapid_global[47] = { {0, 119, 2, "hide_scrollbar", 14, LINK_PROCS(hide_scrollbar)}, {0, 98, 2, "toggle_filebar", 14, LINK_PROCS(toggle_filebar)}, {0, 64, 2, "toggle_mouse", 12, LINK_PROCS(toggle_mouse)}, -{0, 55305, 1, "toggle_fullscreen", 17, LINK_PROCS(toggle_fullscreen)}, {0, 69, 2, "exit_4coder", 11, LINK_PROCS(exit_4coder)}, {0, 43, 1, "increase_face_size", 18, LINK_PROCS(increase_face_size)}, {0, 45, 1, "decrease_face_size", 18, LINK_PROCS(decrease_face_size)}, @@ -391,7 +384,7 @@ static Meta_Key_Bind fcoder_binds_for_default_mapid_global[47] = { {0, 55326, 0, "project_fkey_command", 20, LINK_PROCS(project_fkey_command)}, {0, 55327, 0, "project_fkey_command", 20, LINK_PROCS(project_fkey_command)}, }; -static Meta_Key_Bind fcoder_binds_for_default_mapid_file[68] = { +static Meta_Key_Bind fcoder_binds_for_default_mapid_file[66] = { {1, 0, 0, "write_character", 15, LINK_PROCS(write_character)}, {0, 55308, 0, "click_set_cursor", 16, LINK_PROCS(click_set_cursor)}, {0, 55310, 0, "click_set_mark", 14, LINK_PROCS(click_set_mark)}, @@ -432,7 +425,6 @@ static Meta_Key_Bind fcoder_binds_for_default_mapid_file[68] = { {0, 70, 2, "list_all_substring_locations_case_insensitive", 45, LINK_PROCS(list_all_substring_locations_case_insensitive)}, {0, 103, 1, "goto_line", 9, LINK_PROCS(goto_line)}, {0, 71, 1, "list_all_locations_of_selection", 31, LINK_PROCS(list_all_locations_of_selection)}, -{0, 106, 1, "to_lowercase", 12, LINK_PROCS(to_lowercase)}, {0, 75, 1, "kill_buffer", 11, LINK_PROCS(kill_buffer)}, {0, 108, 1, "toggle_line_wrap", 16, LINK_PROCS(toggle_line_wrap)}, {0, 76, 1, "duplicate_line", 14, LINK_PROCS(duplicate_line)}, @@ -446,7 +438,6 @@ static Meta_Key_Bind fcoder_binds_for_default_mapid_file[68] = { {0, 115, 2, "save_to_query", 13, LINK_PROCS(save_to_query)}, {0, 116, 1, "search_identifier", 17, LINK_PROCS(search_identifier)}, {0, 84, 1, "list_all_locations_of_identifier", 32, LINK_PROCS(list_all_locations_of_identifier)}, -{0, 117, 1, "to_uppercase", 12, LINK_PROCS(to_uppercase)}, {0, 118, 1, "paste_and_indent", 16, LINK_PROCS(paste_and_indent)}, {0, 118, 2, "toggle_virtual_whitespace", 25, LINK_PROCS(toggle_virtual_whitespace)}, {0, 86, 1, "paste_next_and_indent", 21, LINK_PROCS(paste_next_and_indent)}, @@ -496,11 +487,11 @@ static Meta_Key_Bind fcoder_binds_for_default_default_code_map[32] = { {0, 73, 1, "list_all_functions_current_buffer", 33, LINK_PROCS(list_all_functions_current_buffer)}, }; static Meta_Sub_Map fcoder_submaps_for_default[3] = { -{"mapid_global", 12, "The following bindings apply in all situations.", 47, 0, 0, fcoder_binds_for_default_mapid_global, 47}, -{"mapid_file", 10, "The following bindings apply in general text files and most apply in code files, but some are overriden by other commands specific to code files.", 145, 0, 0, fcoder_binds_for_default_mapid_file, 68}, +{"mapid_global", 12, "The following bindings apply in all situations.", 47, 0, 0, fcoder_binds_for_default_mapid_global, 46}, +{"mapid_file", 10, "The following bindings apply in general text files and most apply in code files, but some are overriden by other commands specific to code files.", 145, 0, 0, fcoder_binds_for_default_mapid_file, 66}, {"default_code_map", 16, "The following commands only apply in files where the lexer (syntax highlighting) is turned on.", 94, "mapid_file", 10, fcoder_binds_for_default_default_code_map, 32}, }; -static Meta_Key_Bind fcoder_binds_for_mac_default_mapid_global[47] = { +static Meta_Key_Bind fcoder_binds_for_mac_default_mapid_global[46] = { {0, 112, 4, "open_panel_vsplit", 17, LINK_PROCS(open_panel_vsplit)}, {0, 95, 4, "open_panel_hsplit", 17, LINK_PROCS(open_panel_hsplit)}, {0, 80, 4, "close_panel", 11, LINK_PROCS(close_panel)}, @@ -528,7 +519,6 @@ static Meta_Key_Bind fcoder_binds_for_mac_default_mapid_global[47] = { {0, 119, 1, "hide_scrollbar", 14, LINK_PROCS(hide_scrollbar)}, {0, 98, 1, "toggle_filebar", 14, LINK_PROCS(toggle_filebar)}, {0, 64, 1, "toggle_mouse", 12, LINK_PROCS(toggle_mouse)}, -{0, 55305, 4, "toggle_fullscreen", 17, LINK_PROCS(toggle_fullscreen)}, {0, 69, 1, "exit_4coder", 11, LINK_PROCS(exit_4coder)}, {0, 43, 1, "increase_face_size", 18, LINK_PROCS(increase_face_size)}, {0, 45, 1, "decrease_face_size", 18, LINK_PROCS(decrease_face_size)}, @@ -549,7 +539,7 @@ static Meta_Key_Bind fcoder_binds_for_mac_default_mapid_global[47] = { {0, 55326, 0, "project_fkey_command", 20, LINK_PROCS(project_fkey_command)}, {0, 55327, 0, "project_fkey_command", 20, LINK_PROCS(project_fkey_command)}, }; -static Meta_Key_Bind fcoder_binds_for_mac_default_mapid_file[66] = { +static Meta_Key_Bind fcoder_binds_for_mac_default_mapid_file[64] = { {1, 0, 0, "write_character", 15, LINK_PROCS(write_character)}, {1, 0, 2, "write_character", 15, LINK_PROCS(write_character)}, {0, 55308, 0, "click_set_cursor", 16, LINK_PROCS(click_set_cursor)}, @@ -589,7 +579,6 @@ static Meta_Key_Bind fcoder_binds_for_mac_default_mapid_file[66] = { {0, 70, 1, "list_all_substring_locations_case_insensitive", 45, LINK_PROCS(list_all_substring_locations_case_insensitive)}, {0, 103, 4, "goto_line", 9, LINK_PROCS(goto_line)}, {0, 71, 4, "list_all_locations_of_selection", 31, LINK_PROCS(list_all_locations_of_selection)}, -{0, 106, 4, "to_lowercase", 12, LINK_PROCS(to_lowercase)}, {0, 75, 4, "kill_buffer", 11, LINK_PROCS(kill_buffer)}, {0, 108, 4, "toggle_line_wrap", 16, LINK_PROCS(toggle_line_wrap)}, {0, 76, 4, "duplicate_line", 14, LINK_PROCS(duplicate_line)}, @@ -602,7 +591,6 @@ static Meta_Key_Bind fcoder_binds_for_mac_default_mapid_file[66] = { {0, 115, 1, "save_to_query", 13, LINK_PROCS(save_to_query)}, {0, 116, 4, "search_identifier", 17, LINK_PROCS(search_identifier)}, {0, 84, 4, "list_all_locations_of_identifier", 32, LINK_PROCS(list_all_locations_of_identifier)}, -{0, 117, 4, "to_uppercase", 12, LINK_PROCS(to_uppercase)}, {0, 118, 4, "paste_and_indent", 16, LINK_PROCS(paste_and_indent)}, {0, 118, 1, "toggle_virtual_whitespace", 25, LINK_PROCS(toggle_virtual_whitespace)}, {0, 86, 4, "paste_next_and_indent", 21, LINK_PROCS(paste_next_and_indent)}, @@ -652,8 +640,8 @@ static Meta_Key_Bind fcoder_binds_for_mac_default_default_code_map[32] = { {0, 73, 4, "list_all_functions_current_buffer", 33, LINK_PROCS(list_all_functions_current_buffer)}, }; static Meta_Sub_Map fcoder_submaps_for_mac_default[3] = { -{"mapid_global", 12, "The following bindings apply in all situations.", 47, 0, 0, fcoder_binds_for_mac_default_mapid_global, 47}, -{"mapid_file", 10, "The following bindings apply in general text files and most apply in code files, but some are overriden by other commands specific to code files.", 145, 0, 0, fcoder_binds_for_mac_default_mapid_file, 66}, +{"mapid_global", 12, "The following bindings apply in all situations.", 47, 0, 0, fcoder_binds_for_mac_default_mapid_global, 46}, +{"mapid_file", 10, "The following bindings apply in general text files and most apply in code files, but some are overriden by other commands specific to code files.", 145, 0, 0, fcoder_binds_for_mac_default_mapid_file, 64}, {"default_code_map", 16, "The following commands only apply in files where the lexer (syntax highlighting) is turned on.", 94, "mapid_file", 10, fcoder_binds_for_mac_default_default_code_map, 32}, }; static Meta_Mapping fcoder_meta_maps[2] = { diff --git a/4coder_helper.cpp b/4coder_helper.cpp index 6475189c..16e9fe99 100644 --- a/4coder_helper.cpp +++ b/4coder_helper.cpp @@ -385,16 +385,14 @@ query_user_general(Application_Links *app, Query_Bar *bar, bool32 force_number){ return(success); } -static int32_t +static bool32 query_user_string(Application_Links *app, Query_Bar *bar){ - int32_t success = query_user_general(app, bar, false); - return(success); + return(query_user_general(app, bar, false)); } -static int32_t +static bool32 query_user_number(Application_Links *app, Query_Bar *bar){ - int32_t success = query_user_general(app, bar, true); - return(success); + return(query_user_general(app, bar, true)); } static void @@ -525,7 +523,8 @@ get_first_view_with_buffer(Application_Links *app, int32_t buffer_id){ } static bool32 -open_file(Application_Links *app, Buffer_Summary *buffer_out, char *filename, int32_t filename_len, bool32 background, bool32 never_new){ +open_file(Application_Links *app, Buffer_Summary *buffer_out, + char *filename, int32_t filename_len, bool32 background, bool32 never_new){ bool32 result = false; Buffer_Summary buffer = get_buffer_by_name(app, filename, filename_len, AccessProtected|AccessHidden); @@ -545,7 +544,7 @@ open_file(Application_Links *app, Buffer_Summary *buffer_out, char *filename, in } buffer = create_buffer(app, filename, filename_len, flags); if (buffer.exists){ - if (buffer_out){ + if (buffer_out != 0){ *buffer_out = buffer; } result = true; @@ -573,7 +572,8 @@ buffer_identifier_to_id(Application_Links *app, Buffer_Identifier identifier){ } static bool32 -view_open_file(Application_Links *app, View_Summary *view, char *filename, int32_t filename_len, bool32 never_new){ +view_open_file(Application_Links *app, View_Summary *view, + char *filename, int32_t filename_len, bool32 never_new){ bool32 result = false; if (view != 0){ @@ -972,6 +972,153 @@ backward_stream_tokens(Stream_Tokens *stream){ return(result); } +static String +get_query_string(Application_Links *app, char *query_str, char *string_space, int32_t space_size){ + Query_Bar bar; + bar.prompt = make_string_slowly(query_str); + bar.string = make_string_cap(string_space, 0, space_size); + if (!query_user_string(app, &bar)){ + bar.string.size = 0; + } + return(bar.string); +} + +static String +get_string_in_view_range(Application_Links *app, Partition *arena, View_Summary *view){ + String str = {0}; + Buffer_Summary buffer = get_buffer(app, view->buffer_id, AccessProtected); + if (!buffer.exists) return(str); + Range range = get_view_range(view); + int32_t query_length = range.max - range.min; + if (query_length != 0){ + char *query_space = push_array(arena, char, query_length); + if (buffer_read_range(app, &buffer, range.min, range.max, query_space)){ + str = make_string(query_space, query_length); + } + } + return(str); +} + +static String +get_token_or_word_under_pos(Application_Links *app, Buffer_Summary *buffer, int32_t pos, char *space, int32_t capacity){ + String result = {0}; + Cpp_Get_Token_Result get_result = {0}; + bool32 success = buffer_get_token_index(app, buffer, pos, &get_result); + if (success && !get_result.in_whitespace){ + int32_t size = get_result.token_end - get_result.token_start; + if (size > 0 && size <= capacity){ + success = buffer_read_range(app, buffer, get_result.token_start, get_result.token_end, space); + if (success){ + result = make_string(space, size); + } + } + } + return(result); +} + +static String +build_string(Partition *part, char *s0, char *s1, char *s2){ + String sr = {0}; + sr.memory_size = str_size(s0) + str_size(s1) + str_size(s2); + sr.str = push_array(part, char, sr.memory_size); + if (sr.str != 0){ + append(&sr, s0); + append(&sr, s1); + append(&sr, s2); + } + return(sr); +} + +static String +build_string(Partition *part, char *s0, char *s1, String s2){ + String sr = {0}; + sr.memory_size = str_size(s0) + str_size(s1) + s2.size; + sr.str = push_array(part, char, sr.memory_size); + if (sr.str != 0){ + append(&sr, s0); + append(&sr, s1); + append(&sr, s2); + } + return(sr); +} + +static String +build_string(Partition *part, char *s0, String s1, char *s2){ + String sr = {0}; + sr.memory_size = str_size(s0) + s1.size + str_size(s2); + sr.str = push_array(part, char, sr.memory_size); + if (sr.str != 0){ + append(&sr, s0); + append(&sr, s1); + append(&sr, s2); + } + return(sr); +} + +static String +build_string(Partition *part, char *s0, String s1, String s2){ + String sr = {0}; + sr.memory_size = str_size(s0) + s1.size + s2.size; + sr.str = push_array(part, char, sr.memory_size); + if (sr.str != 0){ + append(&sr, s0); + append(&sr, s1); + append(&sr, s2); + } + return(sr); +} + +static String +build_string(Partition *part, String s0, char *s1, char *s2){ + String sr = {0}; + sr.memory_size = s0.size + str_size(s1) + str_size(s2); + sr.str = push_array(part, char, sr.memory_size); + if (sr.str != 0){ + append(&sr, s0); + append(&sr, s1); + append(&sr, s2); + } + return(sr); +} + +static String +build_string(Partition *part, String s0, char *s1, String s2){ + String sr = {0}; + sr.memory_size = s0.size + str_size(s1) + s2.size; + sr.str = push_array(part, char, sr.memory_size); + if (sr.str != 0){ + append(&sr, s0); + append(&sr, s1); + append(&sr, s2); + } + return(sr); +} + +static String +build_string(Partition *part, String s0, String s1, char *s2){ + String sr = {0}; + sr.memory_size = s0.size + s1.size + str_size(s2); + sr.str = push_array(part, char, sr.memory_size); + if (sr.str != 0){ + append(&sr, s0); + append(&sr, s1); + append(&sr, s2); + } + return(sr); +} + +static String +build_string(Partition *part, String s0, String s1, String s2){ + String sr = {0}; + sr.memory_size = s0.size + s1.size + s2.size; + sr.str = push_array(part, char, sr.memory_size); + if (sr.str != 0){ + append(&sr, s0); + append(&sr, s1); + append(&sr, s2); + } + return(sr); +} // BOTTOM diff --git a/4coder_long_command_switch.cpp b/4coder_long_command_switch.cpp new file mode 100644 index 00000000..946e01cf --- /dev/null +++ b/4coder_long_command_switch.cpp @@ -0,0 +1,62 @@ +/* +4coder_long_command_switch.cpp - Implementation of a command for executing uncommon commands +by inputting key words. +*/ + +// TOP + +CUSTOM_COMMAND_SIG(execute_arbitrary_command) +CUSTOM_DOC("Execute a 'long form' command.") +{ + Query_Bar bar = {0}; + char space[1024]; + bar.prompt = make_lit_string("Command: "); + bar.string = make_fixed_width_string(space); + if (!query_user_string(app, &bar)) return; + end_query_bar(app, &bar, 0); + + if (match(bar.string, make_lit_string("toggle fullscreen"))){ + toggle_fullscreen(app); + } + else if (match(bar.string, make_lit_string("load project"))){ + load_project(app); + } + else if (match(bar.string, make_lit_string("open all code"))){ + open_all_code(app); + } + else if (match(bar.string, make_lit_string("open all code recursive"))){ + open_all_code_recursive(app); + } + else if(match(bar.string, make_lit_string("close all code"))){ + close_all_code(app); + } + else if (match(bar.string, make_lit_string("dos lines")) || + match(bar.string, make_lit_string("dosify"))){ + eol_dosify(app); + } + else if (match(bar.string, make_lit_string("nix lines")) || + match(bar.string, make_lit_string("nixify"))){ + eol_nixify(app); + } + else if (match(bar.string, make_lit_string("remap"))){ + remap_interactive(app); + } + else if (match(bar.string, make_lit_string("new project"))){ + setup_new_project(app); + } + else if (match(bar.string, make_lit_string("delete file"))){ + delete_file_query(app); + } + else if (match(bar.string, make_lit_string("rename file"))){ + rename_file_query(app); + } + else if (match(bar.string, make_lit_string("mkdir"))){ + make_directory_query(app); + } + else{ + print_message(app, literal("unrecognized command\n")); + } +} + +// BOTTOM + diff --git a/4coder_search.cpp b/4coder_search.cpp index 2e19d54b..c718b62e 100644 --- a/4coder_search.cpp +++ b/4coder_search.cpp @@ -560,9 +560,7 @@ initialize_generic_search_all_buffers(Application_Links *app, General_Memory *ge set->count = j; } -// -// List all Locations -// +//////////////////////////////// static void buffered_print_flush(Application_Links *app, Partition *part, Temp_Memory temp, Buffer_Summary *output_buffer){ @@ -615,7 +613,8 @@ buffered_print_match_jump_line(Application_Links *app, Partition *part, Temp_Mem } static void -list_all_locations_parameters(Application_Links *app, General_Memory *general, Partition *part, String *strings, int32_t count, Search_Range_Flag match_flags){ +list__parameters(Application_Links *app, General_Memory *general, Partition *scratch, + String *strings, int32_t count, Search_Range_Flag match_flags){ // Open the search buffer String search_name = make_lit_string("*search*"); Buffer_Summary search_buffer = get_buffer_by_name(app, search_name.str, search_name.size, AccessAll); @@ -636,19 +635,19 @@ list_all_locations_parameters(Application_Links *app, General_Memory *general, P initialize_generic_search_all_buffers(app, general, strings, count, match_flags, &search_buffer.buffer_id, 1, &set, &iter); // List all locations into search buffer - Temp_Memory all_temp = begin_temp_memory(part); - Partition line_part = partition_sub_part(part, (4 << 10)); - Temp_Memory temp = begin_temp_memory(part); + Temp_Memory all_temp = begin_temp_memory(scratch); + Partition line_part = partition_sub_part(scratch, (4 << 10)); + Temp_Memory temp = begin_temp_memory(scratch); for (Search_Match match = search_next_match(app, &set, &iter); match.found_match; match = search_next_match(app, &set, &iter)){ Partial_Cursor word_pos = {0}; if (buffer_compute_cursor(app, &match.buffer, seek_pos(match.start), &word_pos)){ - buffered_print_match_jump_line(app, part, temp, &line_part, &search_buffer, &match.buffer, word_pos); + buffered_print_match_jump_line(app, scratch, temp, &line_part, &search_buffer, &match.buffer, word_pos); } } - buffered_print_flush(app, part, temp, &search_buffer); + buffered_print_flush(app, scratch, temp, &search_buffer); end_temp_memory(all_temp); // Lock this *search* as the jump buffer @@ -657,163 +656,158 @@ list_all_locations_parameters(Application_Links *app, General_Memory *general, P lock_jump_buffer(search_name.str, search_name.size); } - -// -// List Commands -// +static void +list_single__parameters(Application_Links *app, General_Memory *general, Partition *scratch, + String str, bool32 substrings, bool32 case_insensitive){ + Search_Range_Flag flags = 0; + if (substrings){ + flags |= SearchFlag_MatchSubstring; + } + else{ + flags |= SearchFlag_MatchWholeWord; + } + if (case_insensitive){ + flags |= SearchFlag_CaseInsensitive; + } + list__parameters(app, general, scratch, &str, 1, flags); +} static void -get_search_all_string(Application_Links *app, Query_Bar *bar, char *string_space, int32_t space_size){ - bar->prompt = make_lit_string("List Locations For: "); - bar->string = make_string_cap(string_space, 0, space_size); - - if (!query_user_string(app, bar)){ - bar->string.size = 0; +list_query__parameters(Application_Links *app, General_Memory *general, Partition *scratch, + bool32 substrings, bool32 case_insensitive){ + char space[1024]; + String str = get_query_string(app, "List Locations For: ", space, sizeof(space)); + if (str.str != 0){ + change_active_panel(app); + list_single__parameters(app, general, scratch, str, substrings, case_insensitive); } } +static void +list_identifier__parameters(Application_Links *app, General_Memory *general, Partition *scratch, + bool32 substrings, bool32 case_insensitive){ + View_Summary view = get_active_view(app, AccessProtected); + Buffer_Summary buffer = get_buffer(app, view.buffer_id, AccessProtected); + if (!buffer.exists) return; + char space[512]; + String str = get_token_or_word_under_pos(app, &buffer, view.cursor.pos, space, sizeof(space)); + if (str.str != 0){ + change_active_panel(app); + list_single__parameters(app, general, scratch, str, substrings, case_insensitive); + } +} + +static void +list_selected_range__parameters(Application_Links *app, General_Memory *general, Partition *scratch, + bool32 substrings, bool32 case_insensitive){ + View_Summary view = get_active_view(app, AccessProtected); + Temp_Memory temp = begin_temp_memory(scratch); + String str = get_string_in_view_range(app, scratch, &view); + if (str.str != 0){ + change_active_panel(app); + list_single__parameters(app, general, scratch, str, substrings, case_insensitive); + } + end_temp_memory(temp); +} + +static void +list_type_definition__parameters(Application_Links *app, General_Memory *general, Partition *scratch, + String str){ + Temp_Memory temp = begin_temp_memory(scratch); + + String match_strings[6]; + match_strings[0] = build_string(scratch, "struct ", str, "{"); + match_strings[1] = build_string(scratch, "struct ", str, "\n{"); + match_strings[2] = build_string(scratch, "union " , str, "{"); + match_strings[3] = build_string(scratch, "union " , str, "\n{"); + match_strings[4] = build_string(scratch, "enum " , str, "{"); + match_strings[5] = build_string(scratch, "enum " , str, "\n{"); + + list__parameters(app, general, scratch, + match_strings, ArrayCount(match_strings), 0); + + end_temp_memory(temp); + +#if 0 + Buffer_Summary buffer = get_buffer_by_name(app, literal("*search*"), AccessAll); + if (buffer.line_count == 2){ + goto_first_jump_same_panel_sticky(app); + } +#endif +} + +//////////////////////////////// + CUSTOM_COMMAND_SIG(list_all_locations) CUSTOM_DOC("Queries the user for a string and lists all exact case-sensitive matches found in all open buffers.") { - char string_space[1024]; - Query_Bar bar; - get_search_all_string(app, &bar, string_space, sizeof(string_space)); - if (bar.string.size == 0) return; - list_all_locations_parameters(app, &global_general, &global_part, &bar.string, 1, SearchFlag_MatchWholeWord); + list_query__parameters(app, &global_general, &global_part, false, false); } CUSTOM_COMMAND_SIG(list_all_substring_locations) CUSTOM_DOC("Queries the user for a string and lists all case-sensitive substring matches found in all open buffers.") { - char string_space[1024]; - Query_Bar bar; - get_search_all_string(app, &bar, string_space, sizeof(string_space)); - if (bar.string.size == 0) return; - list_all_locations_parameters(app, &global_general, &global_part, &bar.string, 1, SearchFlag_MatchSubstring); -} + list_query__parameters(app, &global_general, &global_part, true, false); + } CUSTOM_COMMAND_SIG(list_all_locations_case_insensitive) CUSTOM_DOC("Queries the user for a string and lists all exact case-insensitive matches found in all open buffers.") { - char string_space[1024]; - Query_Bar bar; - get_search_all_string(app, &bar, string_space, sizeof(string_space)); - if (bar.string.size == 0) return; - list_all_locations_parameters(app, &global_general, &global_part, &bar.string, 1, SearchFlag_CaseInsensitive | SearchFlag_MatchWholeWord); -} + list_query__parameters(app, &global_general, &global_part, false, true); + } CUSTOM_COMMAND_SIG(list_all_substring_locations_case_insensitive) CUSTOM_DOC("Queries the user for a string and lists all case-insensitive substring matches found in all open buffers.") { - char string_space[1024]; - Query_Bar bar; - get_search_all_string(app, &bar, string_space, sizeof(string_space)); - if (bar.string.size == 0) return; - list_all_locations_parameters(app, &global_general, &global_part, &bar.string, 1, SearchFlag_CaseInsensitive | SearchFlag_MatchSubstring); -} - -static String -get_token_or_word_under_pos(Application_Links *app, Buffer_Summary *buffer, int32_t pos, char *space, int32_t capacity){ - String result = {0}; - - Cpp_Get_Token_Result get_result = {0}; - bool32 success = buffer_get_token_index(app, buffer, pos, &get_result); - - if (success && !get_result.in_whitespace){ - int32_t size = get_result.token_end - get_result.token_start; - if (size > 0 && size <= capacity){ - success = buffer_read_range(app, buffer, get_result.token_start, get_result.token_end, space); - if (success){ - result = make_string(space, size); - } - } - } - - return(result); -} - -static void -list_all_locations_of_identifier_parameters(Application_Links *app, bool32 substrings, bool32 case_insensitive){ - View_Summary view = get_active_view(app, AccessProtected); - Buffer_Summary buffer = get_buffer(app, view.buffer_id, AccessProtected); - - char space[512]; - String str = get_token_or_word_under_pos(app, &buffer, view.cursor.pos, space, sizeof(space)); - if (str.str != 0){ - change_active_panel(app); - - Search_Range_Flag flags = 0; - if (substrings){ - flags |= SearchFlag_MatchSubstring; - } - else{ - flags |= SearchFlag_MatchWholeWord; - } - if (case_insensitive){ - flags |= SearchFlag_CaseInsensitive; - } - list_all_locations_parameters(app, &global_general, &global_part, &str, 1, flags); - } + list_query__parameters(app, &global_general, &global_part, true, true); } CUSTOM_COMMAND_SIG(list_all_locations_of_identifier) CUSTOM_DOC("Reads a token or word under the cursor and lists all exact case-sensitive mathces in all open buffers.") { - list_all_locations_of_identifier_parameters(app, false, false); + list_identifier__parameters(app, &global_general, &global_part, false, false); } CUSTOM_COMMAND_SIG(list_all_locations_of_identifier_case_insensitive) CUSTOM_DOC("Reads a token or word under the cursor and lists all exact case-insensitive mathces in all open buffers.") { - list_all_locations_of_identifier_parameters(app, false, true); -} - -static void -list_all_locations_of_selection_parameters(Application_Links *app, bool32 substrings, bool32 case_insensitive){ - View_Summary view = get_active_view(app, AccessProtected); - Buffer_Summary buffer = get_buffer(app, view.buffer_id, AccessProtected); - - if (!buffer.exists){ - return; - } - - Partition *part = &global_part; - Temp_Memory temp = begin_temp_memory(part); - - Range range = get_view_range(&view); - int32_t query_length = range.max - range.min; - if (query_length != 0){ - char *query_space = push_array(part, char, query_length); - if (buffer_read_range(app, &buffer, range.min, range.max, query_space)){ - String query = make_string(query_space, query_length); - - Search_Range_Flag flags = 0; - if (substrings){ - flags |= SearchFlag_MatchSubstring; - } - else{ - flags |= SearchFlag_MatchWholeWord; - } - if (case_insensitive){ - flags |= SearchFlag_CaseInsensitive; - } - list_all_locations_parameters(app, &global_general, &global_part, &query, 1, flags); - } - } - - end_temp_memory(temp); + list_identifier__parameters(app, &global_general, &global_part, false, true); } CUSTOM_COMMAND_SIG(list_all_locations_of_selection) CUSTOM_DOC("Reads the string in the selected range and lists all exact case-sensitive mathces in all open buffers.") { - list_all_locations_of_selection_parameters(app, false, false); + list_selected_range__parameters(app, &global_general, &global_part, false, false); } CUSTOM_COMMAND_SIG(list_all_locations_of_selection_case_insensitive) CUSTOM_DOC("Reads the string in the selected range and lists all exact case-insensitive mathces in all open buffers.") { - list_all_locations_of_selection_parameters(app, false, true); + list_selected_range__parameters(app, &global_general, &global_part, false, true); +} + +CUSTOM_COMMAND_SIG(list_all_locations_of_type_definition) +CUSTOM_DOC("Queries user for string, lists all locations of strings that appear to define a type whose name matches the input string.") +{ + char space[1024]; + String str = get_query_string(app, "List Definitions For: ", space, sizeof(space)); + if (str.str != 0){ + change_active_panel(app); +list_type_definition__parameters(app, &global_general, &global_part, str); +} +} + +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.") +{ + View_Summary view = get_active_view(app, AccessProtected); + Buffer_Summary buffer = get_buffer(app, view.buffer_id, AccessProtected); + char space[512]; + String str = get_token_or_word_under_pos(app, &buffer, view.cursor.pos, space, sizeof(space) - 1); + if (str.str != 0){ + change_active_panel(app); + list_type_definition__parameters(app, &global_general, &global_part, str); + } }