+ if (!kept && S_ISDIR(file->mode)) {
+ /* make an empty directory */
+ if (do_mkdir(buf, file->mode) < 0) {
+ int save_errno = errno ? errno : EINVAL; /* 0 paranoia */
+ if (errno == ENOENT && make_bak_dir(buf) == 0) {
+ if (do_mkdir(buf, file->mode) < 0)
+ save_errno = errno ? errno : save_errno;
+ else
+ save_errno = 0;
+ }
+ if (save_errno) {
+ rsyserr(FINFO, save_errno, "mkdir %s failed",
+ full_fname(buf));
+ }
+ }
+
+ ret_code = do_rmdir(fname);
+ if (DEBUG_GTE(BACKUP, 1)) {
+ rprintf(FINFO, "make_backup: RMDIR %s returns %i\n",
+ full_fname(fname), ret_code);
+ }
+ kept = 1;
+ }
+
+#ifdef SUPPORT_LINKS
+ if (!kept && preserve_links && S_ISLNK(file->mode)) {
+ const char *sl = F_SYMLINK(file);
+ if (safe_symlinks && unsafe_symlink(sl, buf)) {
+ if (INFO_GTE(SYMSAFE, 1)) {
+ rprintf(FINFO, "ignoring unsafe symlink %s -> %s\n",
+ full_fname(buf), sl);
+ }
+ kept = 1;
+ } else {
+ do_unlink(buf);
+ if (do_symlink(sl, buf) < 0) {
+ int save_errno = errno ? errno : EINVAL; /* 0 paranoia */
+ if (errno == ENOENT && make_bak_dir(buf) == 0) {
+ if (do_symlink(sl, buf) < 0)
+ save_errno = errno ? errno : save_errno;
+ else
+ save_errno = 0;
+ }
+ if (save_errno) {
+ rsyserr(FERROR, save_errno, "link %s -> \"%s\"",
+ full_fname(buf), sl);
+ }
+ }
+ do_unlink(fname);
+ kept = 1;
+ }
+ }
+#endif
+
+ if (!kept && !S_ISREG(file->mode)) {
+ rprintf(FINFO, "make_bak: skipping non-regular file %s\n",
+ fname);
+ unmake_file(file);
+ return 1;