X-Git-Url: https://git.cameronkatri.com/cgit.git/blobdiff_plain/670f99097939a08510c2c909cd38f8083800861a..2b9fab8d30420d935745c4d84ea22412ab2485e5:/ui-tree.c diff --git a/ui-tree.c b/ui-tree.c index c608754..b1adcc7 100644 --- a/ui-tree.c +++ b/ui-tree.c @@ -22,29 +22,38 @@ static void print_text_buffer(const char *name, char *buf, unsigned long size) "%1$d\n"; 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++; + } + } + html(" | \n");
+ }
+ else {
+ 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++; - } - } - html("
");
html_txt(buf);
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, "",
@@ -95,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);
@@ -135,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); @@ -162,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(" |