diff -du -dur mine-0.25/check.c mine-0.25-p/check.c --- mine-0.25/check.c 2006-07-15 03:04:31.000000000 +0200 +++ mine-0.25-p/check.c 2006-11-23 16:34:24.000000000 +0100 @@ -78,6 +78,7 @@ case MD5SUM_CHECK_DUPLICATE: printf("Duplicate "); break; case MD5SUM_CHECK_MODIFIED: printf("Modified "); break; case MD5SUM_CHECK_SHARED: printf("Shared "); break; + case MD5SUM_CHECK_NOFILE: printf("Nonexistent "); break; } printf("file: %s\n", filename); modified++; diff -du -dur mine-0.25/install.c mine-0.25-p/install.c --- mine-0.25/install.c 2006-07-16 00:13:33.000000000 +0200 +++ mine-0.25-p/install.c 2006-11-23 16:33:30.000000000 +0100 @@ -246,7 +246,8 @@ if (TH_ISREG(t) && tar_skip_regfile(t) != 0) goto error_errno; } - else if ( ! mode_force && (result = md5sum_check(root, filename)) ) { + else if ( ! mode_force && (result = md5sum_check(root, filename)) + && result != MD5SUM_CHECK_NOFILE ) { if ( ! mode_test || ! mode_verbose ) printf("%s: ", pname); printf("WARNING: Skip "); diff -du -dur mine-0.25/md5sum.c mine-0.25-p/md5sum.c --- mine-0.25/md5sum.c 2006-11-23 16:54:54.000000000 +0100 +++ mine-0.25-p/md5sum.c 2006-11-23 16:57:42.000000000 +0100 @@ -38,7 +38,7 @@ struct stat statbuf; snprintf(realfilename, 1024, "%s/%s", root, filename); - if (lstat(realfilename, &statbuf) != 0 || S_ISDIR(statbuf.st_mode)) + if (lstat(realfilename, &statbuf) != 0) return ""; else if (!S_ISREG(statbuf.st_mode)) return "X"; @@ -46,7 +46,7 @@ return md5_file(realfilename); } -/* Returns if file is unmodified, modified, duplicate, or shared. */ +/* Returns if file is unmodified, modified, duplicate, shared or nonexistent. */ int md5sum_check(char * root, char * filename) { char *md5_f, *md5_d; @@ -57,7 +57,10 @@ /* printf ("md5sum_check(): md5_f: %s, md5_d: %s\n", (md5_f) ? md5_f : "NULL", (md5_d) ? md5_d : "NULL"); */ + if (strcmp(md5_f, "") == 0) + return MD5SUM_CHECK_NOFILE; + else if (strcmp(md5_f, "X") == 0) return MD5SUM_CHECK_OK; else if (md5_d == NULL) return MD5SUM_CHECK_DUPLICATE; diff -du -dur mine-0.25/md5sum.h mine-0.25-p/md5sum.h --- mine-0.25/md5sum.h 2006-07-15 03:04:31.000000000 +0200 +++ mine-0.25-p/md5sum.h 2006-11-23 16:09:12.000000000 +0100 @@ -24,6 +24,7 @@ #define MD5SUM_CHECK_DUPLICATE 1 #define MD5SUM_CHECK_MODIFIED 2 #define MD5SUM_CHECK_SHARED 3 +#define MD5SUM_CHECK_NOFILE 4 char * md5sum_create(char * root, char * filename); int md5sum_check(char * root, char * filename); diff -du -dur mine-0.25/remove.c mine-0.25-p/remove.c --- mine-0.25/remove.c 2006-07-16 00:14:17.000000000 +0200 +++ mine-0.25-p/remove.c 2006-11-23 17:21:32.000000000 +0100 @@ -94,7 +94,6 @@ struct stat statbuf; char value; snprintf(realfn1, 1024, "%s/%s", root, filename); - if ( lstat(realfn1, &statbuf) ) printf("WARNING: Could not stat file %s.\n", realfn1); if ( S_ISDIR(statbuf.st_mode) ) value = 1; else value = 0; @@ -140,8 +139,9 @@ case MD5SUM_CHECK_DUPLICATE: printf("duplicate "); break; case MD5SUM_CHECK_MODIFIED: printf("modified "); break; case MD5SUM_CHECK_SHARED: printf("shared "); break; + case MD5SUM_CHECK_NOFILE: printf("nonexistent "); break; } - printf("file %s:\n", filename); + printf("file %s\n", filename); } else if ( mode_test ) {