2007-10-26 16:59:01 -04:00
|
|
|
$OpenBSD: patch-xdu_c,v 1.1 2007/10/26 20:59:01 jasper Exp $
|
|
|
|
--- xdu.c.orig Sun Jun 5 21:29:23 1994
|
|
|
|
+++ xdu.c Fri Oct 26 22:44:33 2007
|
|
|
|
@@ -235,6 +235,7 @@ char *filename;
|
2000-04-24 19:49:36 -04:00
|
|
|
char name[4096];
|
|
|
|
int size;
|
|
|
|
FILE *fp;
|
|
|
|
+ char *p, *n;
|
|
|
|
|
|
|
|
if (strcmp(filename, "-") == 0) {
|
|
|
|
fp = stdin;
|
2007-10-26 16:59:01 -04:00
|
|
|
@@ -244,11 +245,21 @@ char *filename;
|
2000-04-24 19:49:36 -04:00
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
+
|
|
|
|
while (fgets(buf,sizeof(buf),fp) != NULL) {
|
|
|
|
- sscanf(buf, "%d %s\n", &size, name);
|
|
|
|
+ p = buf;
|
|
|
|
+ while (*p && isspace(*p)) p++;
|
|
|
|
+ size = atoi(p);
|
|
|
|
+ while (*p && !isspace(*p)) p++;
|
|
|
|
+ while (*p && isspace(*p)) p++;
|
|
|
|
+ n = name;
|
|
|
|
+ while (*p && *p != '\n' && *p != '\r')
|
|
|
|
+ *n++ = *p++;
|
|
|
|
+ *n++ = '\0';
|
|
|
|
/*printf("%d %s\n", size, name);*/
|
|
|
|
parse_entry(name,size);
|
|
|
|
}
|
|
|
|
+
|
|
|
|
fclose(fp);
|
|
|
|
}
|
|
|
|
|
2007-10-26 16:59:01 -04:00
|
|
|
@@ -269,7 +280,7 @@ int size;
|
2000-04-24 19:49:36 -04:00
|
|
|
length = strlen(name);
|
|
|
|
if ((length > 0) && (name[length-1] == '/')) {
|
|
|
|
/* strip off trailing / (e.g. GNU du) */
|
|
|
|
- name[length-1] = 0;
|
|
|
|
+ name[--length] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
arg = 0; indx = 0;
|
2007-10-26 16:59:01 -04:00
|
|
|
@@ -289,8 +300,10 @@ int size;
|
2000-04-24 19:49:36 -04:00
|
|
|
}
|
|
|
|
name++;
|
|
|
|
}
|
|
|
|
- buf[indx] = 0;
|
|
|
|
- path[arg++] = strdup(buf);
|
|
|
|
+ if (length) {
|
|
|
|
+ buf[indx] = 0;
|
|
|
|
+ path[arg++] = strdup(buf);
|
|
|
|
+ }
|
|
|
|
path[arg] = NULL;
|
|
|
|
|
|
|
|
addtree(&top,path,size);
|
2007-10-26 16:59:01 -04:00
|
|
|
@@ -399,15 +412,15 @@ int size;
|
2000-04-24 19:49:36 -04:00
|
|
|
|
|
|
|
/*printf("addtree(\"%s\",\"%s\",%d)\n", top->name, path[0], size);*/
|
|
|
|
|
|
|
|
+ if (path[0] == NULL) {
|
|
|
|
+ /* end of the chain, save size */
|
|
|
|
+ top->size = size;
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
/* check all children for a match */
|
|
|
|
for (np = top->child; np != NULL; np = np->peer) {
|
|
|
|
if (strcmp(path[0],np->name) == 0) {
|
|
|
|
- /* name matches */
|
|
|
|
- if (path[1] == NULL) {
|
|
|
|
- /* end of the chain, save size */
|
|
|
|
- np->size = size;
|
|
|
|
- return;
|
|
|
|
- }
|
|
|
|
/* recurse */
|
|
|
|
addtree(np,&path[1],size);
|
|
|
|
return;
|