diff options
| author | Marc André Tanner <mat@brain-dump.org> | 2015-07-06 21:49:19 +0200 |
|---|---|---|
| committer | Marc André Tanner <mat@brain-dump.org> | 2015-07-06 21:49:19 +0200 |
| commit | 22d843e6719c025bf6d711bfdd3644e442ee8966 (patch) | |
| tree | 67a52cf274e92759696d99d1a1dd932e5e369394 /text.c | |
| parent | 071b5f3c94c4b157a153586b087229f9e6b465d3 (diff) | |
| download | vis-22d843e6719c025bf6d711bfdd3644e442ee8966.tar.gz vis-22d843e6719c025bf6d711bfdd3644e442ee8966.tar.xz | |
Warn when saving a file which has been changed outside the editor
Diffstat (limited to 'text.c')
| -rw-r--r-- | text.c | 9 |
1 files changed, 8 insertions, 1 deletions
@@ -802,7 +802,7 @@ static bool preserve_selinux_context(int src, int dest) { * - SELinux security context can not be preserved (if enabled) */ static bool text_range_save_atomic(Text *txt, Filerange *range, const char *filename) { - struct stat meta; + struct stat meta = { 0 }; int fd = -1, oldfd = -1, saved_errno; char *tmpname = NULL; size_t size = text_range_size(range); @@ -877,6 +877,8 @@ static bool text_range_save_atomic(Text *txt, Filerange *range, const char *file if (rename(tmpname, filename) == -1) goto err; + if (meta.st_mtime) + txt->info = meta; free(tmpname); return true; err: @@ -955,6 +957,7 @@ bool text_range_save(Text *txt, Filerange *range, const char *filename) { goto err; if (close(fd) == -1) return false; + txt->info = meta; ok: txt->saved_action = txt->history; text_snapshot(txt); @@ -1043,6 +1046,10 @@ out: return NULL; } +struct stat text_stat(Text *txt) { + return txt->info; +} + /* A delete operation can either start/stop midway through a piece or at * a boundry. In the former case a new piece is created to represent the * remaining text before/after the modification point. |
