summaryrefslogtreecommitdiffabout
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.css4
-rw-r--r--ui-tree.c11
2 files changed, 9 insertions, 6 deletions
diff --git a/cgit.css b/cgit.css
index ae304fa..5f01926 100644
--- a/cgit.css
+++ b/cgit.css
@@ -80,14 +80,14 @@ div.error {
div.ls-dir a {
font-weight: bold;
}
th.filesize, td.filesize {
text-align: right;
}
-th.filemode, td.filemode {
- text-align: center;
+td.filemode {
+ font-family: monospace;
}
td.blob {
white-space: pre;
font-family: courier;
font-size: 100%;
diff --git a/ui-tree.c b/ui-tree.c
index c4d75ab..54dcdbe 100644
--- a/ui-tree.c
+++ b/ui-tree.c
@@ -20,13 +20,15 @@ static int print_entry(const unsigned char *sha1, const char *base,
if (sha1_object_info(sha1, type, &size)) {
cgit_print_error(fmt("Bad object name: %s",
sha1_to_hex(sha1)));
return 0;
}
name = xstrdup(pathname);
- html("<tr><td>");
+ html("<tr><td class='filemode'>");
+ html_filemode(mode);
+ html("</td><td>");
if (S_ISDIR(mode)) {
html("<div class='ls-dir'><a href='");
html_attr(cgit_pageurl(cgit_query_repo, "tree",
fmt("id=%s", sha1_to_hex(sha1))));
} else {
html("<div class='ls-blob'><a href='");
@@ -36,13 +38,12 @@ static int print_entry(const unsigned char *sha1, const char *base,
html("'>");
html_txt(name);
if (S_ISDIR(mode))
html("/");
html("</a></div></td>");
htmlf("<td class='filesize'>%li</td>", size);
- htmlf("<td class='filemode'>%06o</td>", mode);
html("</tr>\n");
free(name);
return 0;
}
void cgit_print_tree(const char *hex)
@@ -59,12 +60,14 @@ void cgit_print_tree(const char *hex)
cgit_print_error(fmt("Not a tree object: %s", hex));
return;
}
html("<h2>Tree content</h2>\n");
html("<table class='list'>\n");
- html("<tr><th class='left'>Name</th>");
+ html("<tr>");
+ html("<th class='left'>Mode</th>");
+ html("<th class='left'>Name</th>");
html("<th class='right'>Size</th>");
- html("<th class='right'>Mode</th></tr>\n");
+ html("</tr>\n");
read_tree_recursive(tree, "", 0, 1, NULL, print_entry);
html("</table>\n");
}