keep recent scroll position for files-view pairs

master
Allen Webster 2016-05-19 14:01:36 -04:00
parent d6cfdf7413
commit 8bf8e36723
5 changed files with 154 additions and 118 deletions

58
4ed.cpp
View File

@ -1,11 +1,11 @@
/* /*
* Mr. 4th Dimention - Allen Webster * Mr. 4th Dimention - Allen Webster
* *
* 12.12.2014 * 12.12.2014
* *
* Application layer for project codename "4ed" * Application layer for project codename "4ed"
* *
*/ */
// TOP // TOP
@ -191,8 +191,8 @@ do_feedback_message(System_Functions *system, Models *models, String value){
output_file_append(system, models, file, value, 1); output_file_append(system, models, file, value, 1);
i32 pos = buffer_size(&file->state.buffer); i32 pos = buffer_size(&file->state.buffer);
for (View_Iter iter = file_view_iter_init(&models->layout, file, 0); for (View_Iter iter = file_view_iter_init(&models->layout, file, 0);
file_view_iter_good(iter); file_view_iter_good(iter);
iter = file_view_iter_next(iter)){ iter = file_view_iter_next(iter)){
view_cursor_move(iter.view, pos); view_cursor_move(iter.view, pos);
} }
} }
@ -277,7 +277,7 @@ COMMAND_DECL(null){
} }
COMMAND_DECL(write_character){ COMMAND_DECL(write_character){
USE_MODELS(models); USE_MODELS(models);
REQ_OPEN_VIEW(view); REQ_OPEN_VIEW(view);
REQ_FILE(file, view); REQ_FILE(file, view);
@ -324,7 +324,7 @@ seek_token_right(Cpp_Token_Stack *tokens, i32 pos){
} }
COMMAND_DECL(seek_left){ COMMAND_DECL(seek_left){
REQ_READABLE_VIEW(view); REQ_READABLE_VIEW(view);
REQ_FILE(file, view); REQ_FILE(file, view);
@ -377,7 +377,7 @@ COMMAND_DECL(seek_left){
} }
COMMAND_DECL(seek_right){ COMMAND_DECL(seek_right){
REQ_READABLE_VIEW(view); REQ_READABLE_VIEW(view);
REQ_FILE(file, view); REQ_FILE(file, view);
@ -432,7 +432,7 @@ COMMAND_DECL(seek_right){
} }
COMMAND_DECL(seek_whitespace_up){ COMMAND_DECL(seek_whitespace_up){
REQ_READABLE_VIEW(view); REQ_READABLE_VIEW(view);
REQ_FILE(file, view); REQ_FILE(file, view);
@ -441,7 +441,7 @@ COMMAND_DECL(seek_whitespace_up){
} }
COMMAND_DECL(seek_whitespace_down){ COMMAND_DECL(seek_whitespace_down){
REQ_READABLE_VIEW(view); REQ_READABLE_VIEW(view);
REQ_FILE(file, view); REQ_FILE(file, view);
@ -450,7 +450,7 @@ COMMAND_DECL(seek_whitespace_down){
} }
COMMAND_DECL(center_view){ COMMAND_DECL(center_view){
USE_VIEW(view); USE_VIEW(view);
REQ_FILE(file, view); REQ_FILE(file, view);
@ -464,9 +464,9 @@ COMMAND_DECL(center_view){
h = view_file_height(view); h = view_file_height(view);
y -= h * .5f; y -= h * .5f;
if (y < view->file_scroll.min_y) y = view->file_scroll.min_y; if (y < view->recent->scroll.min_y) y = view->recent->scroll.min_y;
view->file_scroll.target_y = y; view->recent->scroll.target_y = y;
} }
COMMAND_DECL(word_complete){ COMMAND_DECL(word_complete){
@ -1105,7 +1105,7 @@ COMMAND_DECL(toggle_line_wrap){
if (view->file_data.unwrapped_lines){ if (view->file_data.unwrapped_lines){
view->file_data.unwrapped_lines = 0; view->file_data.unwrapped_lines = 0;
file->settings.unwrapped_lines = 0; file->settings.unwrapped_lines = 0;
view->file_scroll.target_x = 0; view->recent->scroll.target_x = 0;
view->file_data.cursor =view_compute_cursor_from_pos( view->file_data.cursor =view_compute_cursor_from_pos(
view, view->file_data.cursor.pos); view, view->file_data.cursor.pos);
view->file_data.preferred_x = view->file_data.cursor.wrapped_x; view->file_data.preferred_x = view->file_data.cursor.wrapped_x;
@ -1505,26 +1505,26 @@ COMMAND_DECL(page_down){
REQ_READABLE_VIEW(view); REQ_READABLE_VIEW(view);
f32 height = view_file_height(view); f32 height = view_file_height(view);
f32 max_target_y = view->file_scroll.max_y; f32 max_target_y = view->recent->scroll.max_y;
view->file_scroll.target_y += height; view->recent->scroll.target_y += height;
if (view->file_scroll.target_y > max_target_y) view->file_scroll.target_y = max_target_y; if (view->recent->scroll.target_y > max_target_y) view->recent->scroll.target_y = max_target_y;
view->file_data.cursor = view_compute_cursor_from_xy( view->file_data.cursor = view_compute_cursor_from_xy(
view, 0, view->file_scroll.target_y + (height - view->font_height)*.5f); view, 0, view->recent->scroll.target_y + (height - view->font_height)*.5f);
} }
COMMAND_DECL(page_up){ COMMAND_DECL(page_up){
REQ_READABLE_VIEW(view); REQ_READABLE_VIEW(view);
f32 height = view_file_height(view); f32 height = view_file_height(view);
f32 min_target_y = view->file_scroll.min_y; f32 min_target_y = view->recent->scroll.min_y;
view->file_scroll.target_y -= height; view->recent->scroll.target_y -= height;
if (view->file_scroll.target_y < min_target_y) view->file_scroll.target_y = min_target_y; if (view->recent->scroll.target_y < min_target_y) view->recent->scroll.target_y = min_target_y;
view->file_data.cursor = view_compute_cursor_from_xy( view->file_data.cursor = view_compute_cursor_from_xy(
view, 0, view->file_scroll.target_y + (height - view->font_height)*.5f); view, 0, view->recent->scroll.target_y + (height - view->font_height)*.5f);
} }
COMMAND_DECL(open_color_tweaker){ COMMAND_DECL(open_color_tweaker){
@ -4029,12 +4029,12 @@ App_Step_Sig(app_step){
// TODO(allen): This is perhaps not the best system... // TODO(allen): This is perhaps not the best system...
// The problem is that the exact region and scroll position is pretty important // The problem is that the exact region and scroll position is pretty important
// for some commands, so this is here to eliminate the one frame of lag. // for some commands, so this is here to eliminate the one frame of lag.
// Going to leave this here for now because the oder of events is going to // Going to leave this here for now because the order of events is going to
// change a lot soon. // change a lot soon anyway.
for (dll_items(panel, used_panels)){ for (dll_items(panel, used_panels)){
view = panel->view; view = panel->view;
if (view->current_scroll){ if (view->current_scroll){
gui_get_scroll_vars(&view->gui_target, view->showing_ui, view->current_scroll); gui_get_scroll_vars(&view->gui_target, view->showing_ui, view->current_scroll, &view->scroll_region);
} }
} }
} }

View File

@ -54,10 +54,10 @@ struct Models{
Editing_Layout layout; Editing_Layout layout;
Working_Set working_set; Working_Set working_set;
Editing_File *message_buffer; Editing_File *message_buffer;
char hot_dir_base_[256]; char hot_dir_base_[256];
Hot_Directory hot_directory; Hot_Directory hot_directory;
Delay delay1, delay2; Delay delay1, delay2;
Panel *prev_mouse_panel; Panel *prev_mouse_panel;

View File

@ -152,14 +152,14 @@ struct File_Node{
File_Node *next, *prev; File_Node *next, *prev;
}; };
union File_ID{ union Buffer_Slot_ID{
i32 id; i32 id;
i16 part[2]; i16 part[2];
}; };
inline File_ID inline Buffer_Slot_ID
to_file_id(i32 id){ to_file_id(i32 id){
File_ID result; Buffer_Slot_ID result;
result.id = id; result.id = id;
return(result); return(result);
} }
@ -173,12 +173,13 @@ struct Editing_File{
Editing_File_Preload preload; Editing_File_Preload preload;
}; };
Editing_File_Name name; Editing_File_Name name;
File_ID id; Buffer_Slot_ID id;
u64 unique_buffer_id;
}; };
struct Non_File_Table_Entry{ struct Non_File_Table_Entry{
String name; String name;
File_ID id; Buffer_Slot_ID id;
}; };
struct File_Array{ struct File_Array{
@ -199,12 +200,14 @@ struct Working_Set{
String clipboards[64]; String clipboards[64];
i32 clipboard_size, clipboard_max_size; i32 clipboard_size, clipboard_max_size;
i32 clipboard_current, clipboard_rolling; i32 clipboard_current, clipboard_rolling;
u64 unique_file_counter;
}; };
struct File_Entry{ struct File_Entry{
String short_name; String short_name;
String long_name; String long_name;
File_ID id; Buffer_Slot_ID id;
}; };
struct File_Entry_Comparison{ struct File_Entry_Comparison{
@ -239,7 +242,7 @@ tbl_file_compare(void *a, void *b, void *arg){
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){
File_ID id; Buffer_Slot_ID id;
i16 i, high_part; i16 i, high_part;
Editing_File *file_ptr; Editing_File *file_ptr;
File_Node *free_sentinel; File_Node *free_sentinel;
@ -273,7 +276,7 @@ internal Editing_File*
working_set_alloc(Working_Set *working_set){ working_set_alloc(Working_Set *working_set){
Editing_File *result = 0; Editing_File *result = 0;
File_Node *node; File_Node *node;
File_ID id; Buffer_Slot_ID id;
if (working_set->file_count < working_set->file_max){ if (working_set->file_count < working_set->file_max){
node = working_set->free_sentinel.next; node = working_set->free_sentinel.next;
@ -281,15 +284,14 @@ working_set_alloc(Working_Set *working_set){
result = (Editing_File*)node; result = (Editing_File*)node;
dll_remove(node); dll_remove(node);
// NOTE(allen): What I really want to do here is clear everything
// except id, but writing that out will be a pain to maintain.
id = result->id; id = result->id;
*result = editing_file_zero(); *result = editing_file_zero();
result->id = id; result->id = id;
result->unique_buffer_id = ++working_set->unique_file_counter;
dll_insert(&working_set->used_sentinel, node); dll_insert(&working_set->used_sentinel, node);
++working_set->file_count; ++working_set->file_count;
} }
return result; return result;
} }
@ -322,7 +324,7 @@ working_set_free_file(Working_Set *working_set, Editing_File *file){
} }
inline Editing_File* inline Editing_File*
working_set_index(Working_Set *working_set, File_ID id){ working_set_index(Working_Set *working_set, Buffer_Slot_ID id){
Editing_File *result = 0; Editing_File *result = 0;
File_Array *array; File_Array *array;
@ -344,7 +346,7 @@ working_set_index(Working_Set *working_set, i32 id){
} }
inline Editing_File* inline Editing_File*
working_set_get_active_file(Working_Set *working_set, File_ID id){ working_set_get_active_file(Working_Set *working_set, Buffer_Slot_ID id){
Editing_File *result = 0; Editing_File *result = 0;
result = working_set_index(working_set, id); result = working_set_index(working_set, id);
if (result && result->state.is_dummy){ if (result && result->state.is_dummy){

View File

@ -90,6 +90,11 @@ file_viewing_data_zero(){
return(data); return(data);
} }
struct Recent_File_Data{
u64 unique_buffer_id;
GUI_Scroll_Vars scroll;
};
struct View{ struct View{
View *next, *prev; View *next, *prev;
b32 in_use; b32 in_use;
@ -104,9 +109,13 @@ struct View{
File_Viewing_Data file_data; File_Viewing_Data file_data;
GUI_Scroll_Vars file_scroll; //GUI_Scroll_Vars file_scroll;
i32_Rect scroll_region;
Recent_File_Data recent[16];
GUI_Scroll_Vars *current_scroll; GUI_Scroll_Vars *current_scroll;
View_UI showing_ui; View_UI showing_ui;
GUI_Target gui_target; GUI_Target gui_target;
void *gui_mem; void *gui_mem;
@ -164,14 +173,14 @@ view_lock_level(View *view){
inline f32 inline f32
view_file_width(View *view){ view_file_width(View *view){
i32_Rect file_rect = view->file_scroll.region; i32_Rect file_rect = view->scroll_region;
f32 result = (f32)(file_rect.x1 - file_rect.x0); f32 result = (f32)(file_rect.x1 - file_rect.x0);
return (result); return (result);
} }
inline f32 inline f32
view_file_height(View *view){ view_file_height(View *view){
i32_Rect file_rect = view->file_scroll.region; i32_Rect file_rect = view->scroll_region;
f32 result = (f32)(file_rect.y1 - file_rect.y0); f32 result = (f32)(file_rect.y1 - file_rect.y0);
return (result); return (result);
} }
@ -929,14 +938,14 @@ file_post_undo(General_Memory *general, Editing_File *file,
file->state.undo.redo.size = 0; file->state.undo.redo.size = 0;
file->state.undo.redo.edit_count = 0; file->state.undo.redo.edit_count = 0;
} }
Edit_Stack *undo = &file->state.undo.undo; Edit_Stack *undo = &file->state.undo.undo;
Edit_Step *result = 0; Edit_Step *result = 0;
if (step.child_count == 0){ if (step.child_count == 0){
if (step.edit.end - step.edit.start + undo->size > undo->max) if (step.edit.end - step.edit.start + undo->size > undo->max)
undo_stack_grow_string(general, undo, step.edit.end - step.edit.start); undo_stack_grow_string(general, undo, step.edit.end - step.edit.start);
Buffer_Edit inv; Buffer_Edit inv;
buffer_invert_edit(&file->state.buffer, step.edit, &inv, buffer_invert_edit(&file->state.buffer, step.edit, &inv,
(char*)undo->strings, &undo->size, undo->max); (char*)undo->strings, &undo->size, undo->max);
@ -967,7 +976,7 @@ file_post_undo(General_Memory *general, Editing_File *file,
else{ else{
if (undo->edit_count == undo->edit_max) if (undo->edit_count == undo->edit_max)
undo_stack_grow_edits(general, undo); undo_stack_grow_edits(general, undo);
result = undo->edits + (undo->edit_count++); result = undo->edits + (undo->edit_count++);
*result = inv_step; *result = inv_step;
} }
@ -1279,40 +1288,59 @@ view_get_cursor_y(View *view){
internal void internal void
view_set_file(View *view, Editing_File *file, Models *models){ view_set_file(View *view, Editing_File *file, Models *models){
Font_Info *fnt_info; Font_Info *fnt_info;
// TODO(allen): This belongs somewhere else. // TODO(allen): This belongs somewhere else.
fnt_info = get_font_info(models->font_set, models->global_font.font_id); fnt_info = get_font_info(models->font_set, models->global_font.font_id);
view->font_advance = fnt_info->advance; view->font_advance = fnt_info->advance;
view->font_height = fnt_info->height; view->font_height = fnt_info->height;
// NOTE(allen): Stuff that doesn't assume file exists. // NOTE(allen): Stuff that doesn't assume file exists.
// TODO(allen): Use a proper file changer here. // TODO(allen): Use a proper file changer here.
view->file_data = file_viewing_data_zero();; view->file_data = file_viewing_data_zero();
view->file_data.file = file; view->file_data.file = file;
// NOTE(allen): Stuff that does assume file exists. // NOTE(allen): Stuff that does assume file exists.
if (file){ if (file){
u64 unique_buffer_id = file->unique_buffer_id;
Recent_File_Data *recent = view->recent;
Recent_File_Data temp_recent = {0};
i32 i = 0;
i32 max = ArrayCount(view->recent)-1;
b32 found_recent_entry = 0;
for (; i < max; ++i, ++recent){
if (recent->unique_buffer_id == unique_buffer_id){
temp_recent = *recent;
memmove(view->recent+1, view->recent, sizeof(*recent)*i);
view->recent[0] = temp_recent;
found_recent_entry = 1;
break;
}
}
if (!found_recent_entry){
i = 15;
recent = view->recent + i;
temp_recent = *recent;
memmove(view->recent+1, view->recent, sizeof(*recent)*i);
view->recent[0] = temp_recent;
recent = view->recent;
recent->unique_buffer_id = unique_buffer_id;
}
view->file_data.unwrapped_lines = file->settings.unwrapped_lines; view->file_data.unwrapped_lines = file->settings.unwrapped_lines;
if (file_is_ready(file)){ if (file_is_ready(file)){
view_measure_wraps(&models->mem.general, view); view_measure_wraps(&models->mem.general, view);
view->file_data.cursor = view_compute_cursor_from_pos(view, file->state.cursor_pos); view->file_data.cursor = view_compute_cursor_from_pos(view, file->state.cursor_pos);
view->reinit_scrolling = 1; if (!found_recent_entry){
view->reinit_scrolling = 1;
}
} }
} }
#if 0
if (file){
if (open_hook && file->settings.is_initialized == 0){
models->buffer_param_indices[models->buffer_param_count++] = file->id.id;
open_hook(app);
models->buffer_param_count = 0;
file->settings.is_initialized = 1;
}
}
#endif
} }
struct Relative_Scrolling{ struct Relative_Scrolling{
@ -1326,9 +1354,9 @@ view_get_relative_scrolling(View *view){
Relative_Scrolling result; Relative_Scrolling result;
f32 cursor_y; f32 cursor_y;
cursor_y = view_get_cursor_y(view); cursor_y = view_get_cursor_y(view);
result.scroll_y = cursor_y - view->file_scroll.scroll_y; result.scroll_y = cursor_y - view->recent->scroll.scroll_y;
result.target_y = cursor_y - view->file_scroll.target_y; result.target_y = cursor_y - view->recent->scroll.target_y;
result.scroll_min_limit = view->file_scroll.min_y; result.scroll_min_limit = view->recent->scroll.min_y;
return(result); return(result);
} }
@ -1336,10 +1364,10 @@ internal void
view_set_relative_scrolling(View *view, Relative_Scrolling scrolling){ view_set_relative_scrolling(View *view, Relative_Scrolling scrolling){
f32 cursor_y; f32 cursor_y;
cursor_y = view_get_cursor_y(view); cursor_y = view_get_cursor_y(view);
view->file_scroll.scroll_y = cursor_y - scrolling.scroll_y; view->recent->scroll.scroll_y = cursor_y - scrolling.scroll_y;
view->file_scroll.target_y = cursor_y - scrolling.target_y; view->recent->scroll.target_y = cursor_y - scrolling.target_y;
if (view->file_scroll.target_y < scrolling.scroll_min_limit){ if (view->recent->scroll.target_y < scrolling.scroll_min_limit){
view->file_scroll.target_y = scrolling.scroll_min_limit; view->recent->scroll.target_y = scrolling.scroll_min_limit;
} }
} }
@ -1634,17 +1662,17 @@ file_edit_cursor_fix(System_Functions *system,
if (view->file_data.scroll_i != new_scroll_i){ if (view->file_data.scroll_i != new_scroll_i){
view->file_data.scroll_i = new_scroll_i; view->file_data.scroll_i = new_scroll_i;
temp_cursor = view_compute_cursor_from_pos(view, view->file_data.scroll_i); temp_cursor = view_compute_cursor_from_pos(view, view->file_data.scroll_i);
y_offset = MOD(view->file_scroll.scroll_y, view->font_height); y_offset = MOD(view->recent->scroll.scroll_y, view->font_height);
if (view->file_data.unwrapped_lines){ if (view->file_data.unwrapped_lines){
y_position = temp_cursor.unwrapped_y + y_offset; y_position = temp_cursor.unwrapped_y + y_offset;
view->file_scroll.target_y += (y_position - view->file_scroll.scroll_y); view->recent->scroll.target_y += (y_position - view->recent->scroll.scroll_y);
view->file_scroll.scroll_y = y_position; view->recent->scroll.scroll_y = y_position;
} }
else{ else{
y_position = temp_cursor.wrapped_y + y_offset; y_position = temp_cursor.wrapped_y + y_offset;
view->file_scroll.target_y += (y_position - view->file_scroll.scroll_y); view->recent->scroll.target_y += (y_position - view->recent->scroll.scroll_y);
view->file_scroll.scroll_y = y_position; view->recent->scroll.scroll_y = y_position;
} }
} }
} }
@ -2765,7 +2793,6 @@ view_show_theme(View *view, Command_Map *gui_map){
view->current_scroll = &view->gui_scroll; view->current_scroll = &view->gui_scroll;
} }
inline void inline void
view_show_file(View *view, Command_Map *file_map){ view_show_file(View *view, Command_Map *file_map){
if (file_map){ if (file_map){
@ -2775,7 +2802,7 @@ view_show_file(View *view, Command_Map *file_map){
view->map = view->map_for_file; view->map = view->map_for_file;
} }
view->showing_ui = VUI_None; view->showing_ui = VUI_None;
view->current_scroll = &view->file_scroll; view->current_scroll = &view->recent->scroll;
} }
inline void inline void
@ -2982,22 +3009,22 @@ view_reinit_scrolling(View *view){
} }
target_y = (f32)FLOOR32(cursor_y - h*.5f); target_y = (f32)FLOOR32(cursor_y - h*.5f);
if (target_y < view->file_scroll.min_y){ if (target_y < view->recent->scroll.min_y){
target_y = view->file_scroll.min_y; target_y = view->recent->scroll.min_y;
} }
} }
view->file_scroll.target_y = target_y; view->recent->scroll.target_y = target_y;
view->file_scroll.scroll_y = target_y; view->recent->scroll.scroll_y = target_y;
view->file_scroll.prev_target_y = -1000.f; view->recent->scroll.prev_target_y = -1000.f;
view->file_scroll.min_y = view->gui_target.scroll_updated.min_y; view->recent->scroll.min_y = view->gui_target.scroll_updated.min_y;
view->file_scroll.max_y = view->gui_target.scroll_updated.max_y; view->recent->scroll.max_y = view->gui_target.scroll_updated.max_y;
view->file_scroll.target_x = target_x; view->recent->scroll.target_x = target_x;
view->file_scroll.scroll_x = target_x; view->recent->scroll.scroll_x = target_x;
view->file_scroll.prev_target_x = -1000.f; view->recent->scroll.prev_target_x = -1000.f;
gui_post_scroll_vars(&view->gui_target, &view->file_scroll); gui_post_scroll_vars(&view->gui_target, &view->recent->scroll);
} }
#define CursorMaxY_(m,h) ((m) - (h)*3) #define CursorMaxY_(m,h) ((m) - (h)*3)
@ -3036,7 +3063,7 @@ file_step(View *view, i32_Rect region, Input_Summary *user_input, b32 is_active)
} }
if (target_y > scroll_vars.max_y) target_y = scroll_vars.max_y; if (target_y > scroll_vars.max_y) target_y = scroll_vars.max_y;
if (target_y < scroll_vars.min_y) target_y = view->file_scroll.min_y; if (target_y < scroll_vars.min_y) target_y = view->recent->scroll.min_y;
if (cursor_x < target_x){ if (cursor_x < target_x){
target_x = (f32)Max(0, cursor_x - max_x/2); target_x = (f32)Max(0, cursor_x - max_x/2);
@ -3060,7 +3087,7 @@ file_step(View *view, i32_Rect region, Input_Summary *user_input, b32 is_active)
f32 rx = (f32)(user_input->mouse.x - region.x0); f32 rx = (f32)(user_input->mouse.x - region.x0);
f32 ry = (f32)(user_input->mouse.y - region.y0); f32 ry = (f32)(user_input->mouse.y - region.y0);
if (ry >= -view->file_scroll.min_y){ if (ry >= -view->recent->scroll.min_y){
view_set_widget(view, FWIDG_NONE); view_set_widget(view, FWIDG_NONE);
if (rx >= 0 && rx < max_x && ry >= 0 && ry < max_visible_y){ if (rx >= 0 && rx < max_x && ry >= 0 && ry < max_visible_y){
view_cursor_move(view, rx + scroll_vars.scroll_x, ry + scroll_vars.scroll_y, 1); view_cursor_move(view, rx + scroll_vars.scroll_x, ry + scroll_vars.scroll_y, 1);
@ -3367,7 +3394,7 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
Models *models = view->models; Models *models = view->models;
Key_Summary keys = input.keys; Key_Summary keys = input.keys;
f32 min_target_y = view->file_scroll.min_y; f32 min_target_y = view->recent->scroll.min_y;
view->current_scroll = 0; view->current_scroll = 0;
@ -3390,9 +3417,9 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
f32 delta = 9.f * view->font_height; f32 delta = 9.f * view->font_height;
f32 target_y = 0; f32 target_y = 0;
view->current_scroll = &view->file_scroll; view->current_scroll = &view->recent->scroll;
if (gui_get_scroll_vars(target, view->showing_ui, &view->file_scroll)){ if (gui_get_scroll_vars(target, view->showing_ui, &view->recent->scroll, &view->scroll_region)){
target_y = view->file_scroll.target_y; target_y = view->recent->scroll.target_y;
if (cursor_y > target_y + cursor_max_y){ if (cursor_y > target_y + cursor_max_y){
cursor_y = target_y + cursor_max_y; cursor_y = target_y + cursor_max_y;
} }
@ -3411,7 +3438,7 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
} }
} }
gui_begin_scrollable(target, view->showing_ui, view->file_scroll, delta); gui_begin_scrollable(target, view->showing_ui, view->recent->scroll, delta);
gui_do_file(target); gui_do_file(target);
gui_end_scrollable(target); gui_end_scrollable(target);
} }
@ -3491,7 +3518,7 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
gui_do_text_field(target, message, empty_string); gui_do_text_field(target, message, empty_string);
view->current_scroll = &view->gui_scroll; view->current_scroll = &view->gui_scroll;
gui_get_scroll_vars(target, view->showing_ui, &view->gui_scroll); gui_get_scroll_vars(target, view->showing_ui, &view->gui_scroll, &view->scroll_region);
gui_begin_scrollable(target, view->showing_ui, view->gui_scroll, 9.f * view->font_height); gui_begin_scrollable(target, view->showing_ui, view->gui_scroll, 9.f * view->font_height);
{ {
@ -3564,7 +3591,7 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
} }
view->current_scroll = &view->gui_scroll; view->current_scroll = &view->gui_scroll;
gui_get_scroll_vars(target, view->showing_ui, &view->gui_scroll); gui_get_scroll_vars(target, view->showing_ui, &view->gui_scroll, &view->scroll_region);
gui_begin_scrollable(target, view->showing_ui, view->gui_scroll, 9.f * view->font_height); gui_begin_scrollable(target, view->showing_ui, view->gui_scroll, 9.f * view->font_height);
i32 next_color_editing = view->current_color_editing; i32 next_color_editing = view->current_color_editing;
@ -3692,7 +3719,7 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
gui_do_text_field(target, message, hdir->string); gui_do_text_field(target, message, hdir->string);
view->current_scroll = &view->gui_scroll; view->current_scroll = &view->gui_scroll;
if (gui_get_scroll_vars(target, view->showing_ui, &view->gui_scroll)){ if (gui_get_scroll_vars(target, view->showing_ui, &view->gui_scroll, &view->scroll_region)){
snap_into_view = 1; snap_into_view = 1;
} }
gui_begin_scrollable(target, view->showing_ui, gui_begin_scrollable(target, view->showing_ui,
@ -3702,7 +3729,7 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
if (gui_begin_list(target, id, view->list_i, 0, if (gui_begin_list(target, id, view->list_i, 0,
snap_into_view, &update)){ snap_into_view, &update)){
gui_standard_list(target, id, view->gui_scroll, gui_standard_list(target, id, view->scroll_region,
&keys, &view->list_i, &update); &keys, &view->list_i, &update);
} }
@ -3776,7 +3803,7 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
gui_do_text_field(target, message, view->dest); gui_do_text_field(target, message, view->dest);
view->current_scroll = &view->gui_scroll; view->current_scroll = &view->gui_scroll;
if (gui_get_scroll_vars(target, view->showing_ui, &view->gui_scroll)){ if (gui_get_scroll_vars(target, view->showing_ui, &view->gui_scroll, &view->scroll_region)){
snap_into_view = 1; snap_into_view = 1;
} }
gui_begin_scrollable(target, view->showing_ui, view->gui_scroll, 9.f * view->font_height); gui_begin_scrollable(target, view->showing_ui, view->gui_scroll, 9.f * view->font_height);
@ -3784,7 +3811,7 @@ step_file_view(System_Functions *system, View *view, View *active_view, Input_Su
id.id[0] = (u64)(working_set) + 1; id.id[0] = (u64)(working_set) + 1;
if (gui_begin_list(target, id, view->list_i, if (gui_begin_list(target, id, view->list_i,
0, snap_into_view, &update)){ 0, snap_into_view, &update)){
gui_standard_list(target, id, view->gui_scroll, gui_standard_list(target, id, view->scroll_region,
&keys, &view->list_i, &update); &keys, &view->list_i, &update);
} }
@ -3922,7 +3949,7 @@ internal f32
view_get_scroll_y(View *view){ view_get_scroll_y(View *view){
f32 v; f32 v;
if (view->showing_ui == VUI_None){ if (view->showing_ui == VUI_None){
v = view->file_scroll.scroll_y; v = view->recent->scroll.scroll_y;
} }
else{ else{
v = view->gui_scroll.scroll_y; v = view->gui_scroll.scroll_y;
@ -4083,6 +4110,11 @@ do_input_file_view(System_Functions *system, Exchange *exchange,
} }
}break; }break;
case guicom_scrollable:
{
view->scroll_region = target->region_updated;
}break;
case guicom_scrollable_slider: case guicom_scrollable_slider:
{ {
GUI_id id = gui_id_scrollbar_slider(); GUI_id id = gui_id_scrollbar_slider();
@ -4247,8 +4279,8 @@ draw_file_loaded(View *view, i32_Rect rect, b32 is_active, Render_Target *target
Buffer_Render_Options opts = {}; Buffer_Render_Options opts = {};
f32 *wraps = view->file_data.line_wrap_y; f32 *wraps = view->file_data.line_wrap_y;
f32 scroll_x = view->file_scroll.scroll_x; f32 scroll_x = view->recent->scroll.scroll_x;
f32 scroll_y = view->file_scroll.scroll_y; f32 scroll_y = view->recent->scroll.scroll_y;
{ {
render_cursor = buffer_get_start_cursor(&file->state.buffer, wraps, scroll_y, render_cursor = buffer_get_start_cursor(&file->state.buffer, wraps, scroll_y,

View File

@ -130,8 +130,6 @@ struct GUI_Scroll_Vars{
f32 scroll_x; f32 scroll_x;
f32 target_x; f32 target_x;
f32 prev_target_x; f32 prev_target_x;
i32_Rect region;
}; };
struct GUI_Target{ struct GUI_Target{
@ -144,7 +142,10 @@ struct GUI_Target{
// TODO(allen): Can we remove original yet? // TODO(allen): Can we remove original yet?
GUI_Scroll_Vars scroll_original; GUI_Scroll_Vars scroll_original;
i32_Rect region_original;
GUI_Scroll_Vars scroll_updated; GUI_Scroll_Vars scroll_updated;
i32_Rect region_updated;
// TODO(allen): Would rather have a way of tracking this // TODO(allen): Would rather have a way of tracking this
// for more than one list. Perhaps just throw in a hash table? // for more than one list. Perhaps just throw in a hash table?
@ -669,10 +670,11 @@ gui_scroll_eq(GUI_Scroll_Vars *a, GUI_Scroll_Vars *b){
// TODO(allen): Rethink this a little, seems like there are two separate things we want to do here: // TODO(allen): Rethink this a little, seems like there are two separate things we want to do here:
// Getting the updated scroll vars, and telling the user when scrolling actions occur. // Getting the updated scroll vars, and telling the user when scrolling actions occur.
internal b32 internal b32
gui_get_scroll_vars(GUI_Target *target, u32 scroll_id, GUI_Scroll_Vars *vars_out){ gui_get_scroll_vars(GUI_Target *target, u32 scroll_id, GUI_Scroll_Vars *vars_out, i32_Rect *region_out){
b32 result = 0; b32 result = 0;
if (target->scroll_id == scroll_id){ if (target->scroll_id == scroll_id){
*vars_out = target->scroll_updated; *vars_out = target->scroll_updated;
*region_out = target->region_updated;
if (vars_out->target_y < vars_out->min_y) vars_out->target_y = vars_out->min_y; if (vars_out->target_y < vars_out->min_y) vars_out->target_y = vars_out->min_y;
if (vars_out->target_y > vars_out->max_y) vars_out->target_y = vars_out->max_y; if (vars_out->target_y > vars_out->max_y) vars_out->target_y = vars_out->max_y;
@ -1129,7 +1131,7 @@ gui_interpret(GUI_Target *target, GUI_Session *session, GUI_Header *h){
scrollable_rect.x1 = rect.x0; scrollable_rect.x1 = rect.x0;
scrollable_rect.y0 = rect.y0; scrollable_rect.y0 = rect.y0;
scrollable_rect.y1 = rect.y1; scrollable_rect.y1 = rect.y1;
target->scroll_updated.region = scrollable_rect; target->region_updated = scrollable_rect;
} }
break; break;
@ -1189,7 +1191,7 @@ gui_interpret(GUI_Target *target, GUI_Session *session, GUI_Header *h){
if (do_layout){ if (do_layout){
if (session->list.in_list && is_list_item){ if (session->list.in_list && is_list_item){
i32 list_i = session->list.index - 1; i32 list_i = session->list.index - 1;
i32_Rect region = target->scroll_updated.region; i32_Rect region = target->region_updated;
if (rect.y0 - target_v >= region.y0 && if (rect.y0 - target_v >= region.y0 &&
rect.y1 - target_v <= region.y1){ rect.y1 - target_v <= region.y1){
@ -1244,11 +1246,11 @@ struct GUI_View_Jump{
}; };
internal GUI_View_Jump internal GUI_View_Jump
gui_compute_view_jump(GUI_Scroll_Vars scroll, i32_Rect position){ gui_compute_view_jump(i32_Rect scroll_region, i32_Rect position){
GUI_View_Jump jump = {0}; GUI_View_Jump jump = {0};
i32 region_h = scroll.region.y1 - scroll.region.y0; i32 region_h = scroll_region.y1 - scroll_region.y0;
jump.view_min = (f32)position.y1 - region_h - scroll.region.y0; jump.view_min = (f32)position.y1 - region_h - scroll_region.y0;
jump.view_max = (f32)position.y0 - scroll.region.y0; jump.view_max = (f32)position.y0 - scroll_region.y0;
return(jump); return(jump);
} }
@ -1266,7 +1268,7 @@ gui_do_jump(GUI_Target *target, GUI_View_Jump jump){
} }
internal void internal void
gui_standard_list(GUI_Target *target, GUI_id id, GUI_Scroll_Vars scroll, gui_standard_list(GUI_Target *target, GUI_id id, i32_Rect scroll_region,
Key_Summary *keys, i32 *list_i, GUI_Item_Update *update){ Key_Summary *keys, i32 *list_i, GUI_Item_Update *update){
if (update->has_adjustment){ if (update->has_adjustment){
@ -1275,7 +1277,7 @@ gui_standard_list(GUI_Target *target, GUI_id id, GUI_Scroll_Vars scroll,
if (update->has_index_position){ if (update->has_index_position){
GUI_View_Jump jump = GUI_View_Jump jump =
gui_compute_view_jump(scroll, update->index_position); gui_compute_view_jump(scroll_region, update->index_position);
jump.view_min += 45.f; jump.view_min += 45.f;
jump.view_max -= 45.f; jump.view_max -= 45.f;
gui_do_jump(target, jump); gui_do_jump(target, jump);