organized things into an App_Models struct

master
Allen Webster 2016-03-03 20:41:52 -05:00
parent f40161e888
commit a8ababcd23
3 changed files with 805 additions and 742 deletions

1397
4ed.cpp

File diff suppressed because it is too large Load Diff

View File

@ -21,5 +21,43 @@ struct App_Settings{
b32 lctrl_lalt_is_altgr; b32 lctrl_lalt_is_altgr;
}; };
struct App_Models{
Mem_Options mem;
App_Settings settings;
Command_Map map_top;
Command_Map map_file;
Command_Map map_ui;
Command_Map *user_maps;
i32 *map_id_table;
i32 user_map_count;
Command_Binding prev_command;
Coroutine *command_coroutine;
u32 command_coroutine_flags[2];
Custom_Command_Function *hooks[hook_type_count];
Font_Set *font_set;
Style_Font global_font;
Style style;
Style_Library styles;
u32 *palette;
i32 palette_size;
Editing_Layout layout;
Working_Set working_set;
char hot_dir_base_[256];
Hot_Directory hot_directory;
Delay delay1, delay2;
Panel *prev_mouse_panel;
Custom_API config_api;
};
// BOTTOM // BOTTOM

View File

@ -72,6 +72,8 @@ enum Color_View_Mode{
struct View{ struct View{
View *next, *prev; View *next, *prev;
App_Models *models;
Panel *panel; Panel *panel;
Command_Map *map; Command_Map *map;
Scroll_Rule_Function *scroll_rule; Scroll_Rule_Function *scroll_rule;
@ -597,12 +599,14 @@ file_create_empty(
internal b32 internal b32
file_create_super_locked( file_create_super_locked(
System_Functions *system, Mem_Options *mem, System_Functions *system,
Working_Set *working_set, Editing_File *file, App_Models *models,
char *filename, Font_Set *set, i16 font_id){ Editing_File *file,
char *filename){
b32 result = 1; b32 result = 1;
String empty_str = {}; String empty_str = {};
file_create_from_string(system, mem, working_set, file, filename, set, font_id, empty_str, 1); file_create_from_string(system, &models->mem, &models->working_set,
file, filename, models->font_set, models->global_font.font_id, empty_str, 1);
return result; return result;
} }
@ -1309,27 +1313,21 @@ view_set_file(
// NOTE(allen): These parameters are always meaningful // NOTE(allen): These parameters are always meaningful
View *view, View *view,
Editing_File *file, Editing_File *file,
Font_Set *set, App_Models *models,
Style *style,
Style_Font *global_font,
// NOTE(allen): Necessary when file != 0 // NOTE(allen): Necessary when file != 0
System_Functions *system, System_Functions *system,
Hook_Function *open_hook, Hook_Function *open_hook,
Application_Links *app){ Application_Links *app){
Panel *panel;
Font_Info *fnt_info; Font_Info *fnt_info;
panel = view->panel;
// NOTE(allen): This is actually more like view_set_style right? // NOTE(allen): This is actually more like view_set_style right?
fnt_info = get_font_info(set, global_font->font_id); fnt_info = get_font_info(models->font_set, models->global_font.font_id);
view->global_font = global_font; view->global_font = &models->global_font;
view->style = style; view->style = &models->style;
view->font_advance = fnt_info->advance; view->font_advance = fnt_info->advance;
view->font_height = fnt_info->height; view->font_height = fnt_info->height;
view->font_set = set;
// NOTE(allen): Stuff that doesn't assume file exists. // NOTE(allen): Stuff that doesn't assume file exists.
view->file = file; view->file = file;
@ -1340,7 +1338,7 @@ view_set_file(
if (file){ if (file){
// NOTE(allen): Isn't this a bit clumsy? // NOTE(allen): Isn't this a bit clumsy?
file->settings.set = set; file->settings.set = models->font_set;
view->locked = file->settings.super_locked; view->locked = file->settings.super_locked;
view->unwrapped_lines = file->settings.unwrapped_lines; view->unwrapped_lines = file->settings.unwrapped_lines;
@ -1854,6 +1852,7 @@ view_do_white_batch_edit(System_Functions *system, Mem_Options *mem, View *view,
file_edit_cursor_fix(system, part, general, file, layout, desc); file_edit_cursor_fix(system, part, general, file, layout, desc);
} }
#if 0
inline void inline void
file_replace_range(System_Functions *system, file_replace_range(System_Functions *system,
Mem_Options *mem, Editing_File *file, Editing_Layout *layout, Mem_Options *mem, Editing_File *file, Editing_Layout *layout,
@ -1884,6 +1883,37 @@ view_replace_range(System_Functions *system,
spec.str = (u8*)str; spec.str = (u8*)str;
file_do_single_edit(system, mem, view->file, layout, spec, hist_normal); file_do_single_edit(system, mem, view->file, layout, spec, hist_normal);
} }
#endif
inline void
file_replace_range(System_Functions *system,
App_Models *models, Editing_File *file,
i32 start, i32 end, char *str, i32 len, i32 next_cursor){
Edit_Spec spec = {};
spec.step.type = ED_NORMAL;
spec.step.edit.start = start;
spec.step.edit.end = end;
spec.step.edit.len = len;
spec.step.pre_pos = file->state.cursor_pos;
spec.step.post_pos = next_cursor;
spec.str = (u8*)str;
file_do_single_edit(system, &models->mem, file, &models->layout, spec, hist_normal);
}
inline void
view_replace_range(System_Functions *system, App_Models *models, View *view,
i32 start, i32 end, char *str, i32 len, i32 next_cursor){
if (view->locked) return;
Edit_Spec spec = {};
spec.step.type = ED_NORMAL;
spec.step.edit.start = start;
spec.step.edit.end = end;
spec.step.edit.len = len;
spec.step.pre_pos = view->cursor.pos;
spec.step.post_pos = next_cursor;
spec.str = (u8*)str;
file_do_single_edit(system, &models->mem, view->file, &models->layout, spec, hist_normal);
}
inline void inline void
view_post_paste_effect(View *view, i32 ticks, i32 start, i32 size, u32 color){ view_post_paste_effect(View *view, i32 ticks, i32 start, i32 size, u32 color){
@ -1930,15 +1960,15 @@ view_undo_redo(System_Functions *system,
} }
inline void inline void
view_undo(System_Functions *system, Mem_Options *mem, Editing_Layout *layout, View *view){ view_undo(System_Functions *system, App_Models *models, View *view){
Editing_File *file = view->file; Editing_File *file = view->file;
view_undo_redo(system, mem, layout, view, file, &file->state.undo.undo, ED_UNDO); view_undo_redo(system, &models->mem, &models->layout, view, file, &file->state.undo.undo, ED_UNDO);
} }
inline void inline void
view_redo(System_Functions *system, Mem_Options *mem, Editing_Layout *layout, View *view){ view_redo(System_Functions *system, App_Models *models, View *view){
Editing_File *file = view->file; Editing_File *file = view->file;
view_undo_redo(system, mem, layout, view, file, &file->state.undo.redo, ED_REDO); view_undo_redo(system, &models->mem, &models->layout, view, file, &file->state.undo.redo, ED_REDO);
} }
inline u8* inline u8*
@ -2060,6 +2090,11 @@ view_history_step(System_Functions *system, Mem_Options *mem, Editing_Layout *la
} }
} }
inline void
view_history_step(System_Functions *system, App_Models *models, View *view, History_Mode history_mode){
view_history_step(system, &models->mem, &models->layout, view, history_mode);
}
// TODO(allen): write these as streamed operations // TODO(allen): write these as streamed operations
internal i32 internal i32
view_find_end_of_line(View *view, i32 pos){ view_find_end_of_line(View *view, i32 pos){
@ -2203,14 +2238,18 @@ file_compute_whitespace_edit(Mem_Options *mem, Editing_File *file, i32 cursor_po
} }
internal void internal void
view_clean_whitespace(System_Functions *system, Mem_Options *mem, View *view, Editing_Layout *layout){ view_clean_whitespace(System_Functions *system, App_Models *models, View *view){
Mem_Options *mem = &models->mem;
Editing_Layout *layout = &models->layout;
Editing_File *file = view->file; Editing_File *file = view->file;
Assert(file && !file->state.is_dummy);
Partition *part = &mem->part; Partition *part = &mem->part;
i32 line_count = file->state.buffer.line_count; i32 line_count = file->state.buffer.line_count;
i32 edit_max = line_count * 2; i32 edit_max = line_count * 2;
i32 edit_count = 0; i32 edit_count = 0;
Assert(file && !file->state.is_dummy);
Temp_Memory temp = begin_temp_memory(part); Temp_Memory temp = begin_temp_memory(part);
Buffer_Edit *edits = push_array(part, Buffer_Edit, edit_max); Buffer_Edit *edits = push_array(part, Buffer_Edit, edit_max);
@ -2559,11 +2598,11 @@ undo_shit(System_Functions *system, View *view, UI_State *state, UI_Layout *layo
i32 new_count; i32 new_count;
if (do_undo_slider(wid, state, layout, total_count, undo_count, 0, &new_count)){ if (do_undo_slider(wid, state, layout, total_count, undo_count, 0, &new_count)){
for (i32 i = 0; i < scrub_max && new_count < undo_count; ++i){ for (i32 i = 0; i < scrub_max && new_count < undo_count; ++i){
view_undo(system, view->mem, view->layout, view); view_undo(system, view->models, view);
--undo_count; --undo_count;
} }
for (i32 i = 0; i < scrub_max && new_count > undo_count; ++i){ for (i32 i = 0; i < scrub_max && new_count > undo_count; ++i){
view_redo(system, view->mem, view->layout, view); view_redo(system, view->models, view);
++undo_count; ++undo_count;
} }
} }
@ -3890,18 +3929,17 @@ free_file_view(View *view){
} }
internal View* internal View*
file_view_init(View *view, Editing_Layout *layout, file_view_init(View *view, App_Models *models){
Working_Set *working_set, Delay *delay,
App_Settings *settings, Hot_Directory *hot_directory,
Mem_Options *mem, Style_Library *styles){
view->layout = layout; view->models = models;
view->working_set = working_set; view->layout = &models->layout;
view->delay = delay; view->working_set = &models->working_set;
view->settings = settings; view->delay = &models->delay1;
view->hot_directory = hot_directory; view->settings = &models->settings;
view->mem = mem; view->hot_directory = &models->hot_directory;
view->styles = styles; view->mem = &models->mem;
view->styles = &models->styles;
view->font_set = models->font_set;
view->scrub_max = 1; view->scrub_max = 1;