update from texinfo
[gnulib.git] / lib / rename.c
index d3ba5e1..6ff0705 100644 (file)
@@ -1,8 +1,7 @@
-/* @IGNORE@ -*- c -*- */
-/* Work around the bug in some systems whereby rename fails when the
-   source path has a trailing slash.  The rename from SunOS 4.1.1_U1
-   has this bug.
-   Copyright (C) 2001 Free Software Foundation, Inc.
+/* Work around the bug in some systems whereby rename fails when the source
+   path has a trailing slash.  The rename functions of SunOS 4.1.1_U1 and
+   mips-dec-ultrix4.4 have this bug.
+   Copyright (C) 2001-2003 Free Software Foundation, Inc.
 
    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
 
 /* written by Volker Borchert */
 
-#include <config.h>
+#if HAVE_CONFIG_H
+# include <config.h>
+#endif
+#undef rename
+
 #include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
 
-#ifndef HAVE_DECL_FREE
-"this configure-time declaration test was not run"
-#endif
-#if !HAVE_DECL_FREE
-void free ();
-#endif
+#include "dirname.h"
+#include "xalloc.h"
 
-/* Rename the file SRC_PATH to the file DST_PATH, removing any trailing
-   slashes from SRC_PATH. Needed for SunOS 4.1.1_U1.  */
+/* Rename the file SRC_PATH to DST_PATH, removing any trailing
+   slashes from SRC_PATH.  Needed for SunOS 4.1.1_U1.  */
 
 int
 rpl_rename (const char *src_path, const char *dst_path)
 {
   char *src_temp;
-  int i;
-  int t;
+  int ret_val;
+  size_t s_len = strlen (src_path);
 
-  i = strlen (src_path) - 1;
-  if (src_path[i] == '/')
+  if (s_len && src_path[s_len - 1] == '/')
     {
       src_temp = xstrdup (src_path);
-      for ( ; i > 0 && src_path[i] == '/'; i--)
-       src_temp[i] = '\0';
+      strip_trailing_slashes (src_temp);
     }
   else
     src_temp = (char *) src_path;
 
-  t = rename (src_temp, dst_path);
+  ret_val = rename (src_temp, dst_path);
 
   if (src_temp != src_path)
     free (src_temp);
 
-  return t;
+  return ret_val;
 }