author | Lars Hjemli <hjemli@gmail.com> | 2007-12-03 00:49:38 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2007-12-03 00:49:38 (UTC) |
commit | afcdd083dab81afef744e261d81a452698188c30 (patch) (unidiff) | |
tree | 0ca43a6b87567af70c802a25124702c7c7891c9a /shared.c | |
parent | dabb34af760eff2a6ab8e14927fd173cafb77547 (diff) | |
download | cgit-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>
-rw-r--r-- | shared.c | 5 |
1 files changed, 5 insertions, 0 deletions
@@ -18,24 +18,25 @@ char *cgit_root_title = "Git repository browser"; | |||
18 | char *cgit_css = "/cgit.css"; | 18 | char *cgit_css = "/cgit.css"; |
19 | char *cgit_logo = "/git-logo.png"; | 19 | char *cgit_logo = "/git-logo.png"; |
20 | char *cgit_index_header = NULL; | 20 | char *cgit_index_header = NULL; |
21 | char *cgit_index_info = NULL; | 21 | char *cgit_index_info = NULL; |
22 | char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/"; | 22 | char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/"; |
23 | char *cgit_module_link = "./?repo=%s&page=commit&id=%s"; | 23 | char *cgit_module_link = "./?repo=%s&page=commit&id=%s"; |
24 | char *cgit_agefile = "info/web/last-modified"; | 24 | char *cgit_agefile = "info/web/last-modified"; |
25 | char *cgit_virtual_root = NULL; | 25 | char *cgit_virtual_root = NULL; |
26 | char *cgit_script_name = CGIT_SCRIPT_NAME; | 26 | char *cgit_script_name = CGIT_SCRIPT_NAME; |
27 | char *cgit_cache_root = CGIT_CACHE_ROOT; | 27 | char *cgit_cache_root = CGIT_CACHE_ROOT; |
28 | char *cgit_repo_group = NULL; | 28 | char *cgit_repo_group = NULL; |
29 | char *cgit_robots = "index, nofollow"; | 29 | char *cgit_robots = "index, nofollow"; |
30 | char *cgit_clone_prefix = NULL; | ||
30 | 31 | ||
31 | int cgit_nocache = 0; | 32 | int cgit_nocache = 0; |
32 | int cgit_snapshots = 0; | 33 | int cgit_snapshots = 0; |
33 | int cgit_enable_index_links = 0; | 34 | int cgit_enable_index_links = 0; |
34 | int cgit_enable_log_filecount = 0; | 35 | int cgit_enable_log_filecount = 0; |
35 | int cgit_enable_log_linecount = 0; | 36 | int cgit_enable_log_linecount = 0; |
36 | int cgit_max_lock_attempts = 5; | 37 | int cgit_max_lock_attempts = 5; |
37 | int cgit_cache_root_ttl = 5; | 38 | int cgit_cache_root_ttl = 5; |
38 | int cgit_cache_repo_ttl = 5; | 39 | int cgit_cache_repo_ttl = 5; |
39 | int cgit_cache_dynamic_ttl = 5; | 40 | int cgit_cache_dynamic_ttl = 5; |
40 | int cgit_cache_static_ttl = -1; | 41 | int cgit_cache_static_ttl = -1; |
41 | int cgit_cache_max_create_time = 5; | 42 | int 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); |