summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2012-08-29 18:50:54 +0200
committerBram Moolenaar <Bram@vim.org>2012-08-29 18:50:54 +0200
commit465748e41179169f9b432deaae9cabd0e55bb9e3 (patch)
tree5249e67bc57c670bbefe2272ba470e4820421d45
parentdd7d84647521723a0c95b72752beccdb7ce2cd02 (diff)
downloadvim-git-465748e41179169f9b432deaae9cabd0e55bb9e3.tar.gz
updated for version 7.3.646v7.3.646
Problem: When reloading a buffer the undo file becomes unusable unless ":w" is executed. (Dmitri Frank) Solution: After reloading the buffer write the undo file. (Christian Brabandt)
-rw-r--r--src/fileio.c15
-rw-r--r--src/version.c2
2 files changed, 17 insertions, 0 deletions
diff --git a/src/fileio.c b/src/fileio.c
index df694234f..a3113d7b1 100644
--- a/src/fileio.c
+++ b/src/fileio.c
@@ -7060,8 +7060,23 @@ buf_check_timestamp(buf, focus)
}
if (reload)
+ {
/* Reload the buffer. */
buf_reload(buf, orig_mode);
+#ifdef FEAT_PERSISTENT_UNDO
+ if (buf->b_p_udf && buf->b_ffname != NULL)
+ {
+ char_u hash[UNDO_HASH_SIZE];
+ buf_T *save_curbuf = curbuf;
+
+ /* Any existing undo file is unusable, write it now. */
+ curbuf = buf;
+ u_compute_hash(hash);
+ u_write_undo(NULL, FALSE, buf, hash);
+ curbuf = save_curbuf;
+ }
+#endif
+ }
#ifdef FEAT_AUTOCMD
/* Trigger FileChangedShell when the file was changed in any way. */
diff --git a/src/version.c b/src/version.c
index f30551b86..2f20fa674 100644
--- a/src/version.c
+++ b/src/version.c
@@ -720,6 +720,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 646,
+/**/
645,
/**/
644,