Add display of tree content w/ui-tree.c
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
This commit is contained in:
parent
58d04f6523
commit
06fe0c2f47
2
Makefile
2
Makefile
@ -6,7 +6,7 @@ CACHE_ROOT = /var/cache/cgit
|
|||||||
|
|
||||||
EXTLIBS = ../git/libgit.a ../git/xdiff/lib.a -lz -lcrypto
|
EXTLIBS = ../git/libgit.a ../git/xdiff/lib.a -lz -lcrypto
|
||||||
OBJECTS = shared.o cache.o parsing.o html.o ui-shared.o ui-repolist.o \
|
OBJECTS = shared.o cache.o parsing.o html.o ui-shared.o ui-repolist.o \
|
||||||
ui-summary.o ui-log.o ui-view.c
|
ui-summary.o ui-log.o ui-view.c ui-tree.c
|
||||||
|
|
||||||
CFLAGS += -Wall
|
CFLAGS += -Wall
|
||||||
|
|
||||||
|
6
cgit.c
6
cgit.c
@ -26,10 +26,12 @@ static void cgit_print_repo_page(struct cacheitem *item)
|
|||||||
char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc);
|
char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc);
|
||||||
cgit_print_docstart(title, item);
|
cgit_print_docstart(title, item);
|
||||||
cgit_print_pageheader(title);
|
cgit_print_pageheader(title);
|
||||||
if (!cgit_query_page)
|
if (!cgit_query_page) {
|
||||||
cgit_print_summary();
|
cgit_print_summary();
|
||||||
else if (!strcmp(cgit_query_page, "log")) {
|
} else if (!strcmp(cgit_query_page, "log")) {
|
||||||
cgit_print_log(cgit_query_head, 0, 100);
|
cgit_print_log(cgit_query_head, 0, 100);
|
||||||
|
} else if (!strcmp(cgit_query_page, "tree")) {
|
||||||
|
cgit_print_tree(cgit_query_sha1);
|
||||||
} else if (!strcmp(cgit_query_page, "view")) {
|
} else if (!strcmp(cgit_query_page, "view")) {
|
||||||
cgit_print_view(cgit_query_sha1);
|
cgit_print_view(cgit_query_sha1);
|
||||||
}
|
}
|
||||||
|
11
cgit.css
11
cgit.css
@ -30,7 +30,7 @@ table.list th {
|
|||||||
}
|
}
|
||||||
table.list td {
|
table.list td {
|
||||||
border: none;
|
border: none;
|
||||||
padding: 0.1em 0.5em;
|
padding: 0.1em 1em 0.1em 0.5em;
|
||||||
background: white;
|
background: white;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -61,3 +61,12 @@ div.error {
|
|||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
margin: 1em 2em;
|
margin: 1em 2em;
|
||||||
}
|
}
|
||||||
|
div.ls-dir a {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
th.filesize, td.filesize {
|
||||||
|
text-align: right;
|
||||||
|
}
|
||||||
|
th.filemode, td.filemode {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
1
cgit.h
1
cgit.h
@ -83,5 +83,6 @@ extern void cgit_print_repolist(struct cacheitem *item);
|
|||||||
extern void cgit_print_summary();
|
extern void cgit_print_summary();
|
||||||
extern void cgit_print_log(const char *tip, int ofs, int cnt);
|
extern void cgit_print_log(const char *tip, int ofs, int cnt);
|
||||||
extern void cgit_print_view(char *hex);
|
extern void cgit_print_view(char *hex);
|
||||||
|
extern void cgit_print_tree(const char *sha1);
|
||||||
|
|
||||||
#endif /* CGIT_H */
|
#endif /* CGIT_H */
|
||||||
|
13
git.h
13
git.h
@ -188,6 +188,19 @@ struct tree {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
struct tree *lookup_tree(const unsigned char *sha1);
|
||||||
|
int parse_tree_buffer(struct tree *item, void *buffer, unsigned long size);
|
||||||
|
int parse_tree(struct tree *tree);
|
||||||
|
struct tree *parse_tree_indirect(const unsigned char *sha1);
|
||||||
|
|
||||||
|
typedef int (*read_tree_fn_t)(const unsigned char *, const char *, int, const char *, unsigned int, int);
|
||||||
|
|
||||||
|
extern int read_tree_recursive(struct tree *tree,
|
||||||
|
const char *base, int baselen,
|
||||||
|
int stage, const char **match,
|
||||||
|
read_tree_fn_t fn);
|
||||||
|
|
||||||
|
extern int read_tree(struct tree *tree, int stage, const char **paths);
|
||||||
|
|
||||||
|
|
||||||
/* from git:commit.h */
|
/* from git:commit.h */
|
||||||
|
7
ui-log.c
7
ui-log.c
@ -82,6 +82,11 @@ static void cgit_print_commit_shortlog(struct commit *commit)
|
|||||||
html_link_close();
|
html_link_close();
|
||||||
html("</td><td>");
|
html("</td><td>");
|
||||||
html_txt(author);
|
html_txt(author);
|
||||||
|
html("</td><td><a href='");
|
||||||
|
html_attr(cgit_pageurl(cgit_query_repo, "tree",
|
||||||
|
fmt("id=%s",
|
||||||
|
sha1_to_hex(commit->tree->object.sha1))));
|
||||||
|
html("'>tree</a>");
|
||||||
html("</td></tr>\n");
|
html("</td></tr>\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -102,7 +107,7 @@ void cgit_print_log(const char *tip, int ofs, int cnt)
|
|||||||
|
|
||||||
html("<h2>Log</h2>");
|
html("<h2>Log</h2>");
|
||||||
html("<table class='list'>");
|
html("<table class='list'>");
|
||||||
html("<tr><th>Date</th><th>Message</th><th>Author</th></tr>\n");
|
html("<tr><th>Date</th><th>Message</th><th>Author</th><th>Link</th></tr>\n");
|
||||||
while ((commit = get_revision(&rev)) != NULL && n++ < 100) {
|
while ((commit = get_revision(&rev)) != NULL && n++ < 100) {
|
||||||
cgit_print_commit_shortlog(commit);
|
cgit_print_commit_shortlog(commit);
|
||||||
free(commit->buffer);
|
free(commit->buffer);
|
||||||
|
@ -27,6 +27,11 @@ static int cgit_print_branch_cb(const char *refname, const unsigned char *sha1,
|
|||||||
pretty_print_commit(CMIT_FMT_ONELINE, commit, ~0, buf,
|
pretty_print_commit(CMIT_FMT_ONELINE, commit, ~0, buf,
|
||||||
sizeof(buf), 0, NULL, NULL, 0);
|
sizeof(buf), 0, NULL, NULL, 0);
|
||||||
html_txt(buf);
|
html_txt(buf);
|
||||||
|
html("</td><td><a href='");
|
||||||
|
html_attr(cgit_pageurl(cgit_query_repo, "tree",
|
||||||
|
fmt("id=%s",
|
||||||
|
sha1_to_hex(commit->tree->object.sha1))));
|
||||||
|
html("'>tree</a>");
|
||||||
html("</td></tr>\n");
|
html("</td></tr>\n");
|
||||||
} else {
|
} else {
|
||||||
html("<tr><td>");
|
html("<tr><td>");
|
||||||
@ -41,7 +46,7 @@ static int cgit_print_branch_cb(const char *refname, const unsigned char *sha1,
|
|||||||
static void cgit_print_branches()
|
static void cgit_print_branches()
|
||||||
{
|
{
|
||||||
html("<table class='list'>");
|
html("<table class='list'>");
|
||||||
html("<tr><th>Branch name</th><th>Head commit</th></tr>\n");
|
html("<tr><th>Branch name</th><th>Latest</th><th>Link</th></tr>\n");
|
||||||
for_each_branch_ref(cgit_print_branch_cb, NULL);
|
for_each_branch_ref(cgit_print_branch_cb, NULL);
|
||||||
html("</table>");
|
html("</table>");
|
||||||
}
|
}
|
||||||
|
70
ui-tree.c
Normal file
70
ui-tree.c
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
/* ui-tree.c: functions for tree output
|
||||||
|
*
|
||||||
|
* Copyright (C) 2006 Lars Hjemli
|
||||||
|
*
|
||||||
|
* Licensed under GNU General Public License v2
|
||||||
|
* (see COPYING for full license text)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "cgit.h"
|
||||||
|
|
||||||
|
|
||||||
|
static int print_entry(const unsigned char *sha1, const char *base,
|
||||||
|
int baselen, const char *pathname, unsigned int mode,
|
||||||
|
int stage)
|
||||||
|
{
|
||||||
|
char *name;
|
||||||
|
char type[20];
|
||||||
|
unsigned long size;
|
||||||
|
|
||||||
|
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>");
|
||||||
|
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='");
|
||||||
|
html_attr(cgit_pageurl(cgit_query_repo, "view",
|
||||||
|
fmt("id=%s", sha1_to_hex(sha1))));
|
||||||
|
}
|
||||||
|
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)
|
||||||
|
{
|
||||||
|
struct tree *tree;
|
||||||
|
unsigned char sha1[20];
|
||||||
|
|
||||||
|
if (get_sha1_hex(hex, sha1)) {
|
||||||
|
cgit_print_error(fmt("Invalid object id: %s", hex));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
tree = parse_tree_indirect(sha1);
|
||||||
|
if (!tree) {
|
||||||
|
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>Name</th>");
|
||||||
|
html("<th class='filesize'>Size</th>");
|
||||||
|
html("<th class='filemode'>Mode</th></tr>\n");
|
||||||
|
read_tree_recursive(tree, "", 0, 1, NULL, print_entry);
|
||||||
|
html("</table>\n");
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user