X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/06fe0c2f47eaf467db8ab1443e61dfa1c280f30a..ae4c1ee11379e353f2a94201181a3a9dab75b646:/ui-tree.c diff --git a/ui-tree.c b/ui-tree.c index 84930cb..dee8309 100644 --- a/ui-tree.c +++ b/ui-tree.c @@ -14,38 +14,47 @@ static int print_entry(const unsigned char *sha1, const char *base, int stage) { char *name; - char type[20]; - unsigned long size; + enum object_type type; + unsigned long size = 0; - if (sha1_object_info(sha1, type, &size)) { - cgit_print_error(fmt("Bad object name: %s", - sha1_to_hex(sha1))); + name = xstrdup(pathname); + type = sha1_object_info(sha1, &size); + if (type == OBJ_BAD && !S_ISDIRLNK(mode)) { + htmlf("Bad object: %s %s", + name, + sha1_to_hex(sha1)); return 0; } - name = xstrdup(pathname); - html(""); - if (S_ISDIR(mode)) { - html("
"); + html_filemode(mode); + html(""); - html_txt(name); - if (S_ISDIR(mode)) - html("/"); - html("
"); + htmlf("'>%s", name); htmlf("%li", size); - htmlf("%06o", mode); html("\n"); free(name); return 0; } -void cgit_print_tree(const char *hex) +void cgit_print_tree(const char *hex, char *path) { struct tree *tree; unsigned char sha1[20]; @@ -60,11 +69,13 @@ void cgit_print_tree(const char *hex) return; } - html("

Tree content

\n"); + html_txt(path); html("\n"); - html(""); - html(""); - html("\n"); + html(""); + html(""); + html(""); + html(""); + html("\n"); read_tree_recursive(tree, "", 0, 1, NULL, print_entry); html("
NameSizeMode
ModeNameSize
\n"); }