]> git.eshelyaron.com Git - emacs.git/commitdiff
(Fmake_symbolic_link, Fadd_name_to_file):
authorRichard M. Stallman <rms@gnu.org>
Sat, 2 Sep 1995 01:21:55 +0000 (01:21 +0000)
committerRichard M. Stallman <rms@gnu.org>
Sat, 2 Sep 1995 01:21:55 +0000 (01:21 +0000)
Look for handler for the new name as well as for the target.

src/fileio.c

index d58a15041c95eb9c89014a7cb619bb55a7e59cc0..cd2e9bbfe0f83394f1f35e05bec3ea5bfde555d9 100644 (file)
@@ -2124,6 +2124,13 @@ This is what happens in interactive use with M-x.")
     RETURN_UNGCPRO (call4 (handler, Qadd_name_to_file, filename,
                           newname, ok_if_already_exists));
 
+  /* If the new name has special constructs in it,
+     call the corresponding file handler.  */
+  handler = Ffind_file_name_handler (newname, Qadd_name_to_file);
+  if (!NILP (handler))
+    RETURN_UNGCPRO (call4 (handler, Qadd_name_to_file, filename,
+                          newname, ok_if_already_exists));
+
   if (NILP (ok_if_already_exists)
       || INTEGERP (ok_if_already_exists))
     barf_or_query_if_file_exists (newname, "make it a new name",
@@ -2184,6 +2191,13 @@ This happens for interactive use with M-x.")
     RETURN_UNGCPRO (call4 (handler, Qmake_symbolic_link, filename,
                           linkname, ok_if_already_exists));
 
+  /* If the new link name has special constructs in it,
+     call the corresponding file handler.  */
+  handler = Ffind_file_name_handler (linkname, Qmake_symbolic_link);
+  if (!NILP (handler))
+    RETURN_UNGCPRO (call4 (handler, Qmake_symbolic_link, filename,
+                          linkname, ok_if_already_exists));
+
   if (NILP (ok_if_already_exists)
       || INTEGERP (ok_if_already_exists))
     barf_or_query_if_file_exists (linkname, "make it a link",