summaryrefslogtreecommitdiffabout
path: root/cgit.c
authorLars Hjemli <hjemli@gmail.com>2008-04-28 22:55:34 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2008-04-28 22:55:34 (UTC)
commit4c9916043d6aabb8278e0d78f5fa71a59f82889d (patch) (unidiff)
tree02259d3ef9c31379c2733d1944412a9015e2f311 /cgit.c
parent8062817885495b07cf70304c484e8f18c78ab2b5 (diff)
downloadcgit-4c9916043d6aabb8278e0d78f5fa71a59f82889d.zip
cgit-4c9916043d6aabb8278e0d78f5fa71a59f82889d.tar.gz
cgit-4c9916043d6aabb8278e0d78f5fa71a59f82889d.tar.bz2
Re-enable 'index-info' and add support for 'root-desc' in cgitrc
The 'index-info' option got lost when the layout was converted from sidebar to old-fashioned header (noticed by Harley Laue, thanks!), and this commit re-enables it. But there is now also an alternative in the 'root-desc' option; where 'index-info' specifies a file to include, 'root-desc' specifies the text literally. This might be nicer for the one-liner descriptions which these options typically provides. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to 'cgit.c') (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/cgit.c b/cgit.c
index 38b0ba5..bbde64b 100644
--- a/cgit.c
+++ b/cgit.c
@@ -6,32 +6,34 @@
6 * (see COPYING for full license text) 6 * (see COPYING for full license text)
7 */ 7 */
8 8
9#include "cgit.h" 9#include "cgit.h"
10#include "cache.h" 10#include "cache.h"
11#include "cmd.h" 11#include "cmd.h"
12#include "configfile.h" 12#include "configfile.h"
13#include "html.h" 13#include "html.h"
14#include "ui-shared.h" 14#include "ui-shared.h"
15 15
16const char *cgit_version = CGIT_VERSION; 16const char *cgit_version = CGIT_VERSION;
17 17
18void config_cb(const char *name, const char *value) 18void config_cb(const char *name, const char *value)
19{ 19{
20 if (!strcmp(name, "root-title")) 20 if (!strcmp(name, "root-title"))
21 ctx.cfg.root_title = xstrdup(value); 21 ctx.cfg.root_title = xstrdup(value);
22 else if (!strcmp(name, "root-desc"))
23 ctx.cfg.root_desc = xstrdup(value);
22 else if (!strcmp(name, "css")) 24 else if (!strcmp(name, "css"))
23 ctx.cfg.css = xstrdup(value); 25 ctx.cfg.css = xstrdup(value);
24 else if (!strcmp(name, "logo")) 26 else if (!strcmp(name, "logo"))
25 ctx.cfg.logo = xstrdup(value); 27 ctx.cfg.logo = xstrdup(value);
26 else if (!strcmp(name, "index-header")) 28 else if (!strcmp(name, "index-header"))
27 ctx.cfg.index_header = xstrdup(value); 29 ctx.cfg.index_header = xstrdup(value);
28 else if (!strcmp(name, "index-info")) 30 else if (!strcmp(name, "index-info"))
29 ctx.cfg.index_info = xstrdup(value); 31 ctx.cfg.index_info = xstrdup(value);
30 else if (!strcmp(name, "logo-link")) 32 else if (!strcmp(name, "logo-link"))
31 ctx.cfg.logo_link = xstrdup(value); 33 ctx.cfg.logo_link = xstrdup(value);
32 else if (!strcmp(name, "module-link")) 34 else if (!strcmp(name, "module-link"))
33 ctx.cfg.module_link = xstrdup(value); 35 ctx.cfg.module_link = xstrdup(value);
34 else if (!strcmp(name, "virtual-root")) { 36 else if (!strcmp(name, "virtual-root")) {
35 ctx.cfg.virtual_root = trim_end(value, '/'); 37 ctx.cfg.virtual_root = trim_end(value, '/');
36 if (!ctx.cfg.virtual_root && (!strcmp(value, "/"))) 38 if (!ctx.cfg.virtual_root && (!strcmp(value, "/")))
37 ctx.cfg.virtual_root = ""; 39 ctx.cfg.virtual_root = "";
@@ -146,32 +148,33 @@ static void prepare_context(struct cgit_context *ctx)
146 ctx->cfg.cache_dynamic_ttl = 5; 148 ctx->cfg.cache_dynamic_ttl = 5;
147 ctx->cfg.cache_max_create_time = 5; 149 ctx->cfg.cache_max_create_time = 5;
148 ctx->cfg.cache_repo_ttl = 5; 150 ctx->cfg.cache_repo_ttl = 5;
149 ctx->cfg.cache_root = CGIT_CACHE_ROOT; 151 ctx->cfg.cache_root = CGIT_CACHE_ROOT;
150 ctx->cfg.cache_root_ttl = 5; 152 ctx->cfg.cache_root_ttl = 5;
151 ctx->cfg.cache_static_ttl = -1; 153 ctx->cfg.cache_static_ttl = -1;
152 ctx->cfg.css = "/cgit.css"; 154 ctx->cfg.css = "/cgit.css";
153 ctx->cfg.logo = "/git-logo.png"; 155 ctx->cfg.logo = "/git-logo.png";
154 ctx->cfg.max_commit_count = 50; 156 ctx->cfg.max_commit_count = 50;
155 ctx->cfg.max_lock_attempts = 5; 157 ctx->cfg.max_lock_attempts = 5;
156 ctx->cfg.max_msg_len = 60; 158 ctx->cfg.max_msg_len = 60;
157 ctx->cfg.max_repodesc_len = 60; 159 ctx->cfg.max_repodesc_len = 60;
158 ctx->cfg.module_link = "./?repo=%s&page=commit&id=%s"; 160 ctx->cfg.module_link = "./?repo=%s&page=commit&id=%s";
159 ctx->cfg.renamelimit = -1; 161 ctx->cfg.renamelimit = -1;
160 ctx->cfg.robots = "index, nofollow"; 162 ctx->cfg.robots = "index, nofollow";
161 ctx->cfg.root_title = "Git repository browser"; 163 ctx->cfg.root_title = "Git repository browser";
164 ctx->cfg.root_desc = "a fast webinterface for the git dscm";
162 ctx->cfg.script_name = CGIT_SCRIPT_NAME; 165 ctx->cfg.script_name = CGIT_SCRIPT_NAME;
163 ctx->page.mimetype = "text/html"; 166 ctx->page.mimetype = "text/html";
164 ctx->page.charset = PAGE_ENCODING; 167 ctx->page.charset = PAGE_ENCODING;
165 ctx->page.filename = NULL; 168 ctx->page.filename = NULL;
166} 169}
167 170
168static int cgit_prepare_cache(struct cacheitem *item) 171static int cgit_prepare_cache(struct cacheitem *item)
169{ 172{
170 if (!ctx.repo && ctx.qry.repo) { 173 if (!ctx.repo && ctx.qry.repo) {
171 ctx.page.title = fmt("%s - %s", ctx.cfg.root_title, 174 ctx.page.title = fmt("%s - %s", ctx.cfg.root_title,
172 "Bad request"); 175 "Bad request");
173 cgit_print_http_headers(&ctx); 176 cgit_print_http_headers(&ctx);
174 cgit_print_docstart(&ctx); 177 cgit_print_docstart(&ctx);
175 cgit_print_pageheader(&ctx); 178 cgit_print_pageheader(&ctx);
176 cgit_print_error(fmt("Unknown repo: %s", ctx.qry.repo)); 179 cgit_print_error(fmt("Unknown repo: %s", ctx.qry.repo));
177 cgit_print_docend(); 180 cgit_print_docend();