Cut down 4ed_view.cpp a lot more, cut the old debug view
parent
f6ce7477c4
commit
40b5e61e91
|
@ -87,8 +87,6 @@ ENUM(uint64_t, Command_ID){
|
||||||
|
|
||||||
/* DOC(cmdid_open_color_tweaker opens the theme editing GUI.) */
|
/* DOC(cmdid_open_color_tweaker opens the theme editing GUI.) */
|
||||||
cmdid_open_color_tweaker,
|
cmdid_open_color_tweaker,
|
||||||
/* DOC(cmdid_open_debug opens the debug information viewer mode.) */
|
|
||||||
cmdid_open_debug,
|
|
||||||
|
|
||||||
// count
|
// count
|
||||||
cmdid_count
|
cmdid_count
|
||||||
|
|
|
@ -1282,12 +1282,6 @@ CUSTOM_DOC("Opens the 4coder colors and fonts selector menu.")
|
||||||
exec_command(app, cmdid_open_color_tweaker);
|
exec_command(app, cmdid_open_color_tweaker);
|
||||||
}
|
}
|
||||||
|
|
||||||
CUSTOM_COMMAND_SIG(open_debug)
|
|
||||||
CUSTOM_DOC("Opens a debug view for internal use.")
|
|
||||||
{
|
|
||||||
exec_command(app, cmdid_open_debug);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// BOTTOM
|
// BOTTOM
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#define command_id(c) (fcoder_metacmd_ID_##c)
|
#define command_id(c) (fcoder_metacmd_ID_##c)
|
||||||
#define command_metadata(c) (&fcoder_metacmd_table[command_id(c)])
|
#define command_metadata(c) (&fcoder_metacmd_table[command_id(c)])
|
||||||
#define command_metadata_by_id(id) (&fcoder_metacmd_table[id])
|
#define command_metadata_by_id(id) (&fcoder_metacmd_table[id])
|
||||||
#define command_one_past_last_id 195
|
#define command_one_past_last_id 194
|
||||||
#if defined(CUSTOM_COMMAND_SIG)
|
#if defined(CUSTOM_COMMAND_SIG)
|
||||||
#define PROC_LINKS(x,y) x
|
#define PROC_LINKS(x,y) x
|
||||||
#else
|
#else
|
||||||
|
@ -115,7 +115,6 @@ CUSTOM_COMMAND_SIG(newline_or_goto_position_sticky);
|
||||||
CUSTOM_COMMAND_SIG(open_all_code);
|
CUSTOM_COMMAND_SIG(open_all_code);
|
||||||
CUSTOM_COMMAND_SIG(open_all_code_recursive);
|
CUSTOM_COMMAND_SIG(open_all_code_recursive);
|
||||||
CUSTOM_COMMAND_SIG(open_color_tweaker);
|
CUSTOM_COMMAND_SIG(open_color_tweaker);
|
||||||
CUSTOM_COMMAND_SIG(open_debug);
|
|
||||||
CUSTOM_COMMAND_SIG(open_file_in_quotes);
|
CUSTOM_COMMAND_SIG(open_file_in_quotes);
|
||||||
CUSTOM_COMMAND_SIG(open_in_other);
|
CUSTOM_COMMAND_SIG(open_in_other);
|
||||||
CUSTOM_COMMAND_SIG(open_long_braces);
|
CUSTOM_COMMAND_SIG(open_long_braces);
|
||||||
|
@ -214,7 +213,7 @@ char *source_name;
|
||||||
int32_t source_name_len;
|
int32_t source_name_len;
|
||||||
int32_t line_number;
|
int32_t line_number;
|
||||||
};
|
};
|
||||||
static Command_Metadata fcoder_metacmd_table[195] = {
|
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:\\work\\4ed\\code\\4coder_default_framework.h", 47, 232 },
|
{ 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.h", 47, 232 },
|
||||||
{ 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, 667 },
|
{ 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, 667 },
|
||||||
{ 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, 678 },
|
{ 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, 678 },
|
||||||
|
@ -322,7 +321,6 @@ static Command_Metadata fcoder_metacmd_table[195] = {
|
||||||
{ 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, 165 },
|
{ 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, 165 },
|
||||||
{ 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, 180 },
|
{ 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, 180 },
|
||||||
{ 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, 1279 },
|
{ 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, 1279 },
|
||||||
{ PROC_LINKS(open_debug, 0), "open_debug", 10, "Opens a debug view for internal use.", 36, "C:\\work\\4ed\\code\\4coder_base_commands.cpp", 45, 1285 },
|
|
||||||
{ 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_default_include.cpp", 47, 634 },
|
{ 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_default_include.cpp", 47, 634 },
|
||||||
{ 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:\\work\\4ed\\code\\4coder_default_include.cpp", 47, 651 },
|
{ 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:\\work\\4ed\\code\\4coder_default_include.cpp", 47, 651 },
|
||||||
{ 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_default_include.cpp", 47, 513 },
|
{ 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_default_include.cpp", 47, 513 },
|
||||||
|
@ -518,91 +516,90 @@ static int32_t fcoder_metacmd_ID_newline_or_goto_position_sticky = 103;
|
||||||
static int32_t fcoder_metacmd_ID_open_all_code = 104;
|
static int32_t fcoder_metacmd_ID_open_all_code = 104;
|
||||||
static int32_t fcoder_metacmd_ID_open_all_code_recursive = 105;
|
static int32_t fcoder_metacmd_ID_open_all_code_recursive = 105;
|
||||||
static int32_t fcoder_metacmd_ID_open_color_tweaker = 106;
|
static int32_t fcoder_metacmd_ID_open_color_tweaker = 106;
|
||||||
static int32_t fcoder_metacmd_ID_open_debug = 107;
|
static int32_t fcoder_metacmd_ID_open_file_in_quotes = 107;
|
||||||
static int32_t fcoder_metacmd_ID_open_file_in_quotes = 108;
|
static int32_t fcoder_metacmd_ID_open_in_other = 108;
|
||||||
static int32_t fcoder_metacmd_ID_open_in_other = 109;
|
static int32_t fcoder_metacmd_ID_open_long_braces = 109;
|
||||||
static int32_t fcoder_metacmd_ID_open_long_braces = 110;
|
static int32_t fcoder_metacmd_ID_open_long_braces_break = 110;
|
||||||
static int32_t fcoder_metacmd_ID_open_long_braces_break = 111;
|
static int32_t fcoder_metacmd_ID_open_long_braces_semicolon = 111;
|
||||||
static int32_t fcoder_metacmd_ID_open_long_braces_semicolon = 112;
|
static int32_t fcoder_metacmd_ID_open_matching_file_cpp = 112;
|
||||||
static int32_t fcoder_metacmd_ID_open_matching_file_cpp = 113;
|
static int32_t fcoder_metacmd_ID_open_panel_hsplit = 113;
|
||||||
static int32_t fcoder_metacmd_ID_open_panel_hsplit = 114;
|
static int32_t fcoder_metacmd_ID_open_panel_vsplit = 114;
|
||||||
static int32_t fcoder_metacmd_ID_open_panel_vsplit = 115;
|
static int32_t fcoder_metacmd_ID_page_down = 115;
|
||||||
static int32_t fcoder_metacmd_ID_page_down = 116;
|
static int32_t fcoder_metacmd_ID_page_up = 116;
|
||||||
static int32_t fcoder_metacmd_ID_page_up = 117;
|
static int32_t fcoder_metacmd_ID_paste = 117;
|
||||||
static int32_t fcoder_metacmd_ID_paste = 118;
|
static int32_t fcoder_metacmd_ID_paste_and_indent = 118;
|
||||||
static int32_t fcoder_metacmd_ID_paste_and_indent = 119;
|
static int32_t fcoder_metacmd_ID_paste_next = 119;
|
||||||
static int32_t fcoder_metacmd_ID_paste_next = 120;
|
static int32_t fcoder_metacmd_ID_paste_next_and_indent = 120;
|
||||||
static int32_t fcoder_metacmd_ID_paste_next_and_indent = 121;
|
static int32_t fcoder_metacmd_ID_place_in_scope = 121;
|
||||||
static int32_t fcoder_metacmd_ID_place_in_scope = 122;
|
static int32_t fcoder_metacmd_ID_project_fkey_command = 122;
|
||||||
static int32_t fcoder_metacmd_ID_project_fkey_command = 123;
|
static int32_t fcoder_metacmd_ID_project_go_to_root_directory = 123;
|
||||||
static int32_t fcoder_metacmd_ID_project_go_to_root_directory = 124;
|
static int32_t fcoder_metacmd_ID_query_replace = 124;
|
||||||
static int32_t fcoder_metacmd_ID_query_replace = 125;
|
static int32_t fcoder_metacmd_ID_query_replace_identifier = 125;
|
||||||
static int32_t fcoder_metacmd_ID_query_replace_identifier = 126;
|
static int32_t fcoder_metacmd_ID_query_replace_selection = 126;
|
||||||
static int32_t fcoder_metacmd_ID_query_replace_selection = 127;
|
static int32_t fcoder_metacmd_ID_redo = 127;
|
||||||
static int32_t fcoder_metacmd_ID_redo = 128;
|
static int32_t fcoder_metacmd_ID_reload_current_project = 128;
|
||||||
static int32_t fcoder_metacmd_ID_reload_current_project = 129;
|
static int32_t fcoder_metacmd_ID_remap_interactive = 129;
|
||||||
static int32_t fcoder_metacmd_ID_remap_interactive = 130;
|
static int32_t fcoder_metacmd_ID_rename_file_query = 130;
|
||||||
static int32_t fcoder_metacmd_ID_rename_file_query = 131;
|
static int32_t fcoder_metacmd_ID_rename_parameter = 131;
|
||||||
static int32_t fcoder_metacmd_ID_rename_parameter = 132;
|
static int32_t fcoder_metacmd_ID_reopen = 132;
|
||||||
static int32_t fcoder_metacmd_ID_reopen = 133;
|
static int32_t fcoder_metacmd_ID_replace_all_occurrences = 133;
|
||||||
static int32_t fcoder_metacmd_ID_replace_all_occurrences = 134;
|
static int32_t fcoder_metacmd_ID_replace_in_range = 134;
|
||||||
static int32_t fcoder_metacmd_ID_replace_in_range = 135;
|
static int32_t fcoder_metacmd_ID_reverse_search = 135;
|
||||||
static int32_t fcoder_metacmd_ID_reverse_search = 136;
|
static int32_t fcoder_metacmd_ID_reverse_search_identifier = 136;
|
||||||
static int32_t fcoder_metacmd_ID_reverse_search_identifier = 137;
|
static int32_t fcoder_metacmd_ID_save = 137;
|
||||||
static int32_t fcoder_metacmd_ID_save = 138;
|
static int32_t fcoder_metacmd_ID_save_all_dirty_buffers = 138;
|
||||||
static int32_t fcoder_metacmd_ID_save_all_dirty_buffers = 139;
|
static int32_t fcoder_metacmd_ID_save_to_query = 139;
|
||||||
static int32_t fcoder_metacmd_ID_save_to_query = 140;
|
static int32_t fcoder_metacmd_ID_scope_absorb_down = 140;
|
||||||
static int32_t fcoder_metacmd_ID_scope_absorb_down = 141;
|
static int32_t fcoder_metacmd_ID_search = 141;
|
||||||
static int32_t fcoder_metacmd_ID_search = 142;
|
static int32_t fcoder_metacmd_ID_search_identifier = 142;
|
||||||
static int32_t fcoder_metacmd_ID_search_identifier = 143;
|
static int32_t fcoder_metacmd_ID_seek_alphanumeric_left = 143;
|
||||||
static int32_t fcoder_metacmd_ID_seek_alphanumeric_left = 144;
|
static int32_t fcoder_metacmd_ID_seek_alphanumeric_or_camel_left = 144;
|
||||||
static int32_t fcoder_metacmd_ID_seek_alphanumeric_or_camel_left = 145;
|
static int32_t fcoder_metacmd_ID_seek_alphanumeric_or_camel_right = 145;
|
||||||
static int32_t fcoder_metacmd_ID_seek_alphanumeric_or_camel_right = 146;
|
static int32_t fcoder_metacmd_ID_seek_alphanumeric_right = 146;
|
||||||
static int32_t fcoder_metacmd_ID_seek_alphanumeric_right = 147;
|
static int32_t fcoder_metacmd_ID_seek_beginning_of_line = 147;
|
||||||
static int32_t fcoder_metacmd_ID_seek_beginning_of_line = 148;
|
static int32_t fcoder_metacmd_ID_seek_beginning_of_textual_line = 148;
|
||||||
static int32_t fcoder_metacmd_ID_seek_beginning_of_textual_line = 149;
|
static int32_t fcoder_metacmd_ID_seek_end_of_line = 149;
|
||||||
static int32_t fcoder_metacmd_ID_seek_end_of_line = 150;
|
static int32_t fcoder_metacmd_ID_seek_end_of_textual_line = 150;
|
||||||
static int32_t fcoder_metacmd_ID_seek_end_of_textual_line = 151;
|
static int32_t fcoder_metacmd_ID_seek_token_left = 151;
|
||||||
static int32_t fcoder_metacmd_ID_seek_token_left = 152;
|
static int32_t fcoder_metacmd_ID_seek_token_right = 152;
|
||||||
static int32_t fcoder_metacmd_ID_seek_token_right = 153;
|
static int32_t fcoder_metacmd_ID_seek_white_or_token_left = 153;
|
||||||
static int32_t fcoder_metacmd_ID_seek_white_or_token_left = 154;
|
static int32_t fcoder_metacmd_ID_seek_white_or_token_right = 154;
|
||||||
static int32_t fcoder_metacmd_ID_seek_white_or_token_right = 155;
|
static int32_t fcoder_metacmd_ID_seek_whitespace_down = 155;
|
||||||
static int32_t fcoder_metacmd_ID_seek_whitespace_down = 156;
|
static int32_t fcoder_metacmd_ID_seek_whitespace_down_end_line = 156;
|
||||||
static int32_t fcoder_metacmd_ID_seek_whitespace_down_end_line = 157;
|
static int32_t fcoder_metacmd_ID_seek_whitespace_left = 157;
|
||||||
static int32_t fcoder_metacmd_ID_seek_whitespace_left = 158;
|
static int32_t fcoder_metacmd_ID_seek_whitespace_right = 158;
|
||||||
static int32_t fcoder_metacmd_ID_seek_whitespace_right = 159;
|
static int32_t fcoder_metacmd_ID_seek_whitespace_up = 159;
|
||||||
static int32_t fcoder_metacmd_ID_seek_whitespace_up = 160;
|
static int32_t fcoder_metacmd_ID_seek_whitespace_up_end_line = 160;
|
||||||
static int32_t fcoder_metacmd_ID_seek_whitespace_up_end_line = 161;
|
static int32_t fcoder_metacmd_ID_select_all = 161;
|
||||||
static int32_t fcoder_metacmd_ID_select_all = 162;
|
static int32_t fcoder_metacmd_ID_set_bindings_choose = 162;
|
||||||
static int32_t fcoder_metacmd_ID_set_bindings_choose = 163;
|
static int32_t fcoder_metacmd_ID_set_bindings_default = 163;
|
||||||
static int32_t fcoder_metacmd_ID_set_bindings_default = 164;
|
static int32_t fcoder_metacmd_ID_set_bindings_mac_default = 164;
|
||||||
static int32_t fcoder_metacmd_ID_set_bindings_mac_default = 165;
|
static int32_t fcoder_metacmd_ID_set_mark = 165;
|
||||||
static int32_t fcoder_metacmd_ID_set_mark = 166;
|
static int32_t fcoder_metacmd_ID_setup_new_project = 166;
|
||||||
static int32_t fcoder_metacmd_ID_setup_new_project = 167;
|
static int32_t fcoder_metacmd_ID_show_filebar = 167;
|
||||||
static int32_t fcoder_metacmd_ID_show_filebar = 168;
|
static int32_t fcoder_metacmd_ID_show_scrollbar = 168;
|
||||||
static int32_t fcoder_metacmd_ID_show_scrollbar = 169;
|
static int32_t fcoder_metacmd_ID_snipe_token_or_word = 169;
|
||||||
static int32_t fcoder_metacmd_ID_snipe_token_or_word = 170;
|
static int32_t fcoder_metacmd_ID_snipe_token_or_word_right = 170;
|
||||||
static int32_t fcoder_metacmd_ID_snipe_token_or_word_right = 171;
|
static int32_t fcoder_metacmd_ID_suppress_mouse = 171;
|
||||||
static int32_t fcoder_metacmd_ID_suppress_mouse = 172;
|
static int32_t fcoder_metacmd_ID_swap_buffers_between_panels = 172;
|
||||||
static int32_t fcoder_metacmd_ID_swap_buffers_between_panels = 173;
|
static int32_t fcoder_metacmd_ID_to_lowercase = 173;
|
||||||
static int32_t fcoder_metacmd_ID_to_lowercase = 174;
|
static int32_t fcoder_metacmd_ID_to_uppercase = 174;
|
||||||
static int32_t fcoder_metacmd_ID_to_uppercase = 175;
|
static int32_t fcoder_metacmd_ID_toggle_filebar = 175;
|
||||||
static int32_t fcoder_metacmd_ID_toggle_filebar = 176;
|
static int32_t fcoder_metacmd_ID_toggle_fullscreen = 176;
|
||||||
static int32_t fcoder_metacmd_ID_toggle_fullscreen = 177;
|
static int32_t fcoder_metacmd_ID_toggle_line_wrap = 177;
|
||||||
static int32_t fcoder_metacmd_ID_toggle_line_wrap = 178;
|
static int32_t fcoder_metacmd_ID_toggle_mouse = 178;
|
||||||
static int32_t fcoder_metacmd_ID_toggle_mouse = 179;
|
static int32_t fcoder_metacmd_ID_toggle_show_whitespace = 179;
|
||||||
static int32_t fcoder_metacmd_ID_toggle_show_whitespace = 180;
|
static int32_t fcoder_metacmd_ID_toggle_virtual_whitespace = 180;
|
||||||
static int32_t fcoder_metacmd_ID_toggle_virtual_whitespace = 181;
|
static int32_t fcoder_metacmd_ID_undo = 181;
|
||||||
static int32_t fcoder_metacmd_ID_undo = 182;
|
static int32_t fcoder_metacmd_ID_view_buffer_other_panel = 182;
|
||||||
static int32_t fcoder_metacmd_ID_view_buffer_other_panel = 183;
|
static int32_t fcoder_metacmd_ID_word_complete = 183;
|
||||||
static int32_t fcoder_metacmd_ID_word_complete = 184;
|
static int32_t fcoder_metacmd_ID_write_and_auto_tab = 184;
|
||||||
static int32_t fcoder_metacmd_ID_write_and_auto_tab = 185;
|
static int32_t fcoder_metacmd_ID_write_block = 185;
|
||||||
static int32_t fcoder_metacmd_ID_write_block = 186;
|
static int32_t fcoder_metacmd_ID_write_character = 186;
|
||||||
static int32_t fcoder_metacmd_ID_write_character = 187;
|
static int32_t fcoder_metacmd_ID_write_explicit_enum_flags = 187;
|
||||||
static int32_t fcoder_metacmd_ID_write_explicit_enum_flags = 188;
|
static int32_t fcoder_metacmd_ID_write_explicit_enum_values = 188;
|
||||||
static int32_t fcoder_metacmd_ID_write_explicit_enum_values = 189;
|
static int32_t fcoder_metacmd_ID_write_hack = 189;
|
||||||
static int32_t fcoder_metacmd_ID_write_hack = 190;
|
static int32_t fcoder_metacmd_ID_write_note = 190;
|
||||||
static int32_t fcoder_metacmd_ID_write_note = 191;
|
static int32_t fcoder_metacmd_ID_write_todo = 191;
|
||||||
static int32_t fcoder_metacmd_ID_write_todo = 192;
|
static int32_t fcoder_metacmd_ID_write_underscore = 192;
|
||||||
static int32_t fcoder_metacmd_ID_write_underscore = 193;
|
static int32_t fcoder_metacmd_ID_write_zero_struct = 193;
|
||||||
static int32_t fcoder_metacmd_ID_write_zero_struct = 194;
|
|
||||||
|
|
|
@ -15,7 +15,6 @@ bind(context, 'h', MDFR_CTRL, project_go_to_root_directory);
|
||||||
bind(context, 'H', MDFR_CTRL, reload_current_project);
|
bind(context, 'H', MDFR_CTRL, reload_current_project);
|
||||||
bind(context, 'S', MDFR_CTRL, save_all_dirty_buffers);
|
bind(context, 'S', MDFR_CTRL, save_all_dirty_buffers);
|
||||||
bind(context, 'c', MDFR_ALT, open_color_tweaker);
|
bind(context, 'c', MDFR_ALT, open_color_tweaker);
|
||||||
bind(context, 'd', MDFR_ALT, open_debug);
|
|
||||||
bind(context, '.', MDFR_ALT, change_to_build_panel);
|
bind(context, '.', MDFR_ALT, change_to_build_panel);
|
||||||
bind(context, ',', MDFR_ALT, close_build_panel);
|
bind(context, ',', MDFR_ALT, close_build_panel);
|
||||||
bind(context, 'n', MDFR_ALT, goto_next_jump_no_skips_sticky);
|
bind(context, 'n', MDFR_ALT, goto_next_jump_no_skips_sticky);
|
||||||
|
@ -172,7 +171,6 @@ bind(context, 'h', MDFR_CMND, project_go_to_root_directory);
|
||||||
bind(context, 'H', MDFR_CMND, reload_current_project);
|
bind(context, 'H', MDFR_CMND, reload_current_project);
|
||||||
bind(context, 'S', MDFR_CMND, save_all_dirty_buffers);
|
bind(context, 'S', MDFR_CMND, save_all_dirty_buffers);
|
||||||
bind(context, 'c', MDFR_CTRL, open_color_tweaker);
|
bind(context, 'c', MDFR_CTRL, open_color_tweaker);
|
||||||
bind(context, 'd', MDFR_CTRL, open_debug);
|
|
||||||
bind(context, '.', MDFR_CTRL, change_to_build_panel);
|
bind(context, '.', MDFR_CTRL, change_to_build_panel);
|
||||||
bind(context, ',', MDFR_CTRL, close_build_panel);
|
bind(context, ',', MDFR_CTRL, close_build_panel);
|
||||||
bind(context, 'n', MDFR_CTRL, goto_next_jump_sticky);
|
bind(context, 'n', MDFR_CTRL, goto_next_jump_sticky);
|
||||||
|
@ -344,7 +342,7 @@ Meta_Sub_Map *sub_maps;
|
||||||
int32_t sub_map_count;
|
int32_t sub_map_count;
|
||||||
LINK_PROCS(void (*fill_keys_proc)(Bind_Helper *context);)
|
LINK_PROCS(void (*fill_keys_proc)(Bind_Helper *context);)
|
||||||
};
|
};
|
||||||
static Meta_Key_Bind fcoder_binds_for_default_mapid_global[48] = {
|
static Meta_Key_Bind fcoder_binds_for_default_mapid_global[47] = {
|
||||||
{0, 112, 1, "open_panel_vsplit", 17, LINK_PROCS(open_panel_vsplit)},
|
{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, 95, 1, "open_panel_hsplit", 17, LINK_PROCS(open_panel_hsplit)},
|
||||||
{0, 80, 1, "close_panel", 11, LINK_PROCS(close_panel)},
|
{0, 80, 1, "close_panel", 11, LINK_PROCS(close_panel)},
|
||||||
|
@ -359,7 +357,6 @@ static Meta_Key_Bind fcoder_binds_for_default_mapid_global[48] = {
|
||||||
{0, 72, 1, "reload_current_project", 22, LINK_PROCS(reload_current_project)},
|
{0, 72, 1, "reload_current_project", 22, LINK_PROCS(reload_current_project)},
|
||||||
{0, 83, 1, "save_all_dirty_buffers", 22, LINK_PROCS(save_all_dirty_buffers)},
|
{0, 83, 1, "save_all_dirty_buffers", 22, LINK_PROCS(save_all_dirty_buffers)},
|
||||||
{0, 99, 2, "open_color_tweaker", 18, LINK_PROCS(open_color_tweaker)},
|
{0, 99, 2, "open_color_tweaker", 18, LINK_PROCS(open_color_tweaker)},
|
||||||
{0, 100, 2, "open_debug", 10, LINK_PROCS(open_debug)},
|
|
||||||
{0, 46, 2, "change_to_build_panel", 21, LINK_PROCS(change_to_build_panel)},
|
{0, 46, 2, "change_to_build_panel", 21, LINK_PROCS(change_to_build_panel)},
|
||||||
{0, 44, 2, "close_build_panel", 17, LINK_PROCS(close_build_panel)},
|
{0, 44, 2, "close_build_panel", 17, LINK_PROCS(close_build_panel)},
|
||||||
{0, 110, 2, "goto_next_jump_no_skips_sticky", 30, LINK_PROCS(goto_next_jump_no_skips_sticky)},
|
{0, 110, 2, "goto_next_jump_no_skips_sticky", 30, LINK_PROCS(goto_next_jump_no_skips_sticky)},
|
||||||
|
@ -499,11 +496,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)},
|
{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] = {
|
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, 48},
|
{"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_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},
|
||||||
{"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},
|
{"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[48] = {
|
static Meta_Key_Bind fcoder_binds_for_mac_default_mapid_global[47] = {
|
||||||
{0, 112, 4, "open_panel_vsplit", 17, LINK_PROCS(open_panel_vsplit)},
|
{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, 95, 4, "open_panel_hsplit", 17, LINK_PROCS(open_panel_hsplit)},
|
||||||
{0, 80, 4, "close_panel", 11, LINK_PROCS(close_panel)},
|
{0, 80, 4, "close_panel", 11, LINK_PROCS(close_panel)},
|
||||||
|
@ -518,7 +515,6 @@ static Meta_Key_Bind fcoder_binds_for_mac_default_mapid_global[48] = {
|
||||||
{0, 72, 4, "reload_current_project", 22, LINK_PROCS(reload_current_project)},
|
{0, 72, 4, "reload_current_project", 22, LINK_PROCS(reload_current_project)},
|
||||||
{0, 83, 4, "save_all_dirty_buffers", 22, LINK_PROCS(save_all_dirty_buffers)},
|
{0, 83, 4, "save_all_dirty_buffers", 22, LINK_PROCS(save_all_dirty_buffers)},
|
||||||
{0, 99, 1, "open_color_tweaker", 18, LINK_PROCS(open_color_tweaker)},
|
{0, 99, 1, "open_color_tweaker", 18, LINK_PROCS(open_color_tweaker)},
|
||||||
{0, 100, 1, "open_debug", 10, LINK_PROCS(open_debug)},
|
|
||||||
{0, 46, 1, "change_to_build_panel", 21, LINK_PROCS(change_to_build_panel)},
|
{0, 46, 1, "change_to_build_panel", 21, LINK_PROCS(change_to_build_panel)},
|
||||||
{0, 44, 1, "close_build_panel", 17, LINK_PROCS(close_build_panel)},
|
{0, 44, 1, "close_build_panel", 17, LINK_PROCS(close_build_panel)},
|
||||||
{0, 110, 1, "goto_next_jump_sticky", 21, LINK_PROCS(goto_next_jump_sticky)},
|
{0, 110, 1, "goto_next_jump_sticky", 21, LINK_PROCS(goto_next_jump_sticky)},
|
||||||
|
@ -656,7 +652,7 @@ 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)},
|
{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] = {
|
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, 48},
|
{"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_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},
|
||||||
{"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},
|
{"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},
|
||||||
};
|
};
|
||||||
|
|
46
4ed.cpp
46
4ed.cpp
|
@ -371,7 +371,7 @@ internal View*
|
||||||
panel_make_empty(System_Functions *system, Models *models, Panel *panel){
|
panel_make_empty(System_Functions *system, Models *models, Panel *panel){
|
||||||
Assert(panel->view == 0);
|
Assert(panel->view == 0);
|
||||||
View_And_ID new_view = live_set_alloc_view(&models->live_set, panel, models);
|
View_And_ID new_view = live_set_alloc_view(&models->live_set, panel, models);
|
||||||
view_set_file(system, new_view.view, models->scratch_buffer, models);
|
view_set_file(system, models, new_view.view, models->scratch_buffer);
|
||||||
new_view.view->transient.map = models->scratch_buffer->settings.base_map_id;
|
new_view.view->transient.map = models->scratch_buffer->settings.base_map_id;
|
||||||
return(new_view.view);
|
return(new_view.view);
|
||||||
}
|
}
|
||||||
|
@ -475,10 +475,10 @@ COMMAND_DECL(reopen){
|
||||||
}
|
}
|
||||||
|
|
||||||
file_free(system, general, file);
|
file_free(system, general, file);
|
||||||
init_normal_file(system, models, file, buffer, size);
|
init_normal_file(system, models, buffer, size, file);
|
||||||
|
|
||||||
for (i32 i = 0; i < vptr_count; ++i){
|
for (i32 i = 0; i < vptr_count; ++i){
|
||||||
view_set_file(system, vptrs[i], file, models);
|
view_set_file(system, models, vptrs[i], file);
|
||||||
|
|
||||||
int32_t line = line_number[i];
|
int32_t line = line_number[i];
|
||||||
int32_t character = column_number[i];
|
int32_t character = column_number[i];
|
||||||
|
@ -515,14 +515,12 @@ COMMAND_DECL(save){
|
||||||
COMMAND_DECL(interactive_switch_buffer){
|
COMMAND_DECL(interactive_switch_buffer){
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
|
|
||||||
view_show_interactive(system, view, models, IAct_Switch, IInt_Live_File_List, make_lit_string("Switch Buffer: "));
|
view_show_interactive(system, view, models, IAct_Switch, IInt_Live_File_List, make_lit_string("Switch Buffer: "));
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(interactive_kill_buffer){
|
COMMAND_DECL(interactive_kill_buffer){
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
|
|
||||||
view_show_interactive(system, view, models, IAct_Kill, IInt_Live_File_List, make_lit_string("Kill Buffer: "));
|
view_show_interactive(system, view, models, IAct_Kill, IInt_Live_File_List, make_lit_string("Kill Buffer: "));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -530,8 +528,9 @@ COMMAND_DECL(kill_buffer){
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
REQ_FILE(file, view);
|
REQ_FILE(file, view);
|
||||||
|
if (interactive_try_kill_file(system, models, file) == TryKill_NeedDialogue){
|
||||||
interactive_try_kill_file(system, models, view, file);
|
interactive_begin_sure_to_kill(system, view, models, file);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
|
@ -567,20 +566,19 @@ case_change_range(System_Functions *system, Models *models, View *view, Editing_
|
||||||
|
|
||||||
COMMAND_DECL(open_color_tweaker){
|
COMMAND_DECL(open_color_tweaker){
|
||||||
USE_VIEW(view);
|
USE_VIEW(view);
|
||||||
USE_MODELS(models);
|
view->transient.map = mapid_ui;
|
||||||
view_show_theme(view, models);
|
view->transient.showing_ui = VUI_Theme;
|
||||||
}
|
view->transient.color_mode = CV_Mode_Library;
|
||||||
|
view->transient.color = super_color_create(0xFF000000);
|
||||||
COMMAND_DECL(open_debug){
|
view->transient.current_color_editing = 0;
|
||||||
USE_VIEW(view);
|
view->transient.changed_context_in_step = true;
|
||||||
USE_MODELS(models);
|
|
||||||
view_show_GUI(view, models, VUI_Debug);
|
|
||||||
view->transient.debug_vars = null_debug_vars;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMAND_DECL(user_callback){
|
COMMAND_DECL(user_callback){
|
||||||
USE_MODELS(models);
|
USE_MODELS(models);
|
||||||
if (binding.custom) binding.custom(&models->app_links);
|
if (binding.custom != 0){
|
||||||
|
binding.custom(&models->app_links);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
global Command_Function *command_table[cmdid_count];
|
global Command_Function *command_table[cmdid_count];
|
||||||
|
@ -981,7 +979,6 @@ setup_command_table(){
|
||||||
SET(kill_buffer);
|
SET(kill_buffer);
|
||||||
|
|
||||||
SET(open_color_tweaker);
|
SET(open_color_tweaker);
|
||||||
SET(open_debug);
|
|
||||||
#undef SET
|
#undef SET
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1403,13 +1400,12 @@ App_Init_Sig(app_init){
|
||||||
|
|
||||||
cmd->key = null_key_event_data;
|
cmd->key = null_key_event_data;
|
||||||
|
|
||||||
General_Memory *general = &models->mem.general;
|
|
||||||
|
|
||||||
File_Init init_files[] = {
|
File_Init init_files[] = {
|
||||||
{ make_lit_string("*messages*"), &models->message_buffer, true , },
|
{ make_lit_string("*messages*"), &models->message_buffer, true , },
|
||||||
{ make_lit_string("*scratch*"), &models->scratch_buffer, false, }
|
{ make_lit_string("*scratch*"), &models->scratch_buffer, false, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
General_Memory *general = &models->mem.general;
|
||||||
for (i32 i = 0; i < ArrayCount(init_files); ++i){
|
for (i32 i = 0; i < ArrayCount(init_files); ++i){
|
||||||
Editing_File *file = working_set_alloc_always(&models->working_set, general);
|
Editing_File *file = working_set_alloc_always(&models->working_set, general);
|
||||||
buffer_bind_name(models, general, partition, &models->working_set, file, init_files[i].name);
|
buffer_bind_name(models, general, partition, &models->working_set, file, init_files[i].name);
|
||||||
|
@ -1418,7 +1414,7 @@ App_Init_Sig(app_init){
|
||||||
init_read_only_file(system, models, file);
|
init_read_only_file(system, models, file);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
init_normal_file(system, models, file, 0, 0);
|
init_normal_file(system, models, 0, 0, file);
|
||||||
}
|
}
|
||||||
|
|
||||||
file->settings.never_kill = true;
|
file->settings.never_kill = true;
|
||||||
|
@ -1583,7 +1579,8 @@ App_Step_Sig(app_step){
|
||||||
for (;system->get_file_change(buffer, buffer_size, &mem_too_small, &size);){
|
for (;system->get_file_change(buffer, buffer_size, &mem_too_small, &size);){
|
||||||
Assert(!mem_too_small);
|
Assert(!mem_too_small);
|
||||||
Editing_File_Name canon = {0};
|
Editing_File_Name canon = {0};
|
||||||
if (get_canon_name(system, &canon, make_string(buffer, size))){
|
if (get_canon_name(system, make_string(buffer, size),
|
||||||
|
&canon)){
|
||||||
Editing_File *file = working_set_contains_canon(working_set, canon.name);
|
Editing_File *file = working_set_contains_canon(working_set, canon.name);
|
||||||
if (file != 0){
|
if (file != 0){
|
||||||
if (file->state.ignore_behind_os == 0){
|
if (file->state.ignore_behind_os == 0){
|
||||||
|
@ -1799,7 +1796,8 @@ App_Step_Sig(app_step){
|
||||||
|
|
||||||
String filename = {0};
|
String filename = {0};
|
||||||
Editing_File_Name canon_name = {0};
|
Editing_File_Name canon_name = {0};
|
||||||
if (get_canon_name(system, &canon_name, make_string_slowly(models->settings.init_files[i]))){
|
if (get_canon_name(system, make_string_slowly(models->settings.init_files[i]),
|
||||||
|
&canon_name)){
|
||||||
filename = canon_name.name;
|
filename = canon_name.name;
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
|
|
|
@ -282,15 +282,19 @@ DOC_SEE(Command_Line_Interface_Flag)
|
||||||
}
|
}
|
||||||
|
|
||||||
// NOTE(allen): If the buffer is specified by name but does not already exist, then create it.
|
// NOTE(allen): If the buffer is specified by name but does not already exist, then create it.
|
||||||
if (file == 0 && buffer_id.name){
|
if (file == 0 && buffer_id.name != 0){
|
||||||
file = working_set_alloc_always(working_set, general);
|
file = working_set_alloc_always(working_set, general);
|
||||||
|
Assert(file != 0);
|
||||||
|
|
||||||
|
#if 0
|
||||||
if (file == 0){
|
if (file == 0){
|
||||||
append(&feedback_str, make_lit_string("ERROR: unable to allocate a new buffer\n"));
|
append(&feedback_str, make_lit_string("ERROR: unable to allocate a new buffer\n"));
|
||||||
result = false;
|
result = false;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
String name = make_string_terminated(part, buffer_id.name, buffer_id.name_len);
|
String name = push_string(part, buffer_id.name, buffer_id.name_len);
|
||||||
buffer_bind_name(models, general, part, working_set, file, name);
|
buffer_bind_name(models, general, part, working_set, file, name);
|
||||||
init_read_only_file(system, models, file);
|
init_read_only_file(system, models, file);
|
||||||
}
|
}
|
||||||
|
@ -336,7 +340,7 @@ DOC_SEE(Command_Line_Interface_Flag)
|
||||||
if (bind_to_new_view){
|
if (bind_to_new_view){
|
||||||
View *vptr = imp_get_view(cmd, view);
|
View *vptr = imp_get_view(cmd, view);
|
||||||
if (vptr != 0){
|
if (vptr != 0){
|
||||||
view_set_file(system, vptr, file, models);
|
view_set_file(system, models, vptr, file);
|
||||||
view_show_file(vptr);
|
view_show_file(vptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -349,7 +353,7 @@ DOC_SEE(Command_Line_Interface_Flag)
|
||||||
path_string = models->hot_directory.string;
|
path_string = models->hot_directory.string;
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
path_string = make_string_terminated(part, path, path_len);
|
path_string = push_string(part, path, path_len);
|
||||||
}
|
}
|
||||||
|
|
||||||
// NOTE(allen): Figure out the command string.
|
// NOTE(allen): Figure out the command string.
|
||||||
|
@ -358,7 +362,7 @@ DOC_SEE(Command_Line_Interface_Flag)
|
||||||
command_string = make_lit_string(" echo no script specified");
|
command_string = make_lit_string(" echo no script specified");
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
command_string = make_string_terminated(part, command, command_len);
|
command_string = push_string(part, command, command_len);
|
||||||
}
|
}
|
||||||
|
|
||||||
// NOTE(allen): Attept to execute the command.
|
// NOTE(allen): Attept to execute the command.
|
||||||
|
@ -619,7 +623,8 @@ DOC_SEE(Access_Flag)
|
||||||
|
|
||||||
String fname = make_string(name, len);
|
String fname = make_string(name, len);
|
||||||
Editing_File_Name canon = {0};
|
Editing_File_Name canon = {0};
|
||||||
if (get_canon_name(system, &canon, fname)){
|
if (get_canon_name(system, fname,
|
||||||
|
&canon)){
|
||||||
Editing_File *file = working_set_contains_canon(working_set, canon.name);
|
Editing_File *file = working_set_contains_canon(working_set, canon.name);
|
||||||
fill_buffer_summary(&buffer, file, working_set);
|
fill_buffer_summary(&buffer, file, working_set);
|
||||||
if (!access_test(buffer.lock_flags, access)){
|
if (!access_test(buffer.lock_flags, access)){
|
||||||
|
@ -770,7 +775,10 @@ DOC_SEE(Buffer_Batch_Edit_Type)
|
||||||
char *inv_str = (char*)part->base + part->pos;
|
char *inv_str = (char*)part->base + part->pos;
|
||||||
int32_t inv_str_max = part->max - part->pos;
|
int32_t inv_str_max = part->max - part->pos;
|
||||||
|
|
||||||
Edit_Spec spec = file_compute_edit(mem, file, edits, str, str_len, inverse_edits, inv_str, inv_str_max, edit_count, type);
|
Edit_Spec spec = edit_compute_batch_spec(&mem->general,
|
||||||
|
file,
|
||||||
|
edits, str, str_len,
|
||||||
|
inverse_edits, inv_str, inv_str_max, edit_count, type);
|
||||||
|
|
||||||
edit_batch(system, models, file, spec, hist_normal, type);
|
edit_batch(system, models, file, spec, hist_normal, type);
|
||||||
|
|
||||||
|
@ -1063,7 +1071,7 @@ DOC_SEE(Buffer_Setting_ID)
|
||||||
Font_Pointers font = system->font.get_pointers_by_id(file->settings.font_id);
|
Font_Pointers font = system->font.get_pointers_by_id(file->settings.font_id);
|
||||||
file->settings.display_width = new_value;
|
file->settings.display_width = new_value;
|
||||||
file_measure_wraps(system, &models->mem, file, font);
|
file_measure_wraps(system, &models->mem, file, font);
|
||||||
adjust_views_looking_at_files_to_new_cursor(system, models, file);
|
adjust_views_looking_at_file_to_new_cursor(system, models, file);
|
||||||
}
|
}
|
||||||
}break;
|
}break;
|
||||||
|
|
||||||
|
@ -1077,7 +1085,7 @@ DOC_SEE(Buffer_Setting_ID)
|
||||||
Font_Pointers font = system->font.get_pointers_by_id(file->settings.font_id);
|
Font_Pointers font = system->font.get_pointers_by_id(file->settings.font_id);
|
||||||
file->settings.minimum_base_display_width = new_value;
|
file->settings.minimum_base_display_width = new_value;
|
||||||
file_measure_wraps(system, &models->mem, file, font);
|
file_measure_wraps(system, &models->mem, file, font);
|
||||||
adjust_views_looking_at_files_to_new_cursor(system, models, file);
|
adjust_views_looking_at_file_to_new_cursor(system, models, file);
|
||||||
}
|
}
|
||||||
}break;
|
}break;
|
||||||
|
|
||||||
|
@ -1167,7 +1175,7 @@ DOC_SEE(Buffer_Setting_ID)
|
||||||
file_allocate_character_starts_as_needed(&models->mem.general, file);
|
file_allocate_character_starts_as_needed(&models->mem.general, file);
|
||||||
buffer_measure_character_starts(system, font, &file->state.buffer, file->state.character_starts, 0, file->settings.virtual_white);
|
buffer_measure_character_starts(system, font, &file->state.buffer, file->state.character_starts, 0, file->settings.virtual_white);
|
||||||
file_measure_wraps(system, &models->mem, file, font);
|
file_measure_wraps(system, &models->mem, file, font);
|
||||||
adjust_views_looking_at_files_to_new_cursor(system, models, file);
|
adjust_views_looking_at_file_to_new_cursor(system, models, file);
|
||||||
}
|
}
|
||||||
}break;
|
}break;
|
||||||
|
|
||||||
|
@ -1303,7 +1311,7 @@ DOC_SEE(Buffer_Create_Flag)
|
||||||
Editing_File *file = 0;
|
Editing_File *file = 0;
|
||||||
b32 do_new_file = false;
|
b32 do_new_file = false;
|
||||||
Editing_File_Name canon = {0};
|
Editing_File_Name canon = {0};
|
||||||
if (get_canon_name(system, &canon, fname)){
|
if (get_canon_name(system, fname, &canon)){
|
||||||
file = working_set_contains_canon(working_set, canon.name);
|
file = working_set_contains_canon(working_set, canon.name);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
|
@ -1321,7 +1329,7 @@ DOC_SEE(Buffer_Create_Flag)
|
||||||
|
|
||||||
// NOTE(allen): Figure out whether this is a new file, or an existing file.
|
// NOTE(allen): Figure out whether this is a new file, or an existing file.
|
||||||
if (!do_new_file){
|
if (!do_new_file){
|
||||||
if (flags & BufferCreate_AlwaysNew){
|
if ((flags & BufferCreate_AlwaysNew) != 0){
|
||||||
do_new_file = true;
|
do_new_file = true;
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
|
@ -1332,11 +1340,11 @@ DOC_SEE(Buffer_Create_Flag)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (do_new_file){
|
if (do_new_file){
|
||||||
if (!(flags & BufferCreate_NeverNew)){
|
if ((flags & BufferCreate_NeverNew) == 0){
|
||||||
file = working_set_alloc_always(working_set, general);
|
file = working_set_alloc_always(working_set, general);
|
||||||
if (file != 0){
|
if (file != 0){
|
||||||
buffer_bind_name(models, general, part, working_set, file, fname);
|
buffer_bind_name(models, general, part, working_set, file, front_of_directory(fname));
|
||||||
init_normal_file(system, models, file, 0, 0);
|
init_normal_file(system, models, 0, 0, file);
|
||||||
fill_buffer_summary(&result, file, cmd);
|
fill_buffer_summary(&result, file, cmd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1359,8 +1367,8 @@ DOC_SEE(Buffer_Create_Flag)
|
||||||
file = working_set_alloc_always(working_set, general);
|
file = working_set_alloc_always(working_set, general);
|
||||||
if (file != 0){
|
if (file != 0){
|
||||||
buffer_bind_file(system, general, working_set, file, canon.name);
|
buffer_bind_file(system, general, working_set, file, canon.name);
|
||||||
buffer_bind_name(models, general, part, working_set, file, fname);
|
buffer_bind_name(models, general, part, working_set, file, front_of_directory(fname));
|
||||||
init_normal_file(system, models, file, buffer, size);
|
init_normal_file(system, models, buffer, size, file);
|
||||||
fill_buffer_summary(&result, file, cmd);
|
fill_buffer_summary(&result, file, cmd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1417,7 +1425,7 @@ DOC_SEE(Buffer_Save_Flag)
|
||||||
|
|
||||||
Partition *part = &models->mem.part;
|
Partition *part = &models->mem.part;
|
||||||
Temp_Memory temp = begin_temp_memory(part);
|
Temp_Memory temp = begin_temp_memory(part);
|
||||||
String name = make_string_terminated(part, file_name, file_name_len);
|
String name = push_string(part, file_name, file_name_len);
|
||||||
save_file_to_name(system, models, file, name.str);
|
save_file_to_name(system, models, file, name.str);
|
||||||
end_temp_memory(temp);
|
end_temp_memory(temp);
|
||||||
}
|
}
|
||||||
|
@ -1444,26 +1452,25 @@ DOC_SEE(Buffer_Identifier)
|
||||||
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
System_Functions *system = cmd->system;
|
System_Functions *system = cmd->system;
|
||||||
Models *models = cmd->models;
|
Models *models = cmd->models;
|
||||||
Working_Set *working_set = &models->working_set;
|
|
||||||
View *vptr = imp_get_view(cmd, view_id);
|
|
||||||
Editing_File *file = get_file_from_identifier(system, working_set, buffer);
|
|
||||||
int32_t result = false;
|
|
||||||
|
|
||||||
if (file){
|
bool32 result = false;
|
||||||
if (flags & BufferKill_AlwaysKill){
|
Working_Set *working_set = &models->working_set;
|
||||||
|
Editing_File *file = get_file_from_identifier(system, working_set, buffer);
|
||||||
|
if (file != 0){
|
||||||
|
if ((flags & BufferKill_AlwaysKill) != 0){
|
||||||
result = true;
|
result = true;
|
||||||
kill_file(system, models, file);
|
kill_file_and_update_views(system, models, file);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
Try_Kill_Result kill_result = interactive_try_kill_file(system, models, file);
|
Try_Kill_Result kill_result = interactive_try_kill_file(system, models, file);
|
||||||
if (kill_result == TryKill_NeedDialogue){
|
if (kill_result == TryKill_NeedDialogue){
|
||||||
if (vptr){
|
View *vptr = imp_get_view(cmd, view_id);
|
||||||
|
if (vptr != 0){
|
||||||
interactive_begin_sure_to_kill(system, vptr, models, file);
|
interactive_begin_sure_to_kill(system, vptr, models, file);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
#define MESSAGE "CUSTOM WARNING: the buffer is dirty and no view was specified for a dialogue.\n"
|
char m[] = "WARNING: the buffer is dirty and no view was specified for a dialogue.\n";
|
||||||
print_message(app, literal(MESSAGE));
|
print_message(app, m, sizeof(m) - 1);
|
||||||
#undef MESSAGE
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
|
@ -2079,7 +2086,7 @@ DOC_SEE(Set_Buffer_Flag)
|
||||||
if (file != 0){
|
if (file != 0){
|
||||||
result = true;
|
result = true;
|
||||||
if (file != vptr->transient.file_data.file){
|
if (file != vptr->transient.file_data.file){
|
||||||
view_set_file(system, vptr, file, models);
|
view_set_file(system, models, vptr, file);
|
||||||
if (!(flags & SetBuffer_KeepOriginalGUI)){
|
if (!(flags & SetBuffer_KeepOriginalGUI)){
|
||||||
view_show_file(vptr);
|
view_show_file(vptr);
|
||||||
}
|
}
|
||||||
|
@ -2341,7 +2348,7 @@ DOC_RETURN(Returns true if the given id was a valid face and the change was made
|
||||||
|
|
||||||
Models *models = cmd->models;
|
Models *models = cmd->models;
|
||||||
if (apply_to_all_buffers){
|
if (apply_to_all_buffers){
|
||||||
global_set_font(system, models, id);
|
global_set_font_and_update_files(system, models, id);
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
models->global_font_id = id;
|
models->global_font_id = id;
|
||||||
|
@ -2543,7 +2550,7 @@ DOC_SEE(try_create_new_face)
|
||||||
Font_Settings settings;
|
Font_Settings settings;
|
||||||
if (face_description_to_settings(system, *description, &settings)){
|
if (face_description_to_settings(system, *description, &settings)){
|
||||||
Models *models = cmd->models;
|
Models *models = cmd->models;
|
||||||
if (alter_font(system, models, id, &settings)){
|
if (alter_font_and_update_files(system, models, id, &settings)){
|
||||||
success = true;
|
success = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2567,12 +2574,7 @@ DOC_RETURN(Returns true on success and zero on failure.)
|
||||||
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
Command_Data *cmd = (Command_Data*)app->cmd_context;
|
||||||
System_Functions *system = cmd->system;
|
System_Functions *system = cmd->system;
|
||||||
Models *models = cmd->models;
|
Models *models = cmd->models;
|
||||||
|
bool32 success = release_font_and_update_files(system, models, id, replacement_id);
|
||||||
bool32 success = false;
|
|
||||||
if (release_font(system, models, id, replacement_id)){
|
|
||||||
success = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return(success);
|
return(success);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2707,7 +2709,7 @@ DOC_SEE(File_List)
|
||||||
Partition *part = &cmd->models->mem.part;
|
Partition *part = &cmd->models->mem.part;
|
||||||
File_List result = {};
|
File_List result = {};
|
||||||
Temp_Memory temp = begin_temp_memory(part);
|
Temp_Memory temp = begin_temp_memory(part);
|
||||||
String str = make_string_terminated(part, dir, len);
|
String str = push_string(part, dir, len);
|
||||||
system->set_file_list(&result, str.str, 0, 0, 0);
|
system->set_file_list(&result, str.str, 0, 0, 0);
|
||||||
end_temp_memory(temp);
|
end_temp_memory(temp);
|
||||||
return(result);
|
return(result);
|
||||||
|
|
|
@ -63,6 +63,7 @@
|
||||||
#include "4ed_view.h"
|
#include "4ed_view.h"
|
||||||
#include "4ed_app_models.h"
|
#include "4ed_app_models.h"
|
||||||
|
|
||||||
|
#include "4ed_parse_context.cpp"
|
||||||
#include "4ed_font.cpp"
|
#include "4ed_font.cpp"
|
||||||
#include "4ed_translation.cpp"
|
#include "4ed_translation.cpp"
|
||||||
#include "4ed_render_target.cpp"
|
#include "4ed_render_target.cpp"
|
||||||
|
@ -70,12 +71,11 @@
|
||||||
#include "4ed_command.cpp"
|
#include "4ed_command.cpp"
|
||||||
#include "4ed_buffer.cpp"
|
#include "4ed_buffer.cpp"
|
||||||
#include "4ed_undo.cpp"
|
#include "4ed_undo.cpp"
|
||||||
|
#include "4ed_file_lex.cpp"
|
||||||
#include "4ed_file.cpp"
|
#include "4ed_file.cpp"
|
||||||
#include "4ed_code_wrap.cpp"
|
#include "4ed_code_wrap.cpp"
|
||||||
#include "4ed_working_set.cpp"
|
#include "4ed_working_set.cpp"
|
||||||
#include "4ed_hot_directory.cpp"
|
#include "4ed_hot_directory.cpp"
|
||||||
#include "4ed_parse_context.cpp"
|
|
||||||
#include "4ed_file_lex.cpp"
|
|
||||||
#include "4ed_cli.cpp"
|
#include "4ed_cli.cpp"
|
||||||
#include "4ed_gui.cpp"
|
#include "4ed_gui.cpp"
|
||||||
#include "4ed_layout.cpp"
|
#include "4ed_layout.cpp"
|
||||||
|
|
34
4ed_file.cpp
34
4ed_file.cpp
|
@ -681,5 +681,39 @@ file_free(System_Functions *system, General_Memory *general, Editing_File *file)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal void
|
||||||
|
init_normal_file(System_Functions *system, Models *models,
|
||||||
|
char *buffer, i32 size,
|
||||||
|
Editing_File *file){
|
||||||
|
PRFL_FUNC_GROUP();
|
||||||
|
|
||||||
|
String val = make_string(buffer, size);
|
||||||
|
file_create_from_string(system, models, file, val, 0);
|
||||||
|
|
||||||
|
if (file->settings.tokens_exist && file->state.token_array.tokens == 0){
|
||||||
|
if (!file->settings.virtual_white){
|
||||||
|
file_first_lex_parallel(system, models, file);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
file_first_lex_serial(models, file);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
internal void
|
||||||
|
init_read_only_file(System_Functions *system, Models *models, Editing_File *file){
|
||||||
|
String val = null_string;
|
||||||
|
file_create_from_string(system, models, file, val, FileCreateFlag_ReadOnly);
|
||||||
|
|
||||||
|
if (file->settings.tokens_exist && file->state.token_array.tokens == 0){
|
||||||
|
if (!file->settings.virtual_white){
|
||||||
|
file_first_lex_parallel(system, models, file);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
file_first_lex_serial(models, file);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// BOTTOM
|
// BOTTOM
|
||||||
|
|
||||||
|
|
|
@ -41,7 +41,7 @@ struct Font_Settings{
|
||||||
Font_Parameters parameters;
|
Font_Parameters parameters;
|
||||||
};
|
};
|
||||||
|
|
||||||
// NOTE(allen): Results about the font true for the entire font as a whole.
|
// NOTE(allen): Data about the font true for the entire font as a whole.
|
||||||
struct Font_Metrics{
|
struct Font_Metrics{
|
||||||
i32 name_len;
|
i32 name_len;
|
||||||
char name[256];
|
char name[256];
|
||||||
|
|
1587
4ed_view.cpp
1587
4ed_view.cpp
File diff suppressed because it is too large
Load Diff
53
4ed_view.h
53
4ed_view.h
|
@ -40,33 +40,36 @@ enum Interactive_Action{
|
||||||
IAct_Sure_To_Close
|
IAct_Sure_To_Close
|
||||||
};
|
};
|
||||||
|
|
||||||
enum Interactive_Interaction{
|
typedef i32 Unsaved_Changes_User_Response;
|
||||||
IInt_Sys_File_List,
|
enum{
|
||||||
IInt_Live_File_List,
|
UnsavedChangesUserResponse_ContinueAnyway = 0,
|
||||||
IInt_Sure_To_Kill,
|
UnsavedChangesUserResponse_Cancel = 1,
|
||||||
IInt_Sure_To_Close
|
UnsavedChangesUserResponse_SaveAndContinue = 2,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum View_UI{
|
typedef i32 Interactive_Interaction;
|
||||||
VUI_None,
|
enum{
|
||||||
VUI_Theme,
|
IInt_Sys_File_List = 0,
|
||||||
VUI_Interactive,
|
IInt_Live_File_List = 1,
|
||||||
VUI_Debug
|
IInt_Sure_To_Kill = 2,
|
||||||
|
IInt_Sure_To_Close = 3
|
||||||
};
|
};
|
||||||
|
|
||||||
enum Debug_Mode{
|
typedef i32 View_UI;
|
||||||
DBG_Input,
|
enum{
|
||||||
DBG_Threads_And_Memory,
|
VUI_None = 0,
|
||||||
DBG_View_Inspection
|
VUI_Theme = 1,
|
||||||
|
VUI_Interactive = 2,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum Color_View_Mode{
|
typedef i32 Color_View_Mode;
|
||||||
CV_Mode_Library,
|
enum{
|
||||||
CV_Mode_Font,
|
CV_Mode_Library = 0,
|
||||||
CV_Mode_Global_Font,
|
CV_Mode_Font = 1,
|
||||||
CV_Mode_Font_Editing,
|
CV_Mode_Global_Font = 2,
|
||||||
CV_Mode_Global_Font_Editing,
|
CV_Mode_Font_Editing = 3,
|
||||||
CV_Mode_Adjusting,
|
CV_Mode_Global_Font_Editing = 4,
|
||||||
|
CV_Mode_Adjusting = 5,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Scroll_Context{
|
struct Scroll_Context{
|
||||||
|
@ -75,12 +78,6 @@ struct Scroll_Context{
|
||||||
View_UI mode;
|
View_UI mode;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Debug_Vars{
|
|
||||||
i32 mode;
|
|
||||||
i32 inspecting_view_id;
|
|
||||||
};
|
|
||||||
global_const Debug_Vars null_debug_vars = {0};
|
|
||||||
|
|
||||||
struct View_Transient{
|
struct View_Transient{
|
||||||
struct View *next;
|
struct View *next;
|
||||||
struct View *prev;
|
struct View *prev;
|
||||||
|
@ -139,8 +136,6 @@ struct View_Transient{
|
||||||
f32 widget_height;
|
f32 widget_height;
|
||||||
|
|
||||||
b32 reinit_scrolling;
|
b32 reinit_scrolling;
|
||||||
|
|
||||||
Debug_Vars debug_vars;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct View{
|
struct View{
|
||||||
|
|
|
@ -9,9 +9,39 @@
|
||||||
|
|
||||||
// TOP
|
// TOP
|
||||||
|
|
||||||
//
|
// TODO(allen): Find a real home for this... string library needs a makeover.
|
||||||
// Working_Set of files
|
internal String
|
||||||
//
|
push_string(Partition *part, char *str, i32 len){
|
||||||
|
char *space = (char*)push_array(part, char, len + 1);
|
||||||
|
memcpy(space, str, len);
|
||||||
|
space[len] = 0;
|
||||||
|
String string = make_string_cap(space, len, len + 1);
|
||||||
|
return(string);
|
||||||
|
}
|
||||||
|
|
||||||
|
internal String
|
||||||
|
push_string(Partition *part, String str){
|
||||||
|
String res = push_string(part, str.str, str.size);
|
||||||
|
return(res);
|
||||||
|
}
|
||||||
|
|
||||||
|
internal String
|
||||||
|
push_string(Partition *part, char *str, i32 len, i32 cap){
|
||||||
|
cap = clamp_bottom(len + 1, cap);
|
||||||
|
char *space = (char*)push_array(part, char, cap);
|
||||||
|
memcpy(space, str, len);
|
||||||
|
space[len] = 0;
|
||||||
|
String string = make_string_cap(space, len, cap);
|
||||||
|
return(string);
|
||||||
|
}
|
||||||
|
|
||||||
|
internal String
|
||||||
|
push_string(Partition *part, String str, i32 cap){
|
||||||
|
String res = push_string(part, str.str, str.size, cap);
|
||||||
|
return(res);
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
working_set_extend_memory(Working_Set *working_set, Editing_File *new_space, i16 number_of_files){
|
working_set_extend_memory(Working_Set *working_set, Editing_File *new_space, i16 number_of_files){
|
||||||
|
@ -279,25 +309,87 @@ working_set_lookup_file(Working_Set *working_set, String string){
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
touch_file(Working_Set *working_set, Editing_File *file){
|
touch_file(Working_Set *working_set, Editing_File *file){
|
||||||
TentativeAssert(file != 0);
|
Assert(file != 0);
|
||||||
Assert(!file->is_dummy);
|
Assert(!file->is_dummy);
|
||||||
dll_remove(&file->node);
|
dll_remove(&file->node);
|
||||||
dll_insert(&working_set->used_sentinel, &file->node);
|
dll_insert(&working_set->used_sentinel, &file->node);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
////////////////////////////////
|
||||||
|
|
||||||
//
|
// TODO(allen): Bring the clipboard fully to the custom side.
|
||||||
// Name Binding
|
internal String*
|
||||||
//
|
working_set_next_clipboard_string(General_Memory *general, Working_Set *working, i32 str_size){
|
||||||
|
i32 clipboard_current = working->clipboard_current;
|
||||||
internal void
|
if (working->clipboard_size == 0){
|
||||||
editing_file_name_init(Editing_File_Name *name){
|
clipboard_current = 0;
|
||||||
name->name = make_fixed_width_string(name->name_);
|
working->clipboard_size = 1;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
++clipboard_current;
|
||||||
|
if (clipboard_current >= working->clipboard_max_size){
|
||||||
|
clipboard_current = 0;
|
||||||
|
}
|
||||||
|
else if (working->clipboard_size <= clipboard_current){
|
||||||
|
working->clipboard_size = clipboard_current + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
String *result = &working->clipboards[clipboard_current];
|
||||||
|
working->clipboard_current = clipboard_current;
|
||||||
|
working->clipboard_rolling = clipboard_current;
|
||||||
|
char *new_str;
|
||||||
|
if (result->str != 0){
|
||||||
|
new_str = (char*)general_memory_reallocate(general, result->str, result->size, str_size);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
new_str = (char*)general_memory_allocate(general, str_size+1);
|
||||||
|
}
|
||||||
|
// TODO(allen): What if new_str == 0?
|
||||||
|
*result = make_string_cap(new_str, 0, str_size);
|
||||||
|
return(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal String*
|
||||||
|
working_set_clipboard_index(Working_Set *working, i32 index){
|
||||||
|
String *result = 0;
|
||||||
|
i32 size = working->clipboard_size;
|
||||||
|
i32 current = working->clipboard_current;
|
||||||
|
if (index >= 0 && size > 0){
|
||||||
|
index = index % size;
|
||||||
|
index = current + size - index;
|
||||||
|
index = index % size;
|
||||||
|
result = &working->clipboards[index];
|
||||||
|
}
|
||||||
|
return(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
internal String*
|
||||||
|
working_set_clipboard_head(Working_Set *working){
|
||||||
|
String *result = 0;
|
||||||
|
if (working->clipboard_size > 0){
|
||||||
|
working->clipboard_rolling = 0;
|
||||||
|
result = working_set_clipboard_index(working, working->clipboard_rolling);
|
||||||
|
}
|
||||||
|
return(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
internal String*
|
||||||
|
working_set_clipboard_roll_down(Working_Set *working){
|
||||||
|
String *result = 0;
|
||||||
|
if (working->clipboard_size > 0){
|
||||||
|
i32 clipboard_index = working->clipboard_rolling;
|
||||||
|
++clipboard_index;
|
||||||
|
working->clipboard_rolling = clipboard_index;
|
||||||
|
result = working_set_clipboard_index(working, working->clipboard_rolling);
|
||||||
|
}
|
||||||
|
return(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////
|
||||||
|
|
||||||
internal b32
|
internal b32
|
||||||
get_canon_name(System_Functions *system, Editing_File_Name *canon_name, String filename){
|
get_canon_name(System_Functions *system, String filename,
|
||||||
|
Editing_File_Name *canon_name){
|
||||||
canon_name->name = make_fixed_width_string(canon_name->name_);
|
canon_name->name = make_fixed_width_string(canon_name->name_);
|
||||||
|
|
||||||
canon_name->name.size = system->get_canonical(filename.str, filename.size, canon_name->name.str, canon_name->name.memory_size);
|
canon_name->name.size = system->get_canonical(filename.str, filename.size, canon_name->name.str, canon_name->name.memory_size);
|
||||||
|
@ -308,16 +400,19 @@ get_canon_name(System_Functions *system, Editing_File_Name *canon_name, String f
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
buffer_bind_file(System_Functions *system, General_Memory *general, Working_Set *working_set, Editing_File *file, String canon_filename){
|
buffer_bind_file(System_Functions *system, General_Memory *general,
|
||||||
|
Working_Set *working_set,
|
||||||
|
Editing_File *file, String canon_filename){
|
||||||
Assert(file->unique_name.name.size == 0);
|
Assert(file->unique_name.name.size == 0);
|
||||||
Assert(file->canon.name.size == 0);
|
Assert(file->canon.name.size == 0);
|
||||||
|
|
||||||
file->canon.name = make_fixed_width_string(file->canon.name_);
|
file->canon.name = make_fixed_width_string(file->canon.name_);
|
||||||
copy_ss(&file->canon.name, canon_filename);
|
copy(&file->canon.name, canon_filename);
|
||||||
terminate_with_null(&file->canon.name);
|
terminate_with_null(&file->canon.name);
|
||||||
system->add_listener(file->canon.name.str);
|
system->add_listener(file->canon.name.str);
|
||||||
b32 result = working_set_canon_add(general, working_set, file, file->canon.name);
|
if (!working_set_canon_add(general, working_set, file, file->canon.name)){
|
||||||
Assert(result); AllowLocal(result);
|
InvalidCodePath;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
|
@ -371,17 +466,18 @@ buffer_bind_name_low_level(General_Memory *general, Working_Set *working_set, Ed
|
||||||
Assert(file->unique_name.name.size == 0);
|
Assert(file->unique_name.name.size == 0);
|
||||||
|
|
||||||
Editing_File_Name new_name = {0};
|
Editing_File_Name new_name = {0};
|
||||||
editing_file_name_init(&new_name);
|
new_name.name = make_fixed_width_string(new_name.name_);
|
||||||
buffer_resolve_name_low_level(working_set, &new_name, name);
|
buffer_resolve_name_low_level(working_set, &new_name, name);
|
||||||
|
|
||||||
editing_file_name_init(&file->base_name);
|
file->base_name.name = make_fixed_width_string(file->base_name.name_);
|
||||||
copy(&file->base_name.name, base_name);
|
copy(&file->base_name.name, base_name);
|
||||||
|
|
||||||
editing_file_name_init(&file->unique_name);
|
file->unique_name.name = make_fixed_width_string(file->unique_name.name_);
|
||||||
copy(&file->unique_name.name, new_name.name);
|
copy(&file->unique_name.name, new_name.name);
|
||||||
|
|
||||||
b32 result = working_set_add_name(general, working_set, file, file->unique_name.name);
|
if (!working_set_add_name(general, working_set, file, file->unique_name.name)){
|
||||||
Assert(result); AllowLocal(result);
|
InvalidCodePath;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void
|
internal void
|
||||||
|
@ -393,5 +489,135 @@ buffer_unbind_name_low_level(Working_Set *working_set, Editing_File *file){
|
||||||
file->unique_name.name.size = 0;
|
file->unique_name.name.size = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal void
|
||||||
|
buffer_bind_name(Models *models, General_Memory *general, Partition *scratch,
|
||||||
|
Working_Set *working_set,
|
||||||
|
Editing_File *file, String base_name){
|
||||||
|
Temp_Memory temp = begin_temp_memory(scratch);
|
||||||
|
|
||||||
|
// List of conflict files.
|
||||||
|
Editing_File **conflict_file_ptrs = push_array(scratch, Editing_File*, 0);
|
||||||
|
int32_t conflict_count = 0;
|
||||||
|
|
||||||
|
{
|
||||||
|
Editing_File **new_file_ptr = push_array(scratch, Editing_File*, 1);
|
||||||
|
*new_file_ptr = file;
|
||||||
|
++conflict_count;
|
||||||
|
}
|
||||||
|
|
||||||
|
File_Node *used_nodes = &working_set->used_sentinel;
|
||||||
|
for (File_Node *node = used_nodes->next; node != used_nodes; node = node->next){
|
||||||
|
Editing_File *file_ptr = (Editing_File*)node;
|
||||||
|
if (file_is_ready(file_ptr) && match(base_name, file_ptr->base_name.name)){
|
||||||
|
Editing_File **new_file_ptr = push_array(scratch, Editing_File*, 1);
|
||||||
|
*new_file_ptr = file_ptr;
|
||||||
|
++conflict_count;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fill conflict array.
|
||||||
|
Buffer_Name_Conflict_Entry *conflicts = push_array(scratch, Buffer_Name_Conflict_Entry, conflict_count);
|
||||||
|
|
||||||
|
for (int32_t i = 0; i < conflict_count; ++i){
|
||||||
|
Editing_File *file_ptr = conflict_file_ptrs[i];
|
||||||
|
Buffer_Name_Conflict_Entry *entry = &conflicts[i];
|
||||||
|
entry->buffer_id = file_ptr->id.id;
|
||||||
|
|
||||||
|
String file_name = push_string(scratch, file_ptr->canon.name);
|
||||||
|
entry->file_name = file_name.str;
|
||||||
|
entry->file_name_len = file_name.size;
|
||||||
|
|
||||||
|
String term_base_name = push_string(scratch, base_name);
|
||||||
|
entry->base_name = term_base_name.str;
|
||||||
|
entry->base_name_len = term_base_name.size;
|
||||||
|
|
||||||
|
String b = base_name;
|
||||||
|
if (i > 0){
|
||||||
|
b = file_ptr->unique_name.name;
|
||||||
|
}
|
||||||
|
i32 unique_name_capacity = 256;
|
||||||
|
String unique_name = push_string(scratch, b, unique_name_capacity);
|
||||||
|
entry->unique_name_in_out = unique_name.str;
|
||||||
|
entry->unique_name_len_in_out = unique_name.size;
|
||||||
|
entry->unique_name_capacity = unique_name_capacity;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get user's resolution data.
|
||||||
|
if (models->buffer_name_resolver != 0){
|
||||||
|
models->buffer_name_resolver(&models->app_links, conflicts, conflict_count);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Re-bind all of the files
|
||||||
|
for (int32_t i = 0; i < conflict_count; ++i){
|
||||||
|
Editing_File *file_ptr = conflict_file_ptrs[i];
|
||||||
|
if (file_ptr->unique_name.name.str != 0){
|
||||||
|
buffer_unbind_name_low_level(working_set, file_ptr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (int32_t i = 0; i < conflict_count; ++i){
|
||||||
|
Editing_File *file_ptr = conflict_file_ptrs[i];
|
||||||
|
Buffer_Name_Conflict_Entry *entry = &conflicts[i];
|
||||||
|
String unique_name = make_string(entry->unique_name_in_out, entry->unique_name_len_in_out);
|
||||||
|
buffer_bind_name_low_level(general, working_set, file_ptr, base_name, unique_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
end_temp_memory(temp);
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////
|
||||||
|
|
||||||
|
internal Editing_File*
|
||||||
|
open_file(System_Functions *system, Models *models, String filename){
|
||||||
|
Editing_File *file = 0;
|
||||||
|
Editing_File_Name canon_name = {0};
|
||||||
|
|
||||||
|
if (terminate_with_null(&filename) &&
|
||||||
|
get_canon_name(system, filename, &canon_name)){
|
||||||
|
Working_Set *working_set = &models->working_set;
|
||||||
|
file = working_set_contains_canon(working_set, canon_name.name);
|
||||||
|
if (file == 0){
|
||||||
|
Plat_Handle handle;
|
||||||
|
if (system->load_handle(canon_name.name.str, &handle)){
|
||||||
|
Mem_Options *mem = &models->mem;
|
||||||
|
General_Memory *general = &mem->general;
|
||||||
|
Partition *part = &mem->part;
|
||||||
|
|
||||||
|
file = working_set_alloc_always(working_set, general);
|
||||||
|
buffer_bind_file(system, general, working_set, file, canon_name.name);
|
||||||
|
buffer_bind_name(models, general, part, working_set, file, front_of_directory(filename));
|
||||||
|
|
||||||
|
i32 size = system->load_size(handle);
|
||||||
|
char *buffer = 0;
|
||||||
|
b32 gen_buffer = 0;
|
||||||
|
|
||||||
|
Temp_Memory temp = begin_temp_memory(part);
|
||||||
|
|
||||||
|
buffer = push_array(part, char, size);
|
||||||
|
if (buffer == 0){
|
||||||
|
buffer = (char*)general_memory_allocate(general, size);
|
||||||
|
Assert(buffer);
|
||||||
|
gen_buffer = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (system->load_file(handle, buffer, size)){
|
||||||
|
system->load_close(handle);
|
||||||
|
init_normal_file(system, models, buffer, size, file);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
system->load_close(handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gen_buffer){
|
||||||
|
general_memory_free(general, buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
end_temp_memory(temp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return(file);
|
||||||
|
}
|
||||||
|
|
||||||
// BOTTOM
|
// BOTTOM
|
||||||
|
|
||||||
|
|
|
@ -688,7 +688,6 @@ generate_remapping_code_and_data(){
|
||||||
bind(mappings, 'S', MDFR_CTRL, save_all_dirty_buffers);
|
bind(mappings, 'S', MDFR_CTRL, save_all_dirty_buffers);
|
||||||
|
|
||||||
bind(mappings, 'c', MDFR_ALT, open_color_tweaker);
|
bind(mappings, 'c', MDFR_ALT, open_color_tweaker);
|
||||||
bind(mappings, 'd', MDFR_ALT, open_debug);
|
|
||||||
|
|
||||||
bind(mappings, '.', MDFR_ALT, change_to_build_panel);
|
bind(mappings, '.', MDFR_ALT, change_to_build_panel);
|
||||||
bind(mappings, ',', MDFR_ALT, close_build_panel);
|
bind(mappings, ',', MDFR_ALT, close_build_panel);
|
||||||
|
@ -888,7 +887,6 @@ generate_remapping_code_and_data(){
|
||||||
bind(mappings, 'S', MDFR_CMND, save_all_dirty_buffers);
|
bind(mappings, 'S', MDFR_CMND, save_all_dirty_buffers);
|
||||||
|
|
||||||
bind(mappings, 'c', MDFR_CTRL, open_color_tweaker);
|
bind(mappings, 'c', MDFR_CTRL, open_color_tweaker);
|
||||||
bind(mappings, 'd', MDFR_CTRL, open_debug);
|
|
||||||
|
|
||||||
bind(mappings, '.', MDFR_CTRL, change_to_build_panel);
|
bind(mappings, '.', MDFR_CTRL, change_to_build_panel);
|
||||||
bind(mappings, ',', MDFR_CTRL, close_build_panel);
|
bind(mappings, ',', MDFR_CTRL, close_build_panel);
|
||||||
|
|
Loading…
Reference in New Issue