summaryrefslogtreecommitdiffabout
path: root/shared.c
authorLars Hjemli <hjemli@gmail.com>2007-05-13 15:15:06 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2007-05-13 15:15:06 (UTC)
commitc6cf3a424a0860d69b290254d9b19d35527b2d27 (patch) (unidiff)
tree2874f2c42e907cba1187ae32ee686daebc2de59e /shared.c
parent80e577c3ef2a73becabff7e9c9c242f317a87de9 (diff)
downloadcgit-c6cf3a424a0860d69b290254d9b19d35527b2d27.zip
cgit-c6cf3a424a0860d69b290254d9b19d35527b2d27.tar.gz
cgit-c6cf3a424a0860d69b290254d9b19d35527b2d27.tar.bz2
Add max-commit-count parameter to cgitrc
This enabled customizing number of commits shown per page in log view. It also changes the default from 100 to 50, mainly due to the more cpu intensive log pages (number of files/lines changed) but also since 100 log messages requires excessive scrolling. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to 'shared.c') (more/less context) (ignore whitespace changes)
-rw-r--r--shared.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/shared.c b/shared.c
index 801f68d..ffecac8 100644
--- a/shared.c
+++ b/shared.c
@@ -1,218 +1,221 @@
1/* shared.c: global vars + some callback functions 1/* shared.c: global vars + some callback functions
2 * 2 *
3 * Copyright (C) 2006 Lars Hjemli 3 * Copyright (C) 2006 Lars Hjemli
4 * 4 *
5 * Licensed under GNU General Public License v2 5 * Licensed under GNU General Public License v2
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 10
11struct repolist cgit_repolist; 11struct repolist cgit_repolist;
12struct repoinfo *cgit_repo; 12struct repoinfo *cgit_repo;
13 13
14char *cgit_root_title = "Git repository browser"; 14char *cgit_root_title = "Git repository browser";
15char *cgit_css = "/cgit.css"; 15char *cgit_css = "/cgit.css";
16char *cgit_logo = "/git-logo.png"; 16char *cgit_logo = "/git-logo.png";
17char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/"; 17char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/";
18char *cgit_module_link = "./?repo=%s&page=commit&id=%s"; 18char *cgit_module_link = "./?repo=%s&page=commit&id=%s";
19char *cgit_virtual_root = NULL; 19char *cgit_virtual_root = NULL;
20 20
21char *cgit_cache_root = "/var/cache/cgit"; 21char *cgit_cache_root = "/var/cache/cgit";
22 22
23int cgit_nocache = 0; 23int cgit_nocache = 0;
24int cgit_snapshots = 0; 24int cgit_snapshots = 0;
25int cgit_max_lock_attempts = 5; 25int cgit_max_lock_attempts = 5;
26int cgit_cache_root_ttl = 5; 26int cgit_cache_root_ttl = 5;
27int cgit_cache_repo_ttl = 5; 27int cgit_cache_repo_ttl = 5;
28int cgit_cache_dynamic_ttl = 5; 28int cgit_cache_dynamic_ttl = 5;
29int cgit_cache_static_ttl = -1; 29int cgit_cache_static_ttl = -1;
30int cgit_cache_max_create_time = 5; 30int cgit_cache_max_create_time = 5;
31 31
32int cgit_max_msg_len = 60; 32int cgit_max_msg_len = 60;
33int cgit_max_commit_count = 50;
33 34
34char *cgit_repo_name = NULL; 35char *cgit_repo_name = NULL;
35char *cgit_repo_desc = NULL; 36char *cgit_repo_desc = NULL;
36char *cgit_repo_owner = NULL; 37char *cgit_repo_owner = NULL;
37 38
38int cgit_query_has_symref = 0; 39int cgit_query_has_symref = 0;
39int cgit_query_has_sha1 = 0; 40int cgit_query_has_sha1 = 0;
40 41
41char *cgit_querystring = NULL; 42char *cgit_querystring = NULL;
42char *cgit_query_repo = NULL; 43char *cgit_query_repo = NULL;
43char *cgit_query_page = NULL; 44char *cgit_query_page = NULL;
44char *cgit_query_head = NULL; 45char *cgit_query_head = NULL;
45char *cgit_query_search = NULL; 46char *cgit_query_search = NULL;
46char *cgit_query_sha1 = NULL; 47char *cgit_query_sha1 = NULL;
47char *cgit_query_sha2 = NULL; 48char *cgit_query_sha2 = NULL;
48char *cgit_query_path = NULL; 49char *cgit_query_path = NULL;
49char *cgit_query_name = NULL; 50char *cgit_query_name = NULL;
50int cgit_query_ofs = 0; 51int cgit_query_ofs = 0;
51 52
52int htmlfd = 0; 53int htmlfd = 0;
53 54
54int chk_zero(int result, char *msg) 55int chk_zero(int result, char *msg)
55{ 56{
56 if (result != 0) 57 if (result != 0)
57 die("%s: %s", msg, strerror(errno)); 58 die("%s: %s", msg, strerror(errno));
58 return result; 59 return result;
59} 60}
60 61
61int chk_positive(int result, char *msg) 62int chk_positive(int result, char *msg)
62{ 63{
63 if (result <= 0) 64 if (result <= 0)
64 die("%s: %s", msg, strerror(errno)); 65 die("%s: %s", msg, strerror(errno));
65 return result; 66 return result;
66} 67}
67 68
68struct repoinfo *add_repo(const char *url) 69struct repoinfo *add_repo(const char *url)
69{ 70{
70 struct repoinfo *ret; 71 struct repoinfo *ret;
71 72
72 if (++cgit_repolist.count > cgit_repolist.length) { 73 if (++cgit_repolist.count > cgit_repolist.length) {
73 if (cgit_repolist.length == 0) 74 if (cgit_repolist.length == 0)
74 cgit_repolist.length = 8; 75 cgit_repolist.length = 8;
75 else 76 else
76 cgit_repolist.length *= 2; 77 cgit_repolist.length *= 2;
77 cgit_repolist.repos = xrealloc(cgit_repolist.repos, 78 cgit_repolist.repos = xrealloc(cgit_repolist.repos,
78 cgit_repolist.length * 79 cgit_repolist.length *
79 sizeof(struct repoinfo)); 80 sizeof(struct repoinfo));
80 } 81 }
81 82
82 ret = &cgit_repolist.repos[cgit_repolist.count-1]; 83 ret = &cgit_repolist.repos[cgit_repolist.count-1];
83 ret->url = xstrdup(url); 84 ret->url = xstrdup(url);
84 ret->name = ret->url; 85 ret->name = ret->url;
85 ret->path = NULL; 86 ret->path = NULL;
86 ret->desc = NULL; 87 ret->desc = NULL;
87 ret->owner = NULL; 88 ret->owner = NULL;
88 ret->snapshots = cgit_snapshots; 89 ret->snapshots = cgit_snapshots;
89 ret->module_link = cgit_module_link; 90 ret->module_link = cgit_module_link;
90 return ret; 91 return ret;
91} 92}
92 93
93void cgit_global_config_cb(const char *name, const char *value) 94void cgit_global_config_cb(const char *name, const char *value)
94{ 95{
95 if (!strcmp(name, "root-title")) 96 if (!strcmp(name, "root-title"))
96 cgit_root_title = xstrdup(value); 97 cgit_root_title = xstrdup(value);
97 else if (!strcmp(name, "css")) 98 else if (!strcmp(name, "css"))
98 cgit_css = xstrdup(value); 99 cgit_css = xstrdup(value);
99 else if (!strcmp(name, "logo")) 100 else if (!strcmp(name, "logo"))
100 cgit_logo = xstrdup(value); 101 cgit_logo = xstrdup(value);
101 else if (!strcmp(name, "logo-link")) 102 else if (!strcmp(name, "logo-link"))
102 cgit_logo_link = xstrdup(value); 103 cgit_logo_link = xstrdup(value);
103 else if (!strcmp(name, "module-link")) 104 else if (!strcmp(name, "module-link"))
104 cgit_module_link = xstrdup(value); 105 cgit_module_link = xstrdup(value);
105 else if (!strcmp(name, "virtual-root")) 106 else if (!strcmp(name, "virtual-root"))
106 cgit_virtual_root = xstrdup(value); 107 cgit_virtual_root = xstrdup(value);
107 else if (!strcmp(name, "nocache")) 108 else if (!strcmp(name, "nocache"))
108 cgit_nocache = atoi(value); 109 cgit_nocache = atoi(value);
109 else if (!strcmp(name, "snapshots")) 110 else if (!strcmp(name, "snapshots"))
110 cgit_snapshots = atoi(value); 111 cgit_snapshots = atoi(value);
111 else if (!strcmp(name, "cache-root")) 112 else if (!strcmp(name, "cache-root"))
112 cgit_cache_root = xstrdup(value); 113 cgit_cache_root = xstrdup(value);
113 else if (!strcmp(name, "cache-root-ttl")) 114 else if (!strcmp(name, "cache-root-ttl"))
114 cgit_cache_root_ttl = atoi(value); 115 cgit_cache_root_ttl = atoi(value);
115 else if (!strcmp(name, "cache-repo-ttl")) 116 else if (!strcmp(name, "cache-repo-ttl"))
116 cgit_cache_repo_ttl = atoi(value); 117 cgit_cache_repo_ttl = atoi(value);
117 else if (!strcmp(name, "cache-static-ttl")) 118 else if (!strcmp(name, "cache-static-ttl"))
118 cgit_cache_static_ttl = atoi(value); 119 cgit_cache_static_ttl = atoi(value);
119 else if (!strcmp(name, "cache-dynamic-ttl")) 120 else if (!strcmp(name, "cache-dynamic-ttl"))
120 cgit_cache_dynamic_ttl = atoi(value); 121 cgit_cache_dynamic_ttl = atoi(value);
121 else if (!strcmp(name, "max-message-length")) 122 else if (!strcmp(name, "max-message-length"))
122 cgit_max_msg_len = atoi(value); 123 cgit_max_msg_len = atoi(value);
124 else if (!strcmp(name, "max-commit-count"))
125 cgit_max_commit_count = atoi(value);
123 else if (!strcmp(name, "repo.url")) 126 else if (!strcmp(name, "repo.url"))
124 cgit_repo = add_repo(value); 127 cgit_repo = add_repo(value);
125 else if (!strcmp(name, "repo.name")) 128 else if (!strcmp(name, "repo.name"))
126 cgit_repo->name = xstrdup(value); 129 cgit_repo->name = xstrdup(value);
127 else if (cgit_repo && !strcmp(name, "repo.path")) 130 else if (cgit_repo && !strcmp(name, "repo.path"))
128 cgit_repo->path = xstrdup(value); 131 cgit_repo->path = xstrdup(value);
129 else if (cgit_repo && !strcmp(name, "repo.desc")) 132 else if (cgit_repo && !strcmp(name, "repo.desc"))
130 cgit_repo->desc = xstrdup(value); 133 cgit_repo->desc = xstrdup(value);
131 else if (cgit_repo && !strcmp(name, "repo.owner")) 134 else if (cgit_repo && !strcmp(name, "repo.owner"))
132 cgit_repo->owner = xstrdup(value); 135 cgit_repo->owner = xstrdup(value);
133 else if (cgit_repo && !strcmp(name, "repo.snapshots")) 136 else if (cgit_repo && !strcmp(name, "repo.snapshots"))
134 cgit_repo->snapshots = atoi(value); 137 cgit_repo->snapshots = atoi(value);
135 else if (cgit_repo && !strcmp(name, "repo.module-link")) 138 else if (cgit_repo && !strcmp(name, "repo.module-link"))
136 cgit_repo->module_link= xstrdup(value); 139 cgit_repo->module_link= xstrdup(value);
137} 140}
138 141
139void cgit_repo_config_cb(const char *name, const char *value) 142void cgit_repo_config_cb(const char *name, const char *value)
140{ 143{
141 if (!strcmp(name, "name")) 144 if (!strcmp(name, "name"))
142 cgit_repo_name = xstrdup(value); 145 cgit_repo_name = xstrdup(value);
143 else if (!strcmp(name, "desc")) 146 else if (!strcmp(name, "desc"))
144 cgit_repo_desc = xstrdup(value); 147 cgit_repo_desc = xstrdup(value);
145 else if (!strcmp(name, "owner")) 148 else if (!strcmp(name, "owner"))
146 cgit_repo_owner = xstrdup(value); 149 cgit_repo_owner = xstrdup(value);
147} 150}
148 151
149void cgit_querystring_cb(const char *name, const char *value) 152void cgit_querystring_cb(const char *name, const char *value)
150{ 153{
151 if (!strcmp(name,"r")) { 154 if (!strcmp(name,"r")) {
152 cgit_query_repo = xstrdup(value); 155 cgit_query_repo = xstrdup(value);
153 } else if (!strcmp(name, "p")) { 156 } else if (!strcmp(name, "p")) {
154 cgit_query_page = xstrdup(value); 157 cgit_query_page = xstrdup(value);
155 } else if (!strcmp(name, "q")) { 158 } else if (!strcmp(name, "q")) {
156 cgit_query_search = xstrdup(value); 159 cgit_query_search = xstrdup(value);
157 } else if (!strcmp(name, "h")) { 160 } else if (!strcmp(name, "h")) {
158 cgit_query_head = xstrdup(value); 161 cgit_query_head = xstrdup(value);
159 cgit_query_has_symref = 1; 162 cgit_query_has_symref = 1;
160 } else if (!strcmp(name, "id")) { 163 } else if (!strcmp(name, "id")) {
161 cgit_query_sha1 = xstrdup(value); 164 cgit_query_sha1 = xstrdup(value);
162 cgit_query_has_sha1 = 1; 165 cgit_query_has_sha1 = 1;
163 } else if (!strcmp(name, "id2")) { 166 } else if (!strcmp(name, "id2")) {
164 cgit_query_sha2 = xstrdup(value); 167 cgit_query_sha2 = xstrdup(value);
165 cgit_query_has_sha1 = 1; 168 cgit_query_has_sha1 = 1;
166 } else if (!strcmp(name, "ofs")) { 169 } else if (!strcmp(name, "ofs")) {
167 cgit_query_ofs = atoi(value); 170 cgit_query_ofs = atoi(value);
168 } else if (!strcmp(name, "path")) { 171 } else if (!strcmp(name, "path")) {
169 cgit_query_path = xstrdup(value); 172 cgit_query_path = xstrdup(value);
170 } else if (!strcmp(name, "name")) { 173 } else if (!strcmp(name, "name")) {
171 cgit_query_name = xstrdup(value); 174 cgit_query_name = xstrdup(value);
172 } 175 }
173} 176}
174 177
175void *cgit_free_commitinfo(struct commitinfo *info) 178void *cgit_free_commitinfo(struct commitinfo *info)
176{ 179{
177 free(info->author); 180 free(info->author);
178 free(info->author_email); 181 free(info->author_email);
179 free(info->committer); 182 free(info->committer);
180 free(info->committer_email); 183 free(info->committer_email);
181 free(info->subject); 184 free(info->subject);
182 free(info); 185 free(info);
183 return NULL; 186 return NULL;
184} 187}
185 188
186int hextoint(char c) 189int hextoint(char c)
187{ 190{
188 if (c >= 'a' && c <= 'f') 191 if (c >= 'a' && c <= 'f')
189 return 10 + c - 'a'; 192 return 10 + c - 'a';
190 else if (c >= 'A' && c <= 'F') 193 else if (c >= 'A' && c <= 'F')
191 return 10 + c - 'A'; 194 return 10 + c - 'A';
192 else if (c >= '0' && c <= '9') 195 else if (c >= '0' && c <= '9')
193 return c - '0'; 196 return c - '0';
194 else 197 else
195 return -1; 198 return -1;
196} 199}
197 200
198void cgit_diff_tree_cb(struct diff_queue_struct *q, 201void cgit_diff_tree_cb(struct diff_queue_struct *q,
199 struct diff_options *options, void *data) 202 struct diff_options *options, void *data)
200{ 203{
201 int i; 204 int i;
202 205
203 for (i = 0; i < q->nr; i++) { 206 for (i = 0; i < q->nr; i++) {
204 if (q->queue[i]->status == 'U') 207 if (q->queue[i]->status == 'U')
205 continue; 208 continue;
206 ((filepair_fn)data)(q->queue[i]); 209 ((filepair_fn)data)(q->queue[i]);
207 } 210 }
208} 211}
209 212
210static int load_mmfile(mmfile_t *file, const unsigned char *sha1) 213static int load_mmfile(mmfile_t *file, const unsigned char *sha1)
211{ 214{
212 enum object_type type; 215 enum object_type type;
213 216
214 if (is_null_sha1(sha1)) { 217 if (is_null_sha1(sha1)) {
215 file->ptr = (char *)""; 218 file->ptr = (char *)"";
216 file->size = 0; 219 file->size = 0;
217 } else { 220 } else {
218 file->ptr = read_sha1_file(sha1, &type, &file->size); 221 file->ptr = read_sha1_file(sha1, &type, &file->size);