From 5e75128a8bee885d83563d8c521172328d511d12 Mon Sep 17 00:00:00 2001 From: Lars Hjemli Date: Fri, 18 May 2007 23:56:10 +0200 Subject: Add html_include() This is a function used to include external htmlfiles in cgit- generated pages. Signed-off-by: Lars Hjemli --- cgit.h | 1 + html.c | 14 ++++++++++++++ 2 files changed, 15 insertions(+) diff --git a/cgit.h b/cgit.h index f3d783e..fc44a71 100644 --- a/cgit.h +++ b/cgit.h @@ -144,6 +144,7 @@ extern void html_hidden(char *name, char *value); extern void html_link_open(char *url, char *title, char *class); extern void html_link_close(void); extern void html_filemode(unsigned short mode); +extern int html_include(const char *filename); extern int cgit_read_config(const char *filename, configfn fn); extern int cgit_parse_query(char *txt, configfn fn); diff --git a/html.c b/html.c index 175b4b6..33a956f 100644 --- a/html.c +++ b/html.c @@ -166,3 +166,17 @@ void html_filemode(unsigned short mode) html_fileperm(mode >> 3); html_fileperm(mode); } + +int html_include(const char *filename) +{ + FILE *f; + char buf[4096]; + size_t len; + + if (!(f = fopen(filename, "r"))) + return -1; + while((len = fread(buf, 1, 4096, f)) > 0) + write(htmlfd, buf, len); + fclose(f); + return 0; +} -- cgit v1.2.3-59-g8ed1b From de69ce020c4ccd7146d6ac72bbd8f417088e8c03 Mon Sep 17 00:00:00 2001 From: Lars Hjemli Date: Sat, 19 May 2007 00:00:25 +0200 Subject: Teach cgit howto include an external file on index page. The new parameter index-header can be used to name an external file which will be included verbatim at the top of the index page. Signed-off-by: Lars Hjemli --- cgit.h | 1 + shared.c | 3 +++ ui-repolist.c | 5 +++++ 3 files changed, 9 insertions(+) diff --git a/cgit.h b/cgit.h index fc44a71..3ee11bb 100644 --- a/cgit.h +++ b/cgit.h @@ -75,6 +75,7 @@ extern struct repoinfo *cgit_repo; extern char *cgit_root_title; extern char *cgit_css; extern char *cgit_logo; +extern char *cgit_index_header; extern char *cgit_logo_link; extern char *cgit_module_link; extern char *cgit_virtual_root; diff --git a/shared.c b/shared.c index 53cd9b0..54b1813 100644 --- a/shared.c +++ b/shared.c @@ -14,6 +14,7 @@ struct repoinfo *cgit_repo; char *cgit_root_title = "Git repository browser"; char *cgit_css = "/cgit.css"; char *cgit_logo = "/git-logo.png"; +char *cgit_index_header = NULL; char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/"; char *cgit_module_link = "./?repo=%s&page=commit&id=%s"; char *cgit_virtual_root = NULL; @@ -101,6 +102,8 @@ void cgit_global_config_cb(const char *name, const char *value) cgit_css = xstrdup(value); else if (!strcmp(name, "logo")) cgit_logo = xstrdup(value); + else if (!strcmp(name, "index-header")) + cgit_index_header = xstrdup(value); else if (!strcmp(name, "logo-link")) cgit_logo_link = xstrdup(value); else if (!strcmp(name, "module-link")) diff --git a/ui-repolist.c b/ui-repolist.c index d7311e4..8e367a2 100644 --- a/ui-repolist.c +++ b/ui-repolist.c @@ -17,6 +17,11 @@ void cgit_print_repolist(struct cacheitem *item) cgit_print_pageheader(cgit_root_title, 0); html(""); + if (cgit_index_header) { + html(""); + } html("" "" "" -- cgit v1.2.3-59-g8ed1b
"); + html_include(cgit_index_header); + html("
NameDescription