]> git.eshelyaron.com Git - emacs.git/commitdiff
Delete previous emacs.exe before dumping to fix problem with hard links to it.
authorEli Zaretskii <eliz@gnu.org>
Tue, 16 Apr 2013 18:08:03 +0000 (21:08 +0300)
committerEli Zaretskii <eliz@gnu.org>
Tue, 16 Apr 2013 18:08:03 +0000 (21:08 +0300)
src/unexw32.c

index e8b553a87d3123cf2a41217b68e00249d1fb860a..a01ac7995921bd10d0d6eee0785c24869a2fbf61 100644 (file)
@@ -159,6 +159,14 @@ open_output_file (file_data *p_file, char *filename, unsigned long size)
   HANDLE file_mapping;
   void  *file_base;
 
+  /* We delete any existing FILENAME because loadup.el will create a
+     hard link to it under the name emacs-XX.YY.ZZ.nn.exe.  Evidently,
+     overwriting a file on Unix breaks any hard links to it, but that
+     doesn't happen on Windows.  If we don't delete the file before
+     creating it, all the emacs-XX.YY.ZZ.nn.exe end up being hard
+     links to the same file, which defeats the purpose of these hard
+     links: being able to run previous builds.  */
+  DeleteFile (filename);
   file = CreateFile (filename, GENERIC_READ | GENERIC_WRITE, 0, NULL,
                     CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0);
   if (file == INVALID_HANDLE_VALUE)