X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/942a4c200168e110ec009c3260dc5f5f050de325..cb92d05b6b729cd0e219b43d7a79aff832a9c1ac:/ui-tree.c diff --git a/ui-tree.c b/ui-tree.c index c6159ec..c608754 100644 --- a/ui-tree.c +++ b/ui-tree.c @@ -15,21 +15,34 @@ char *curr_rev; char *match_path; int header = 0; -static void print_text_buffer(char *buf, unsigned long size) +static void print_text_buffer(const char *name, char *buf, unsigned long size) { unsigned long lineno, idx; const char *numberfmt = "%1$d\n"; html("
|
");
idx = 0;
lineno = 0;
- htmlf(numberfmt, ++lineno);
- while(idx < size - 1) { // skip absolute last newline
- if (buf[idx] == '\n')
- htmlf(numberfmt, ++lineno);
- idx++;
+
+ if (size) {
+ htmlf(numberfmt, ++lineno);
+ while(idx < size - 1) { // skip absolute last newline
+ if (buf[idx] == '\n')
+ htmlf(numberfmt, ++lineno);
+ idx++;
+ }
}
html("");
@@ -62,7 +75,7 @@ static void print_binary_buffer(char *buf, unsigned long size)
html("\n");
}
-static void print_object(const unsigned char *sha1, char *path)
+static void print_object(const unsigned char *sha1, char *path, const char *basename)
{
enum object_type type;
char *buf;
@@ -90,7 +103,7 @@ static void print_object(const unsigned char *sha1, char *path)
if (buffer_is_binary(buf, size))
print_binary_buffer(buf, size);
else
- print_text_buffer(buf, size);
+ print_text_buffer(basename, buf, size);
}
@@ -100,6 +113,7 @@ static int ls_item(const unsigned char *sha1, const char *base, int baselen,
{
char *name;
char *fullpath;
+ char *class;
enum object_type type;
unsigned long size = 0;
@@ -132,7 +146,12 @@ static int ls_item(const unsigned char *sha1, const char *base, int baselen,
cgit_tree_link(name, NULL, "ls-dir", ctx.qry.head,
curr_rev, fullpath);
} else {
- cgit_tree_link(name, NULL, "ls-blob", ctx.qry.head,
+ class = strrchr(name, '.');
+ if (class != NULL) {
+ class = fmt("ls-blob %s", class + 1);
+ } else
+ class = "ls-blob";
+ cgit_tree_link(name, NULL, class, ctx.qry.head,
curr_rev, fullpath);
}
htmlf("