|
diff --git a/shared.c b/shared.c index 8e6df31..6fd70a8 100644 --- a/ shared.c+++ b/ shared.c |
|
@@ -7,9 +7,11 @@ |
7 | */ |
7 | */ |
8 | |
8 | |
9 | #include "cgit.h" |
9 | #include "cgit.h" |
10 | |
10 | |
11 | char *cgit_root = "/usr/src/git"; |
11 | struct repolist cgit_repolist; |
| |
12 | struct repoinfo *cgit_repo; |
| |
13 | |
12 | char *cgit_root_title = "Git repository browser"; |
14 | char *cgit_root_title = "Git repository browser"; |
13 | char *cgit_css = "/cgit.css"; |
15 | char *cgit_css = "/cgit.css"; |
14 | char *cgit_logo = "/git-logo.png"; |
16 | char *cgit_logo = "/git-logo.png"; |
15 | char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/"; |
17 | char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/"; |
@@ -45,13 +47,34 @@ char *cgit_query_path = NULL; |
45 | int cgit_query_ofs = 0; |
47 | int cgit_query_ofs = 0; |
46 | |
48 | |
47 | int htmlfd = 0; |
49 | int htmlfd = 0; |
48 | |
50 | |
| |
51 | struct repoinfo *add_repo(const char *url) |
| |
52 | { |
| |
53 | struct repoinfo *ret; |
| |
54 | |
| |
55 | if (++cgit_repolist.count > cgit_repolist.length) { |
| |
56 | if (cgit_repolist.length == 0) |
| |
57 | cgit_repolist.length = 8; |
| |
58 | else |
| |
59 | cgit_repolist.length *= 2; |
| |
60 | cgit_repolist.repos = xrealloc(cgit_repolist.repos, |
| |
61 | cgit_repolist.length * |
| |
62 | sizeof(struct repoinfo)); |
| |
63 | } |
| |
64 | |
| |
65 | ret = &cgit_repolist.repos[cgit_repolist.count-1]; |
| |
66 | ret->url = xstrdup(url); |
| |
67 | ret->name = ret->url; |
| |
68 | ret->path = NULL; |
| |
69 | ret->desc = NULL; |
| |
70 | ret->owner = NULL; |
| |
71 | return ret; |
| |
72 | } |
| |
73 | |
49 | void cgit_global_config_cb(const char *name, const char *value) |
74 | void cgit_global_config_cb(const char *name, const char *value) |
50 | { |
75 | { |
51 | if (!strcmp(name, "root")) |
76 | if (!strcmp(name, "root-title")) |
52 | cgit_root = xstrdup(value); |
| |
53 | else if (!strcmp(name, "root-title")) |
| |
54 | cgit_root_title = xstrdup(value); |
77 | cgit_root_title = xstrdup(value); |
55 | else if (!strcmp(name, "css")) |
78 | else if (!strcmp(name, "css")) |
56 | cgit_css = xstrdup(value); |
79 | cgit_css = xstrdup(value); |
57 | else if (!strcmp(name, "logo")) |
80 | else if (!strcmp(name, "logo")) |
@@ -73,8 +96,18 @@ void cgit_global_config_cb(const char *name, const char *value) |
73 | else if (!strcmp(name, "cache-dynamic-ttl")) |
96 | else if (!strcmp(name, "cache-dynamic-ttl")) |
74 | cgit_cache_dynamic_ttl = atoi(value); |
97 | cgit_cache_dynamic_ttl = atoi(value); |
75 | else if (!strcmp(name, "max-message-length")) |
98 | else if (!strcmp(name, "max-message-length")) |
76 | cgit_max_msg_len = atoi(value); |
99 | cgit_max_msg_len = atoi(value); |
| |
100 | else if (!strcmp(name, "repo.url")) |
| |
101 | cgit_repo = add_repo(value); |
| |
102 | else if (!strcmp(name, "repo.name")) |
| |
103 | cgit_repo->name = xstrdup(value); |
| |
104 | else if (cgit_repo && !strcmp(name, "repo.path")) |
| |
105 | cgit_repo->path = xstrdup(value); |
| |
106 | else if (cgit_repo && !strcmp(name, "repo.desc")) |
| |
107 | cgit_repo->desc = xstrdup(value); |
| |
108 | else if (cgit_repo && !strcmp(name, "repo.owner")) |
| |
109 | cgit_repo->owner = xstrdup(value); |
77 | } |
110 | } |
78 | |
111 | |
79 | void cgit_repo_config_cb(const char *name, const char *value) |
112 | void cgit_repo_config_cb(const char *name, const char *value) |
80 | { |
113 | { |
|