mirror of the now-defunct rocklinux.org
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

89 lines
3.3 KiB

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 ) {