summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.h19
-rw-r--r--shared.c41
2 files changed, 60 insertions, 0 deletions
diff --git a/cgit.h b/cgit.h
index e96311f..75e919b 100644
--- a/cgit.h
+++ b/cgit.h
@@ -69,128 +69,147 @@ struct repoinfo {
69 char *module_link; 69 char *module_link;
70 char *readme; 70 char *readme;
71 int snapshots; 71 int snapshots;
72 int enable_log_filecount; 72 int enable_log_filecount;
73 int enable_log_linecount; 73 int enable_log_linecount;
74}; 74};
75 75
76struct repolist { 76struct repolist {
77 int length; 77 int length;
78 int count; 78 int count;
79 struct repoinfo *repos; 79 struct repoinfo *repos;
80}; 80};
81 81
82struct commitinfo { 82struct commitinfo {
83 struct commit *commit; 83 struct commit *commit;
84 char *author; 84 char *author;
85 char *author_email; 85 char *author_email;
86 unsigned long author_date; 86 unsigned long author_date;
87 char *committer; 87 char *committer;
88 char *committer_email; 88 char *committer_email;
89 unsigned long committer_date; 89 unsigned long committer_date;
90 char *subject; 90 char *subject;
91 char *msg; 91 char *msg;
92}; 92};
93 93
94struct taginfo { 94struct taginfo {
95 char *tagger; 95 char *tagger;
96 char *tagger_email; 96 char *tagger_email;
97 int tagger_date; 97 int tagger_date;
98 char *msg; 98 char *msg;
99}; 99};
100 100
101struct refinfo {
102 const char *refname;
103 struct object *object;
104 union {
105 struct taginfo *tag;
106 struct commitinfo *commit;
107 };
108};
109
110struct reflist {
111 struct refinfo **refs;
112 int alloc;
113 int count;
114};
115
101extern const char *cgit_version; 116extern const char *cgit_version;
102 117
103extern struct repolist cgit_repolist; 118extern struct repolist cgit_repolist;
104extern struct repoinfo *cgit_repo; 119extern struct repoinfo *cgit_repo;
105extern int cgit_cmd; 120extern int cgit_cmd;
106 121
107extern char *cgit_root_title; 122extern char *cgit_root_title;
108extern char *cgit_css; 123extern char *cgit_css;
109extern char *cgit_logo; 124extern char *cgit_logo;
110extern char *cgit_index_header; 125extern char *cgit_index_header;
111extern char *cgit_logo_link; 126extern char *cgit_logo_link;
112extern char *cgit_module_link; 127extern char *cgit_module_link;
113extern char *cgit_agefile; 128extern char *cgit_agefile;
114extern char *cgit_virtual_root; 129extern char *cgit_virtual_root;
115extern char *cgit_script_name; 130extern char *cgit_script_name;
116extern char *cgit_cache_root; 131extern char *cgit_cache_root;
117extern char *cgit_repo_group; 132extern char *cgit_repo_group;
118 133
119extern int cgit_nocache; 134extern int cgit_nocache;
120extern int cgit_snapshots; 135extern int cgit_snapshots;
121extern int cgit_enable_index_links; 136extern int cgit_enable_index_links;
122extern int cgit_enable_log_filecount; 137extern int cgit_enable_log_filecount;
123extern int cgit_enable_log_linecount; 138extern int cgit_enable_log_linecount;
124extern int cgit_max_lock_attempts; 139extern int cgit_max_lock_attempts;
125extern int cgit_cache_root_ttl; 140extern int cgit_cache_root_ttl;
126extern int cgit_cache_repo_ttl; 141extern int cgit_cache_repo_ttl;
127extern int cgit_cache_dynamic_ttl; 142extern int cgit_cache_dynamic_ttl;
128extern int cgit_cache_static_ttl; 143extern int cgit_cache_static_ttl;
129extern int cgit_cache_max_create_time; 144extern int cgit_cache_max_create_time;
130extern int cgit_summary_log; 145extern int cgit_summary_log;
131 146
132extern int cgit_max_msg_len; 147extern int cgit_max_msg_len;
133extern int cgit_max_repodesc_len; 148extern int cgit_max_repodesc_len;
134extern int cgit_max_commit_count; 149extern int cgit_max_commit_count;
135 150
136extern int cgit_query_has_symref; 151extern int cgit_query_has_symref;
137extern int cgit_query_has_sha1; 152extern int cgit_query_has_sha1;
138 153
139extern char *cgit_querystring; 154extern char *cgit_querystring;
140extern char *cgit_query_repo; 155extern char *cgit_query_repo;
141extern char *cgit_query_page; 156extern char *cgit_query_page;
142extern char *cgit_query_search; 157extern char *cgit_query_search;
143extern char *cgit_query_head; 158extern char *cgit_query_head;
144extern char *cgit_query_sha1; 159extern char *cgit_query_sha1;
145extern char *cgit_query_sha2; 160extern char *cgit_query_sha2;
146extern char *cgit_query_path; 161extern char *cgit_query_path;
147extern char *cgit_query_name; 162extern char *cgit_query_name;
148extern int cgit_query_ofs; 163extern int cgit_query_ofs;
149 164
150extern int htmlfd; 165extern int htmlfd;
151 166
152extern int cgit_get_cmd_index(const char *cmd); 167extern int cgit_get_cmd_index(const char *cmd);
153extern struct repoinfo *cgit_get_repoinfo(const char *url); 168extern struct repoinfo *cgit_get_repoinfo(const char *url);
154extern void cgit_global_config_cb(const char *name, const char *value); 169extern void cgit_global_config_cb(const char *name, const char *value);
155extern void cgit_repo_config_cb(const char *name, const char *value); 170extern void cgit_repo_config_cb(const char *name, const char *value);
156extern void cgit_querystring_cb(const char *name, const char *value); 171extern void cgit_querystring_cb(const char *name, const char *value);
157 172
158extern int chk_zero(int result, char *msg); 173extern int chk_zero(int result, char *msg);
159extern int chk_positive(int result, char *msg); 174extern int chk_positive(int result, char *msg);
160extern int chk_non_negative(int result, char *msg); 175extern int chk_non_negative(int result, char *msg);
161 176
162extern int hextoint(char c); 177extern int hextoint(char c);
163extern char *trim_end(const char *str, char c); 178extern char *trim_end(const char *str, char c);
164 179
180extern void cgit_add_ref(struct reflist *list, struct refinfo *ref);
181extern int cgit_refs_cb(const char *refname, const unsigned char *sha1,
182 int flags, void *cb_data);
183
165extern void *cgit_free_commitinfo(struct commitinfo *info); 184extern void *cgit_free_commitinfo(struct commitinfo *info);
166 185
167extern int cgit_diff_files(const unsigned char *old_sha1, 186extern int cgit_diff_files(const unsigned char *old_sha1,
168 const unsigned char *new_sha1, 187 const unsigned char *new_sha1,
169 linediff_fn fn); 188 linediff_fn fn);
170 189
171extern void cgit_diff_tree(const unsigned char *old_sha1, 190extern void cgit_diff_tree(const unsigned char *old_sha1,
172 const unsigned char *new_sha1, 191 const unsigned char *new_sha1,
173 filepair_fn fn, const char *prefix); 192 filepair_fn fn, const char *prefix);
174 193
175extern void cgit_diff_commit(struct commit *commit, filepair_fn fn); 194extern void cgit_diff_commit(struct commit *commit, filepair_fn fn);
176 195
177extern char *fmt(const char *format,...); 196extern char *fmt(const char *format,...);
178 197
179extern void html(const char *txt); 198extern void html(const char *txt);
180extern void htmlf(const char *format,...); 199extern void htmlf(const char *format,...);
181extern void html_txt(char *txt); 200extern void html_txt(char *txt);
182extern void html_ntxt(int len, char *txt); 201extern void html_ntxt(int len, char *txt);
183extern void html_attr(char *txt); 202extern void html_attr(char *txt);
184extern void html_hidden(char *name, char *value); 203extern void html_hidden(char *name, char *value);
185extern void html_link_open(char *url, char *title, char *class); 204extern void html_link_open(char *url, char *title, char *class);
186extern void html_link_close(void); 205extern void html_link_close(void);
187extern void html_filemode(unsigned short mode); 206extern void html_filemode(unsigned short mode);
188extern int html_include(const char *filename); 207extern int html_include(const char *filename);
189 208
190extern int cgit_read_config(const char *filename, configfn fn); 209extern int cgit_read_config(const char *filename, configfn fn);
191extern int cgit_parse_query(char *txt, configfn fn); 210extern int cgit_parse_query(char *txt, configfn fn);
192extern struct commitinfo *cgit_parse_commit(struct commit *commit); 211extern struct commitinfo *cgit_parse_commit(struct commit *commit);
193extern struct taginfo *cgit_parse_tag(struct tag *tag); 212extern struct taginfo *cgit_parse_tag(struct tag *tag);
194extern void cgit_parse_url(const char *url); 213extern void cgit_parse_url(const char *url);
195 214
196extern char *cache_safe_filename(const char *unsafe); 215extern char *cache_safe_filename(const char *unsafe);
diff --git a/shared.c b/shared.c
index 3d4feea..d815cb1 100644
--- a/shared.c
+++ b/shared.c
@@ -262,64 +262,105 @@ int hextoint(char c)
262 if (c >= 'a' && c <= 'f') 262 if (c >= 'a' && c <= 'f')
263 return 10 + c - 'a'; 263 return 10 + c - 'a';
264 else if (c >= 'A' && c <= 'F') 264 else if (c >= 'A' && c <= 'F')
265 return 10 + c - 'A'; 265 return 10 + c - 'A';
266 else if (c >= '0' && c <= '9') 266 else if (c >= '0' && c <= '9')
267 return c - '0'; 267 return c - '0';
268 else 268 else
269 return -1; 269 return -1;
270} 270}
271 271
272char *trim_end(const char *str, char c) 272char *trim_end(const char *str, char c)
273{ 273{
274 int len; 274 int len;
275 char *s, *t; 275 char *s, *t;
276 276
277 if (str == NULL) 277 if (str == NULL)
278 return NULL; 278 return NULL;
279 t = (char *)str; 279 t = (char *)str;
280 len = strlen(t); 280 len = strlen(t);
281 while(len > 0 && t[len - 1] == c) 281 while(len > 0 && t[len - 1] == c)
282 len--; 282 len--;
283 283
284 if (len == 0) 284 if (len == 0)
285 return NULL; 285 return NULL;
286 286
287 c = t[len]; 287 c = t[len];
288 t[len] = '\0'; 288 t[len] = '\0';
289 s = xstrdup(t); 289 s = xstrdup(t);
290 t[len] = c; 290 t[len] = c;
291 return s; 291 return s;
292} 292}
293 293
294void cgit_add_ref(struct reflist *list, struct refinfo *ref)
295{
296 size_t size;
297
298 if (list->count >= list->alloc) {
299 list->alloc += (list->alloc ? list->alloc : 4);
300 size = list->alloc * sizeof(struct refinfo *);
301 list->refs = xrealloc(list->refs, size);
302 }
303 list->refs[list->count++] = ref;
304}
305
306struct refinfo *cgit_mk_refinfo(const char *refname, const unsigned char *sha1)
307{
308 struct refinfo *ref;
309
310 ref = xmalloc(sizeof (struct refinfo));
311 ref->refname = xstrdup(refname);
312 ref->object = parse_object(sha1);
313 switch (ref->object->type) {
314 case OBJ_TAG:
315 ref->tag = cgit_parse_tag((struct tag *)ref->object);
316 break;
317 case OBJ_COMMIT:
318 ref->commit = cgit_parse_commit((struct commit *)ref->object);
319 break;
320 }
321 return ref;
322}
323
324int cgit_refs_cb(const char *refname, const unsigned char *sha1, int flags,
325 void *cb_data)
326{
327 struct reflist *list = (struct reflist *)cb_data;
328 struct refinfo *info = cgit_mk_refinfo(refname, sha1);
329
330 if (info)
331 cgit_add_ref(list, info);
332 return 0;
333}
334
294void cgit_diff_tree_cb(struct diff_queue_struct *q, 335void cgit_diff_tree_cb(struct diff_queue_struct *q,
295 struct diff_options *options, void *data) 336 struct diff_options *options, void *data)
296{ 337{
297 int i; 338 int i;
298 339
299 for (i = 0; i < q->nr; i++) { 340 for (i = 0; i < q->nr; i++) {
300 if (q->queue[i]->status == 'U') 341 if (q->queue[i]->status == 'U')
301 continue; 342 continue;
302 ((filepair_fn)data)(q->queue[i]); 343 ((filepair_fn)data)(q->queue[i]);
303 } 344 }
304} 345}
305 346
306static int load_mmfile(mmfile_t *file, const unsigned char *sha1) 347static int load_mmfile(mmfile_t *file, const unsigned char *sha1)
307{ 348{
308 enum object_type type; 349 enum object_type type;
309 350
310 if (is_null_sha1(sha1)) { 351 if (is_null_sha1(sha1)) {
311 file->ptr = (char *)""; 352 file->ptr = (char *)"";
312 file->size = 0; 353 file->size = 0;
313 } else { 354 } else {
314 file->ptr = read_sha1_file(sha1, &type, 355 file->ptr = read_sha1_file(sha1, &type,
315 (unsigned long *)&file->size); 356 (unsigned long *)&file->size);
316 } 357 }
317 return 1; 358 return 1;
318} 359}
319 360
320/* 361/*
321 * Receive diff-buffers from xdiff and concatenate them as 362 * Receive diff-buffers from xdiff and concatenate them as
322 * needed across multiple callbacks. 363 * needed across multiple callbacks.
323 * 364 *
324 * This is basically a copy of xdiff-interface.c/xdiff_outf(), 365 * This is basically a copy of xdiff-interface.c/xdiff_outf(),
325 * ripped from git and modified to use globals instead of 366 * ripped from git and modified to use globals instead of