summaryrefslogtreecommitdiff
path: root/sbin
diff options
context:
space:
mode:
Diffstat (limited to 'sbin')
-rw-r--r--sbin/restore/Makefile5
-rw-r--r--sbin/restore/dirs.c129
-rw-r--r--sbin/restore/extern.h4
-rw-r--r--sbin/restore/interactive.c51
-rw-r--r--sbin/restore/main.c42
-rw-r--r--sbin/restore/restore.840
-rw-r--r--sbin/restore/restore.c97
-rw-r--r--sbin/restore/restore.h10
-rw-r--r--sbin/restore/symtab.c50
-rw-r--r--sbin/restore/tape.c238
-rw-r--r--sbin/restore/utilities.c71
11 files changed, 351 insertions, 386 deletions
diff --git a/sbin/restore/Makefile b/sbin/restore/Makefile
index b4d614196c0..5fe7e6ebcac 100644
--- a/sbin/restore/Makefile
+++ b/sbin/restore/Makefile
@@ -1,5 +1,6 @@
-# $OpenBSD: Makefile,v 1.3 1996/09/01 15:27:28 deraadt Exp $
-# $NetBSD: Makefile,v 1.14 1995/03/18 14:59:39 cgd Exp $
+# $OpenBSD: Makefile,v 1.4 1997/07/05 20:51:20 millert Exp $
+# $NetBSD: Makefile,v 1.18 1997/06/30 09:47:27 lukem Exp $
+# @(#)Makefile 8.1 (Berkeley) 6/5/93
PROG= restore
LINKS= ${BINDIR}/restore ${BINDIR}/rrestore
diff --git a/sbin/restore/dirs.c b/sbin/restore/dirs.c
index 5284fd6f0d2..c24f25ebd46 100644
--- a/sbin/restore/dirs.c
+++ b/sbin/restore/dirs.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: dirs.c,v 1.13 1997/04/16 04:07:35 millert Exp $ */
-/* $NetBSD: dirs.c,v 1.16 1995/06/19 00:20:11 cgd Exp $ */
+/* $OpenBSD: dirs.c,v 1.14 1997/07/05 20:51:21 millert Exp $ */
+/* $NetBSD: dirs.c,v 1.26 1997/07/01 05:37:49 lukem Exp $ */
/*
* Copyright (c) 1983, 1993
@@ -43,7 +43,7 @@
#if 0
static char sccsid[] = "@(#)dirs.c 8.5 (Berkeley) 8/31/94";
#else
-static char rcsid[] = "$OpenBSD: dirs.c,v 1.13 1997/04/16 04:07:35 millert Exp $";
+static char rcsid[] = "$OpenBSD: dirs.c,v 1.14 1997/07/05 20:51:21 millert Exp $";
#endif
#endif /* not lint */
@@ -57,7 +57,7 @@ static char rcsid[] = "$OpenBSD: dirs.c,v 1.13 1997/04/16 04:07:35 millert Exp $
#include <ufs/ufs/dir.h>
#include <protocols/dumprestore.h>
-#include <errno.h>
+#include <err.h>
#include <paths.h>
#include <stdio.h>
#include <stdlib.h>
@@ -152,56 +152,52 @@ extractdirs(genmode)
struct direct nulldir;
int fd;
- vprintf(stdout, "Extract directories from tape\n");
- (void) sprintf(dirfile, "%srstdir%d", _PATH_TMP, dumpdate);
+ Vprintf(stdout, "Extract directories from tape\n");
+ (void)snprintf(dirfile, sizeof(dirfile), "%s/rstdir%d", tmpdir,
+ dumpdate);
if (command != 'r' && command != 'R') {
- (void *) strcat(dirfile, "-XXXXXX");
+ strncat(dirfile, "-XXXXXXXXXX",
+ sizeof(dirfile) - strlen(dirfile));
fd = mkstemp(dirfile);
} else
fd = open(dirfile, O_RDWR|O_CREAT|O_EXCL, 0666);
if (fd == -1 || (df = fdopen(fd, "w")) == NULL) {
if (fd != -1)
close(fd);
- fprintf(stderr,
- "restore: %s - cannot create directory temporary\n",
- dirfile);
- fprintf(stderr, "fopen: %s\n", strerror(errno));
- exit(1);
+ err(1, "cannot create directory temporary %s", dirfile);
}
if (genmode != 0) {
- (void) sprintf(modefile, "%srstmode%d", _PATH_TMP, dumpdate);
+ (void)snprintf(modefile, sizeof(modefile), "%s/rstmode%d",
+ tmpdir, dumpdate);
if (command != 'r' && command != 'R') {
- (void *) strcat(modefile, "-XXXXXX");
+ strncat(modefile, "-XXXXXXXXXX",
+ sizeof(modefile) - strlen(modefile));
fd = mkstemp(modefile);
} else
fd = open(modefile, O_RDWR|O_CREAT|O_EXCL, 0666);
if (fd == -1 || (mf = fdopen(fd, "w")) == NULL) {
if (fd != -1)
close(fd);
- fprintf(stderr,
- "restore: %s - cannot create modefile \n",
- modefile);
- fprintf(stderr, "fopen: %s\n", strerror(errno));
- exit(1);
+ err(1, "cannot create modefile %s", modefile);
}
}
nulldir.d_ino = 0;
nulldir.d_type = DT_DIR;
nulldir.d_namlen = 1;
- (void) strcpy(nulldir.d_name, "/");
+ nulldir.d_name[0] = '/';
+ nulldir.d_name[1] = '\0';
nulldir.d_reclen = DIRSIZ(0, &nulldir);
for (;;) {
curfile.name = "<directory file - name unknown>";
curfile.action = USING;
ip = curfile.dip;
if (ip == NULL || (ip->di_mode & IFMT) != IFDIR) {
- (void) fclose(df);
+ (void)fclose(df);
dirp = opendirfile(dirfile);
if (dirp == NULL)
- fprintf(stderr, "opendirfile: %s\n",
- strerror(errno));
+ warn("opendirfile");
if (mf != NULL)
- (void) fclose(mf);
+ (void)fclose(mf);
i = dirlookup(dot);
if (i == 0)
panic("Root directory is not on tape\n");
@@ -228,7 +224,7 @@ skipdirs()
}
/*
- * Recursively find names and inumbers of all files in subtree
+ * Recursively find names and inumbers of all files in subtree
* pname and pass them off to be processed.
*/
void
@@ -248,7 +244,7 @@ treescan(pname, ino, todo)
/*
* Pname is name of a simple file or an unchanged directory.
*/
- (void) (*todo)(pname, ino, LEAF);
+ (void)(*todo)(pname, ino, LEAF);
return;
}
/*
@@ -260,10 +256,7 @@ treescan(pname, ino, todo)
* begin search through the directory
* skipping over "." and ".."
*/
- (void) strncpy(locname, pname, sizeof(locname) - 1);
- locname[sizeof(locname) - 1] = '\0';
- (void) strncat(locname, "/", sizeof(locname) - strlen(locname));
- namelen = strlen(locname);
+ namelen = snprintf(locname, sizeof(locname), "%s/", pname);
rst_seekdir(dirp, itp->t_seekpt, itp->t_seekpt);
dp = rst_readdir(dirp); /* "." */
if (dp != NULL && strcmp(dp->d_name, ".") == 0)
@@ -286,7 +279,7 @@ treescan(pname, ino, todo)
fprintf(stderr, "%s%s: name exceeds %d char\n",
locname, dp->d_name, sizeof(locname) - 1);
} else {
- (void) strncat(locname, dp->d_name, (int)dp->d_namlen);
+ (void)strncat(locname, dp->d_name, (int)dp->d_namlen);
treescan(locname, dp->d_ino, todo);
rst_seekdir(dirp, bpt, itp->t_seekpt);
}
@@ -312,7 +305,7 @@ pathsearch(pathname)
while (*path == '/')
path++;
dp = NULL;
- while ((name = strsep(&path, "/")) != NULL && *name != NULL) {
+ while ((name = strsep(&path, "/")) != NULL && *name != '\0') {
if ((dp = searchdir(ino, name)) == NULL)
return (NULL);
ino = dp->d_ino;
@@ -387,19 +380,19 @@ putdir(buf, size)
dp->d_reclen > i ||
dp->d_reclen < DIRSIZ(0, dp) ||
dp->d_namlen > NAME_MAX) {
- vprintf(stdout, "Mangled directory: ");
+ Vprintf(stdout, "Mangled directory: ");
if ((dp->d_reclen & 0x3) != 0)
- vprintf(stdout,
+ Vprintf(stdout,
"reclen not multiple of 4 ");
if (dp->d_reclen < DIRSIZ(0, dp))
- vprintf(stdout,
+ Vprintf(stdout,
"reclen less than DIRSIZ (%d < %d) ",
dp->d_reclen, DIRSIZ(0, dp));
if (dp->d_namlen > NAME_MAX)
- vprintf(stdout,
+ Vprintf(stdout,
"reclen name too big (%d > %d) ",
dp->d_namlen, NAME_MAX);
- vprintf(stdout, "\n");
+ Vprintf(stdout, "\n");
loc += i;
continue;
}
@@ -429,7 +422,7 @@ putent(dp)
if (dirloc + dp->d_reclen > DIRBLKSIZ) {
((struct direct *)(dirbuf + prev))->d_reclen =
DIRBLKSIZ - prev;
- (void) fwrite(dirbuf, 1, DIRBLKSIZ, df);
+ (void)fwrite(dirbuf, 1, DIRBLKSIZ, df);
dirloc = 0;
}
memcpy(dirbuf + dirloc, dp, (long)dp->d_reclen);
@@ -444,7 +437,7 @@ static void
flushent()
{
((struct direct *)(dirbuf + prev))->d_reclen = DIRBLKSIZ - prev;
- (void) fwrite(dirbuf, (int)dirloc, 1, df);
+ (void)fwrite(dirbuf, (int)dirloc, 1, df);
seekpt = ftell(df);
dirloc = 0;
}
@@ -458,7 +451,7 @@ dcvt(odp, ndp)
memset(ndp, 0, (size_t)(sizeof *ndp));
ndp->d_ino = odp->d_ino;
ndp->d_type = DT_UNKNOWN;
- (void) strncpy(ndp->d_name, odp->d_name, ODIRSIZ);
+ (void)strncpy(ndp->d_name, odp->d_name, ODIRSIZ);
ndp->d_namlen = strlen(ndp->d_name);
ndp->d_reclen = DIRSIZ(0, ndp);
}
@@ -480,8 +473,8 @@ rst_seekdir(dirp, loc, base)
return;
loc -= base;
if (loc < 0)
- fprintf(stderr, "bad seek pointer to rst_seekdir %d\n", loc);
- (void) lseek(dirp->dd_fd, base + (loc & ~(DIRBLKSIZ - 1)), SEEK_SET);
+ fprintf(stderr, "bad seek pointer to rst_seekdir %ld\n", loc);
+ (void)lseek(dirp->dd_fd, base + (loc & ~(DIRBLKSIZ - 1)), SEEK_SET);
dirp->dd_loc = loc & (DIRBLKSIZ - 1);
if (dirp->dd_loc != 0)
dirp->dd_size = read(dirp->dd_fd, dirp->dd_buf, DIRBLKSIZ);
@@ -498,10 +491,10 @@ rst_readdir(dirp)
for (;;) {
if (dirp->dd_loc == 0) {
- dirp->dd_size = read(dirp->dd_fd, dirp->dd_buf,
+ dirp->dd_size = read(dirp->dd_fd, dirp->dd_buf,
DIRBLKSIZ);
if (dirp->dd_size <= 0) {
- dprintf(stderr, "error reading directory\n");
+ Dprintf(stderr, "error reading directory\n");
return (NULL);
}
}
@@ -512,7 +505,7 @@ rst_readdir(dirp)
dp = (struct direct *)(dirp->dd_buf + dirp->dd_loc);
if (dp->d_reclen == 0 ||
dp->d_reclen > DIRBLKSIZ + 1 - dirp->dd_loc) {
- dprintf(stderr, "corrupted directory: bad reclen %d\n",
+ Dprintf(stderr, "corrupted directory: bad reclen %d\n",
dp->d_reclen);
return (NULL);
}
@@ -520,7 +513,7 @@ rst_readdir(dirp)
if (dp->d_ino == 0 && strcmp(dp->d_name, "/") == 0)
return (NULL);
if (dp->d_ino >= maxino) {
- dprintf(stderr, "corrupted directory: bad inum %d\n",
+ Dprintf(stderr, "corrupted directory: bad inum %d\n",
dp->d_ino);
continue;
}
@@ -605,24 +598,25 @@ setdirmodes(flags)
struct entry *ep;
char *cp;
- vprintf(stdout, "Set directory mode, owner, and times.\n");
+ Vprintf(stdout, "Set directory mode, owner, and times.\n");
if (command == 'r' || command == 'R')
- (void) sprintf(modefile, "%srstmode%d", _PATH_TMP, dumpdate);
+ (void)snprintf(modefile, sizeof(modefile), "%s/rstmode%d",
+ tmpdir, dumpdate);
if (modefile[0] == '#') {
panic("modefile not defined\n");
- fprintf(stderr, "directory mode, owner, and times not set\n");
+ fputs("directory mode, owner, and times not set\n", stderr);
return;
}
mf = fopen(modefile, "r");
if (mf == NULL) {
- fprintf(stderr, "fopen: %s\n", strerror(errno));
+ warn("fopen");
fprintf(stderr, "cannot open mode file %s\n", modefile);
fprintf(stderr, "directory mode, owner, and times not set\n");
return;
}
clearerr(mf);
for (;;) {
- (void) fread((char *)&node, 1, sizeof(struct modeinfo), mf);
+ (void)fread((char *)&node, 1, sizeof(struct modeinfo), mf);
if (feof(mf))
break;
ep = lookupino(node.ino);
@@ -641,16 +635,16 @@ setdirmodes(flags)
panic("cannot find directory inode %d\n", node.ino);
} else {
cp = myname(ep);
- (void) chown(cp, node.uid, node.gid);
- (void) chmod(cp, node.mode);
- (void) chflags(cp, node.flags);
+ (void)chown(cp, node.uid, node.gid);
+ (void)chmod(cp, node.mode);
+ (void)chflags(cp, node.flags);
utimes(cp, node.timep);
ep->e_flags &= ~NEW;
}
}
if (ferror(mf))
panic("error setting directory modes\n");
- (void) fclose(mf);
+ (void)fclose(mf);
}
/*
@@ -669,9 +663,7 @@ genliteraldir(name, ino)
if (itp == NULL)
panic("Cannot find directory inode %d named %s\n", ino, name);
if ((ofile = open(name, O_WRONLY | O_CREAT | O_TRUNC, 0666)) < 0) {
- fprintf(stderr, "%s: ", name);
- (void) fflush(stderr);
- fprintf(stderr, "cannot create file: %s\n", strerror(errno));
+ warn("%s: cannot create file", name);
return (FAIL);
}
rst_seekdir(dirp, itp->t_seekpt, itp->t_seekpt);
@@ -679,22 +671,19 @@ genliteraldir(name, ino)
for (i = itp->t_size; i > 0; i -= BUFSIZ) {
size = i < BUFSIZ ? i : BUFSIZ;
if (read(dp, buf, (int) size) == -1) {
- fprintf(stderr,
- "write error extracting inode %d, name %s\n",
- curfile.ino, curfile.name);
- fprintf(stderr, "read: %s\n", strerror(errno));
- exit(1);
+ warnx("write error extracting inode %d, name %s",
+ curfile.ino, curfile.name);
+ err(1, "read");
}
if (!Nflag && write(ofile, buf, (int) size) == -1) {
fprintf(stderr,
"write error extracting inode %d, name %s\n",
curfile.ino, curfile.name);
- fprintf(stderr, "write: %s\n", strerror(errno));
- exit(1);
+ err(1, "write");
}
}
- (void) close(dp);
- (void) close(ofile);
+ (void)close(dp);
+ (void)close(ofile);
return (GOOD);
}
@@ -744,7 +733,7 @@ allocinotab(ino, dip, seekpt)
node.flags = dip->di_flags;
node.uid = dip->di_uid;
node.gid = dip->di_gid;
- (void) fwrite((char *)&node, 1, sizeof(struct modeinfo), mf);
+ (void)fwrite((char *)&node, 1, sizeof(struct modeinfo), mf);
return (itp);
}
@@ -772,7 +761,7 @@ cleanup()
closemt();
if (modefile[0] != '#')
- (void) unlink(modefile);
+ (void)unlink(modefile);
if (dirfile[0] != '#')
- (void) unlink(dirfile);
+ (void)unlink(dirfile);
}
diff --git a/sbin/restore/extern.h b/sbin/restore/extern.h
index ec59d73b620..134906612e3 100644
--- a/sbin/restore/extern.h
+++ b/sbin/restore/extern.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: extern.h,v 1.2 1996/06/23 14:32:15 deraadt Exp $ */
+/* $OpenBSD: extern.h,v 1.3 1997/07/05 20:51:21 millert Exp $ */
/* $NetBSD: extern.h,v 1.4 1995/03/18 14:59:43 cgd Exp $ */
/*-
@@ -38,6 +38,7 @@
struct entry *addentry __P((char *, ino_t, int));
long addfile __P((char *, ino_t, int));
+int addwhiteout __P((char *));
void badentry __P((struct entry *, char *));
void canon __P((char *, char *));
void checkrestore __P((void));
@@ -48,6 +49,7 @@ void createleaves __P((char *));
void createlinks __P((void));
long deletefile __P((char *, ino_t, int));
void deleteino __P((ino_t));
+void delwhiteout __P((struct entry *));
ino_t dirlookup __P((const char *));
void dumpsymtable __P((char *, long));
void extractdirs __P((int));
diff --git a/sbin/restore/interactive.c b/sbin/restore/interactive.c
index 69b6657a082..43b49a11699 100644
--- a/sbin/restore/interactive.c
+++ b/sbin/restore/interactive.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: interactive.c,v 1.3 1996/12/16 17:11:43 deraadt Exp $ */
-/* $NetBSD: interactive.c,v 1.9 1995/03/18 14:59:44 cgd Exp $ */
+/* $OpenBSD: interactive.c,v 1.4 1997/07/05 20:51:22 millert Exp $ */
+/* $NetBSD: interactive.c,v 1.10 1997/03/19 08:42:52 lukem Exp $ */
/*
* Copyright (c) 1985, 1993
@@ -38,7 +38,7 @@
#if 0
static char sccsid[] = "@(#)interactive.c 8.3 (Berkeley) 9/13/94";
#else
-static char rcsid[] = "$OpenBSD: interactive.c,v 1.3 1996/12/16 17:11:43 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: interactive.c,v 1.4 1997/07/05 20:51:22 millert Exp $";
#endif
#endif /* not lint */
@@ -156,7 +156,7 @@ loop:
fprintf(stderr, "%s: not a directory\n", name);
break;
}
- (void) strcpy(curdir, name);
+ (void)strcpy(curdir, name);
break;
/*
* Delete elements from the extraction list.
@@ -326,13 +326,13 @@ getcmd(curdir, cmd, name, ap)
/*
* Read a command line and trim off trailing white space.
*/
- do {
- fprintf(stderr, "restore > ");
- (void) fflush(stderr);
- (void) fgets(input, BUFSIZ, terminal);
+ do {
+ (void)fprintf(stderr, "%s > ", __progname);
+ (void)fflush(stderr);
+ (void)fgets(input, BUFSIZ, terminal);
} while (!feof(terminal) && input[0] == '\n');
if (feof(terminal)) {
- (void) strcpy(cmd, "quit");
+ (void)strcpy(cmd, "quit");
return;
}
for (cp = &input[strlen(input) - 2]; *cp == ' ' || *cp == '\t'; cp--)
@@ -347,7 +347,7 @@ getcmd(curdir, cmd, name, ap)
* If no argument, use curdir as the default.
*/
if (*cp == '\0') {
- (void) strcpy(name, curdir);
+ (void)strcpy(name, curdir);
return;
}
nextarg = cp;
@@ -370,9 +370,9 @@ getnext:
* For relative pathnames, prepend the current directory to
* it then canonicalize and return it.
*/
- (void) strcpy(output, curdir);
- (void) strcat(output, "/");
- (void) strcat(output, rawname);
+ (void)strcpy(output, curdir);
+ (void)strcat(output, "/");
+ (void)strcat(output, rawname);
canon(output, name);
}
if (glob(name, GLOB_ALTDIRFUNC, NULL, &ap->glob) < 0)
@@ -451,12 +451,12 @@ canon(rawname, canonname)
register char *cp, *np;
if (strcmp(rawname, ".") == 0 || strncmp(rawname, "./", 2) == 0)
- (void) strcpy(canonname, "");
+ (void)strcpy(canonname, "");
else if (rawname[0] == '/')
- (void) strcpy(canonname, ".");
+ (void)strcpy(canonname, ".");
else
- (void) strcpy(canonname, "./");
- (void) strcat(canonname, rawname);
+ (void)strcpy(canonname, "./");
+ (void)strcat(canonname, rawname);
/*
* Eliminate multiple and trailing '/'s
*/
@@ -478,14 +478,14 @@ canon(rawname, canonname)
np++;
if (np - cp == 1 && *cp == '.') {
cp--;
- (void) strcpy(cp, np);
+ (void)strcpy(cp, np);
np = cp;
}
if (np - cp == 2 && strncmp(cp, "..", 2) == 0) {
cp--;
while (cp > &canonname[1] && *--cp != '/')
/* find beginning of name */;
- (void) strcpy(cp, np);
+ (void)strcpy(cp, np);
np = cp;
}
}
@@ -504,7 +504,7 @@ printlist(name, basename)
struct afile single;
RST_DIR *dirp;
int entries, len, namelen;
- char locname[MAXPATHLEN + 1];
+ char locname[MAXPATHLEN];
dp = pathsearch(name);
if (dp == NULL || (!dflag && TSTINO(dp->d_ino, dumpmap) == 0) ||
@@ -522,7 +522,7 @@ printlist(name, basename)
}
} else {
entries = 0;
- while (dp = rst_readdir(dirp))
+ while ((dp = rst_readdir(dirp)))
entries++;
rst_closedir(dirp);
list = (struct afile *)malloc(entries * sizeof(struct afile));
@@ -535,11 +535,8 @@ printlist(name, basename)
fprintf(stderr, "%s:\n", name);
entries = 0;
listp = list;
- (void) strncpy(locname, name, MAXPATHLEN);
- locname[sizeof locname - 1] = '\0';
- (void) strncat(locname, "/", MAXPATHLEN - strlen(locname));
- namelen = strlen(locname);
- while (dp = rst_readdir(dirp)) {
+ namelen = snprintf(locname, sizeof(locname), "%s/", name);
+ while ((dp = rst_readdir(dirp))) {
if (dp == NULL)
break;
if (!dflag && TSTINO(dp->d_ino, dumpmap) == 0)
@@ -553,7 +550,7 @@ printlist(name, basename)
fprintf(stderr, "%s%s: name exceeds %d char\n",
locname, dp->d_name, MAXPATHLEN);
} else {
- (void) strncat(locname, dp->d_name,
+ (void)strncat(locname, dp->d_name,
(int)dp->d_namlen);
mkentry(locname, dp, listp++);
entries++;
diff --git a/sbin/restore/main.c b/sbin/restore/main.c
index edc60dcfdf7..ef4b043b8b8 100644
--- a/sbin/restore/main.c
+++ b/sbin/restore/main.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: main.c,v 1.8 1997/06/25 18:34:30 kstailey Exp $ */
-/* $NetBSD: main.c,v 1.11 1996/03/15 22:39:39 scottr Exp $ */
+/* $OpenBSD: main.c,v 1.9 1997/07/05 20:51:23 millert Exp $ */
+/* $NetBSD: main.c,v 1.13 1997/07/01 05:37:51 lukem Exp $ */
/*
* Copyright (c) 1983, 1993
@@ -49,6 +49,7 @@ static char rcsid[] = "$NetBSD: main.c,v 1.11 1996/03/15 22:39:39 scottr Exp $";
#endif /* not lint */
#include <sys/param.h>
+#include <sys/stat.h>
#include <sys/time.h>
#include <ufs/ffs/fs.h>
@@ -56,7 +57,6 @@ static char rcsid[] = "$NetBSD: main.c,v 1.11 1996/03/15 22:39:39 scottr Exp $";
#include <protocols/dumprestore.h>
#include <err.h>
-#include <errno.h>
#include <paths.h>
#include <signal.h>
#include <stdio.h>
@@ -78,6 +78,7 @@ ino_t maxino;
time_t dumptime;
time_t dumpdate;
FILE *terminal;
+char *tmpdir;
static void obsolete __P((int *, char **[]));
static void usage __P((void));
@@ -94,13 +95,19 @@ main(argc, argv)
char *p, name[MAXPATHLEN];
/* Temp files should *not* be readable. We set permissions later. */
- (void) umask(077);
+ (void)umask(077);
if (argc < 2)
usage();
if ((inputdev = getenv("TAPE")) == NULL)
inputdev = _PATH_DEFTAPE;
+ if ((tmpdir = getenv("TMPDIR")) == NULL)
+ tmpdir = _PATH_TMP;
+ if ((tmpdir = strdup(tmpdir)) == NULL)
+ err(1, NULL);
+ for (p = tmpdir + strlen(tmpdir) - 1; p >= tmpdir && *p == '/'; p--)
+ ;
obsolete(&argc, &argv);
while ((ch = getopt(argc, argv, "b:cdf:himNRrs:tvxy")) != -1)
switch(ch) {
@@ -166,9 +173,9 @@ main(argc, argv)
errx(1, "none of i, R, r, t or x options specified");
if (signal(SIGINT, onintr) == SIG_IGN)
- (void) signal(SIGINT, SIG_IGN);
+ (void)signal(SIGINT, SIG_IGN);
if (signal(SIGTERM, onintr) == SIG_IGN)
- (void) signal(SIGTERM, SIG_IGN);
+ (void)signal(SIGTERM, SIG_IGN);
setlinebuf(stderr);
atexit(cleanup);
@@ -199,11 +206,11 @@ main(argc, argv)
/*
* This is an incremental dump tape.
*/
- vprintf(stdout, "Begin incremental restore\n");
+ Vprintf(stdout, "Begin incremental restore\n");
initsymtable(symtbl);
extractdirs(1);
removeoldleaves();
- vprintf(stdout, "Calculate node updates.\n");
+ Vprintf(stdout, "Calculate node updates.\n");
treescan(".", ROOTINO, nodeupdates);
findunreflinks();
removeoldnodes();
@@ -211,10 +218,10 @@ main(argc, argv)
/*
* This is a level zero dump tape.
*/
- vprintf(stdout, "Begin level 0 restore\n");
+ Vprintf(stdout, "Begin level 0 restore\n");
initsymtable(NULL);
extractdirs(1);
- vprintf(stdout, "Calculate extraction list.\n");
+ Vprintf(stdout, "Calculate extraction list.\n");
treescan(".", ROOTINO, nodeupdates);
}
createleaves(symtbl);
@@ -222,7 +229,7 @@ main(argc, argv)
setdirmodes(FORCE);
checkrestore();
if (dflag) {
- vprintf(stdout, "Verify the directory structure\n");
+ Vprintf(stdout, "Verify the directory structure\n");
treescan(".", ROOTINO, verifyfile);
}
dumpsymtable(symtbl, (long)1);
@@ -286,11 +293,11 @@ static void
usage()
{
- (void)fprintf(stderr, "usage: restore -i [-chmvy] [-b blocksize] [-f file] [-s fileno]\n");
- (void)fprintf(stderr, " restore -R [-cvy] [-b blocksize] [-f file] [-s fileno]\n");
- (void)fprintf(stderr, " restore -r [-cvy] [-b blocksize] [-f file] [-s fileno]\n");
- (void)fprintf(stderr, " restore -t [-chvy] [-b blocksize] [-f file] [-s fileno] [file ...]\n");
- (void)fprintf(stderr, " restore -x [-chmvy] [-b blocksize] [-f file] [-s fileno] [file ...]\n");
+ (void)fprintf(stderr, "usage: %s -i [-chmvy] [-b blocksize] [-f file] [-s fileno]\n", __progname);
+ (void)fprintf(stderr, " %s -R [-cvy] [-b blocksize] [-f file] [-s fileno]\n", __progname);
+ (void)fprintf(stderr, " %s -r [-cvy] [-b blocksize] [-f file] [-s fileno]\n", __progname);
+ (void)fprintf(stderr, " %s -t [-chvy] [-b blocksize] [-f file] [-s fileno] [file ...]\n", __progname);
+ (void)fprintf(stderr, " %s -x [-chmvy] [-b blocksize] [-f file] [-s fileno] [file ...]\n", __progname);
exit(1);
}
@@ -358,7 +365,8 @@ obsolete(argcp, argvp)
}
/* Copy remaining arguments. */
- while (*nargv++ = *argv++);
+ while ((*nargv++ = *argv++))
+ ;
/* Update argument count. */
*argcp = nargv - *argvp - 1;
diff --git a/sbin/restore/restore.8 b/sbin/restore/restore.8
index 2af517062f0..baf20ecf1eb 100644
--- a/sbin/restore/restore.8
+++ b/sbin/restore/restore.8
@@ -1,5 +1,5 @@
-.\" $OpenBSD: restore.8,v 1.6 1997/04/16 04:07:39 millert Exp $
-.\" $NetBSD: restore.8,v 1.11 1996/02/02 22:29:33 phil Exp $
+.\" $OpenBSD: restore.8,v 1.7 1997/07/05 20:51:23 millert Exp $
+.\" $NetBSD: restore.8,v 1.15 1997/07/01 05:37:53 lukem Exp $
.\"
.\" Copyright (c) 1985, 1991, 1993
.\" The Regents of the University of California. All rights reserved.
@@ -34,39 +34,39 @@
.\"
.\" @(#)restore.8 8.3 (Berkeley) 6/1/94
.\"
-.Dd June 1, 1994
+.Dd July 1, 1997
.Dt RESTORE 8
.Os BSD 4
.Sh NAME
.Nm restore
.Nd "restore files or file systems from backups made with dump"
.Sh SYNOPSIS
-.Nm
+.Nm restore
.Fl i
.Op Fl chmvy
.Op Fl b Ar blocksize
.Op Fl f Ar file
.Op Fl s Ar fileno
-.Nm
+.Nm restore
.Fl R
.Op Fl cvy
.Op Fl b Ar blocksize
.Op Fl f Ar file
.Op Fl s Ar fileno
-.Nm
+.Nm restore
.Fl r
.Op Fl cvy
.Op Fl b Ar blocksize
.Op Fl f Ar file
.Op Fl s Ar fileno
-.Nm
+.Nm restore
.Fl t
.Op Fl chvy
.Op Fl b Ar blocksize
.Op Fl f Ar file
.Op Fl s Ar fileno
.Op file ...
-.Nm
+.Nm restore
.Fl x
.Op Fl chmvy
.Op Fl b Ar blocksize
@@ -89,7 +89,7 @@ subsequent incremental backups layered on top of it.
Single files and
directory subtrees may be restored from full or partial
backups.
-.Nm Restore
+.Nm
works across a network;
to do this see the
.Fl f
@@ -141,7 +141,7 @@ those files that are not needed.
.It Ic extract
All the files that are on the extraction list are extracted
from the dump.
-.Nm Restore
+.Nm
will ask which volume the user wishes to mount.
The fastest way to extract a few files is to
start with the last volume, and work towards the first volume.
@@ -175,7 +175,7 @@ It also causes
to print out information about each file as it is extracted.
.El
.It Fl R
-.Nm Restore
+.Nm
requests a particular tape of a multi volume set on which to restart
a full restore
(see the
@@ -216,7 +216,7 @@ restore passes.
This file should be removed when the last incremental has been
restored.
.Pp
-.Nm Restore ,
+.Nm restore ,
in conjunction with
.Xr newfs 8
and
@@ -394,6 +394,19 @@ After a dump read error,
may have to resynchronize itself.
This message lists the number of blocks that were skipped over.
.El
+.Sh ENVIRONMENT
+If the following environment variable exists it will be utilized by
+.Nm restore :
+.Bl -tag -width "TMPDIR" -compact
+.It TMPDIR
+The directory given in TMPDIR will be used
+instead of
+.Pa /tmp
+to store temporary files.
+Refer to
+.Xr environ 7
+for more information.
+.El
.Sh FILES
.Bl -tag -width "./restoresymtable" -compact
.It Pa /dev/rst0
@@ -408,12 +421,13 @@ owner, mode, and time stamps for directories.
information passed between incremental restores.
.El
.Sh SEE ALSO
+.Xr environ 7 ,
.Xr dump 8 ,
.Xr newfs 8 ,
.Xr mount 8 ,
.Xr rmt 8
.Sh BUGS
-.Nm Restore
+.Nm
can get confused when doing incremental restores from
dumps that were made on active file systems.
.Pp
diff --git a/sbin/restore/restore.c b/sbin/restore/restore.c
index e06d84ccdd6..0a9225f21c5 100644
--- a/sbin/restore/restore.c
+++ b/sbin/restore/restore.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: restore.c,v 1.3 1997/06/18 01:46:40 millert Exp $ */
-/* $NetBSD: restore.c,v 1.6 1995/03/18 14:59:51 cgd Exp $ */
+/* $OpenBSD: restore.c,v 1.4 1997/07/05 20:51:24 millert Exp $ */
+/* $NetBSD: restore.c,v 1.9 1997/06/18 07:10:16 lukem Exp $ */
/*
* Copyright (c) 1983, 1993
@@ -38,7 +38,7 @@
#if 0
static char sccsid[] = "@(#)restore.c 8.3 (Berkeley) 9/13/94";
#else
-static char rcsid[] = "$OpenBSD: restore.c,v 1.3 1997/06/18 01:46:40 millert Exp $";
+static char rcsid[] = "$OpenBSD: restore.c,v 1.4 1997/07/05 20:51:24 millert Exp $";
#endif
#endif /* not lint */
@@ -69,7 +69,7 @@ listfile(name, ino, type)
if (TSTINO(ino, dumpmap) == 0)
return (descend);
- vprintf(stdout, "%s", type == LEAF ? "leaf" : "dir ");
+ Vprintf(stdout, "%s", type == LEAF ? "leaf" : "dir ");
fprintf(stdout, "%10d\t%s\n", ino, name);
return (descend);
}
@@ -89,16 +89,16 @@ addfile(name, ino, type)
char buf[100];
if (TSTINO(ino, dumpmap) == 0) {
- dprintf(stdout, "%s: not on the tape\n", name);
+ Dprintf(stdout, "%s: not on the tape\n", name);
return (descend);
}
if (ino == WINO && command == 'i' && !vflag)
return (descend);
if (!mflag) {
- (void) sprintf(buf, "./%u", ino);
+ (void)snprintf(buf, sizeof(buf), "./%u", ino);
name = buf;
if (type == NODE) {
- (void) genliteraldir(name, ino);
+ (void)genliteraldir(name, ino);
return (descend);
}
}
@@ -143,7 +143,7 @@ deletefile(name, ino, type)
return (descend);
}
-/*
+/*
* The following four routines implement the incremental
* restore algorithm. The first removes old entries, the second
* does renames and calculates the extraction list, the third
@@ -152,7 +152,7 @@ deletefile(name, ino, type)
*
* Directories cannot be immediately deleted, as they may have
* other files in them which need to be moved out first. As
- * directories to be deleted are found, they are put on the
+ * directories to be deleted are found, they are put on the
* following deletion list. After all deletions and renames
* are done, this list is actually deleted.
*/
@@ -169,9 +169,9 @@ removeoldleaves()
register struct entry *ep, *nextep;
register ino_t i, mydirino;
- vprintf(stdout, "Mark entries to be removed.\n");
- if (ep = lookupino(WINO)) {
- vprintf(stdout, "Delete whiteouts\n");
+ Vprintf(stdout, "Mark entries to be removed.\n");
+ if ((ep = lookupino(WINO))) {
+ Vprintf(stdout, "Delete whiteouts\n");
for ( ; ep != NULL; ep = nextep) {
nextep = ep->e_links;
mydirino = ep->e_parent->e_ino;
@@ -193,7 +193,7 @@ removeoldleaves()
if (TSTINO(i, usedinomap))
continue;
for ( ; ep != NULL; ep = ep->e_links) {
- dprintf(stdout, "%s: REMOVE\n", myname(ep));
+ Dprintf(stdout, "%s: REMOVE\n", myname(ep));
if (ep->e_type == LEAF) {
removeleaf(ep);
freeentry(ep);
@@ -233,7 +233,7 @@ nodeupdates(name, ino, type)
# define MODECHG 0x8 /* mode of inode changed */
/*
- * This routine is called once for each element in the
+ * This routine is called once for each element in the
* directory hierarchy, with a full path name.
* The "type" value is incorrectly specified as LEAF for
* directories that are not on the dump tape.
@@ -286,7 +286,7 @@ nodeupdates(name, ino, type)
removeleaf(np);
freeentry(np);
} else {
- dprintf(stdout, "name/inode conflict, mktempname %s\n",
+ Dprintf(stdout, "name/inode conflict, mktempname %s\n",
myname(np));
mktempname(np);
}
@@ -314,7 +314,7 @@ nodeupdates(name, ino, type)
*/
case INOFND|NAMEFND:
ip->e_flags |= KEEP;
- dprintf(stdout, "[%s] %s: %s\n", keyval(key), name,
+ Dprintf(stdout, "[%s] %s: %s\n", keyval(key), name,
flagvalues(ip));
break;
@@ -350,7 +350,7 @@ nodeupdates(name, ino, type)
if (type == NODE)
newnode(ep);
ep->e_flags |= NEW|KEEP;
- dprintf(stdout, "[%s] %s: %s\n", keyval(key), name,
+ Dprintf(stdout, "[%s] %s: %s\n", keyval(key), name,
flagvalues(ep));
break;
@@ -374,7 +374,7 @@ nodeupdates(name, ino, type)
renameit(myname(ip), name);
moveentry(ip, name);
ip->e_flags |= KEEP;
- dprintf(stdout, "[%s] %s: %s\n", keyval(key), name,
+ Dprintf(stdout, "[%s] %s: %s\n", keyval(key), name,
flagvalues(ip));
break;
}
@@ -387,7 +387,7 @@ nodeupdates(name, ino, type)
}
ep = addentry(name, ino, type|LINK);
ep->e_flags |= NEW;
- dprintf(stdout, "[%s] %s: %s|LINK\n", keyval(key), name,
+ Dprintf(stdout, "[%s] %s: %s|LINK\n", keyval(key), name,
flagvalues(ep));
break;
@@ -404,14 +404,14 @@ nodeupdates(name, ino, type)
if (type == NODE)
newnode(ep);
ep->e_flags |= NEW|KEEP;
- dprintf(stdout, "[%s] %s: %s|LINK\n", keyval(key), name,
+ Dprintf(stdout, "[%s] %s: %s|LINK\n", keyval(key), name,
flagvalues(ep));
break;
}
if (type == LEAF && lookuptype != LINK)
np->e_flags |= EXTRACT;
np->e_flags |= KEEP;
- dprintf(stdout, "[%s] %s: %s\n", keyval(key), name,
+ Dprintf(stdout, "[%s] %s: %s\n", keyval(key), name,
flagvalues(np));
break;
@@ -424,7 +424,7 @@ nodeupdates(name, ino, type)
* that we need to rename, so we delete it from the symbol
* table, and put it on the list to be deleted eventually.
* Conversely if a directory is to be created, it must be
- * done immediately, rather than waiting until the
+ * done immediately, rather than waiting until the
* extraction phase.
*/
case ONTAPE|INOFND|MODECHG:
@@ -437,7 +437,8 @@ nodeupdates(name, ino, type)
/* changing from leaf to node */
for ( ; ip != NULL; ip = ip->e_links) {
if (ip->e_type != LEAF)
- badentry(ip, "NODE and LEAF links to same inode");
+ badentry(ip,
+ "NODE and LEAF links to same inode");
removeleaf(ip);
freeentry(ip);
}
@@ -453,7 +454,7 @@ nodeupdates(name, ino, type)
ip = addentry(name, ino, type);
}
ip->e_flags |= NEW|KEEP;
- dprintf(stdout, "[%s] %s: %s\n", keyval(key), name,
+ Dprintf(stdout, "[%s] %s: %s\n", keyval(key), name,
flagvalues(ip));
break;
@@ -462,7 +463,7 @@ nodeupdates(name, ino, type)
* Ignore it.
*/
case NAMEFND:
- dprintf(stdout, "[%s] %s: Extraneous name\n", keyval(key),
+ Dprintf(stdout, "[%s] %s: Extraneous name\n", keyval(key),
name);
descend = FAIL;
break;
@@ -511,16 +512,16 @@ keyval(key)
{
static char keybuf[32];
- (void) strcpy(keybuf, "|NIL");
+ (void)strcpy(keybuf, "|NIL");
keybuf[0] = '\0';
if (key & ONTAPE)
- (void) strcat(keybuf, "|ONTAPE");
+ (void)strcat(keybuf, "|ONTAPE");
if (key & INOFND)
- (void) strcat(keybuf, "|INOFND");
+ (void)strcat(keybuf, "|INOFND");
if (key & NAMEFND)
- (void) strcat(keybuf, "|NAMEFND");
+ (void)strcat(keybuf, "|NAMEFND");
if (key & MODECHG)
- (void) strcat(keybuf, "|MODECHG");
+ (void)strcat(keybuf, "|MODECHG");
return (&keybuf[1]);
}
@@ -533,14 +534,14 @@ findunreflinks()
register struct entry *ep, *np;
register ino_t i;
- vprintf(stdout, "Find unreferenced names.\n");
+ Vprintf(stdout, "Find unreferenced names.\n");
for (i = ROOTINO; i < maxino; i++) {
ep = lookupino(i);
if (ep == NULL || ep->e_type == LEAF || TSTINO(i, dumpmap) == 0)
continue;
for (np = ep->e_entries; np != NULL; np = np->e_sibling) {
if (np->e_flags == 0) {
- dprintf(stdout,
+ Dprintf(stdout,
"%s: remove unreferenced name\n",
myname(np));
removeleaf(np);
@@ -556,7 +557,7 @@ findunreflinks()
if (np->e_type == LEAF) {
if (np->e_flags != 0)
badentry(np, "unreferenced with flags");
- dprintf(stdout,
+ Dprintf(stdout,
"%s: remove unreferenced name\n",
myname(np));
removeleaf(np);
@@ -581,7 +582,7 @@ removeoldnodes()
register struct entry *ep, **prev;
long change;
- vprintf(stdout, "Remove old nodes (directories).\n");
+ Vprintf(stdout, "Remove old nodes (directories).\n");
do {
change = 0;
prev = &removelist;
@@ -613,9 +614,9 @@ createleaves(symtabfile)
long curvol;
if (command == 'R') {
- vprintf(stdout, "Continue extraction of new leaves\n");
+ Vprintf(stdout, "Continue extraction of new leaves\n");
} else {
- vprintf(stdout, "Extract new leaves.\n");
+ Vprintf(stdout, "Extract new leaves.\n");
dumpsymtable(symtabfile, volno);
}
first = lowerbnd(ROOTINO);
@@ -640,7 +641,7 @@ createleaves(symtabfile)
/*
* If we find files on the tape that have no corresponding
* directory entries, then we must have found a file that
- * was created while the dump was in progress. Since we have
+ * was created while the dump was in progress. Since we have
* no name for it, we discard it knowing that it will be
* on the next incremental tape.
*/
@@ -664,7 +665,7 @@ createleaves(symtabfile)
removeleaf(ep);
ep->e_flags &= ~REMOVED;
}
- (void) extractfile(myname(ep));
+ (void)extractfile(myname(ep));
ep->e_flags &= ~(NEW|EXTRACT);
/*
* We checkpoint the restore after every tape reel, so
@@ -691,7 +692,7 @@ createfiles()
register struct entry *ep;
long curvol;
- vprintf(stdout, "Extract requested files\n");
+ Vprintf(stdout, "Extract requested files\n");
curfile.action = SKIP;
getvol((long)1);
skipmaps();
@@ -761,7 +762,7 @@ createfiles()
ep = lookupino(next);
if (ep == NULL)
panic("corrupted symbol table\n");
- (void) extractfile(myname(ep));
+ (void)extractfile(myname(ep));
ep->e_flags &= ~NEW;
if (volno != curvol)
skipmaps();
@@ -779,16 +780,16 @@ createlinks()
register ino_t i;
char name[BUFSIZ];
- if (ep = lookupino(WINO)) {
- vprintf(stdout, "Add whiteouts\n");
+ if ((ep = lookupino(WINO))) {
+ Vprintf(stdout, "Add whiteouts\n");
for ( ; ep != NULL; ep = ep->e_links) {
if ((ep->e_flags & NEW) == 0)
continue;
- (void) addwhiteout(myname(ep));
+ (void)addwhiteout(myname(ep));
ep->e_flags &= ~NEW;
}
}
- vprintf(stdout, "Add links\n");
+ Vprintf(stdout, "Add links\n");
for (i = ROOTINO; i < maxino; i++) {
ep = lookupino(i);
if (ep == NULL)
@@ -796,11 +797,11 @@ createlinks()
for (np = ep->e_links; np != NULL; np = np->e_links) {
if ((np->e_flags & NEW) == 0)
continue;
- (void) strcpy(name, myname(ep));
+ (void)strcpy(name, myname(ep));
if (ep->e_type == NODE) {
- (void) linkit(name, myname(np), SYMLINK);
+ (void)linkit(name, myname(np), SYMLINK);
} else {
- (void) linkit(name, myname(np), HARDLINK);
+ (void)linkit(name, myname(np), HARDLINK);
}
np->e_flags &= ~NEW;
}
@@ -818,7 +819,7 @@ checkrestore()
register struct entry *ep;
register ino_t i;
- vprintf(stdout, "Check the symbol table.\n");
+ Vprintf(stdout, "Check the symbol table.\n");
for (i = WINO; i < maxino; i++) {
for (ep = lookupino(i); ep != NULL; ep = ep->e_links) {
ep->e_flags &= ~KEEP;
diff --git a/sbin/restore/restore.h b/sbin/restore/restore.h
index a61434da8dc..32b0aa4f5f5 100644
--- a/sbin/restore/restore.h
+++ b/sbin/restore/restore.h
@@ -1,5 +1,5 @@
-/* $OpenBSD: restore.h,v 1.2 1996/06/23 14:32:18 deraadt Exp $ */
-/* $NetBSD: restore.h,v 1.7 1995/03/18 14:59:53 cgd Exp $ */
+/* $OpenBSD: restore.h,v 1.3 1997/07/05 20:51:25 millert Exp $ */
+/* $NetBSD: restore.h,v 1.8 1997/07/01 05:37:54 lukem Exp $ */
/*
* Copyright (c) 1983, 1993
@@ -65,8 +65,10 @@ extern time_t dumptime; /* time that this dump begins */
extern time_t dumpdate; /* time that this dump was made */
extern char command; /* opration being performed */
extern FILE *terminal; /* file descriptor for the terminal input */
+extern char *tmpdir; /* where to store temporary files */
extern int oldinofmt; /* reading tape with old format inodes */
extern int Bcvt; /* need byte swapping on inodes and dirs */
+extern char *__progname; /* from crt0.o */
/*
* Each file in the file system is described by one of these entries
@@ -135,8 +137,8 @@ typedef struct rstdirdesc RST_DIR;
#define SETINO(ino, map) \
map[(u_int)((ino) - 1) / NBBY] |= 1 << ((u_int)((ino) - 1) % NBBY)
-#define dprintf if (dflag) fprintf
-#define vprintf if (vflag) fprintf
+#define Dprintf if (dflag) fprintf
+#define Vprintf if (vflag) fprintf
#define GOOD 1
#define FAIL 0
diff --git a/sbin/restore/symtab.c b/sbin/restore/symtab.c
index d877e12cba7..2d56cd5e7fa 100644
--- a/sbin/restore/symtab.c
+++ b/sbin/restore/symtab.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: symtab.c,v 1.4 1997/02/09 18:55:16 deraadt Exp $ */
-/* $NetBSD: symtab.c,v 1.9 1996/11/30 18:04:47 cgd Exp $ */
+/* $OpenBSD: symtab.c,v 1.5 1997/07/05 20:51:25 millert Exp $ */
+/* $NetBSD: symtab.c,v 1.10 1997/03/19 08:42:54 lukem Exp $ */
/*
* Copyright (c) 1983, 1993
@@ -38,7 +38,7 @@
#if 0
static char sccsid[] = "@(#)symtab.c 8.2 (Berkeley) 9/13/94";
#else
-static char rcsid[] = "$OpenBSD: symtab.c,v 1.4 1997/02/09 18:55:16 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: symtab.c,v 1.5 1997/07/05 20:51:25 millert Exp $";
#endif
#endif /* not lint */
@@ -56,7 +56,7 @@ static char rcsid[] = "$OpenBSD: symtab.c,v 1.4 1997/02/09 18:55:16 deraadt Exp
#include <ufs/ufs/dinode.h>
-#include <errno.h>
+#include <err.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
@@ -376,7 +376,7 @@ removeentry(ep)
/*
* Table of unused string entries, sorted by length.
- *
+ *
* Entries are allocated in STRTBLINCR sized pieces so that names
* of similar lengths can use the same entry. The value of STRTBLINCR
* is chosen so that every entry has at least enough space to hold
@@ -419,7 +419,7 @@ savename(name)
if (cp == NULL)
panic("no space for string table\n");
}
- (void) strcpy(cp, name);
+ (void)strcpy(cp, name);
return (cp);
}
@@ -467,13 +467,13 @@ dumpsymtable(filename, checkpt)
FILE *fd;
struct symtableheader hdr;
- vprintf(stdout, "Check pointing the restore\n");
+ Vprintf(stdout, "Check pointing the restore\n");
if (Nflag)
return;
if ((fd = fopen(filename, "w")) == NULL) {
- fprintf(stderr, "fopen: %s\n", strerror(errno));
+ warn("fopen");
panic("cannot create save file %s for symbol table\n",
- filename);
+ filename);
}
clearerr(fd);
/*
@@ -483,7 +483,7 @@ dumpsymtable(filename, checkpt)
for (i = WINO; i <= maxino; i++) {
for (ep = lookupino(i); ep != NULL; ep = ep->e_links) {
ep->e_index = mynum++;
- (void) fwrite(ep->e_name, sizeof(char),
+ (void)fwrite(ep->e_name, sizeof(char),
(int)allocsize(ep->e_namlen), fd);
}
}
@@ -510,7 +510,7 @@ dumpsymtable(filename, checkpt)
if (ep->e_next != NULL)
tep->e_next =
(struct entry *)ep->e_next->e_index;
- (void) fwrite((char *)tep, sizeof(struct entry), 1, fd);
+ (void)fwrite((char *)tep, sizeof(struct entry), 1, fd);
}
}
/*
@@ -521,7 +521,7 @@ dumpsymtable(filename, checkpt)
tentry = NULL;
else
tentry = (struct entry *)entry[i]->e_index;
- (void) fwrite((char *)&tentry, sizeof(struct entry *), 1, fd);
+ (void)fwrite((char *)&tentry, sizeof(struct entry *), 1, fd);
}
hdr.volno = checkpt;
hdr.maxino = maxino;
@@ -530,13 +530,13 @@ dumpsymtable(filename, checkpt)
hdr.dumptime = dumptime;
hdr.dumpdate = dumpdate;
hdr.ntrec = ntrec;
- (void) fwrite((char *)&hdr, sizeof(struct symtableheader), 1, fd);
+ (void)fwrite((char *)&hdr, sizeof(struct symtableheader), 1, fd);
if (ferror(fd)) {
- fprintf(stderr, "fwrite: %s\n", strerror(errno));
+ warn("fwrite");
panic("output error to file %s writing symbol table\n",
- filename);
+ filename);
}
- (void) fclose(fd);
+ (void)fclose(fd);
}
/*
@@ -555,7 +555,7 @@ initsymtable(filename)
register long i;
int fd;
- vprintf(stdout, "Initialize symbol table.\n");
+ Vprintf(stdout, "Initialize symbol table.\n");
if (filename == NULL) {
entrytblsize = maxino / HASHFACTOR;
entry = (struct entry **)
@@ -567,11 +567,11 @@ initsymtable(filename)
return;
}
if ((fd = open(filename, O_RDONLY, 0)) < 0) {
- fprintf(stderr, "open: %s\n", strerror(errno));
+ warn("open");
panic("cannot open symbol table file %s\n", filename);
}
if (fstat(fd, &stbuf) < 0) {
- fprintf(stderr, "stat: %s\n", strerror(errno));
+ warn("stat");
panic("cannot stat symbol table file %s\n", filename);
}
tblsize = stbuf.st_size - sizeof(struct symtableheader);
@@ -580,7 +580,7 @@ initsymtable(filename)
panic("cannot allocate space for symbol table\n");
if (read(fd, base, (int)tblsize) < 0 ||
read(fd, (char *)&hdr, sizeof(struct symtableheader)) < 0) {
- fprintf(stderr, "read: %s\n", strerror(errno));
+ warn("read");
panic("cannot read symbol table file %s\n", filename);
}
switch (command) {
@@ -589,13 +589,9 @@ initsymtable(filename)
* For normal continuation, insure that we are using
* the next incremental tape
*/
- if (hdr.dumpdate != dumptime) {
- if (hdr.dumpdate < dumptime)
- fprintf(stderr, "Incremental tape too low\n");
- else
- fprintf(stderr, "Incremental tape too high\n");
- exit(1);
- }
+ if (hdr.dumpdate != dumptime)
+ errx(1, "Incremental tape too %s",
+ (hdr.dumpdate < dumptime) ? "low" : "high");
break;
case 'R':
/*
diff --git a/sbin/restore/tape.c b/sbin/restore/tape.c
index 17c5b7b7075..eb4d52deef5 100644
--- a/sbin/restore/tape.c
+++ b/sbin/restore/tape.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: tape.c,v 1.8 1997/04/16 04:07:40 millert Exp $ */
-/* $NetBSD: tape.c,v 1.22 1996/11/30 18:31:29 cgd Exp $ */
+/* $OpenBSD: tape.c,v 1.9 1997/07/05 20:51:26 millert Exp $ */
+/* $NetBSD: tape.c,v 1.26 1997/04/15 07:12:25 lukem Exp $ */
/*
* Copyright (c) 1983, 1993
@@ -56,7 +56,7 @@ static char rcsid[] = "$NetBSD: tape.c,v 1.22 1996/11/30 18:31:29 cgd Exp $";
#include <ufs/ufs/dinode.h>
#include <protocols/dumprestore.h>
-#include <errno.h>
+#include <err.h>
#include <paths.h>
#include <setjmp.h>
#include <stdio.h>
@@ -141,18 +141,14 @@ setinput(source)
*/
terminal = fopen(_PATH_TTY, "r");
if (terminal == NULL) {
- (void)fprintf(stderr, "cannot open %s: %s\n",
- _PATH_TTY, strerror(errno));
+ warn("cannot open %s", _PATH_TTY);
terminal = fopen(_PATH_DEVNULL, "r");
- if (terminal == NULL) {
- (void)fprintf(stderr, "cannot open %s: %s\n",
- _PATH_DEVNULL, strerror(errno));
- exit(1);
- }
+ if (terminal == NULL)
+ err(1, "cannot open %s", _PATH_DEVNULL);
}
pipein++;
}
- (void) strcpy(magtape, source);
+ (void)strcpy(magtape, source);
}
void
@@ -167,10 +163,8 @@ newtapebuf(size)
if (tapebuf != NULL)
free(tapebuf);
tapebuf = malloc(size * TP_BSIZE);
- if (tapebuf == NULL) {
- fprintf(stderr, "Cannot allocate space for tape buffer\n");
- exit(1);
- }
+ if (tapebuf == NULL)
+ errx(1, "Cannot allocate space for tape buffer");
tapebufsize = size;
}
@@ -184,7 +178,7 @@ setup()
int i, j, *ip;
struct stat stbuf;
- vprintf(stdout, "Verify tape and initialize maps\n");
+ Vprintf(stdout, "Verify tape and initialize maps\n");
#ifdef RRESTORE
if (host)
mt = rmtopen(magtape, 0);
@@ -194,10 +188,8 @@ setup()
mt = 0;
else
mt = open(magtape, O_RDONLY, 0);
- if (mt < 0) {
- fprintf(stderr, "%s: %s\n", magtape, strerror(errno));
- exit(1);
- }
+ if (mt < 0)
+ err(1, magtape);
volno = 1;
setdumpnum();
FLUSHTAPEBUF();
@@ -208,11 +200,9 @@ setup()
blksread--;
tpblksread--;
cvtflag++;
- if (gethead(&spcl) == FAIL) {
- fprintf(stderr, "Tape is not a dump tape\n");
- exit(1);
- }
- fprintf(stderr, "Converting to new file system format.\n");
+ if (gethead(&spcl) == FAIL)
+ errx(1, "Tape is not a dump tape");
+ (void)fputs("Converting to new file system format.\n", stderr);
}
if (pipein) {
endoftapemark.s_spcl.c_magic = cvtflag ? OFS_MAGIC : NFS_MAGIC;
@@ -229,43 +219,33 @@ setup()
printdumpinfo();
dumptime = spcl.c_ddate;
dumpdate = spcl.c_date;
- if (stat(".", &stbuf) < 0) {
- fprintf(stderr, "cannot stat .: %s\n", strerror(errno));
- exit(1);
- }
+ if (stat(".", &stbuf) < 0)
+ err(1, "cannot stat .");
if (stbuf.st_blksize >= TP_BSIZE && stbuf.st_blksize <= MAXBSIZE)
fssize = stbuf.st_blksize;
- if (((fssize - 1) & fssize) != 0) {
- fprintf(stderr, "bad block size %d\n", fssize);
- exit(1);
- }
- if (spcl.c_volume != 1) {
- fprintf(stderr, "Tape is not volume 1 of the dump\n");
- exit(1);
- }
+ if (((fssize - 1) & fssize) != 0)
+ errx(1, "bad block size %ld", fssize);
+ if (spcl.c_volume != 1)
+ errx(1, "Tape is not volume 1 of the dump");
if (gethead(&spcl) == FAIL) {
- dprintf(stdout, "header read failed at %d blocks\n", blksread);
+ Dprintf(stdout, "header read failed at %ld blocks\n", blksread);
panic("no header after volume mark!\n");
}
findinode(&spcl);
- if (spcl.c_type != TS_CLRI) {
- fprintf(stderr, "Cannot find file removal list\n");
- exit(1);
- }
+ if (spcl.c_type != TS_CLRI)
+ errx(1, "Cannot find file removal list");
maxino = (spcl.c_count * TP_BSIZE * NBBY) + 1;
- dprintf(stdout, "maxino = %d\n", maxino);
+ Dprintf(stdout, "maxino = %d\n", maxino);
map = calloc((unsigned)1, (unsigned)howmany(maxino, NBBY));
if (map == NULL)
panic("no memory for active inode map\n");
usedinomap = map;
curfile.action = USING;
getfile(xtrmap, xtrmapskip);
- if (spcl.c_type != TS_BITS) {
- fprintf(stderr, "Cannot find file dump list\n");
- exit(1);
- }
- map = calloc((unsigned)1, (unsigned)howmany(maxino, NBBY));
- if (map == (char *)NULL)
+ if (spcl.c_type != TS_BITS)
+ errx(1, "Cannot find file dump list");
+ map = calloc((size_t)1, (size_t)howmany(maxino, NBBY));
+ if (map == NULL)
panic("no memory for file dump list\n");
dumpmap = map;
curfile.action = USING;
@@ -313,7 +293,7 @@ again:
if (command == 'R' || command == 'r' || curfile.action != SKIP) {
newvol = nextvol;
wantnext = 1;
- } else {
+ } else {
newvol = 0;
wantnext = 0;
}
@@ -330,15 +310,15 @@ again:
strcpy(buf, ": ");
for (i = 1; i < 32; i++)
if (tapesread & (1 << i)) {
- fprintf(stderr, "%s%d", buf, i);
+ fprintf(stderr, "%s%ld", buf, i);
strcpy(buf, ", ");
}
fprintf(stderr, "\n");
}
do {
fprintf(stderr, "Specify next volume #: ");
- (void) fflush(stderr);
- (void) fgets(buf, BUFSIZ, terminal);
+ (void)fflush(stderr);
+ (void)fgets(buf, BUFSIZ, terminal);
} while (!feof(terminal) && buf[0] == '\n');
if (feof(terminal))
exit(1);
@@ -353,11 +333,11 @@ again:
return;
}
closemt();
- fprintf(stderr, "Mount tape volume %d\n", newvol);
+ fprintf(stderr, "Mount tape volume %ld\n", newvol);
fprintf(stderr, "Enter ``none'' if there are no more tapes\n");
fprintf(stderr, "otherwise enter tape name (default: %s) ", magtape);
- (void) fflush(stderr);
- (void) fgets(buf, BUFSIZ, terminal);
+ (void)fflush(stderr);
+ (void)fgets(buf, BUFSIZ, terminal);
if (feof(terminal))
exit(1);
if (!strcmp(buf, "none\n")) {
@@ -365,7 +345,7 @@ again:
return;
}
if (buf[0] != '\n') {
- (void) strcpy(magtape, buf);
+ (void)strcpy(magtape, buf);
magtape[strlen(magtape) - 1] = '\0';
}
#ifdef RRESTORE
@@ -385,7 +365,7 @@ gethdr:
setdumpnum();
FLUSHTAPEBUF();
if (gethead(&tmpbuf) == FAIL) {
- dprintf(stdout, "header read failed at %d blocks\n", blksread);
+ Dprintf(stdout, "header read failed at %ld blocks\n", blksread);
fprintf(stderr, "tape is not dump tape\n");
volno = 0;
goto again;
@@ -411,7 +391,7 @@ gethdr:
* If coming to this volume at random, skip to the beginning
* of the next record.
*/
- dprintf(stdout, "read %ld recs, tape starts with %ld\n",
+ Dprintf(stdout, "read %ld recs, tape starts with %d\n",
tpblksread, tmpbuf.c_firstrec);
if (tmpbuf.c_type == TS_TAPE && (tmpbuf.c_flags & DR_NEWHEADER)) {
if (!wantnext) {
@@ -424,8 +404,8 @@ gethdr:
* -1 since we've read the volume header
*/
i = tpblksread - tmpbuf.c_firstrec - 1;
- dprintf(stderr, "Skipping %d duplicate record%s.\n",
- i, i > 1 ? "s" : "");
+ Dprintf(stderr, "Skipping %ld duplicate record%s.\n",
+ i, (i == 1) ? "" : "s");
while (--i >= 0)
readtape(buf);
}
@@ -441,7 +421,7 @@ gethdr:
if (tmpbuf.c_type == TS_TAPE && (tmpbuf.c_flags & DR_NEWHEADER))
for (i = tmpbuf.c_count; i > 0; i--)
readtape(buf);
- (void) gethead(&spcl);
+ (void)gethead(&spcl);
findinode(&spcl);
if (gettingfile) {
gettingfile = 0;
@@ -481,19 +461,17 @@ setdumpnum()
if (dumpnum == 1 || volno != 1)
return;
- if (pipein) {
- fprintf(stderr, "Cannot have multiple dumps on pipe input\n");
- exit(1);
- }
+ if (pipein)
+ errx(1, "Cannot have multiple dumps on pipe input");
tcom.mt_op = MTFSF;
tcom.mt_count = dumpnum - 1;
#ifdef RRESTORE
if (host)
rmtioctl(MTFSF, dumpnum - 1);
- else
+ else
#endif
if (ioctl(mt, (int)MTIOCTOP, (char *)&tcom) < 0)
- fprintf(stderr, "ioctl MTFSF: %s\n", strerror(errno));
+ warn("ioctl MTFSF");
}
void
@@ -534,7 +512,7 @@ extractfile(name)
return (FAIL);
case IFSOCK:
- vprintf(stdout, "skipped socket %s\n", name);
+ Vprintf(stdout, "skipped socket %s\n", name);
skipfile();
return (GOOD);
@@ -546,7 +524,7 @@ extractfile(name)
skipfile();
return (GOOD);
}
- vprintf(stdout, "extract file %s\n", name);
+ Vprintf(stdout, "extract file %s\n", name);
return (genliteraldir(name, curfile.ino));
case IFLNK: {
@@ -558,74 +536,71 @@ extractfile(name)
pathlen = 0;
getfile(xtrlnkfile, xtrlnkskip);
if (pathlen == 0) {
- vprintf(stdout,
+ Vprintf(stdout,
"%s: zero length symbolic link (ignored)\n",
name);
return (GOOD);
}
if (linkit(lnkbuf, name, SYMLINK) == FAIL)
return (FAIL);
- (void) lchown(name, luid, lgid);
+ (void)lchown(name, luid, lgid);
return (GOOD);
}
case IFCHR:
case IFBLK:
- vprintf(stdout, "extract special file %s\n", name);
+ Vprintf(stdout, "extract special file %s\n", name);
if (Nflag) {
skipfile();
return (GOOD);
}
if (mknod(name, mode, (int)curfile.dip->di_rdev) < 0) {
- fprintf(stderr, "%s: cannot create special file: %s\n",
- name, strerror(errno));
+ warn("%s: cannot create special file", name);
skipfile();
return (FAIL);
}
- (void) chown(name, curfile.dip->di_uid, curfile.dip->di_gid);
- (void) chmod(name, mode);
- (void) chflags(name, flags);
+ (void)chown(name, curfile.dip->di_uid, curfile.dip->di_gid);
+ (void)chmod(name, mode);
+ (void)chflags(name, flags);
skipfile();
utimes(name, timep);
return (GOOD);
case IFIFO:
- vprintf(stdout, "extract fifo %s\n", name);
+ Vprintf(stdout, "extract fifo %s\n", name);
if (Nflag) {
skipfile();
return (GOOD);
}
if (mkfifo(name, mode) < 0) {
- fprintf(stderr, "%s: cannot create fifo: %s\n",
- name, strerror(errno));
+ warn("%s: cannot create fifo", name);
skipfile();
return (FAIL);
}
- (void) chown(name, curfile.dip->di_uid, curfile.dip->di_gid);
- (void) chmod(name, mode);
- (void) chflags(name, flags);
+ (void)chown(name, curfile.dip->di_uid, curfile.dip->di_gid);
+ (void)chmod(name, mode);
+ (void)chflags(name, flags);
skipfile();
utimes(name, timep);
return (GOOD);
case IFREG:
- vprintf(stdout, "extract file %s\n", name);
+ Vprintf(stdout, "extract file %s\n", name);
if (Nflag) {
skipfile();
return (GOOD);
}
if ((ofile = open(name, O_WRONLY | O_CREAT | O_TRUNC,
0666)) < 0) {
- fprintf(stderr, "%s: cannot create file: %s\n",
- name, strerror(errno));
+ warn("%s: cannot create file", name);
skipfile();
return (FAIL);
}
- (void) fchown(ofile, curfile.dip->di_uid, curfile.dip->di_gid);
- (void) fchmod(ofile, mode);
- (void) fchflags(ofile, flags);
+ (void)fchown(ofile, curfile.dip->di_uid, curfile.dip->di_gid);
+ (void)fchmod(ofile, mode);
+ (void)fchflags(ofile, flags);
getfile(xtrfile, xtrskip);
- (void) close(ofile);
+ (void)close(ofile);
utimes(name, timep);
return (GOOD);
}
@@ -666,8 +641,8 @@ getfile(fill, skip)
void (*skip) __P((char *, long));
{
register int i;
- int curblk = 0;
- long size = spcl.c_dinode.di_size;
+ volatile int curblk = 0;
+ volatile long size = spcl.c_dinode.di_size;
static char clearedbuf[MAXBSIZE];
char buf[MAXBSIZE / TP_BSIZE][TP_BSIZE];
char junk[TP_BSIZE];
@@ -709,8 +684,8 @@ loop:
if (gethead(&spcl) == GOOD && size > 0) {
if (spcl.c_type == TS_ADDR)
goto loop;
- dprintf(stdout,
- "Missing address (header) block for %s at %d blocks\n",
+ Dprintf(stdout,
+ "Missing address (header) block for %s at %ld blocks\n",
curfile.name, blksread);
}
if (curblk > 0)
@@ -730,12 +705,9 @@ xtrfile(buf, size)
if (Nflag)
return;
- if (write(ofile, buf, (int) size) == -1) {
- fprintf(stderr,
- "write error extracting inode %d, name %s\nwrite: %s\n",
- curfile.ino, curfile.name, strerror(errno));
- exit(1);
- }
+ if (write(ofile, buf, (int) size) == -1)
+ err(1, "write error extracting inode %d, name %s\nwrite",
+ curfile.ino, curfile.name);
}
/*
@@ -748,12 +720,9 @@ xtrskip(buf, size)
long size;
{
- if (lseek(ofile, size, SEEK_CUR) == -1) {
- fprintf(stderr,
- "seek error extracting inode %d, name %s\nlseek: %s\n",
- curfile.ino, curfile.name, strerror(errno));
- exit(1);
- }
+ if (lseek(ofile, size, SEEK_CUR) == -1)
+ err(1, "seek error extracting inode %d, name %s\nlseek",
+ curfile.ino, curfile.name);
}
/*
@@ -766,12 +735,10 @@ xtrlnkfile(buf, size)
{
pathlen += size;
- if (pathlen > MAXPATHLEN) {
- fprintf(stderr, "symbolic link name: %s->%s%s; too long %d\n",
+ if (pathlen > MAXPATHLEN)
+ errx(1, "symbolic link name: %s->%s%s; too long %d",
curfile.name, lnkbuf, buf, pathlen);
- exit(1);
- }
- (void) strcat(lnkbuf, buf);
+ (void)strcat(lnkbuf, buf);
}
/*
@@ -784,9 +751,7 @@ xtrlnkskip(buf, size)
long size;
{
- fprintf(stderr, "unallocated block in symbolic link %s\n",
- curfile.name);
- exit(1);
+ errx(1, "unallocated block in symbolic link %s", curfile.name);
}
/*
@@ -864,7 +829,7 @@ getmore:
* If found, skip rest of buffer and start with the next.
*/
if (!pipein && numtrec < ntrec && i > 0) {
- dprintf(stdout, "mid-media short read error.\n");
+ Dprintf(stdout, "mid-media short read error.\n");
numtrec = ntrec;
}
/*
@@ -884,8 +849,8 @@ getmore:
* Short read. Process the blocks read.
*/
if (i % TP_BSIZE != 0)
- vprintf(stdout,
- "partial block read: %d should be %d\n",
+ Vprintf(stdout,
+ "partial block read: %ld should be %ld\n",
i, ntrec * TP_BSIZE);
numtrec = i / TP_BSIZE;
}
@@ -921,17 +886,14 @@ getmore:
#endif
seek_failed = (lseek(mt, i, SEEK_CUR) == (off_t)-1);
- if (seek_failed) {
- fprintf(stderr,
- "continuation failed: %s\n", strerror(errno));
- exit(1);
- }
+ if (seek_failed)
+ err(1, "continuation failed");
}
/*
* Handle end of tape.
*/
if (i == 0) {
- vprintf(stdout, "End-of-tape encountered\n");
+ Vprintf(stdout, "End-of-tape encountered\n");
if (!pipein) {
newvol = volno + 1;
volno = 0;
@@ -967,18 +929,16 @@ findtapeblksize()
#endif
i = read(mt, tapebuf, ntrec * TP_BSIZE);
- if (i <= 0) {
- fprintf(stderr, "tape read error: %s\n", strerror(errno));
- exit(1);
- }
+ if (i <= 0)
+ err(1, "tape read error");
if (i % TP_BSIZE != 0) {
- fprintf(stderr, "Tape block size (%d) %s (%d)\n",
- i, "is not a multiple of dump block size", TP_BSIZE);
- exit(1);
+ errx(1,
+ "Tape block size (%ld) is not a multiple of dump block size (%d)",
+ i, TP_BSIZE);
}
ntrec = i / TP_BSIZE;
numtrec = ntrec;
- vprintf(stdout, "Tape block size is %d\n", ntrec);
+ Vprintf(stdout, "Tape block size is %ld\n", ntrec);
}
void
@@ -992,7 +952,7 @@ closemt()
rmtclose();
else
#endif
- (void) close(mt);
+ (void)close(mt);
}
/*
@@ -1028,7 +988,7 @@ gethead(buf)
u_int16_t odi_gid;
int32_t odi_size;
int32_t odi_rdev;
- char odi_addr[36];
+ char odi_addr[36];
int32_t odi_atime;
int32_t odi_mtime;
int32_t odi_ctime;
@@ -1044,7 +1004,7 @@ gethead(buf)
if (swabl(buf->c_magic) != NFS_MAGIC)
return (FAIL);
if (!Bcvt) {
- vprintf(stdout, "Note: Doing Byte swapping\n");
+ Vprintf(stdout, "Note: Doing Byte swapping\n");
Bcvt = 1;
}
}
@@ -1127,7 +1087,7 @@ good:
break;
}
/*
- * If we are restoring a filesystem with old format inodes,
+ * If we are restoring a filesystem with old format inodes,
* copy the uid/gid to the new location.
*/
if (oldinofmt) {
@@ -1181,7 +1141,7 @@ accthdr(header)
break;
}
if (predict != blksread - 1)
- fprintf(stderr, "; predicted %d blocks, got %d blocks",
+ fprintf(stderr, "; predicted %ld blocks, got %ld blocks",
predict, blksread - 1);
fprintf(stderr, "\n");
newcalc:
@@ -1261,7 +1221,7 @@ findinode(header)
}
} while (header->c_type == TS_ADDR);
if (skipcnt > 0)
- fprintf(stderr, "resync restore, skipped %d blocks\n", skipcnt);
+ fprintf(stderr, "resync restore, skipped %ld blocks\n", skipcnt);
skipcnt = 0;
}
@@ -1280,7 +1240,7 @@ checksum(buf)
} else {
/* What happens if we want to read restore tapes
for a 16bit int machine??? */
- do
+ do
i += swabl(*buf++);
while (--j);
}
diff --git a/sbin/restore/utilities.c b/sbin/restore/utilities.c
index 4d95aaffcd1..766cc3b2488 100644
--- a/sbin/restore/utilities.c
+++ b/sbin/restore/utilities.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: utilities.c,v 1.2 1996/06/23 14:32:19 deraadt Exp $ */
-/* $NetBSD: utilities.c,v 1.9 1995/03/18 14:59:59 cgd Exp $ */
+/* $OpenBSD: utilities.c,v 1.3 1997/07/05 20:51:27 millert Exp $ */
+/* $NetBSD: utilities.c,v 1.11 1997/03/19 08:42:56 lukem Exp $ */
/*
* Copyright (c) 1983, 1993
@@ -38,7 +38,7 @@
#if 0
static char sccsid[] = "@(#)utilities.c 8.4 (Berkeley) 10/18/94";
#else
-static char rcsid[] = "$OpenBSD: utilities.c,v 1.2 1996/06/23 14:32:19 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: utilities.c,v 1.3 1997/07/05 20:51:27 millert Exp $";
#endif
#endif /* not lint */
@@ -48,7 +48,7 @@ static char rcsid[] = "$OpenBSD: utilities.c,v 1.2 1996/06/23 14:32:19 deraadt E
#include <ufs/ufs/dinode.h>
#include <ufs/ufs/dir.h>
-#include <errno.h>
+#include <err.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
@@ -98,7 +98,7 @@ mktempname(ep)
if (ep->e_flags & TMPNAME)
badentry(ep, "mktempname: called with TMPNAME");
ep->e_flags |= TMPNAME;
- (void) strcpy(oldname, myname(ep));
+ (void)strcpy(oldname, myname(ep));
freename(ep->e_name);
ep->e_name = savename(gentempname(ep));
ep->e_namlen = strlen(ep->e_name);
@@ -121,7 +121,7 @@ gentempname(ep)
i++;
if (np == NULL)
badentry(ep, "not on ino list");
- (void) sprintf(name, "%s%d%d", TMPHDR, i, ep->e_ino);
+ (void)snprintf(name, sizeof(name), "%s%ld%d", TMPHDR, i, ep->e_ino);
return (name);
}
@@ -133,11 +133,10 @@ renameit(from, to)
char *from, *to;
{
if (!Nflag && rename(from, to) < 0) {
- fprintf(stderr, "warning: cannot rename %s to %s: %s\n",
- from, to, strerror(errno));
+ warn("cannot rename %s to %s", from, to);
return;
}
- vprintf(stdout, "rename %s to %s\n", from, to);
+ Vprintf(stdout, "rename %s to %s\n", from, to);
}
/*
@@ -154,10 +153,10 @@ newnode(np)
cp = myname(np);
if (!Nflag && mkdir(cp, 0777) < 0) {
np->e_flags |= EXISTED;
- fprintf(stderr, "warning: %s: %s\n", cp, strerror(errno));
+ warn(cp);
return;
}
- vprintf(stdout, "Make node %s\n", cp);
+ Vprintf(stdout, "Make node %s\n", cp);
}
/*
@@ -177,10 +176,10 @@ removenode(ep)
ep->e_flags &= ~TMPNAME;
cp = myname(ep);
if (!Nflag && rmdir(cp) < 0) {
- fprintf(stderr, "warning: %s: %s\n", cp, strerror(errno));
+ warn(cp);
return;
}
- vprintf(stdout, "Remove node %s\n", cp);
+ Vprintf(stdout, "Remove node %s\n", cp);
}
/*
@@ -198,10 +197,10 @@ removeleaf(ep)
ep->e_flags &= ~TMPNAME;
cp = myname(ep);
if (!Nflag && unlink(cp) < 0) {
- fprintf(stderr, "warning: %s: %s\n", cp, strerror(errno));
+ warn(cp);
return;
}
- vprintf(stdout, "Remove leaf %s\n", cp);
+ Vprintf(stdout, "Remove leaf %s\n", cp);
}
/*
@@ -215,23 +214,21 @@ linkit(existing, new, type)
if (type == SYMLINK) {
if (!Nflag && symlink(existing, new) < 0) {
- fprintf(stderr,
- "warning: cannot create symbolic link %s->%s: %s\n",
- new, existing, strerror(errno));
+ warn("cannot create symbolic link %s->%s",
+ new, existing);
return (FAIL);
}
} else if (type == HARDLINK) {
if (!Nflag && link(existing, new) < 0) {
- fprintf(stderr,
- "warning: cannot create hard link %s->%s: %s\n",
- new, existing, strerror(errno));
+ warn("cannot create hard link %s->%s",
+ new, existing);
return (FAIL);
}
} else {
panic("linkit: unknown type %d\n", type);
return (FAIL);
}
- vprintf(stdout, "Create %s link %s->%s\n",
+ Vprintf(stdout, "Create %s link %s->%s\n",
type == SYMLINK ? "symbolic" : "hard", new, existing);
return (GOOD);
}
@@ -245,11 +242,10 @@ addwhiteout(name)
{
if (!Nflag && mknod(name, S_IFWHT, 0) < 0) {
- fprintf(stderr, "warning: cannot create whiteout %s: %s\n",
- name, strerror(errno));
+ warn("cannot create whiteout %s", name);
return (FAIL);
}
- vprintf(stdout, "Create whiteout %s\n", name);
+ Vprintf(stdout, "Create whiteout %s\n", name);
return (GOOD);
}
@@ -268,11 +264,10 @@ delwhiteout(ep)
ep->e_flags &= ~TMPNAME;
name = myname(ep);
if (!Nflag && undelete(name) < 0) {
- fprintf(stderr, "warning: cannot delete whiteout %s: %s\n",
- name, strerror(errno));
+ warn("cannot delete whiteout %s", name);
return;
}
- vprintf(stdout, "Delete whiteout %s\n", name);
+ Vprintf(stdout, "Delete whiteout %s\n", name);
}
/*
@@ -336,7 +331,7 @@ badentry(ep, msg)
"next hashchain name: %s\n", myname(ep->e_next));
fprintf(stderr, "entry type: %s\n",
ep->e_type == NODE ? "NODE" : "LEAF");
- fprintf(stderr, "inode number: %ld\n", ep->e_ino);
+ fprintf(stderr, "inode number: %d\n", ep->e_ino);
panic("flags: %s\n", flagvalues(ep));
}
@@ -349,20 +344,20 @@ flagvalues(ep)
{
static char flagbuf[BUFSIZ];
- (void) strcpy(flagbuf, "|NIL");
+ (void)strcpy(flagbuf, "|NIL");
flagbuf[0] = '\0';
if (ep->e_flags & REMOVED)
- (void) strcat(flagbuf, "|REMOVED");
+ (void)strcat(flagbuf, "|REMOVED");
if (ep->e_flags & TMPNAME)
- (void) strcat(flagbuf, "|TMPNAME");
+ (void)strcat(flagbuf, "|TMPNAME");
if (ep->e_flags & EXTRACT)
- (void) strcat(flagbuf, "|EXTRACT");
+ (void)strcat(flagbuf, "|EXTRACT");
if (ep->e_flags & NEW)
- (void) strcat(flagbuf, "|NEW");
+ (void)strcat(flagbuf, "|NEW");
if (ep->e_flags & KEEP)
- (void) strcat(flagbuf, "|KEEP");
+ (void)strcat(flagbuf, "|KEEP");
if (ep->e_flags & EXISTED)
- (void) strcat(flagbuf, "|EXISTED");
+ (void)strcat(flagbuf, "|EXISTED");
return (&flagbuf[1]);
}
@@ -375,7 +370,7 @@ dirlookup(name)
{
struct direct *dp;
ino_t ino;
-
+
ino = ((dp = pathsearch(name)) == NULL) ? 0 : dp->d_ino;
if (ino == 0 || TSTINO(ino, dumpmap) == 0)
@@ -394,7 +389,7 @@ reply(question)
do {
fprintf(stderr, "%s? [yn] ", question);
- (void) fflush(stderr);
+ (void)fflush(stderr);
c = getc(terminal);
while (c != '\n' && getc(terminal) != '\n')
if (feof(terminal))