]> git.eshelyaron.com Git - emacs.git/commitdiff
(Ffile_modes): Doc fix.
authorKim F. Storm <storm@cua.dk>
Fri, 5 Nov 2004 12:33:07 +0000 (12:33 +0000)
committerKim F. Storm <storm@cua.dk>
Fri, 5 Nov 2004 12:33:07 +0000 (12:33 +0000)
(auto_save_1): Check for Ffile_modes nil value.

src/ChangeLog
src/fileio.c

index ce45e97514fc55e7cfb2cfb19dfd79d468ec01c5..a38c3f7baebaa711e668fdafa3afec839b370956 100644 (file)
@@ -1,3 +1,8 @@
+2004-11-05  Kim F. Storm  <storm@cua.dk>
+
+       * fileio.c (Ffile_modes): Doc fix.
+       (auto_save_1): Check for Ffile_modes nil value.
+
 2004-11-05  Kim F. Storm  <storm@cua.dk>
 
        * xselect.c (struct selection_event_queue, selection_queue)
index 4b5f4942566c3a83a59f127ca92849f38cb87ae1..aa37c296eb35248fe21127b9a31b6f5631f52270 100644 (file)
@@ -3366,7 +3366,8 @@ This is the sort of file that holds an ordinary stream of data bytes.  */)
 }
 \f
 DEFUN ("file-modes", Ffile_modes, Sfile_modes, 1, 1, 0,
-       doc: /* Return mode bits of file named FILENAME, as an integer.  */)
+       doc: /* Return mode bits of file named FILENAME, as an integer.
+Return nil, if file does not exist or is not accessible.  */)
      (filename)
      Lisp_Object filename;
 {
@@ -5712,17 +5713,21 @@ Lisp_Object
 auto_save_1 ()
 {
   struct stat st;
+  Lisp_Object modes;
+
+  auto_save_mode_bits = 0666;
 
   /* Get visited file's mode to become the auto save file's mode.  */
-  if (! NILP (current_buffer->filename)
-      && stat (SDATA (current_buffer->filename), &st) >= 0)
-    /* But make sure we can overwrite it later!  */
-    auto_save_mode_bits = st.st_mode | 0600;
-  else if (! NILP (current_buffer->filename))
-    /* Remote files don't cooperate with stat.  */
-    auto_save_mode_bits = XINT (Ffile_modes (current_buffer->filename)) | 0600;
-  else
-    auto_save_mode_bits = 0666;
+  if (! NILP (current_buffer->filename))
+    {
+      if (stat (SDATA (current_buffer->filename), &st) >= 0)
+       /* But make sure we can overwrite it later!  */
+       auto_save_mode_bits = st.st_mode | 0600;
+      else if ((modes = Ffile_modes (current_buffer->filename),
+               INTEGERP (modes)))
+       /* Remote files don't cooperate with stat.  */
+       auto_save_mode_bits = XINT (modes) | 0600;
+    }
 
   return
     Fwrite_region (Qnil, Qnil,
@@ -6190,7 +6195,7 @@ before any other event (mouse or keypress) is handeled.  */)
 #endif
   return Qnil;
 }
-       
+
 DEFUN ("read-file-name", Fread_file_name, Sread_file_name, 1, 6, 0,
        doc: /* Read file name, prompting with PROMPT and completing in directory DIR.
 Value is not expanded---you must call `expand-file-name' yourself.