X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/03389d6e67bfda5cb3ff1504db815f09715ec6f4..c366bd6fa88fb7dbe1e42c84d56e2bda0b1682c5:/ui-tree.c diff --git a/ui-tree.c b/ui-tree.c index 7bf2ad2..b1adcc7 100644 --- a/ui-tree.c +++ b/ui-tree.c @@ -23,26 +23,33 @@ static void print_text_buffer(const char *name, char *buf, unsigned long size) html("
");
- idx = 0;
- lineno = 0;
-
- if (size) {
- htmlf(numberfmt, ++lineno);
- while(idx < size - 1) { // skip absolute last newline
- if (buf[idx] == '\n')
- htmlf(numberfmt, ++lineno);
- idx++;
+ if (ctx.cfg.enable_tree_linenumbers) {
+ html(" |
| ofs | hex dump | ascii |
|---|---|---|
| %04x | ", ofs); + htmlf(" | |
| %04lx | ", ofs);
for (idx = 0; idx < ROWLEN && ofs + idx < size; idx++)
htmlf("%*s%02x",
idx == 16 ? 4 : 1, "",
@@ -97,10 +104,16 @@ static void print_object(const unsigned char *sha1, char *path, const char *base
return;
}
- html(" (");
+ htmlf("blob: %s (", sha1_to_hex(sha1));
cgit_plain_link("plain", NULL, NULL, ctx.qry.head,
curr_rev, path);
- htmlf(") blob: %s\n", sha1_to_hex(sha1)); + html(")\n"); + + if (ctx.cfg.max_blob_size && size / 1024 > ctx.cfg.max_blob_size) { + htmlf(" blob size (%ldKB) exceeds display size limit (%dKB). ",
+ size / 1024, ctx.cfg.max_blob_size);
+ return;
+ }
if (buffer_is_binary(buf, size))
print_binary_buffer(buf, size);
@@ -137,13 +150,7 @@ static int ls_item(const unsigned char *sha1, const char *base, int baselen,
cgit_print_filemode(mode);
html(" | "); if (S_ISGITLINK(mode)) { - htmlf(""); - html_txt(name); - html(""); + cgit_submodule_link("ls-mod", fullpath, sha1_to_hex(sha1)); } else if (S_ISDIR(mode)) { cgit_tree_link(name, NULL, "ls-dir", ctx.qry.head, curr_rev, fullpath); @@ -164,6 +171,9 @@ static int ls_item(const unsigned char *sha1, const char *base, int baselen, if (ctx.repo->max_stats) cgit_stats_link("stats", NULL, "button", ctx.qry.head, fullpath); + if (!S_ISGITLINK(mode)) + cgit_plain_link("plain", NULL, "button", ctx.qry.head, curr_rev, + fullpath); html(" |