From: Paul Eggert Date: Sat, 12 Apr 2014 21:54:27 +0000 (-0700) Subject: * keyboard.c (Fopen_dribble_file): Avoid some races. X-Git-Tag: emacs-24.3.91~156 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=a9108bf189e6cccfe568348ec604b9eecd17a125;p=emacs.git * keyboard.c (Fopen_dribble_file): Avoid some races. Fixes: debbugs:17187 --- diff --git a/src/ChangeLog b/src/ChangeLog index cb17738d139..2d7307412b2 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,7 @@ +2014-04-12 Paul Eggert + + * keyboard.c (Fopen_dribble_file): Avoid some races. (Bug#17187) + 2014-04-12 Eli Zaretskii * xdisp.c (move_it_by_lines): If a large portion of buffer text is diff --git a/src/keyboard.c b/src/keyboard.c index f74ba0ee581..a66054f153f 100644 --- a/src/keyboard.c +++ b/src/keyboard.c @@ -10088,15 +10088,9 @@ This may include sensitive information such as passwords. */) { int fd; file = Fexpand_file_name (file, Qnil); - /* This isn't robust, since eg file could be created after we - check whether it exists but before emacs_open. - Feel free to improve it, but this is not critical. (Bug#17187) */ - if (! NILP (Ffile_exists_p (file))) - { - if (chmod (SSDATA (file), 0600) < 0) - report_file_error ("Doing chmod", file); - } - fd = emacs_open (SSDATA (file), O_WRONLY | O_CREAT | O_TRUNC, 0600); + fd = emacs_open (SSDATA (file), O_WRONLY | O_CREAT | O_EXCL, 0600); + if (fd < 0 && errno == EEXIST && unlink (SSDATA (file)) == 0) + fd = emacs_open (SSDATA (file), O_WRONLY | O_CREAT | O_EXCL, 0600); dribble = fd < 0 ? 0 : fdopen (fd, "w"); if (dribble == 0) report_file_error ("Opening dribble", file);