Moved built-in mark out of the edit pos
This commit is contained in:
parent
b0007d387f
commit
66a06053b6
3
4ed.cpp
3
4ed.cpp
|
@ -83,8 +83,7 @@ file_cursor_to_end(System_Functions *system, Models *models, Editing_File *file)
|
||||||
}
|
}
|
||||||
view_cursor_move(system, view, pos);
|
view_cursor_move(system, view, pos);
|
||||||
File_Edit_Positions edit_pos = view_get_edit_pos(view);
|
File_Edit_Positions edit_pos = view_get_edit_pos(view);
|
||||||
edit_pos.mark = edit_pos.cursor_pos;
|
view->transient.mark = edit_pos.cursor_pos;
|
||||||
view_set_edit_pos(view, edit_pos);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -68,7 +68,7 @@ fill_view_summary(System_Functions *system, View_Summary *view, View *vptr, Live
|
||||||
Assert(data->file != 0);
|
Assert(data->file != 0);
|
||||||
File_Edit_Positions edit_pos = view_get_edit_pos(vptr);
|
File_Edit_Positions edit_pos = view_get_edit_pos(vptr);
|
||||||
|
|
||||||
view->mark = file_compute_cursor(system, data->file, seek_pos(edit_pos.mark));
|
view->mark = file_compute_cursor(system, data->file, seek_pos(vptr->transient.mark));
|
||||||
view->cursor = file_compute_cursor(system, data->file, seek_pos(edit_pos.cursor_pos));
|
view->cursor = file_compute_cursor(system, data->file, seek_pos(edit_pos.cursor_pos));
|
||||||
|
|
||||||
view->preferred_x = edit_pos.preferred_x;
|
view->preferred_x = edit_pos.preferred_x;
|
||||||
|
@ -1948,16 +1948,12 @@ DOC_SEE(Buffer_Seek)
|
||||||
if (!file->is_loading){
|
if (!file->is_loading){
|
||||||
if (seek.type != buffer_seek_pos){
|
if (seek.type != buffer_seek_pos){
|
||||||
result = true;
|
result = true;
|
||||||
File_Edit_Positions edit_pos = view_get_edit_pos(vptr);
|
|
||||||
Full_Cursor cursor = file_compute_cursor(system, file, seek);
|
Full_Cursor cursor = file_compute_cursor(system, file, seek);
|
||||||
edit_pos.mark = cursor.pos;
|
vptr->transient.mark = cursor.pos;
|
||||||
view_set_edit_pos(vptr, edit_pos);
|
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
result = true;
|
result = true;
|
||||||
File_Edit_Positions edit_pos = view_get_edit_pos(vptr);
|
vptr->transient.mark = seek.pos;
|
||||||
edit_pos.mark = seek.pos;
|
|
||||||
view_set_edit_pos(vptr, edit_pos);
|
|
||||||
}
|
}
|
||||||
fill_view_summary(system, view, vptr, models);
|
fill_view_summary(system, view, vptr, models);
|
||||||
}
|
}
|
||||||
|
|
|
@ -115,9 +115,9 @@ edit_fix_markers(System_Functions *system, Models *models, Editing_File *file, E
|
||||||
View *view = panel->view;
|
View *view = panel->view;
|
||||||
if (view->transient.file_data.file == file){
|
if (view->transient.file_data.file == file){
|
||||||
File_Edit_Positions edit_pos = view_get_edit_pos(view);
|
File_Edit_Positions edit_pos = view_get_edit_pos(view);
|
||||||
write_cursor_with_index(cursors, &cursor_count, edit_pos.cursor_pos);
|
write_cursor_with_index(cursors, &cursor_count, edit_pos.cursor_pos );
|
||||||
write_cursor_with_index(cursors, &cursor_count, edit_pos.mark );
|
write_cursor_with_index(cursors, &cursor_count, view->transient.mark);
|
||||||
write_cursor_with_index(cursors, &cursor_count, edit_pos.scroll_i );
|
write_cursor_with_index(cursors, &cursor_count, edit_pos.scroll_i );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -165,8 +165,7 @@ edit_fix_markers(System_Functions *system, Models *models, Editing_File *file, E
|
||||||
File_Edit_Positions edit_pos = view_get_edit_pos(view);
|
File_Edit_Positions edit_pos = view_get_edit_pos(view);
|
||||||
GUI_Scroll_Vars scroll = edit_pos.scroll;
|
GUI_Scroll_Vars scroll = edit_pos.scroll;
|
||||||
|
|
||||||
edit_pos.mark = cursors[cursor_count++].pos;
|
view->transient.mark = cursors[cursor_count++].pos;
|
||||||
view_set_edit_pos(view, edit_pos);
|
|
||||||
i32 new_scroll_i = cursors[cursor_count++].pos;
|
i32 new_scroll_i = cursors[cursor_count++].pos;
|
||||||
if (edit_pos.scroll_i != new_scroll_i){
|
if (edit_pos.scroll_i != new_scroll_i){
|
||||||
edit_pos.scroll_i = new_scroll_i;
|
edit_pos.scroll_i = new_scroll_i;
|
||||||
|
|
|
@ -20,7 +20,6 @@ enum Edit_Pos_Set_Type{
|
||||||
struct File_Edit_Positions{
|
struct File_Edit_Positions{
|
||||||
GUI_Scroll_Vars scroll;
|
GUI_Scroll_Vars scroll;
|
||||||
i32 cursor_pos;
|
i32 cursor_pos;
|
||||||
i32 mark;
|
|
||||||
f32 preferred_x;
|
f32 preferred_x;
|
||||||
i32 scroll_i;
|
i32 scroll_i;
|
||||||
i32 last_set_type;
|
i32 last_set_type;
|
||||||
|
|
|
@ -342,8 +342,9 @@ view_set_file(System_Functions *system, Models *models, View *view, Editing_File
|
||||||
block_zero(&view->transient.file_data, sizeof(view->transient.file_data));
|
block_zero(&view->transient.file_data, sizeof(view->transient.file_data));
|
||||||
view->transient.file_data.file = file;
|
view->transient.file_data.file = file;
|
||||||
|
|
||||||
// TODO(allen): do(set edit pos without updating file when popping)
|
File_Edit_Positions edit_pos = file_edit_positions_pop(file);
|
||||||
view->transient.edit_pos_ = file_edit_positions_pop(file);
|
view_set_edit_pos(view, edit_pos);
|
||||||
|
view->transient.mark = edit_pos.cursor_pos;
|
||||||
|
|
||||||
Font_Pointers font = system->font.get_pointers_by_id(file->settings.font_id);
|
Font_Pointers font = system->font.get_pointers_by_id(file->settings.font_id);
|
||||||
view->transient.line_height = font.metrics->height;
|
view->transient.line_height = font.metrics->height;
|
||||||
|
|
|
@ -37,6 +37,7 @@ struct View_Transient{
|
||||||
|
|
||||||
i32_Rect scroll_region;
|
i32_Rect scroll_region;
|
||||||
File_Edit_Positions edit_pos_;
|
File_Edit_Positions edit_pos_;
|
||||||
|
i32 mark;
|
||||||
|
|
||||||
b32 ui_mode;
|
b32 ui_mode;
|
||||||
UI_Quit_Function_Type *ui_quit;
|
UI_Quit_Function_Type *ui_quit;
|
||||||
|
|
Loading…
Reference in New Issue