From 114216c4173e2821b1e0615dd7341c03e6d6d607 Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Tue, 14 Mar 2006 23:08:30 +0000 Subject: updated for version 7.0224 --- src/ex_cmds.c | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) (limited to 'src/ex_cmds.c') diff --git a/src/ex_cmds.c b/src/ex_cmds.c index 37cef12a5e..e77d05aad5 100644 --- a/src/ex_cmds.c +++ b/src/ex_cmds.c @@ -1811,6 +1811,15 @@ write_viminfo(file, forceit) if (tempname != NULL) { +#ifdef VMS + /* fdopen() fails for some reason */ + if (fp_out == NULL) + { + umask_save = umask(077); + fp_out = mch_fopen((char *)tempname, WRITEBIN); + (void)umask(umask_save); + } +#else int fd; /* Use mch_open() to be able to use O_NOFOLLOW and set file @@ -1818,20 +1827,21 @@ write_viminfo(file, forceit) * Unix: same as original file, but strip s-bit. Reset umask to * avoid it getting in the way. * Others: r&w for user only. */ -#ifdef UNIX +# ifdef UNIX umask_save = umask(0); fd = mch_open((char *)tempname, O_CREAT|O_EXTRA|O_EXCL|O_WRONLY|O_NOFOLLOW, (int)((st_old.st_mode & 0777) | 0600)); (void)umask(umask_save); -#else +# else fd = mch_open((char *)tempname, O_CREAT|O_EXTRA|O_EXCL|O_WRONLY|O_NOFOLLOW, 0600); -#endif +# endif if (fd < 0) fp_out = NULL; else fp_out = fdopen(fd, WRITEBIN); +#endif /* VMS */ /* * If we can't create in the same directory, try creating a -- cgit v1.2.3