X-Git-Url: https://git.wh0rd.org/?a=blobdiff_plain;f=dump%2Fitime.c;h=64d7644c6f8123f4e6ec31e1fb17602b030b015c;hb=92a9bf12543aadfcc46e7ab9c2729b4d4d1f22ee;hp=62792253d13b33e0ccc8ce8a0936a3b809a47c68;hpb=60f5ede9f87288e50fc52fbe12dd70fcd67d322d;p=dump.git diff --git a/dump/itime.c b/dump/itime.c index 6279225..64d7644 100644 --- a/dump/itime.c +++ b/dump/itime.c @@ -2,7 +2,7 @@ * Ported to Linux's Second Extended File System as part of the * dump and restore backup suit * Remy Card , 1994-1997 - * Stelian Pop , 1999 + * Stelian Pop , 1999-2000 */ /*- @@ -40,7 +40,7 @@ #ifndef lint static const char rcsid[] = - "$Id: itime.c,v 1.7 1999/10/31 19:48:28 tiniou Exp $"; + "$Id: itime.c,v 1.10 2000/03/01 10:16:05 stelian Exp $"; #endif /* not lint */ #include @@ -168,10 +168,11 @@ getdumptime(int createdumpdates) spcl.c_ddate = 0; lastlevel = '0'; - /* If this is a level 0 dump, there's no point in trying to read + /* If this is a level 0 dump, and we're not updating + dumpdates, there's no point in trying to read dumpdates. It may not exist yet, or may not be mounted. For incrementals, we *must* read dumpdates (fail if it's not there!) */ - if (level == lastlevel) + if ( (level == lastlevel) && !createdumpdates) return; initdumptimes(createdumpdates); if (ddatev == NULL) @@ -261,7 +262,7 @@ static void dumprecout(FILE *file, struct dumpdates *what) { - if (fprintf(file, DUMPOUTFMT, + if (fprintf(file, "%s %c %s", what->dd_name, what->dd_level, ctime(&what->dd_ddate)) < 0) @@ -293,10 +294,27 @@ getrecord(FILE *df, struct dumpdates *ddatep) static int makedumpdate(struct dumpdates *ddp, char *tbuf) { - char un_buf[BUFSIZ]; + char *tok; + + /* device name */ + if ( NULL == (tok = strsep( &tbuf, " ")) ) + return(-1); + if ( strlen(tok) > MAXPATHLEN ) + return(-1); + strcpy(ddp->dd_name, tok); + + /* eat whitespace */ + for( ; *tbuf == ' ' ; tbuf++); + + /* dump level */ + ddp->dd_level = *tbuf; + ++tbuf; + + /* eat whitespace */ + for( ; *tbuf == ' ' ; tbuf++); - (void) sscanf(tbuf, DUMPINFMT, ddp->dd_name, &ddp->dd_level, un_buf); - ddp->dd_ddate = unctime(un_buf); + /* dump date */ + ddp->dd_ddate = unctime(tbuf); if (ddp->dd_ddate < 0) return(-1); return(0);