copydir() is supposed to return on failure, not elog(ERROR). Reduce
authorTom Lane
Wed, 10 Sep 2003 20:12:01 +0000 (20:12 +0000)
committerTom Lane
Wed, 10 Sep 2003 20:12:01 +0000 (20:12 +0000)
ERROR to WARNING so we keep control.

src/port/copydir.c

index 68959971fd34f67e76cda6c856c616e9225363e8..29fbad8e259efcae930fd27ca84edfd784ca086c 100644 (file)
@@ -1,7 +1,9 @@
 /*
  * While "xcopy /e /i /q" works fine for copying directories, on Windows XP
- * it requires an Window handle which prevents it from working when invoked
+ * it requires a Window handle which prevents it from working when invoked
  * as a service.
+ *
+ * $Header: /cvsroot/pgsql/src/port/Attic/copydir.c,v 1.5 2003/09/10 20:12:01 tgl Exp $
  */
 
 #include "postgres.h"
 #include 
 
 
+/*
+ * copydir: copy a directory (we only need to go one level deep)
+ *
+ * Return 0 on success, nonzero on failure.
+ *
+ * NB: do not elog(ERROR) on failure.  Return to caller so it can try to
+ * clean up.
+ */
 int
 copydir(char *fromdir, char *todir)
 {
@@ -22,18 +32,18 @@ copydir(char *fromdir, char *todir)
 
    if (mkdir(todir) != 0)
    {
-       ereport(ERROR,
+       ereport(WARNING,
                (errcode_for_file_access(),
                 errmsg("could not create directory \"%s\": %m", todir)));
-       return 1;
+       return -1;
    }
    xldir = opendir(fromdir);
    if (xldir == NULL)
    {
-       ereport(ERROR,
+       ereport(WARNING,
                (errcode_for_file_access(),
                 errmsg("could not open directory \"%s\": %m", fromdir)));
-       return 1;
+       return -1;
    }
 
    while ((xlde = readdir(xldir)) != NULL)
@@ -42,14 +52,11 @@ copydir(char *fromdir, char *todir)
        snprintf(tofl, MAXPGPATH, "%s/%s", todir, xlde->d_name);
        if (CopyFile(fromfl, tofl, TRUE) < 0)
        {
-           int         save_errno = errno;
-
-           closedir(xldir);
-           errno = save_errno;
-           ereport(ERROR,
+           ereport(WARNING,
                    (errcode_for_file_access(),
                     errmsg("could not copy file \"%s\": %m", fromfl)));
-           return 1;
+           closedir(xldir);
+           return -1;
        }
    }