summaryrefslogtreecommitdiffabout
path: root/shared.c
authorLars Hjemli <hjemli@gmail.com>2007-12-03 00:49:38 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2007-12-03 00:49:38 (UTC)
commitafcdd083dab81afef744e261d81a452698188c30 (patch) (unidiff)
tree0ca43a6b87567af70c802a25124702c7c7891c9a /shared.c
parentdabb34af760eff2a6ab8e14927fd173cafb77547 (diff)
downloadcgit-afcdd083dab81afef744e261d81a452698188c30.zip
cgit-afcdd083dab81afef744e261d81a452698188c30.tar.gz
cgit-afcdd083dab81afef744e261d81a452698188c30.tar.bz2
Add support for automatic and custom clone urls
This adds support for two new parameters to cgitrc: clone-prefix and repo.clone-url. If clone-prefix is specified, all repos will get a clone url printed in the sidebar; the url is generated by clone-prefix + repo.url. Additionally, each repo can specify repo.clone-url which will override any such auto-generated url. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to 'shared.c') (more/less context) (ignore whitespace changes)
-rw-r--r--shared.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/shared.c b/shared.c
index fd8b1e3..2c309f5 100644
--- a/shared.c
+++ b/shared.c
@@ -18,24 +18,25 @@ char *cgit_root_title = "Git repository browser";
18char *cgit_css = "/cgit.css"; 18char *cgit_css = "/cgit.css";
19char *cgit_logo = "/git-logo.png"; 19char *cgit_logo = "/git-logo.png";
20char *cgit_index_header = NULL; 20char *cgit_index_header = NULL;
21char *cgit_index_info = NULL; 21char *cgit_index_info = NULL;
22char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/"; 22char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/";
23char *cgit_module_link = "./?repo=%s&page=commit&id=%s"; 23char *cgit_module_link = "./?repo=%s&page=commit&id=%s";
24char *cgit_agefile = "info/web/last-modified"; 24char *cgit_agefile = "info/web/last-modified";
25char *cgit_virtual_root = NULL; 25char *cgit_virtual_root = NULL;
26char *cgit_script_name = CGIT_SCRIPT_NAME; 26char *cgit_script_name = CGIT_SCRIPT_NAME;
27char *cgit_cache_root = CGIT_CACHE_ROOT; 27char *cgit_cache_root = CGIT_CACHE_ROOT;
28char *cgit_repo_group = NULL; 28char *cgit_repo_group = NULL;
29char *cgit_robots = "index, nofollow"; 29char *cgit_robots = "index, nofollow";
30char *cgit_clone_prefix = NULL;
30 31
31int cgit_nocache = 0; 32int cgit_nocache = 0;
32int cgit_snapshots = 0; 33int cgit_snapshots = 0;
33int cgit_enable_index_links = 0; 34int cgit_enable_index_links = 0;
34int cgit_enable_log_filecount = 0; 35int cgit_enable_log_filecount = 0;
35int cgit_enable_log_linecount = 0; 36int cgit_enable_log_linecount = 0;
36int cgit_max_lock_attempts = 5; 37int cgit_max_lock_attempts = 5;
37int cgit_cache_root_ttl = 5; 38int cgit_cache_root_ttl = 5;
38int cgit_cache_repo_ttl = 5; 39int cgit_cache_repo_ttl = 5;
39int cgit_cache_dynamic_ttl = 5; 40int cgit_cache_dynamic_ttl = 5;
40int cgit_cache_static_ttl = -1; 41int cgit_cache_static_ttl = -1;
41int cgit_cache_max_create_time = 5; 42int cgit_cache_max_create_time = 5;
@@ -191,32 +192,36 @@ void cgit_global_config_cb(const char *name, const char *value)
191 else if (!strcmp(name, "summary-log")) 192 else if (!strcmp(name, "summary-log"))
192 cgit_summary_log = atoi(value); 193 cgit_summary_log = atoi(value);
193 else if (!strcmp(name, "summary-branches")) 194 else if (!strcmp(name, "summary-branches"))
194 cgit_summary_branches = atoi(value); 195 cgit_summary_branches = atoi(value);
195 else if (!strcmp(name, "summary-tags")) 196 else if (!strcmp(name, "summary-tags"))
196 cgit_summary_tags = atoi(value); 197 cgit_summary_tags = atoi(value);
197 else if (!strcmp(name, "agefile")) 198 else if (!strcmp(name, "agefile"))
198 cgit_agefile = xstrdup(value); 199 cgit_agefile = xstrdup(value);
199 else if (!strcmp(name, "renamelimit")) 200 else if (!strcmp(name, "renamelimit"))
200 cgit_renamelimit = atoi(value); 201 cgit_renamelimit = atoi(value);
201 else if (!strcmp(name, "robots")) 202 else if (!strcmp(name, "robots"))
202 cgit_robots = xstrdup(value); 203 cgit_robots = xstrdup(value);
204 else if (!strcmp(name, "clone-prefix"))
205 cgit_clone_prefix = xstrdup(value);
203 else if (!strcmp(name, "repo.group")) 206 else if (!strcmp(name, "repo.group"))
204 cgit_repo_group = xstrdup(value); 207 cgit_repo_group = xstrdup(value);
205 else if (!strcmp(name, "repo.url")) 208 else if (!strcmp(name, "repo.url"))
206 cgit_repo = add_repo(value); 209 cgit_repo = add_repo(value);
207 else if (!strcmp(name, "repo.name")) 210 else if (!strcmp(name, "repo.name"))
208 cgit_repo->name = xstrdup(value); 211 cgit_repo->name = xstrdup(value);
209 else if (cgit_repo && !strcmp(name, "repo.path")) 212 else if (cgit_repo && !strcmp(name, "repo.path"))
210 cgit_repo->path = trim_end(value, '/'); 213 cgit_repo->path = trim_end(value, '/');
214 else if (cgit_repo && !strcmp(name, "repo.clone-url"))
215 cgit_repo->clone_url = xstrdup(value);
211 else if (cgit_repo && !strcmp(name, "repo.desc")) 216 else if (cgit_repo && !strcmp(name, "repo.desc"))
212 cgit_repo->desc = xstrdup(value); 217 cgit_repo->desc = xstrdup(value);
213 else if (cgit_repo && !strcmp(name, "repo.owner")) 218 else if (cgit_repo && !strcmp(name, "repo.owner"))
214 cgit_repo->owner = xstrdup(value); 219 cgit_repo->owner = xstrdup(value);
215 else if (cgit_repo && !strcmp(name, "repo.defbranch")) 220 else if (cgit_repo && !strcmp(name, "repo.defbranch"))
216 cgit_repo->defbranch = xstrdup(value); 221 cgit_repo->defbranch = xstrdup(value);
217 else if (cgit_repo && !strcmp(name, "repo.snapshots")) 222 else if (cgit_repo && !strcmp(name, "repo.snapshots"))
218 cgit_repo->snapshots = cgit_snapshots & cgit_parse_snapshots_mask(value); /* XXX: &? */ 223 cgit_repo->snapshots = cgit_snapshots & cgit_parse_snapshots_mask(value); /* XXX: &? */
219 else if (cgit_repo && !strcmp(name, "repo.enable-log-filecount")) 224 else if (cgit_repo && !strcmp(name, "repo.enable-log-filecount"))
220 cgit_repo->enable_log_filecount = cgit_enable_log_filecount * atoi(value); 225 cgit_repo->enable_log_filecount = cgit_enable_log_filecount * atoi(value);
221 else if (cgit_repo && !strcmp(name, "repo.enable-log-linecount")) 226 else if (cgit_repo && !strcmp(name, "repo.enable-log-linecount"))
222 cgit_repo->enable_log_linecount = cgit_enable_log_linecount * atoi(value); 227 cgit_repo->enable_log_linecount = cgit_enable_log_linecount * atoi(value);