|
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 | |
76 | struct repolist { |
76 | struct 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 | |
82 | struct commitinfo { |
82 | struct 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 | |
94 | struct taginfo { |
94 | struct 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 | |
| |
101 | struct refinfo { |
| |
102 | const char *refname; |
| |
103 | struct object *object; |
| |
104 | union { |
| |
105 | struct taginfo *tag; |
| |
106 | struct commitinfo *commit; |
| |
107 | }; |
| |
108 | }; |
| |
109 | |
| |
110 | struct reflist { |
| |
111 | struct refinfo **refs; |
| |
112 | int alloc; |
| |
113 | int count; |
| |
114 | }; |
| |
115 | |
101 | extern const char *cgit_version; |
116 | extern const char *cgit_version; |
102 | |
117 | |
103 | extern struct repolist cgit_repolist; |
118 | extern struct repolist cgit_repolist; |
104 | extern struct repoinfo *cgit_repo; |
119 | extern struct repoinfo *cgit_repo; |
105 | extern int cgit_cmd; |
120 | extern int cgit_cmd; |
106 | |
121 | |
107 | extern char *cgit_root_title; |
122 | extern char *cgit_root_title; |
108 | extern char *cgit_css; |
123 | extern char *cgit_css; |
109 | extern char *cgit_logo; |
124 | extern char *cgit_logo; |
110 | extern char *cgit_index_header; |
125 | extern char *cgit_index_header; |
111 | extern char *cgit_logo_link; |
126 | extern char *cgit_logo_link; |
112 | extern char *cgit_module_link; |
127 | extern char *cgit_module_link; |
113 | extern char *cgit_agefile; |
128 | extern char *cgit_agefile; |
114 | extern char *cgit_virtual_root; |
129 | extern char *cgit_virtual_root; |
115 | extern char *cgit_script_name; |
130 | extern char *cgit_script_name; |
116 | extern char *cgit_cache_root; |
131 | extern char *cgit_cache_root; |
117 | extern char *cgit_repo_group; |
132 | extern char *cgit_repo_group; |
118 | |
133 | |
119 | extern int cgit_nocache; |
134 | extern int cgit_nocache; |
120 | extern int cgit_snapshots; |
135 | extern int cgit_snapshots; |
121 | extern int cgit_enable_index_links; |
136 | extern int cgit_enable_index_links; |
122 | extern int cgit_enable_log_filecount; |
137 | extern int cgit_enable_log_filecount; |
123 | extern int cgit_enable_log_linecount; |
138 | extern int cgit_enable_log_linecount; |
124 | extern int cgit_max_lock_attempts; |
139 | extern int cgit_max_lock_attempts; |
125 | extern int cgit_cache_root_ttl; |
140 | extern int cgit_cache_root_ttl; |
126 | extern int cgit_cache_repo_ttl; |
141 | extern int cgit_cache_repo_ttl; |
127 | extern int cgit_cache_dynamic_ttl; |
142 | extern int cgit_cache_dynamic_ttl; |
128 | extern int cgit_cache_static_ttl; |
143 | extern int cgit_cache_static_ttl; |
129 | extern int cgit_cache_max_create_time; |
144 | extern int cgit_cache_max_create_time; |
130 | extern int cgit_summary_log; |
145 | extern int cgit_summary_log; |
131 | |
146 | |
132 | extern int cgit_max_msg_len; |
147 | extern int cgit_max_msg_len; |
133 | extern int cgit_max_repodesc_len; |
148 | extern int cgit_max_repodesc_len; |
134 | extern int cgit_max_commit_count; |
149 | extern int cgit_max_commit_count; |
135 | |
150 | |
136 | extern int cgit_query_has_symref; |
151 | extern int cgit_query_has_symref; |
137 | extern int cgit_query_has_sha1; |
152 | extern int cgit_query_has_sha1; |
138 | |
153 | |
139 | extern char *cgit_querystring; |
154 | extern char *cgit_querystring; |
140 | extern char *cgit_query_repo; |
155 | extern char *cgit_query_repo; |
141 | extern char *cgit_query_page; |
156 | extern char *cgit_query_page; |
142 | extern char *cgit_query_search; |
157 | extern char *cgit_query_search; |
143 | extern char *cgit_query_head; |
158 | extern char *cgit_query_head; |
144 | extern char *cgit_query_sha1; |
159 | extern char *cgit_query_sha1; |
145 | extern char *cgit_query_sha2; |
160 | extern char *cgit_query_sha2; |
146 | extern char *cgit_query_path; |
161 | extern char *cgit_query_path; |
147 | extern char *cgit_query_name; |
162 | extern char *cgit_query_name; |
148 | extern int cgit_query_ofs; |
163 | extern int cgit_query_ofs; |
149 | |
164 | |
150 | extern int htmlfd; |
165 | extern int htmlfd; |
151 | |
166 | |
152 | extern int cgit_get_cmd_index(const char *cmd); |
167 | extern int cgit_get_cmd_index(const char *cmd); |
153 | extern struct repoinfo *cgit_get_repoinfo(const char *url); |
168 | extern struct repoinfo *cgit_get_repoinfo(const char *url); |
154 | extern void cgit_global_config_cb(const char *name, const char *value); |
169 | extern void cgit_global_config_cb(const char *name, const char *value); |
155 | extern void cgit_repo_config_cb(const char *name, const char *value); |
170 | extern void cgit_repo_config_cb(const char *name, const char *value); |
156 | extern void cgit_querystring_cb(const char *name, const char *value); |
171 | extern void cgit_querystring_cb(const char *name, const char *value); |
157 | |
172 | |
158 | extern int chk_zero(int result, char *msg); |
173 | extern int chk_zero(int result, char *msg); |
159 | extern int chk_positive(int result, char *msg); |
174 | extern int chk_positive(int result, char *msg); |
160 | extern int chk_non_negative(int result, char *msg); |
175 | extern int chk_non_negative(int result, char *msg); |
161 | |
176 | |
162 | extern int hextoint(char c); |
177 | extern int hextoint(char c); |
163 | extern char *trim_end(const char *str, char c); |
178 | extern char *trim_end(const char *str, char c); |
164 | |
179 | |
| |
180 | extern void cgit_add_ref(struct reflist *list, struct refinfo *ref); |
| |
181 | extern int cgit_refs_cb(const char *refname, const unsigned char *sha1, |
| |
182 | int flags, void *cb_data); |
| |
183 | |
165 | extern void *cgit_free_commitinfo(struct commitinfo *info); |
184 | extern void *cgit_free_commitinfo(struct commitinfo *info); |
166 | |
185 | |
167 | extern int cgit_diff_files(const unsigned char *old_sha1, |
186 | extern 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 | |
171 | extern void cgit_diff_tree(const unsigned char *old_sha1, |
190 | extern 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 | |
175 | extern void cgit_diff_commit(struct commit *commit, filepair_fn fn); |
194 | extern void cgit_diff_commit(struct commit *commit, filepair_fn fn); |
176 | |
195 | |
177 | extern char *fmt(const char *format,...); |
196 | extern char *fmt(const char *format,...); |
178 | |
197 | |
179 | extern void html(const char *txt); |
198 | extern void html(const char *txt); |
180 | extern void htmlf(const char *format,...); |
199 | extern void htmlf(const char *format,...); |
181 | extern void html_txt(char *txt); |
200 | extern void html_txt(char *txt); |
182 | extern void html_ntxt(int len, char *txt); |
201 | extern void html_ntxt(int len, char *txt); |
183 | extern void html_attr(char *txt); |
202 | extern void html_attr(char *txt); |
184 | extern void html_hidden(char *name, char *value); |
203 | extern void html_hidden(char *name, char *value); |
185 | extern void html_link_open(char *url, char *title, char *class); |
204 | extern void html_link_open(char *url, char *title, char *class); |
186 | extern void html_link_close(void); |
205 | extern void html_link_close(void); |
187 | extern void html_filemode(unsigned short mode); |
206 | extern void html_filemode(unsigned short mode); |
188 | extern int html_include(const char *filename); |
207 | extern int html_include(const char *filename); |
189 | |
208 | |
190 | extern int cgit_read_config(const char *filename, configfn fn); |
209 | extern int cgit_read_config(const char *filename, configfn fn); |
191 | extern int cgit_parse_query(char *txt, configfn fn); |
210 | extern int cgit_parse_query(char *txt, configfn fn); |
192 | extern struct commitinfo *cgit_parse_commit(struct commit *commit); |
211 | extern struct commitinfo *cgit_parse_commit(struct commit *commit); |
193 | extern struct taginfo *cgit_parse_tag(struct tag *tag); |
212 | extern struct taginfo *cgit_parse_tag(struct tag *tag); |
194 | extern void cgit_parse_url(const char *url); |
213 | extern void cgit_parse_url(const char *url); |
195 | |
214 | |
196 | extern char *cache_safe_filename(const char *unsafe); |
215 | extern 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 | |
272 | char *trim_end(const char *str, char c) |
272 | char *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 | |
| |
294 | void 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 | |
| |
306 | struct 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 | |
| |
324 | int 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 | |
294 | void cgit_diff_tree_cb(struct diff_queue_struct *q, |
335 | void 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 | |
306 | static int load_mmfile(mmfile_t *file, const unsigned char *sha1) |
347 | static 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 |
|