diff options
author | pommicket <pommicket@gmail.com> | 2023-08-13 22:19:21 -0300 |
---|---|---|
committer | pommicket <pommicket@gmail.com> | 2023-08-13 22:19:21 -0300 |
commit | 79af91046d6c9f8ddca52dee1cb72181168c0f73 (patch) | |
tree | 82b70ee555d20fc6036a7f97bf94f3853130d64a | |
parent | 74c32a957d8533f746c960e8f726670e3d6b1baf (diff) |
fix ask-reload menu
-rw-r--r-- | buffer.c | 6 | ||||
-rw-r--r-- | main.c | 3 | ||||
-rw-r--r-- | menu.c | 2 | ||||
-rw-r--r-- | ted.h | 2 |
4 files changed, 11 insertions, 2 deletions
@@ -206,6 +206,12 @@ double buffer_last_write_time(TextBuffer *buffer) { return buffer->last_write_time; } +void buffer_ignore_changes_on_disk(TextBuffer *buffer) { + buffer->last_write_time = timespec_to_seconds(time_last_modified(buffer->path)); + // no matter what, buffer_unsaved_changes should return true + buffer->undo_history_write_pos = U32_MAX; +} + BufferPos buffer_cursor_pos(TextBuffer *buffer) { return buffer->cursor_pos; } @@ -1,6 +1,5 @@ /* TODO: -- fix ask-reload menu (clicking "no" will probably do nothing) - public Node API - public Selector/FileSelector API - public Settings API @@ -16,7 +15,7 @@ FUTURE FEATURES: - "remove file..." menu - auto-close brackets - with macros we can really test performance of buffer_insert_text_at_pos, etc. (which should ideally be fast) -- manual.md +- manual directory - LSP request timeout */ @@ -329,6 +329,8 @@ static void ask_reload_menu_update(Ted *ted) { break; case POPUP_NO: menu_close(ted); + if (buffer) + buffer_ignore_changes_on_disk(buffer); break; case POPUP_CANCEL: assert(0); break; } @@ -329,6 +329,8 @@ double buffer_get_scroll_lines(TextBuffer *buffer); void buffer_scroll_to(TextBuffer *buffer, double cols, double lines); /// get last time buffer was written to, in the format of \ref time_get_seconds double buffer_last_write_time(TextBuffer *buffer); +/// ignore any changes that have been made to the loaded file +void buffer_ignore_changes_on_disk(TextBuffer *buffer); /// get position of the cursor BufferPos buffer_cursor_pos(TextBuffer *buffer); /// returns true if anything is selected |