diff options
author | Jun Kuriyama <kuriyama@FreeBSD.org> | 2001-03-23 14:32:28 +0000 |
---|---|---|
committer | Jun Kuriyama <kuriyama@FreeBSD.org> | 2001-03-23 14:32:28 +0000 |
commit | 63cdda0b245eb3b2f80454ecf35ab620ec69eb28 (patch) | |
tree | f36fb1dcfcb21d1ddd21dc5f9160c68469c888e0 /sysutils/xdu | |
parent | ee56e35fb82a03c0f4afdf9d654f7054e73d93bd (diff) |
o Fix $MASTER_SITES.
o Add WWW: line.
o Add patch from OpenBSD.
Submitted by: KATO Tsuguru <tkato@prontomail.ne.jp>
PR: ports/25871
Notes
Notes:
svn path=/head/; revision=40273
Diffstat (limited to 'sysutils/xdu')
-rw-r--r-- | sysutils/xdu/files/patch-aa | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/sysutils/xdu/files/patch-aa b/sysutils/xdu/files/patch-aa new file mode 100644 index 000000000000..84a506215fa0 --- /dev/null +++ b/sysutils/xdu/files/patch-aa @@ -0,0 +1,77 @@ +--- xdu.c.orig Mon Jun 6 04:29:23 1994 ++++ xdu.c Fri Mar 16 07:20:49 2001 +@@ -235,6 +235,7 @@ + char name[4096]; + int size; + FILE *fp; ++ char *p, *n; + + if (strcmp(filename, "-") == 0) { + fp = stdin; +@@ -244,11 +245,21 @@ + 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); + } + +@@ -269,7 +280,7 @@ + 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; +@@ -289,8 +300,10 @@ + } + name++; + } +- buf[indx] = 0; +- path[arg++] = strdup(buf); ++ if (length) { ++ buf[indx] = 0; ++ path[arg++] = strdup(buf); ++ } + path[arg] = NULL; + + addtree(&top,path,size); +@@ -399,15 +412,15 @@ + + /*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; |