diff options
author | Bram Moolenaar <Bram@vim.org> | 2007-06-28 20:02:32 +0000 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2007-06-28 20:02:32 +0000 |
commit | 5386a123f5038d397848cc0183eda93c7c8b9d95 (patch) | |
tree | 6f81e637dfe5e0d71eb7dccd8c948e74d0c0942b /src/fileio.c | |
parent | 7f51474324cf1a31284f291e7097d989522f9d45 (diff) | |
download | vim-git-5386a123f5038d397848cc0183eda93c7c8b9d95.tar.gz |
updated for version 7.1-017v7.1.017
Diffstat (limited to 'src/fileio.c')
-rw-r--r-- | src/fileio.c | 41 |
1 files changed, 29 insertions, 12 deletions
diff --git a/src/fileio.c b/src/fileio.c index c44a08d37..6fd2799c8 100644 --- a/src/fileio.c +++ b/src/fileio.c @@ -424,7 +424,7 @@ readfile(fname, sfname, from, lines_to_skip, lines_to_read, eap, flags) */ if (!p_odev && mch_nodetype(fname) == NODE_WRITABLE) { - filemess(curbuf, fname, (char_u *)_("is a device (disabled with 'opendevice' option"), 0); + filemess(curbuf, fname, (char_u *)_("is a device (disabled with 'opendevice' option)"), 0); msg_end(); msg_scroll = msg_save; return FAIL; @@ -2734,6 +2734,32 @@ set_file_time(fname, atime, mtime) #endif /* + * Return TRUE if a file appears to be read-only from the file permissions. + */ + int +check_file_readonly(fname, perm) + char_u *fname; /* full path to file */ + int perm; /* known permissions on file */ +{ +#ifndef USE_MCH_ACCESS + int fd = 0; +#endif + + return ( +#ifdef USE_MCH_ACCESS +# ifdef UNIX + (perm & 0222) == 0 || +# endif + mch_access((char *)fname, W_OK) +#else + (fd = mch_open((char *)fname, O_RDWR | O_EXTRA, 0)) < 0 + ? TRUE : (close(fd), FALSE) +#endif + ); +} + + +/* * buf_write() - write to file "fname" lines "start" through "end" * * We do our own buffering here because fwrite() is so slow. @@ -3219,17 +3245,8 @@ buf_write(buf, fname, sfname, start, end, eap, append, forceit, * Check if the file is really writable (when renaming the file to * make a backup we won't discover it later). */ - file_readonly = ( -# ifdef USE_MCH_ACCESS -# ifdef UNIX - (perm & 0222) == 0 || -# endif - mch_access((char *)fname, W_OK) -# else - (fd = mch_open((char *)fname, O_RDWR | O_EXTRA, 0)) < 0 - ? TRUE : (close(fd), FALSE) -# endif - ); + file_readonly = check_file_readonly(fname, (int)perm); + if (!forceit && file_readonly) { if (vim_strchr(p_cpo, CPO_FWRITE) != NULL) |