implemented windows fullscreen (hacking alt tab), improved the next error part of the jump parsing
							parent
							
								
									df236e44b5
								
							
						
					
					
						commit
						084d45b530
					
				|  | @ -102,7 +102,7 @@ CUSTOM_COMMAND_SIG(rewrite_as_single_caps){ | ||||||
| CUSTOM_COMMAND_SIG(open_my_files){ | CUSTOM_COMMAND_SIG(open_my_files){ | ||||||
|     uint32_t access = AccessAll; |     uint32_t access = AccessAll; | ||||||
|     View_Summary view = app->get_active_view(app, access); |     View_Summary view = app->get_active_view(app, access); | ||||||
|     view_open_file(app, &view, literal("w:/4ed/data/test/basic.cpp"), false); |     view_open_file(app, &view, literal("w:/4ed/data/test/basic.cpp"), true); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CUSTOM_COMMAND_SIG(build_at_launch_location){ | CUSTOM_COMMAND_SIG(build_at_launch_location){ | ||||||
|  | @ -160,6 +160,7 @@ CUSTOM_COMMAND_SIG(newline_or_goto_position){ | ||||||
|      |      | ||||||
|     if (buffer.lock_flags & AccessProtected){ |     if (buffer.lock_flags & AccessProtected){ | ||||||
|         exec_command(app, goto_jump_at_cursor); |         exec_command(app, goto_jump_at_cursor); | ||||||
|  |         lock_jump_buffer(buffer); | ||||||
|     } |     } | ||||||
|     else{ |     else{ | ||||||
|         exec_command(app, write_character); |         exec_command(app, write_character); | ||||||
|  |  | ||||||
|  | @ -15,8 +15,10 @@ | ||||||
| //
 | //
 | ||||||
| 
 | 
 | ||||||
| CUSTOM_COMMAND_SIG(build_in_build_panel){ | CUSTOM_COMMAND_SIG(build_in_build_panel){ | ||||||
|  |     String comp_name = make_lit_string("*compilation*"); | ||||||
|  |      | ||||||
|     Buffer_Summary buffer = |     Buffer_Summary buffer = | ||||||
|         app->get_buffer_by_name(app, literal("*compilation*"), AccessAll); |         app->get_buffer_by_name(app, comp_name.str, comp_name.size, AccessAll); | ||||||
|     View_Summary build_view = {0}; |     View_Summary build_view = {0}; | ||||||
|      |      | ||||||
|     View_Summary original_view = app->get_active_view(app, AccessAll); |     View_Summary original_view = app->get_active_view(app, AccessAll); | ||||||
|  | @ -37,10 +39,12 @@ CUSTOM_COMMAND_SIG(build_in_build_panel){ | ||||||
|      |      | ||||||
|     execute_standard_build(app, &build_view, &original_buffer); |     execute_standard_build(app, &build_view, &original_buffer); | ||||||
|      |      | ||||||
|     buffer = app->get_buffer_by_name(app, literal("*compilation*"), AccessAll); |     buffer = app->get_buffer_by_name(app, comp_name.str, comp_name.size, AccessAll); | ||||||
|     app->buffer_set_font(app, &buffer, literal("Inconsolata")); |     app->buffer_set_font(app, &buffer, literal("Inconsolata")); | ||||||
|      |      | ||||||
|     prev_location = null_location; |     prev_location = null_location; | ||||||
|  |      | ||||||
|  |     lock_jump_buffer(comp_name.str, comp_name.size); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // TODO(allen): This is a bit nasty.  I want a system for picking
 | // TODO(allen): This is a bit nasty.  I want a system for picking
 | ||||||
|  | @ -133,7 +137,7 @@ CUSTOM_COMMAND_SIG(open_file_in_quotes_build){ | ||||||
|     if (file_name_in_quotes(app, &file_name)){ |     if (file_name_in_quotes(app, &file_name)){ | ||||||
|         exec_command(app, change_active_panel_build); |         exec_command(app, change_active_panel_build); | ||||||
|         View_Summary view = app->get_active_view(app, AccessAll); |         View_Summary view = app->get_active_view(app, AccessAll); | ||||||
|         view_open_file(app, &view, expand_str(file_name), false); |         view_open_file(app, &view, expand_str(file_name), true); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -19,6 +19,97 @@ | ||||||
| # define DEF_TAB_WIDTH 4 | # define DEF_TAB_WIDTH 4 | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | //
 | ||||||
|  | // Useful helper functions
 | ||||||
|  | //
 | ||||||
|  | 
 | ||||||
|  | static int32_t | ||||||
|  | open_file(Application_Links *app, | ||||||
|  |           Buffer_Summary *buffer_out, | ||||||
|  |           char *filename, | ||||||
|  |           int32_t filename_len, | ||||||
|  |           int32_t background, | ||||||
|  |           int32_t never_new){ | ||||||
|  |     int32_t result = false; | ||||||
|  |     Buffer_Summary buffer = | ||||||
|  |         app->get_buffer_by_name(app, filename, filename_len, | ||||||
|  |                                 AccessProtected|AccessHidden); | ||||||
|  |      | ||||||
|  |     if (buffer.exists){ | ||||||
|  |         if (buffer_out) *buffer_out = buffer; | ||||||
|  |         result = true; | ||||||
|  |     } | ||||||
|  |     else{ | ||||||
|  |         Buffer_Create_Flag flags = 0; | ||||||
|  |         if (background){ | ||||||
|  |             flags |= BufferCreate_Background; | ||||||
|  |         } | ||||||
|  |         if (never_new){ | ||||||
|  |             flags |= BufferCreate_NeverNew; | ||||||
|  |         } | ||||||
|  |         buffer = app->create_buffer(app, filename, filename_len, flags); | ||||||
|  |         if (buffer.exists){ | ||||||
|  |             if (buffer_out) *buffer_out = buffer; | ||||||
|  |             result = true; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     return(result); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static int32_t | ||||||
|  | view_open_file(Application_Links *app, | ||||||
|  |                View_Summary *view, | ||||||
|  |                char *filename, | ||||||
|  |                int32_t filename_len, | ||||||
|  |                int32_t never_new){ | ||||||
|  |     int32_t result = false; | ||||||
|  |      | ||||||
|  |     if (view){ | ||||||
|  |         Buffer_Summary buffer = {0}; | ||||||
|  |         if (open_file(app, &buffer, filename, filename_len, false, never_new)){ | ||||||
|  |             app->view_set_buffer(app, view, buffer.buffer_id, 0); | ||||||
|  |             result = true; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     return(result); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static int32_t | ||||||
|  | read_line(Application_Links *app, | ||||||
|  |           Partition *part, | ||||||
|  |           Buffer_Summary *buffer, | ||||||
|  |           int32_t line, | ||||||
|  |           String *str){ | ||||||
|  |      | ||||||
|  |     Partial_Cursor begin = {0}; | ||||||
|  |     Partial_Cursor end = {0}; | ||||||
|  |      | ||||||
|  |     int32_t success = false; | ||||||
|  |      | ||||||
|  |     if (app->buffer_compute_cursor(app, buffer, | ||||||
|  |                                    seek_line_char(line, 1), &begin)){ | ||||||
|  |         if (app->buffer_compute_cursor(app, buffer, | ||||||
|  |                                        seek_line_char(line, 65536), &end)){ | ||||||
|  |             if (begin.line == line){ | ||||||
|  |                 if (0 <= begin.pos && begin.pos <= end.pos && end.pos <= buffer->size){ | ||||||
|  |                     int32_t size = (end.pos - begin.pos); | ||||||
|  |                     *str = make_string(push_array(part, char, size+1), size+1); | ||||||
|  |                     if (str->str){ | ||||||
|  |                         success = true; | ||||||
|  |                         app->buffer_read_range(app, buffer, begin.pos, end.pos, str->str); | ||||||
|  |                         str->size = size; | ||||||
|  |                         terminate_with_null(str); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     return(success); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| //
 | //
 | ||||||
| // Memory
 | // Memory
 | ||||||
|  | @ -1571,7 +1662,7 @@ CUSTOM_COMMAND_SIG(open_file_in_quotes_regular){ | ||||||
|     if (file_name_in_quotes(app, &file_name)){ |     if (file_name_in_quotes(app, &file_name)){ | ||||||
|         exec_command(app, change_active_panel_regular); |         exec_command(app, change_active_panel_regular); | ||||||
|         View_Summary view = app->get_active_view(app, AccessAll); |         View_Summary view = app->get_active_view(app, AccessAll); | ||||||
|         view_open_file(app, &view, expand_str(file_name), false); |         view_open_file(app, &view, expand_str(file_name), true); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -2241,6 +2332,7 @@ CUSTOM_COMMAND_SIG(eol_nixify){ | ||||||
| 
 | 
 | ||||||
| #include "4coder_table.cpp" | #include "4coder_table.cpp" | ||||||
| #include "4coder_search.cpp" | #include "4coder_search.cpp" | ||||||
|  | #include "4coder_jump_parsing.cpp" | ||||||
| 
 | 
 | ||||||
| static void | static void | ||||||
| generic_search_all_buffers(Application_Links *app, General_Memory *general, Partition *part, | generic_search_all_buffers(Application_Links *app, General_Memory *general, Partition *part, | ||||||
|  | @ -2265,9 +2357,12 @@ generic_search_all_buffers(Application_Links *app, General_Memory *general, Part | ||||||
|      |      | ||||||
|     Search_Range *ranges = set.ranges; |     Search_Range *ranges = set.ranges; | ||||||
|      |      | ||||||
|     Buffer_Summary search_buffer = app->get_buffer_by_name(app, literal("*search*"), AccessAll); |     String search_name = make_lit_string("*search*"); | ||||||
|  |      | ||||||
|  |     Buffer_Summary search_buffer = app->get_buffer_by_name(app, search_name.str, search_name.size, | ||||||
|  |                                                            AccessAll); | ||||||
|     if (!search_buffer.exists){ |     if (!search_buffer.exists){ | ||||||
|         search_buffer = app->create_buffer(app, literal("*search*"), BufferCreate_AlwaysNew); |         search_buffer = app->create_buffer(app, search_name.str, search_name.size, BufferCreate_AlwaysNew); | ||||||
|         app->buffer_set_setting(app, &search_buffer, BufferSetting_Unimportant, true); |         app->buffer_set_setting(app, &search_buffer, BufferSetting_Unimportant, true); | ||||||
|         app->buffer_set_setting(app, &search_buffer, BufferSetting_ReadOnly, true); |         app->buffer_set_setting(app, &search_buffer, BufferSetting_ReadOnly, true); | ||||||
|         app->buffer_set_setting(app, &search_buffer, BufferSetting_WrapLine, false); |         app->buffer_set_setting(app, &search_buffer, BufferSetting_WrapLine, false); | ||||||
|  | @ -2370,6 +2465,8 @@ generic_search_all_buffers(Application_Links *app, General_Memory *general, Part | ||||||
|     View_Summary view = app->get_active_view(app, AccessAll); |     View_Summary view = app->get_active_view(app, AccessAll); | ||||||
|     app->view_set_buffer(app, &view, search_buffer.buffer_id, 0); |     app->view_set_buffer(app, &view, search_buffer.buffer_id, 0); | ||||||
|      |      | ||||||
|  |     lock_jump_buffer(search_name.str, search_name.size); | ||||||
|  |      | ||||||
|     end_temp_memory(temp); |     end_temp_memory(temp); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -418,65 +418,4 @@ buffer_identifier(int32_t id){ | ||||||
|     return(identifier); |     return(identifier); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int32_t |  | ||||||
| view_open_file(Application_Links *app, View_Summary *view, |  | ||||||
|                char *filename, int32_t filename_len, int32_t do_in_background){ |  | ||||||
|     int32_t result = false; |  | ||||||
|     Buffer_Summary buffer = app->get_buffer_by_name(app, filename, filename_len, AccessProtected|AccessHidden); |  | ||||||
|     if (buffer.exists){ |  | ||||||
|         if (!do_in_background){ |  | ||||||
|             if (view){ |  | ||||||
|                 app->view_set_buffer(app, view, buffer.buffer_id, 0); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         result = true; |  | ||||||
|     } |  | ||||||
|     else{ |  | ||||||
|         buffer = app->create_buffer(app, filename, filename_len, do_in_background); |  | ||||||
|         if (!do_in_background){ |  | ||||||
|             if (buffer.exists){ |  | ||||||
|                 if (view){ |  | ||||||
|                     app->view_set_buffer(app, view, buffer.buffer_id, 0); |  | ||||||
|                     result = true; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     return(result); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static int32_t |  | ||||||
| read_line(Application_Links *app, |  | ||||||
|           Partition *part, |  | ||||||
|           Buffer_Summary *buffer, |  | ||||||
|           int32_t line, |  | ||||||
|           String *str){ |  | ||||||
|      |  | ||||||
|     Partial_Cursor begin = {0}; |  | ||||||
|     Partial_Cursor end = {0}; |  | ||||||
|      |  | ||||||
|     int32_t success = false; |  | ||||||
|      |  | ||||||
|     if (app->buffer_compute_cursor(app, buffer, |  | ||||||
|                                    seek_line_char(line, 1), &begin)){ |  | ||||||
|         if (app->buffer_compute_cursor(app, buffer, |  | ||||||
|                                        seek_line_char(line, 65536), &end)){ |  | ||||||
|             if (begin.line == line){ |  | ||||||
|                 if (0 <= begin.pos && begin.pos <= end.pos && end.pos <= buffer->size){ |  | ||||||
|                     int32_t size = (end.pos - begin.pos); |  | ||||||
|                     *str = make_string(push_array(part, char, size+1), size+1); |  | ||||||
|                     if (str->str){ |  | ||||||
|                         success = true; |  | ||||||
|                         app->buffer_read_range(app, buffer, begin.pos, end.pos, str->str); |  | ||||||
|                         str->size = size; |  | ||||||
|                         terminate_with_null(str); |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|      |  | ||||||
|     return(success); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | @ -2,16 +2,24 @@ | ||||||
| #ifndef FCODER_JUMP_PARSING | #ifndef FCODER_JUMP_PARSING | ||||||
| #define FCODER_JUMP_PARSING | #define FCODER_JUMP_PARSING | ||||||
| 
 | 
 | ||||||
| struct Jump_Location{ | typedef struct Name_Based_Jump_Location{ | ||||||
|     String file; |     String file; | ||||||
|     int32_t line; |     int32_t line; | ||||||
|     int32_t column; |     int32_t column; | ||||||
| }; | } Name_Based_Jump_Location; | ||||||
|  | 
 | ||||||
|  | typedef struct ID_Based_Jump_Location{ | ||||||
|  |     int32_t buffer_id; | ||||||
|  |     int32_t line; | ||||||
|  |     int32_t column; | ||||||
|  | } ID_Based_Jump_Location; | ||||||
|  | static ID_Based_Jump_Location null_location = {0}; | ||||||
| 
 | 
 | ||||||
| static void | static void | ||||||
| jump_to_location(Application_Links *app, View_Summary *view, Jump_Location *l){ | jump_to_location(Application_Links *app, View_Summary *view, Name_Based_Jump_Location *l){ | ||||||
|     view_open_file(app, view, l->file.str, l->file.size, false); |     if (view_open_file(app, view, l->file.str, l->file.size, true)){ | ||||||
|     app->view_set_cursor(app, view, seek_line_char(l->line, l->column), true); |         app->view_set_cursor(app, view, seek_line_char(l->line, l->column), true); | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int32_t | static int32_t | ||||||
|  | @ -30,8 +38,8 @@ ms_style_verify(String line, int32_t paren_pos){ | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int32_t | static int32_t | ||||||
| parse_error(String line, Jump_Location *location, | parse_jump_location(String line, Name_Based_Jump_Location *location, | ||||||
|             int32_t skip_sub_errors, int32_t *colon_char){ |                     int32_t skip_sub_errors, int32_t *colon_char){ | ||||||
|     int32_t result = false; |     int32_t result = false; | ||||||
|      |      | ||||||
|     String original_line = line; |     String original_line = line; | ||||||
|  | @ -151,18 +159,19 @@ parse_error(String line, Jump_Location *location, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int32_t | static int32_t | ||||||
| goto_error(Application_Links *app, | parse_jump_from_buffer_line(Application_Links *app, | ||||||
|            Partition *part, |                             Partition *part, | ||||||
|            View_Summary *view, int32_t line, |                             int32_t buffer_id, | ||||||
|            Jump_Location *location, |                             int32_t line, | ||||||
|            int32_t skip_sub_errors){ |                             int32_t skip_sub_errors, | ||||||
|  |                             Name_Based_Jump_Location *location){ | ||||||
|      |      | ||||||
|     int32_t result = false; |     int32_t result = false; | ||||||
|     String line_str = {0}; |     String line_str = {0}; | ||||||
|     Buffer_Summary buffer = app->get_buffer(app, view->buffer_id, AccessAll); |     Buffer_Summary buffer = app->get_buffer(app, buffer_id, AccessAll); | ||||||
|     if (read_line(app, part, &buffer, line, &line_str)){ |     if (read_line(app, part, &buffer, line, &line_str)){ | ||||||
|         int32_t colon_char = 0; |         int32_t colon_char = 0; | ||||||
|         if (parse_error(line_str, location, skip_sub_errors, &colon_char)){ |         if (parse_jump_location(line_str, location, skip_sub_errors, &colon_char)){ | ||||||
|             result = true; |             result = true; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | @ -174,10 +183,10 @@ CUSTOM_COMMAND_SIG(goto_jump_at_cursor){ | ||||||
|     Temp_Memory temp = begin_temp_memory(&global_part); |     Temp_Memory temp = begin_temp_memory(&global_part); | ||||||
|     View_Summary view = app->get_active_view(app, AccessProtected); |     View_Summary view = app->get_active_view(app, AccessProtected); | ||||||
|      |      | ||||||
|     Jump_Location location = {0}; |     Name_Based_Jump_Location location = {0}; | ||||||
|     if (goto_error(app, &global_part, |     if (parse_jump_from_buffer_line(app, &global_part, | ||||||
|                    &view, view.cursor.line, |                                     view.buffer_id, view.cursor.line, false, | ||||||
|                    &location, false)){ |                                     &location)){ | ||||||
|          |          | ||||||
|         exec_command(app, change_active_panel); |         exec_command(app, change_active_panel); | ||||||
|         view = app->get_active_view(app, AccessAll); |         view = app->get_active_view(app, AccessAll); | ||||||
|  | @ -185,38 +194,33 @@ CUSTOM_COMMAND_SIG(goto_jump_at_cursor){ | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     end_temp_memory(temp); |     end_temp_memory(temp); | ||||||
|          |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| //
 | //
 | ||||||
| // Error Jumping
 | // Error Jumping
 | ||||||
| //
 | //
 | ||||||
| 
 | 
 | ||||||
| struct Prev_Jump{ |  | ||||||
|     int32_t buffer_id; |  | ||||||
|     int32_t line; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| static Prev_Jump null_location = {0}; |  | ||||||
| static Prev_Jump prev_location = {0}; |  | ||||||
| 
 |  | ||||||
| // TODO(allen): GIVE THESE THINGS NAMES I CAN FUCKING UNDERSTAND
 |  | ||||||
| static int32_t | static int32_t | ||||||
| next_error(Application_Links *app, | seek_next_jump_in_buffer(Application_Links *app, | ||||||
|            Partition *part, |                          Partition *part, | ||||||
|            View_Summary *comp_out, int32_t *start_line, |                          int32_t buffer_id, | ||||||
|            Jump_Location *location, |                          int32_t first_line, | ||||||
|            int32_t skip_sub_errors, |                          bool32 skip_sub_errors, | ||||||
|            int32_t direction, |                          int32_t direction, | ||||||
|            int32_t *colon_char){ |                          int32_t *line_out, | ||||||
|  |                          int32_t *colon_index_out, | ||||||
|  |                          Name_Based_Jump_Location *location_out){ | ||||||
|  |      | ||||||
|  |     Assert(direction == 1 || direction == -1); | ||||||
|      |      | ||||||
|     int32_t result = false; |     int32_t result = false; | ||||||
|     int32_t line = *start_line + direction; |     int32_t line = first_line; | ||||||
|     String line_str = {0}; |     String line_str = {0}; | ||||||
|     Buffer_Summary buffer = app->get_buffer(app, comp_out->buffer_id, AccessAll); |     Buffer_Summary buffer = app->get_buffer(app, buffer_id, AccessAll); | ||||||
|     for (;;){ |     for (;;){ | ||||||
|         if (read_line(app, part, &buffer, line, &line_str)){ |         if (read_line(app, part, &buffer, line, &line_str)){ | ||||||
|             if (parse_error(line_str, location, skip_sub_errors, colon_char)){ |             if (parse_jump_location(line_str, location_out, skip_sub_errors, colon_index_out)){ | ||||||
|                 result = true; |                 result = true; | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|  | @ -231,79 +235,86 @@ next_error(Application_Links *app, | ||||||
|         line = 0; |         line = 0; | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     *start_line = line; |     *line_out = line; | ||||||
|      |      | ||||||
|     return(result); |     return(result); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static Prev_Jump | static ID_Based_Jump_Location | ||||||
| jump_location_store(Application_Links *app, Jump_Location loc){ | convert_name_based_to_id_based(Application_Links *app, Name_Based_Jump_Location loc){ | ||||||
|     Prev_Jump result = {0}; |     ID_Based_Jump_Location result = {0}; | ||||||
|     Buffer_Summary buffer = |     Buffer_Summary buffer = | ||||||
|         app->get_buffer_by_name(app, loc.file.str, loc.file.size, AccessAll); |         app->get_buffer_by_name(app, loc.file.str, loc.file.size, AccessAll); | ||||||
|      |      | ||||||
|     if (buffer.exists){ |     if (buffer.exists){ | ||||||
|         result.buffer_id = buffer.buffer_id; |         result.buffer_id = buffer.buffer_id; | ||||||
|         result.line = loc.line; |         result.line = loc.line; | ||||||
|  |         result.column = loc.column; | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     return(result); |     return(result); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int32_t | static int32_t | ||||||
| seek_error_internal(Application_Links *app, Partition *part, | seek_next_jump_in_view(Application_Links *app, | ||||||
|                     int32_t skip_sub_errors, int32_t dir, Jump_Location *loc){ |                        Partition *part, | ||||||
|  |                        View_Summary *view, | ||||||
|  |                        int32_t skip_sub_errors, | ||||||
|  |                        int32_t direction, | ||||||
|  |                        int32_t *line_out, | ||||||
|  |                        int32_t *colon_index_out, | ||||||
|  |                        Name_Based_Jump_Location *location_out){ | ||||||
|     int32_t result = false; |     int32_t result = false; | ||||||
|      |      | ||||||
|     Jump_Location location = {0}; |     Name_Based_Jump_Location location = {0}; | ||||||
|     Buffer_Summary buffer = app->get_buffer_by_name(app, literal("*compilation*"), AccessAll); |     int32_t line = view->cursor.line; | ||||||
|     if (buffer.exists){ |     int32_t colon_index = 0; | ||||||
|         View_Summary view = get_first_view_with_buffer(app, buffer.buffer_id); |     if (seek_next_jump_in_buffer(app, part, view->buffer_id, | ||||||
|         int32_t line = view.cursor.line; |                                  line+direction, skip_sub_errors, direction, | ||||||
|          |                                  &line, &colon_index, &location)){ | ||||||
|         int32_t colon_char = 0; |         result = true; | ||||||
|         if (next_error(app, part, &view, &line, &location, |         *line_out = line; | ||||||
|                        skip_sub_errors, dir, &colon_char)){ |         *colon_index_out = colon_index; | ||||||
|              |         *location_out = location; | ||||||
|             View_Summary active_view = app->get_active_view(app, AccessAll); |  | ||||||
|             if (active_view.view_id == view.view_id){ |  | ||||||
|                 exec_command(app, change_active_panel_regular); |  | ||||||
|                 active_view = app->get_active_view(app, AccessAll); |  | ||||||
|             } |  | ||||||
|              |  | ||||||
|             jump_to_location(app, &active_view, &location); |  | ||||||
|             app->view_set_cursor(app, &view, seek_line_char(line, colon_char+1), true); |  | ||||||
|             result = true; |  | ||||||
|             if (loc){ |  | ||||||
|                 *loc = location; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     return(result); |     return(result); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| static int32_t | static int32_t | ||||||
| skip_this_jump(Prev_Jump prev, Prev_Jump jump){ | skip_this_jump(ID_Based_Jump_Location prev, ID_Based_Jump_Location jump){ | ||||||
|     int32_t result = false; |     int32_t result = false; | ||||||
|     if (prev.buffer_id != 0 && prev.buffer_id == jump.buffer_id && |     if (prev.buffer_id != 0 && | ||||||
|         prev.line == jump.line){ |         prev.buffer_id == jump.buffer_id && | ||||||
|  |         prev.line == jump.line && | ||||||
|  |         prev.column <= jump.column){ | ||||||
|         result = true; |         result = true; | ||||||
|     } |     } | ||||||
|     return(result); |     return(result); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static ID_Based_Jump_Location prev_location = {0}; | ||||||
|  | 
 | ||||||
| static int32_t | static int32_t | ||||||
| seek_error_skip_repeats(Application_Links *app, Partition *part, | advance_cursor_in_jump_view(Application_Links *app, | ||||||
|                         int32_t skip_sub_error, int32_t dir){ |                             Partition *part, | ||||||
|  |                             View_Summary *view, | ||||||
|  |                             int32_t skip_repeats, | ||||||
|  |                             int32_t skip_sub_error, | ||||||
|  |                             int32_t direction, | ||||||
|  |                             Name_Based_Jump_Location *location_out){ | ||||||
|     int32_t result = true; |     int32_t result = true; | ||||||
|     Jump_Location location = {0}; |      | ||||||
|     Prev_Jump jump = {0}; |     Name_Based_Jump_Location location = {0}; | ||||||
|  |     ID_Based_Jump_Location jump = {0}; | ||||||
|  |     int32_t line = 0, colon_index = 0; | ||||||
|  |      | ||||||
|     do{ |     do{ | ||||||
|         Temp_Memory temp = begin_temp_memory(part); |         Temp_Memory temp = begin_temp_memory(part); | ||||||
|         if (seek_error_internal(app, part, skip_sub_error, dir, &location)){ |         if (seek_next_jump_in_view(app, part, view, | ||||||
|             jump = jump_location_store(app, location); |                                    skip_sub_error, direction, | ||||||
|  |                                    &line, &colon_index, &location)){ | ||||||
|  |             jump = convert_name_based_to_id_based(app, location); | ||||||
|             result = true; |             result = true; | ||||||
|         } |         } | ||||||
|         else{ |         else{ | ||||||
|  | @ -311,68 +322,121 @@ seek_error_skip_repeats(Application_Links *app, Partition *part, | ||||||
|             result = false; |             result = false; | ||||||
|         } |         } | ||||||
|         end_temp_memory(temp); |         end_temp_memory(temp); | ||||||
|     }while(skip_this_jump(prev_location, jump)); |     }while(skip_repeats && skip_this_jump(prev_location, jump)); | ||||||
|  |      | ||||||
|  |     if (result){ | ||||||
|  |         *location_out = location; | ||||||
|  |         app->view_set_cursor(app, view, seek_line_char(line, colon_index+1), true); | ||||||
|  |     } | ||||||
|  |      | ||||||
|     prev_location = jump; |     prev_location = jump; | ||||||
|  |      | ||||||
|     return(result); |     return(result); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static char locked_buffer_space[256]; | ||||||
|  | static String locked_buffer = make_fixed_width_string(locked_buffer_space); | ||||||
|  | 
 | ||||||
|  | static void | ||||||
|  | unlock_jump_buffer(){ | ||||||
|  |     locked_buffer.size = 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static void | ||||||
|  | lock_jump_buffer(char *name, int32_t size){ | ||||||
|  |     copy(&locked_buffer, make_string(name, size)); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static void | ||||||
|  | lock_jump_buffer(Buffer_Summary buffer){ | ||||||
|  |     copy(&locked_buffer, make_string(buffer.buffer_name, buffer.buffer_name_len)); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static View_Summary | ||||||
|  | get_view_for_locked_jump_buffer(Application_Links *app){ | ||||||
|  |     View_Summary view = {0}; | ||||||
|  |      | ||||||
|  |     if (locked_buffer.size > 0){ | ||||||
|  |         Buffer_Summary buffer = app->get_buffer_by_name(app, locked_buffer.str, locked_buffer.size, AccessAll); | ||||||
|  |         if (buffer.exists){ | ||||||
|  |             view = get_first_view_with_buffer(app, buffer.buffer_id); | ||||||
|  |         } | ||||||
|  |         else{ | ||||||
|  |             unlock_jump_buffer(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     return(view); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static int32_t | static int32_t | ||||||
| seek_error_no_skip(Application_Links *app, Partition *part, | seek_error(Application_Links *app, | ||||||
|                    int32_t skip_sub_error, int32_t dir){ |            Partition *part, | ||||||
|     int32_t result = true; |            int32_t skip_repeats, | ||||||
|     Jump_Location location = {0}; |            int32_t skip_sub_errors, | ||||||
|     Prev_Jump jump = {0}; |            int32_t direction){ | ||||||
|  |     int32_t result = 0; | ||||||
|      |      | ||||||
|     Temp_Memory temp = begin_temp_memory(part); |     View_Summary view = get_view_for_locked_jump_buffer(app); | ||||||
|     if (seek_error_internal(app, part, skip_sub_error, dir, &location)){ |     if (view.exists){ | ||||||
|         jump = jump_location_store(app, location); |          | ||||||
|         result = true; |         Name_Based_Jump_Location location = {0}; | ||||||
|     } |         if (advance_cursor_in_jump_view(app, &global_part, &view, | ||||||
|     else{ |                                         skip_repeats, skip_sub_errors, direction, | ||||||
|         result = false; |                                         &location)){ | ||||||
|     } |             View_Summary active_view = app->get_active_view(app, AccessAll); | ||||||
|     end_temp_memory(temp); |             if (active_view.view_id == view.view_id){ | ||||||
|  |                 exec_command(app, change_active_panel_regular); | ||||||
|  |                 active_view = app->get_active_view(app, AccessAll); | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             jump_to_location(app, &active_view, &location); | ||||||
|  |             result = 1; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|      |      | ||||||
|     prev_location = jump; |  | ||||||
|     return(result); |     return(result); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int32_t |  | ||||||
| seek_error(Application_Links *app, Partition *part, |  | ||||||
|            int32_t skip_sub_error, int32_t skip_same_line, int32_t dir){ |  | ||||||
|     if (skip_same_line){ |  | ||||||
|         seek_error_skip_repeats(app, part, skip_sub_error, dir); |  | ||||||
|     } |  | ||||||
|     else{ |  | ||||||
|         seek_error_no_skip(app, part, skip_sub_error, dir); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| CUSTOM_COMMAND_SIG(goto_next_error){ | CUSTOM_COMMAND_SIG(goto_next_error){ | ||||||
|     seek_error_skip_repeats(app, &global_part, true, 1); |     int32_t skip_repeats = true; | ||||||
|  |     int32_t skip_sub_errors = true; | ||||||
|  |     int32_t dir = 1; | ||||||
|  |     seek_error(app, &global_part, skip_repeats, skip_sub_errors, dir); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CUSTOM_COMMAND_SIG(goto_prev_error){ | CUSTOM_COMMAND_SIG(goto_prev_error){ | ||||||
|     seek_error_skip_repeats(app, &global_part, true, -1); |     int32_t skip_repeats = true; | ||||||
|  |     int32_t skip_sub_errors = true; | ||||||
|  |     int32_t dir = -1; | ||||||
|  |     seek_error(app, &global_part, skip_repeats, skip_sub_errors, dir); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CUSTOM_COMMAND_SIG(goto_next_error_no_skips){ | CUSTOM_COMMAND_SIG(goto_next_error_no_skips){ | ||||||
|     seek_error_no_skip(app, &global_part, true, 1); |     int32_t skip_repeats = false; | ||||||
|  |     int32_t skip_sub_errors = true; | ||||||
|  |     int32_t dir = 1; | ||||||
|  |     seek_error(app, &global_part, skip_repeats, skip_sub_errors, dir); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CUSTOM_COMMAND_SIG(goto_prev_error_no_skips){ | CUSTOM_COMMAND_SIG(goto_prev_error_no_skips){ | ||||||
|     seek_error_no_skip(app, &global_part, true, -1); |     int32_t skip_repeats = false; | ||||||
|  |     int32_t skip_sub_errors = true; | ||||||
|  |     int32_t dir = -1; | ||||||
|  |     seek_error(app, &global_part, skip_repeats, skip_sub_errors, dir); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CUSTOM_COMMAND_SIG(goto_first_error){ | CUSTOM_COMMAND_SIG(goto_first_error){ | ||||||
|     Temp_Memory temp = begin_temp_memory(&global_part); |     Temp_Memory temp = begin_temp_memory(&global_part); | ||||||
|     View_Summary active_view = app->get_active_view(app, AccessAll); |  | ||||||
|     app->view_set_cursor(app, &active_view, seek_pos(0), true); |  | ||||||
|      |      | ||||||
|     Jump_Location location = {0}; |     View_Summary view = get_view_for_locked_jump_buffer(app); | ||||||
|     prev_location = null_location; |     if (view.exists){ | ||||||
|     seek_error_internal(app, &global_part, true, 1, &location); |         app->view_set_cursor(app, &view, seek_pos(0), true); | ||||||
|     prev_location = jump_location_store(app, location); |          | ||||||
|  |         prev_location = null_location; | ||||||
|  |         seek_error(app, &global_part, false, true, 1); | ||||||
|  |     } | ||||||
|     end_temp_memory(temp); |     end_temp_memory(temp); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -93,9 +93,9 @@ ENUM(uint64_t, Command_ID){ | ||||||
| /* DOC(TODO) */ | /* DOC(TODO) */ | ||||||
| FLAGENUM(Memory_Protect_Flags){ | FLAGENUM(Memory_Protect_Flags){ | ||||||
|     /* DOC(TODO) */ |     /* DOC(TODO) */ | ||||||
|     MemProtect_Read = 0x1, |     MemProtect_Read    = 0x1, | ||||||
|     /* DOC(TODO) */ |     /* DOC(TODO) */ | ||||||
|     MemProtect_Write = 0x2, |     MemProtect_Write   = 0x2, | ||||||
|     /* DOC(TODO) */ |     /* DOC(TODO) */ | ||||||
|     MemProtect_Execute = 0x4, |     MemProtect_Execute = 0x4, | ||||||
| }; | }; | ||||||
|  | @ -189,6 +189,9 @@ FLAGENUM(Buffer_Create_Flag){ | ||||||
|     /* DOC(When BufferCreate_AlwaysNew is set it indicates the buffer should be
 |     /* DOC(When BufferCreate_AlwaysNew is set it indicates the buffer should be
 | ||||||
|     cleared to empty even if it's associated file already has content.) */ |     cleared to empty even if it's associated file already has content.) */ | ||||||
|     BufferCreate_AlwaysNew  = 0x2, |     BufferCreate_AlwaysNew  = 0x2, | ||||||
|  |     /* DOC(When BufferCreate_NeverNew is set it indicates that the buffer should
 | ||||||
|  |     only be created if it is an existing file or an open buffer.) */ | ||||||
|  |     BufferCreate_NeverNew   = 0x4, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| /* DOC(A Buffer_Kill_Flag field specifies how a buffer should be killed.) */ | /* DOC(A Buffer_Kill_Flag field specifies how a buffer should be killed.) */ | ||||||
|  |  | ||||||
|  | @ -1046,7 +1046,7 @@ DOC_SEE(Buffer_Create_Flag) | ||||||
|                  |                  | ||||||
|                 system->load_close(handle); |                 system->load_close(handle); | ||||||
|             } |             } | ||||||
|             else{ |             else if (!(flags & BufferCreate_NeverNew)){ | ||||||
|                 file = working_set_alloc_always(working_set, general); |                 file = working_set_alloc_always(working_set, general); | ||||||
|                 if (file){ |                 if (file){ | ||||||
|                     buffer_bind_name(general, working_set, file, fname); |                     buffer_bind_name(general, working_set, file, fname); | ||||||
|  |  | ||||||
							
								
								
									
										6
									
								
								TODO.txt
								
								
								
								
							
							
						
						
									
										6
									
								
								TODO.txt
								
								
								
								
							|  | @ -83,13 +83,16 @@ | ||||||
| 
 | 
 | ||||||
| ; BEFORE I SHIP | ; BEFORE I SHIP | ||||||
| ; | ; | ||||||
|  | ; [X] flag in create buffer to prevent making new files | ||||||
|  | ; [X] full screen option | ||||||
|  | ;     [] add to APIs | ||||||
|  | ; | ||||||
| ; [] tokens in the custom API | ; [] tokens in the custom API | ||||||
| ; [] auto indent on the custom side | ; [] auto indent on the custom side | ||||||
| ; [] expose dirty flags | ; [] expose dirty flags | ||||||
| ; [] option to not open *messages* every startup | ; [] option to not open *messages* every startup | ||||||
| ; [] command for resizing panels | ; [] command for resizing panels | ||||||
| ; [] control over how mouse effects panel focus | ; [] control over how mouse effects panel focus | ||||||
| ; [] full screen option |  | ||||||
| ; [] API docs as text file | ; [] API docs as text file | ||||||
| ; [] user file bar string | ; [] user file bar string | ||||||
| ; [] mouse down/up distinction | ; [] mouse down/up distinction | ||||||
|  | @ -98,7 +101,6 @@ | ||||||
| ; [] read only files | ; [] read only files | ||||||
| ; [] break down the build system and get away from the preproc hack | ; [] break down the build system and get away from the preproc hack | ||||||
| ; [] locking to a view for next position jumping | ; [] locking to a view for next position jumping | ||||||
| ; [] flag in create buffer to prevent making new files |  | ||||||
| ; | ; | ||||||
| 
 | 
 | ||||||
| ; TODOS | ; TODOS | ||||||
|  |  | ||||||
							
								
								
									
										10
									
								
								build.c
								
								
								
								
							
							
						
						
									
										10
									
								
								build.c
								
								
								
								
							|  | @ -1,7 +1,5 @@ | ||||||
| /*
 | /*
 | ||||||
| 
 |  | ||||||
| 4coder development build rule. | 4coder development build rule. | ||||||
| 
 |  | ||||||
| */ | */ | ||||||
| 
 | 
 | ||||||
| // TOP
 | // TOP
 | ||||||
|  | @ -266,7 +264,7 @@ buildsuper(char *code_path, char *out_path, char *filename){ | ||||||
| 
 | 
 | ||||||
| static void | static void | ||||||
| standard_build(char *cdir, uint32_t flags){ | standard_build(char *cdir, uint32_t flags){ | ||||||
| #if 1 | #if 0 | ||||||
|     { |     { | ||||||
|         BEGIN_TIME_SECTION(); |         BEGIN_TIME_SECTION(); | ||||||
|         build(OPTS, cdir, "fsm_table_generator.cpp", |         build(OPTS, cdir, "fsm_table_generator.cpp", | ||||||
|  | @ -281,7 +279,7 @@ standard_build(char *cdir, uint32_t flags){ | ||||||
|     } |     } | ||||||
| #endif | #endif | ||||||
|      |      | ||||||
| #if 1 | #if 0 | ||||||
|     { |     { | ||||||
|         BEGIN_TIME_SECTION(); |         BEGIN_TIME_SECTION(); | ||||||
|         build(OPTS | DEBUG_INFO, cdir, "4ed_metagen.cpp", |         build(OPTS | DEBUG_INFO, cdir, "4ed_metagen.cpp", | ||||||
|  | @ -294,7 +292,9 @@ standard_build(char *cdir, uint32_t flags){ | ||||||
|         execute(cdir, META_DIR"/metagen"); |         execute(cdir, META_DIR"/metagen"); | ||||||
|         END_TIME_SECTION("run metagen"); |         END_TIME_SECTION("run metagen"); | ||||||
|     } |     } | ||||||
|  | #endif | ||||||
|      |      | ||||||
|  | #if 1 | ||||||
|     { |     { | ||||||
|         BEGIN_TIME_SECTION(); |         BEGIN_TIME_SECTION(); | ||||||
|         //buildsuper(cdir, BUILD_DIR, "../code/4coder_default_bindings.cpp");
 |         //buildsuper(cdir, BUILD_DIR, "../code/4coder_default_bindings.cpp");
 | ||||||
|  | @ -303,7 +303,9 @@ standard_build(char *cdir, uint32_t flags){ | ||||||
|         //buildsuper(cdir, BUILD_DIR, "../4vim/4coder_chronal.cpp");
 |         //buildsuper(cdir, BUILD_DIR, "../4vim/4coder_chronal.cpp");
 | ||||||
|         END_TIME_SECTION("build custom"); |         END_TIME_SECTION("build custom"); | ||||||
|     } |     } | ||||||
|  | #endif | ||||||
|      |      | ||||||
|  | #if 0 | ||||||
|     { |     { | ||||||
|         BEGIN_TIME_SECTION(); |         BEGIN_TIME_SECTION(); | ||||||
|         build(OPTS | INCLUDES | SHARED_CODE | flags, cdir, "4ed_app_target.cpp", |         build(OPTS | INCLUDES | SHARED_CODE | flags, cdir, "4ed_app_target.cpp", | ||||||
|  |  | ||||||
|  | @ -128,11 +128,14 @@ | ||||||
| #include "4coder_default_include.cpp" | #include "4coder_default_include.cpp" | ||||||
| #include "4coder_jump_parsing.cpp" | #include "4coder_jump_parsing.cpp" | ||||||
| 
 | 
 | ||||||
| #ifndef Assert | #if !defined(Assert) | ||||||
| #define internal static |  | ||||||
| #define Assert assert  | #define Assert assert  | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | #if !defined(internal) | ||||||
|  | #define internal static | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
| struct Parsed_Error | struct Parsed_Error | ||||||
| { | { | ||||||
|     int exists; |     int exists; | ||||||
|  | @ -514,7 +517,7 @@ SwitchToOrLoadFile(struct Application_Links *app, String FileName, bool CreateIf | ||||||
|         { |         { | ||||||
|             // NOTE(allen): This opens the file and puts it in &view
 |             // NOTE(allen): This opens the file and puts it in &view
 | ||||||
|             // This returns false if the open fails.
 |             // This returns false if the open fails.
 | ||||||
|             view_open_file(app, &view, expand_str(FileName), false); |             view_open_file(app, &view, FileName.str, FileName.size, true); | ||||||
|              |              | ||||||
|             Result.buffer = app->get_buffer_by_name(app, FileName.str, FileName.size, access);             |             Result.buffer = app->get_buffer_by_name(app, FileName.str, FileName.size, access);             | ||||||
|              |              | ||||||
|  | @ -1123,7 +1126,7 @@ OpenProject(Application_Links *app, char *ProjectFileName) | ||||||
|                         dir.size = dir_size; |                         dir.size = dir_size; | ||||||
|                         append(&dir, info->filename); |                         append(&dir, info->filename); | ||||||
| 
 | 
 | ||||||
|                         view_open_file(app, 0, dir.str, dir.size, true); |                         open_file(app, 0, dir.str, dir.size, true, true); | ||||||
|                         ++TotalOpenAttempts; |                         ++TotalOpenAttempts; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|  | @ -184,11 +184,11 @@ CUSTOM_COMMAND_SIG(multi_line_edit){ | ||||||
| // TODO(allen): Both of these brace related commands would work better
 | // TODO(allen): Both of these brace related commands would work better
 | ||||||
| // if the API exposed access to the tokens in a code file.
 | // if the API exposed access to the tokens in a code file.
 | ||||||
| CUSTOM_COMMAND_SIG(mark_matching_brace){ | CUSTOM_COMMAND_SIG(mark_matching_brace){ | ||||||
|     unsigned int access = AccessProtected; |     uint32_t access = AccessProtected; | ||||||
|     View_Summary view = app->get_active_view(app, access); |     View_Summary view = app->get_active_view(app, access); | ||||||
|     Buffer_Summary buffer = app->get_buffer(app, view.buffer_id, access); |     Buffer_Summary buffer = app->get_buffer(app, view.buffer_id, access); | ||||||
|      |      | ||||||
|     int start_pos = view.cursor.pos; |     int32_t start_pos = view.cursor.pos; | ||||||
|      |      | ||||||
|     // NOTE(allen): The user provides the memory that the chunk uses,
 |     // NOTE(allen): The user provides the memory that the chunk uses,
 | ||||||
|     // this chunk will then be filled at each step of the text stream loop.
 |     // this chunk will then be filled at each step of the text stream loop.
 | ||||||
|  | @ -197,12 +197,12 @@ CUSTOM_COMMAND_SIG(mark_matching_brace){ | ||||||
|     Stream_Chunk chunk; |     Stream_Chunk chunk; | ||||||
|     char chunk_space[(1 << 10)]; |     char chunk_space[(1 << 10)]; | ||||||
|      |      | ||||||
|     int result = 0; |     int32_t result = 0; | ||||||
|     int found_result = 0; |     int32_t found_result = 0; | ||||||
|      |      | ||||||
|     int i = start_pos; |     int32_t i = start_pos; | ||||||
|     int still_looping = 1; |     int32_t still_looping = 1; | ||||||
|     int nesting_counter = 0; |     int32_t nesting_counter = 0; | ||||||
|     char at_cursor = 0; |     char at_cursor = 0; | ||||||
|      |      | ||||||
|     if (init_stream_chunk(&chunk, app, &buffer, i, |     if (init_stream_chunk(&chunk, app, &buffer, i, | ||||||
|  | @ -404,8 +404,8 @@ get_bindings(void *data, int size){ | ||||||
|     end_map(context); |     end_map(context); | ||||||
|      |      | ||||||
|     begin_map(context, my_code_map); |     begin_map(context, my_code_map); | ||||||
|     bind(context, '/', MDFR_ALT, mark_matching_brace); |     bind(context, ']', MDFR_ALT, mark_matching_brace); | ||||||
|     bind(context, '\'', MDFR_ALT, cursor_to_surrounding_scope); |     bind(context, '[', MDFR_ALT, cursor_to_surrounding_scope); | ||||||
|     end_map(context); |     end_map(context); | ||||||
|      |      | ||||||
|     BIND_4CODER_TESTS(context); |     BIND_4CODER_TESTS(context); | ||||||
|  |  | ||||||
							
								
								
									
										109
									
								
								win32_4ed.cpp
								
								
								
								
							
							
						
						
									
										109
									
								
								win32_4ed.cpp
								
								
								
								
							|  | @ -139,22 +139,23 @@ struct Win32_Input_Chunk_Persistent{ | ||||||
|     b8 control_keys[MDFR_INDEX_COUNT]; |     b8 control_keys[MDFR_INDEX_COUNT]; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct Win32_Input_Chunk{ | typedef struct Win32_Input_Chunk{ | ||||||
|     Win32_Input_Chunk_Transient trans; |     Win32_Input_Chunk_Transient trans; | ||||||
|     Win32_Input_Chunk_Persistent pers; |     Win32_Input_Chunk_Persistent pers; | ||||||
| }; | } Win32_Input_Chunk; | ||||||
| 
 | 
 | ||||||
| struct Win32_Coroutine{ | typedef struct Win32_Coroutine{ | ||||||
|     Coroutine coroutine; |     Coroutine coroutine; | ||||||
|     Win32_Coroutine *next; |     Win32_Coroutine *next; | ||||||
|     i32 done; |     i32 done; | ||||||
| }; | } Win32_Coroutine; | ||||||
| 
 | 
 | ||||||
| #if FRED_INTERNAL | #if FRED_INTERNAL | ||||||
| struct Sys_Bubble : public Bubble{ | struct Sys_Bubble : public Bubble{ | ||||||
|     i32 line_number; |     i32 line_number; | ||||||
|     char *file_name; |     char *file_name; | ||||||
| }; | }; | ||||||
|  | typedef struct Sys_Bubble Sys_Bubble; | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| enum CV_ID{ | enum CV_ID{ | ||||||
|  | @ -169,12 +170,12 @@ enum CV_ID{ | ||||||
|     CV_COUNT |     CV_COUNT | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct Drive_Strings{ | typedef struct Drive_Strings{ | ||||||
|     char *prefix_[26]; |     char *prefix_[26]; | ||||||
|     char **prefix; |     char **prefix; | ||||||
| }; | } Drive_Strings; | ||||||
| 
 | 
 | ||||||
| struct Win32_Vars{ | typedef struct Win32_Vars{ | ||||||
|     System_Functions system; |     System_Functions system; | ||||||
|     App_Functions app; |     App_Functions app; | ||||||
|     Custom_API custom_api; |     Custom_API custom_api; | ||||||
|  | @ -223,7 +224,7 @@ struct Win32_Vars{ | ||||||
|     CRITICAL_SECTION DEBUG_sysmem_lock; |     CRITICAL_SECTION DEBUG_sysmem_lock; | ||||||
|     Sys_Bubble internal_bubble; |     Sys_Bubble internal_bubble; | ||||||
| #endif | #endif | ||||||
| }; | } Win32_Vars; | ||||||
| 
 | 
 | ||||||
| globalvar Win32_Vars win32vars; | globalvar Win32_Vars win32vars; | ||||||
| globalvar Application_Memory memory_vars; | globalvar Application_Memory memory_vars; | ||||||
|  | @ -271,7 +272,6 @@ internal | ||||||
| Sys_Get_Memory_Sig(system_get_memory_){ | Sys_Get_Memory_Sig(system_get_memory_){ | ||||||
|     void *ptr = 0; |     void *ptr = 0; | ||||||
|     if (size > 0){ |     if (size > 0){ | ||||||
|          |  | ||||||
| #if FRED_INTERNAL | #if FRED_INTERNAL | ||||||
|         ptr = VirtualAlloc(0, size + sizeof(Sys_Bubble), MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE); |         ptr = VirtualAlloc(0, size + sizeof(Sys_Bubble), MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE); | ||||||
|         Sys_Bubble *bubble = (Sys_Bubble*)ptr; |         Sys_Bubble *bubble = (Sys_Bubble*)ptr; | ||||||
|  | @ -289,6 +289,7 @@ Sys_Get_Memory_Sig(system_get_memory_){ | ||||||
|     } |     } | ||||||
|     return(ptr); |     return(ptr); | ||||||
| } | } | ||||||
|  | 
 | ||||||
| internal | internal | ||||||
| Sys_Free_Memory_Sig(system_free_memory){ | Sys_Free_Memory_Sig(system_free_memory){ | ||||||
|     if (block){ |     if (block){ | ||||||
|  | @ -1510,6 +1511,69 @@ Win32Resize(i32 width, i32 height){ | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /*
 | ||||||
|  | NOTE(casey): This follows Raymond Chen's prescription | ||||||
|  | for fullscreen toggling, see: | ||||||
|  | http://blogs.msdn.com/b/oldnewthing/archive/2010/04/12/9994016.aspx
 | ||||||
|  | */ | ||||||
|  | 
 | ||||||
|  | static b32 full_screen = 0; | ||||||
|  | static WINDOWPLACEMENT GlobalWindowPosition = {sizeof(GlobalWindowPosition)}; | ||||||
|  | 
 | ||||||
|  | internal void | ||||||
|  | Win32ToggleFullscreen(void){ | ||||||
|  |     HWND Window = win32vars.window_handle; | ||||||
|  |     LONG_PTR Style = GetWindowLongPtr(Window, GWL_STYLE); | ||||||
|  |     if (Style & WS_OVERLAPPEDWINDOW){ | ||||||
|  |         MONITORINFO MonitorInfo = {sizeof(MonitorInfo)}; | ||||||
|  |         if(GetWindowPlacement(Window, &GlobalWindowPosition) && | ||||||
|  |            GetMonitorInfo(MonitorFromWindow(Window, MONITOR_DEFAULTTOPRIMARY), &MonitorInfo)) | ||||||
|  |         { | ||||||
|  |             SetWindowLongPtr(Window, GWL_STYLE, Style & ~WS_OVERLAPPEDWINDOW); | ||||||
|  |             SetWindowPos(Window, HWND_TOP, | ||||||
|  |                          MonitorInfo.rcMonitor.left, MonitorInfo.rcMonitor.top, | ||||||
|  |                          MonitorInfo.rcMonitor.right - MonitorInfo.rcMonitor.left, | ||||||
|  |                          MonitorInfo.rcMonitor.bottom - MonitorInfo.rcMonitor.top, | ||||||
|  |                          SWP_NOOWNERZORDER | SWP_FRAMECHANGED); | ||||||
|  |             full_screen = 1; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     else{ | ||||||
|  |         SetWindowLongPtr(Window, GWL_STYLE, Style | WS_OVERLAPPEDWINDOW); | ||||||
|  |         SetWindowPlacement(Window, &GlobalWindowPosition); | ||||||
|  |         SetWindowPos(Window, 0, 0, 0, 0, 0, | ||||||
|  |                      SWP_NOMOVE | SWP_NOSIZE | SWP_NOZORDER | | ||||||
|  |                      SWP_NOOWNERZORDER | SWP_FRAMECHANGED); | ||||||
|  |         full_screen = 0; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | internal void | ||||||
|  | Win32FixFullscreenLoseFocus(b32 lose_focus){ | ||||||
|  |     if (full_screen){ | ||||||
|  |          | ||||||
|  |         HWND Window = win32vars.window_handle; | ||||||
|  |         LONG_PTR Style = GetWindowLongPtr(Window, GWL_STYLE); | ||||||
|  |          | ||||||
|  |         MONITORINFO MonitorInfo = {sizeof(MonitorInfo)}; | ||||||
|  |         if(GetMonitorInfo(MonitorFromWindow(Window, MONITOR_DEFAULTTOPRIMARY), &MonitorInfo)) | ||||||
|  |         { | ||||||
|  |             if (lose_focus){ | ||||||
|  |                 SetWindowLongPtr(Window, GWL_STYLE, Style | WS_OVERLAPPEDWINDOW); | ||||||
|  |             } | ||||||
|  |             else{ | ||||||
|  |                 SetWindowLongPtr(Window, GWL_STYLE, Style & ~WS_OVERLAPPEDWINDOW); | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             SetWindowPos(Window, HWND_TOP, | ||||||
|  |                          MonitorInfo.rcMonitor.left, MonitorInfo.rcMonitor.top, | ||||||
|  |                          MonitorInfo.rcMonitor.right - MonitorInfo.rcMonitor.left, | ||||||
|  |                          MonitorInfo.rcMonitor.bottom - MonitorInfo.rcMonitor.top, | ||||||
|  |                          SWP_NOOWNERZORDER | SWP_FRAMECHANGED); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| internal void | internal void | ||||||
| Win32SetCursorFromUpdate(Application_Mouse_Cursor cursor){ | Win32SetCursorFromUpdate(Application_Mouse_Cursor cursor){ | ||||||
|     switch (cursor){ |     switch (cursor){ | ||||||
|  | @ -1542,6 +1606,7 @@ Win32HighResolutionTime(){ | ||||||
| internal LRESULT | internal LRESULT | ||||||
| Win32Callback(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam){ | Win32Callback(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam){ | ||||||
|     LRESULT result = 0; |     LRESULT result = 0; | ||||||
|  |      | ||||||
|     switch (uMsg){ |     switch (uMsg){ | ||||||
|         case WM_MENUCHAR: |         case WM_MENUCHAR: | ||||||
|         case WM_SYSCHAR:break; |         case WM_SYSCHAR:break; | ||||||
|  | @ -1792,9 +1857,11 @@ Win32Callback(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam){ | ||||||
|             win32vars.input_chunk.pers.mouse_l = 0; |             win32vars.input_chunk.pers.mouse_l = 0; | ||||||
|             win32vars.input_chunk.pers.mouse_r = 0; |             win32vars.input_chunk.pers.mouse_r = 0; | ||||||
|              |              | ||||||
|             b8 *control_keys = win32vars.input_chunk.pers.control_keys; |  | ||||||
|             for (i32 i = 0; i < MDFR_INDEX_COUNT; ++i) control_keys[i] = 0; |  | ||||||
|             win32vars.input_chunk.pers.controls = control_keys_zero(); |             win32vars.input_chunk.pers.controls = control_keys_zero(); | ||||||
|  |              | ||||||
|  |             if (uMsg == WM_SETFOCUS){ | ||||||
|  |                 Win32FixFullscreenLoseFocus(false); | ||||||
|  |             } | ||||||
|         }break; |         }break; | ||||||
|          |          | ||||||
|         case WM_SIZE: |         case WM_SIZE: | ||||||
|  | @ -1828,11 +1895,18 @@ Win32Callback(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam){ | ||||||
|         win32vars.got_useful_event = 1; |         win32vars.got_useful_event = 1; | ||||||
|         break; |         break; | ||||||
|          |          | ||||||
|  |         case WM_CANCELMODE: | ||||||
|  |         { | ||||||
|  |             Win32FixFullscreenLoseFocus(true); | ||||||
|  |             result = DefWindowProc(hwnd, uMsg, wParam, lParam); | ||||||
|  |         }break; | ||||||
|  |          | ||||||
|         default: |         default: | ||||||
|         { |         { | ||||||
|             result = DefWindowProc(hwnd, uMsg, wParam, lParam); |             result = DefWindowProc(hwnd, uMsg, wParam, lParam); | ||||||
|         }break; |         }break; | ||||||
|     } |     } | ||||||
|  |      | ||||||
|     return(result); |     return(result); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -2105,20 +2179,15 @@ WinMain(HINSTANCE hInstance, | ||||||
|      |      | ||||||
| #define WINDOW_NAME "4coder-window: " VERSION | #define WINDOW_NAME "4coder-window: " VERSION | ||||||
|      |      | ||||||
|     i32 window_x; |     i32 window_x = CW_USEDEFAULT; | ||||||
|     i32 window_y; |     i32 window_y = CW_USEDEFAULT; | ||||||
|     i32 window_style; |  | ||||||
|      |      | ||||||
|     if (win32vars.settings.set_window_pos){ |     if (win32vars.settings.set_window_pos){ | ||||||
|         window_x = win32vars.settings.window_x; |         window_x = win32vars.settings.window_x; | ||||||
|         window_y = win32vars.settings.window_y; |         window_y = win32vars.settings.window_y; | ||||||
|     } |     } | ||||||
|     else{ |  | ||||||
|         window_x = CW_USEDEFAULT; |  | ||||||
|         window_y = CW_USEDEFAULT; |  | ||||||
|     } |  | ||||||
|      |      | ||||||
|     window_style = WS_OVERLAPPEDWINDOW | WS_VISIBLE; |     i32 window_style = WS_OVERLAPPEDWINDOW; | ||||||
|     if (win32vars.settings.maximize_window){ |     if (win32vars.settings.maximize_window){ | ||||||
|         window_style |= WS_MAXIMIZE; |         window_style |= WS_MAXIMIZE; | ||||||
|     } |     } | ||||||
|  | @ -2238,7 +2307,6 @@ WinMain(HINSTANCE hInstance, | ||||||
|         win32vars.count_per_usecond = 1; |         win32vars.count_per_usecond = 1; | ||||||
|     } |     } | ||||||
|      |      | ||||||
|      |  | ||||||
|     //
 |     //
 | ||||||
|     // Main Loop
 |     // Main Loop
 | ||||||
|     //
 |     //
 | ||||||
|  | @ -2259,6 +2327,7 @@ WinMain(HINSTANCE hInstance, | ||||||
|      |      | ||||||
|     SetForegroundWindow(win32vars.window_handle); |     SetForegroundWindow(win32vars.window_handle); | ||||||
|     SetActiveWindow(win32vars.window_handle); |     SetActiveWindow(win32vars.window_handle); | ||||||
|  |     ShowWindow(win32vars.window_handle, SW_SHOW); | ||||||
|      |      | ||||||
|     u64 timer_start = Win32HighResolutionTime(); |     u64 timer_start = Win32HighResolutionTime(); | ||||||
|     system_acquire_lock(FRAME_LOCK); |     system_acquire_lock(FRAME_LOCK); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Allen Webster
						Allen Webster