summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2019-02-14 12:56:36 +0100
committerBram Moolenaar <Bram@vim.org>2019-02-14 12:56:36 +0100
commita787019518a540a7b4d0070f15467931b870ac89 (patch)
tree684243a253d30b00c171f25144798f80400ecc4b /src
parent5fd0f5052f9a312bb4cfe7b4176b1211d45127ee (diff)
patch 8.1.0915: fsync() may not work properly on Macv8.1.0915
Problem: fsync() may not work properly on Mac. Solution: Use fcntl() with F_FULLFSYNC. (suggested by Justin M. Keyes)
Diffstat (limited to 'src')
-rw-r--r--src/evalfunc.c4
-rw-r--r--src/fileio.c21
-rw-r--r--src/memfile.c6
-rw-r--r--src/proto/fileio.pro1
-rw-r--r--src/version.c2
5 files changed, 28 insertions, 6 deletions
diff --git a/src/evalfunc.c b/src/evalfunc.c
index 6538b36d3c..e693ef9137 100644
--- a/src/evalfunc.c
+++ b/src/evalfunc.c
@@ -14791,7 +14791,7 @@ f_writefile(typval_T *argvars, typval_T *rettv)
else if (do_fsync)
// Ignore the error, the user wouldn't know what to do about it.
// May happen for a device.
- vim_ignored = fsync(fileno(fd));
+ vim_ignored = vim_fsync(fileno(fd));
#endif
fclose(fd);
}
@@ -14803,7 +14803,7 @@ f_writefile(typval_T *argvars, typval_T *rettv)
else if (do_fsync)
/* Ignore the error, the user wouldn't know what to do about it.
* May happen for a device. */
- vim_ignored = fsync(fileno(fd));
+ vim_ignored = vim_fsync(fileno(fd));
#endif
fclose(fd);
}
diff --git a/src/fileio.c b/src/fileio.c
index c7f3ad1768..f9e18d413a 100644
--- a/src/fileio.c
+++ b/src/fileio.c
@@ -4661,7 +4661,7 @@ restore_backup:
* work (could be a pipe).
* If the 'fsync' option is FALSE, don't fsync(). Useful for laptops.
*/
- if (p_fs && fsync(fd) != 0 && !device)
+ if (p_fs && vim_fsync(fd) != 0 && !device)
{
errmsg = (char_u *)_(e_fsync);
end = 0;
@@ -5123,6 +5123,25 @@ nofail:
return retval;
}
+#if defined(HAVE_FSYNC) || defined(PROTO)
+/*
+ * Call fsync() with Mac-specific exception.
+ * Return fsync() result: zero for success.
+ */
+ int
+vim_fsync(int fd)
+{
+ int r;
+
+# ifdef MACOS_X
+ r = fcntl(fd, F_FULLFSYNC);
+ if (r != 0 && errno == ENOTTY)
+# endif
+ r = fsync(fd);
+ return r;
+}
+#endif
+
/*
* Set the name of the current buffer. Use when the buffer doesn't have a
* name and a ":r" or ":w" command with a file name is used.
diff --git a/src/memfile.c b/src/memfile.c
index f2e774a4ed..1a527340ad 100644
--- a/src/memfile.c
+++ b/src/memfile.c
@@ -600,7 +600,7 @@ mf_sync(memfile_T *mfp, int flags)
*/
if (STRCMP(p_sws, "fsync") == 0)
{
- if (fsync(mfp->mf_fd))
+ if (vim_fsync(mfp->mf_fd))
status = FAIL;
}
else
@@ -617,7 +617,7 @@ mf_sync(memfile_T *mfp, int flags)
#ifdef VMS
if (STRCMP(p_sws, "fsync") == 0)
{
- if (fsync(mfp->mf_fd))
+ if (vim_fsync(mfp->mf_fd))
status = FAIL;
}
#endif
@@ -627,7 +627,7 @@ mf_sync(memfile_T *mfp, int flags)
#endif
#ifdef AMIGA
# if defined(__AROS__) || defined(__amigaos4__)
- if (fsync(mfp->mf_fd) != 0)
+ if (vim_fsync(mfp->mf_fd) != 0)
status = FAIL;
# else
/*
diff --git a/src/proto/fileio.pro b/src/proto/fileio.pro
index 21ac55c9d1..e99cbc8bfd 100644
--- a/src/proto/fileio.pro
+++ b/src/proto/fileio.pro
@@ -7,6 +7,7 @@ void set_file_options(int set_options, exarg_T *eap);
void set_forced_fenc(exarg_T *eap);
int check_file_readonly(char_u *fname, int perm);
int buf_write(buf_T *buf, char_u *fname, char_u *sfname, linenr_T start, linenr_T end, exarg_T *eap, int append, int forceit, int reset_changed, int filtering);
+int vim_fsync(int fd);
void msg_add_fname(buf_T *buf, char_u *fname);
void msg_add_lines(int insert_space, long lnum, off_T nchars);
char_u *shorten_fname1(char_u *full_path);
diff --git a/src/version.c b/src/version.c
index ed224a454c..d0255a1b8e 100644
--- a/src/version.c
+++ b/src/version.c
@@ -784,6 +784,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 915,
+/**/
914,
/**/
913,