summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.h7
-rw-r--r--ui-repolist.c8
2 files changed, 11 insertions, 4 deletions
diff --git a/cgit.h b/cgit.h
index ee8c716..a3b6535 100644
--- a/cgit.h
+++ b/cgit.h
@@ -160,65 +160,72 @@ struct cgit_page {
160 char *mimetype; 160 char *mimetype;
161 char *charset; 161 char *charset;
162 char *filename; 162 char *filename;
163 char *title; 163 char *title;
164}; 164};
165 165
166struct cgit_context { 166struct cgit_context {
167 struct cgit_query qry; 167 struct cgit_query qry;
168 struct cgit_config cfg; 168 struct cgit_config cfg;
169 struct cgit_repo *repo; 169 struct cgit_repo *repo;
170 struct cgit_page page; 170 struct cgit_page page;
171}; 171};
172 172
173struct cgit_snapshot_format { 173struct cgit_snapshot_format {
174 const char *suffix; 174 const char *suffix;
175 const char *mimetype; 175 const char *mimetype;
176 write_archive_fn_t write_func; 176 write_archive_fn_t write_func;
177 int bit; 177 int bit;
178}; 178};
179 179
180extern const char *cgit_version; 180extern const char *cgit_version;
181 181
182extern struct cgit_repolist cgit_repolist; 182extern struct cgit_repolist cgit_repolist;
183extern struct cgit_context ctx; 183extern struct cgit_context ctx;
184extern const struct cgit_snapshot_format cgit_snapshot_formats[]; 184extern const struct cgit_snapshot_format cgit_snapshot_formats[];
185 185
186extern struct cgit_repo *cgit_add_repo(const char *url); 186extern struct cgit_repo *cgit_add_repo(const char *url);
187extern struct cgit_repo *cgit_get_repoinfo(const char *url); 187extern struct cgit_repo *cgit_get_repoinfo(const char *url);
188extern void cgit_repo_config_cb(const char *name, const char *value); 188extern void cgit_repo_config_cb(const char *name, const char *value);
189 189
190extern int chk_zero(int result, char *msg); 190extern int chk_zero(int result, char *msg);
191extern int chk_positive(int result, char *msg); 191extern int chk_positive(int result, char *msg);
192extern int chk_non_negative(int result, char *msg); 192extern int chk_non_negative(int result, char *msg);
193 193
194extern char *trim_end(const char *str, char c); 194extern char *trim_end(const char *str, char c);
195extern char *strlpart(char *txt, int maxlen); 195extern char *strlpart(char *txt, int maxlen);
196extern char *strrpart(char *txt, int maxlen); 196extern char *strrpart(char *txt, int maxlen);
197 197
198extern void cgit_add_ref(struct reflist *list, struct refinfo *ref); 198extern void cgit_add_ref(struct reflist *list, struct refinfo *ref);
199extern int cgit_refs_cb(const char *refname, const unsigned char *sha1, 199extern int cgit_refs_cb(const char *refname, const unsigned char *sha1,
200 int flags, void *cb_data); 200 int flags, void *cb_data);
201 201
202extern void *cgit_free_commitinfo(struct commitinfo *info); 202extern void *cgit_free_commitinfo(struct commitinfo *info);
203 203
204extern int cgit_diff_files(const unsigned char *old_sha1, 204extern int cgit_diff_files(const unsigned char *old_sha1,
205 const unsigned char *new_sha1, 205 const unsigned char *new_sha1,
206 linediff_fn fn); 206 linediff_fn fn);
207 207
208extern void cgit_diff_tree(const unsigned char *old_sha1, 208extern void cgit_diff_tree(const unsigned char *old_sha1,
209 const unsigned char *new_sha1, 209 const unsigned char *new_sha1,
210 filepair_fn fn, const char *prefix); 210 filepair_fn fn, const char *prefix);
211 211
212extern void cgit_diff_commit(struct commit *commit, filepair_fn fn); 212extern void cgit_diff_commit(struct commit *commit, filepair_fn fn);
213 213
214extern char *fmt(const char *format,...); 214extern char *fmt(const char *format,...);
215 215
216extern struct commitinfo *cgit_parse_commit(struct commit *commit); 216extern struct commitinfo *cgit_parse_commit(struct commit *commit);
217extern struct taginfo *cgit_parse_tag(struct tag *tag); 217extern struct taginfo *cgit_parse_tag(struct tag *tag);
218extern void cgit_parse_url(const char *url); 218extern void cgit_parse_url(const char *url);
219 219
220extern const char *cgit_repobasename(const char *reponame); 220extern const char *cgit_repobasename(const char *reponame);
221 221
222extern int cgit_parse_snapshots_mask(const char *str); 222extern int cgit_parse_snapshots_mask(const char *str);
223 223
224/* libgit.a either links against or compiles its own implementation of
225 * strcasestr(), and we'd like to reuse it. Simply re-declaring it
226 * seems to do the trick.
227 */
228extern char *strcasestr(const char *haystack, const char *needle);
229
230
224#endif /* CGIT_H */ 231#endif /* CGIT_H */
diff --git a/ui-repolist.c b/ui-repolist.c
index a7de453..7a7e95a 100644
--- a/ui-repolist.c
+++ b/ui-repolist.c
@@ -1,121 +1,121 @@
1/* ui-repolist.c: functions for generating the repolist page 1/* ui-repolist.c: functions for generating the repolist page
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 <time.h> 9#include <time.h>
10 10
11#include "cgit.h" 11#include "cgit.h"
12#include "html.h" 12#include "html.h"
13#include "ui-shared.h" 13#include "ui-shared.h"
14 14
15time_t read_agefile(char *path) 15time_t read_agefile(char *path)
16{ 16{
17 FILE *f; 17 FILE *f;
18 static char buf[64], buf2[64]; 18 static char buf[64], buf2[64];
19 19
20 if (!(f = fopen(path, "r"))) 20 if (!(f = fopen(path, "r")))
21 return -1; 21 return -1;
22 fgets(buf, sizeof(buf), f); 22 fgets(buf, sizeof(buf), f);
23 fclose(f); 23 fclose(f);
24 if (parse_date(buf, buf2, sizeof(buf2))) 24 if (parse_date(buf, buf2, sizeof(buf2)))
25 return strtoul(buf2, NULL, 10); 25 return strtoul(buf2, NULL, 10);
26 else 26 else
27 return 0; 27 return 0;
28} 28}
29 29
30static void print_modtime(struct cgit_repo *repo) 30static void print_modtime(struct cgit_repo *repo)
31{ 31{
32 char *path; 32 char *path;
33 struct stat s; 33 struct stat s;
34 34
35 path = fmt("%s/%s", repo->path, ctx.cfg.agefile); 35 path = fmt("%s/%s", repo->path, ctx.cfg.agefile);
36 if (stat(path, &s) == 0) { 36 if (stat(path, &s) == 0) {
37 cgit_print_age(read_agefile(path), -1, NULL); 37 cgit_print_age(read_agefile(path), -1, NULL);
38 return; 38 return;
39 } 39 }
40 40
41 path = fmt("%s/refs/heads/%s", repo->path, repo->defbranch); 41 path = fmt("%s/refs/heads/%s", repo->path, repo->defbranch);
42 if (stat(path, &s) != 0) 42 if (stat(path, &s) != 0)
43 return; 43 return;
44 cgit_print_age(s.st_mtime, -1, NULL); 44 cgit_print_age(s.st_mtime, -1, NULL);
45} 45}
46 46
47int is_match(struct cgit_repo *repo) 47int is_match(struct cgit_repo *repo)
48{ 48{
49 if (!ctx.qry.search) 49 if (!ctx.qry.search)
50 return 1; 50 return 1;
51 if (repo->url && strstr(repo->url, ctx.qry.search)) 51 if (repo->url && strcasestr(repo->url, ctx.qry.search))
52 return 1; 52 return 1;
53 if (repo->name && strstr(repo->name, ctx.qry.search)) 53 if (repo->name && strcasestr(repo->name, ctx.qry.search))
54 return 1; 54 return 1;
55 if (repo->desc && strstr(repo->desc, ctx.qry.search)) 55 if (repo->desc && strcasestr(repo->desc, ctx.qry.search))
56 return 1; 56 return 1;
57 if (repo->owner && strstr(repo->owner, ctx.qry.search)) 57 if (repo->owner && strcasestr(repo->owner, ctx.qry.search))
58 return 1; 58 return 1;
59 return 0; 59 return 0;
60} 60}
61 61
62void print_header(int columns) 62void print_header(int columns)
63{ 63{
64 if (ctx.cfg.index_header) { 64 if (ctx.cfg.index_header) {
65 htmlf("<tr class='nohover'><td colspan='%d' class='include-block'>", 65 htmlf("<tr class='nohover'><td colspan='%d' class='include-block'>",
66 columns); 66 columns);
67 html_include(ctx.cfg.index_header); 67 html_include(ctx.cfg.index_header);
68 html("</td></tr>"); 68 html("</td></tr>");
69 } 69 }
70 html("<tr class='nohover'>" 70 html("<tr class='nohover'>"
71 "<th class='left'>Name</th>" 71 "<th class='left'>Name</th>"
72 "<th class='left'>Description</th>" 72 "<th class='left'>Description</th>"
73 "<th class='left'>Owner</th>" 73 "<th class='left'>Owner</th>"
74 "<th class='left'>Idle</th>"); 74 "<th class='left'>Idle</th>");
75 if (ctx.cfg.enable_index_links) 75 if (ctx.cfg.enable_index_links)
76 html("<th class='left'>Links</th>"); 76 html("<th class='left'>Links</th>");
77 html("</tr>\n"); 77 html("</tr>\n");
78} 78}
79 79
80void cgit_print_repolist() 80void cgit_print_repolist()
81{ 81{
82 int i, columns = 4, hits = 0, header = 0; 82 int i, columns = 4, hits = 0, header = 0;
83 char *last_group = NULL; 83 char *last_group = NULL;
84 84
85 if (ctx.cfg.enable_index_links) 85 if (ctx.cfg.enable_index_links)
86 columns++; 86 columns++;
87 87
88 ctx.page.title = ctx.cfg.root_title; 88 ctx.page.title = ctx.cfg.root_title;
89 cgit_print_http_headers(&ctx); 89 cgit_print_http_headers(&ctx);
90 cgit_print_docstart(&ctx); 90 cgit_print_docstart(&ctx);
91 cgit_print_pageheader(&ctx); 91 cgit_print_pageheader(&ctx);
92 92
93 html("<table summary='repository list' class='list nowrap'>"); 93 html("<table summary='repository list' class='list nowrap'>");
94 for (i=0; i<cgit_repolist.count; i++) { 94 for (i=0; i<cgit_repolist.count; i++) {
95 ctx.repo = &cgit_repolist.repos[i]; 95 ctx.repo = &cgit_repolist.repos[i];
96 if (!is_match(ctx.repo)) 96 if (!is_match(ctx.repo))
97 continue; 97 continue;
98 if (!header++) 98 if (!header++)
99 print_header(columns); 99 print_header(columns);
100 hits++; 100 hits++;
101 if ((last_group == NULL && ctx.repo->group != NULL) || 101 if ((last_group == NULL && ctx.repo->group != NULL) ||
102 (last_group != NULL && ctx.repo->group == NULL) || 102 (last_group != NULL && ctx.repo->group == NULL) ||
103 (last_group != NULL && ctx.repo->group != NULL && 103 (last_group != NULL && ctx.repo->group != NULL &&
104 strcmp(ctx.repo->group, last_group))) { 104 strcmp(ctx.repo->group, last_group))) {
105 htmlf("<tr class='nohover'><td colspan='%d' class='repogroup'>", 105 htmlf("<tr class='nohover'><td colspan='%d' class='repogroup'>",
106 columns); 106 columns);
107 html_txt(ctx.repo->group); 107 html_txt(ctx.repo->group);
108 html("</td></tr>"); 108 html("</td></tr>");
109 last_group = ctx.repo->group; 109 last_group = ctx.repo->group;
110 } 110 }
111 htmlf("<tr><td class='%s'>", 111 htmlf("<tr><td class='%s'>",
112 ctx.repo->group ? "sublevel-repo" : "toplevel-repo"); 112 ctx.repo->group ? "sublevel-repo" : "toplevel-repo");
113 html_link_open(cgit_repourl(ctx.repo->url), NULL, NULL); 113 html_link_open(cgit_repourl(ctx.repo->url), NULL, NULL);
114 html_txt(ctx.repo->name); 114 html_txt(ctx.repo->name);
115 html_link_close(); 115 html_link_close();
116 html("</td><td>"); 116 html("</td><td>");
117 html_ntxt(ctx.cfg.max_repodesc_len, ctx.repo->desc); 117 html_ntxt(ctx.cfg.max_repodesc_len, ctx.repo->desc);
118 html("</td><td>"); 118 html("</td><td>");
119 html_txt(ctx.repo->owner); 119 html_txt(ctx.repo->owner);
120 html("</td><td>"); 120 html("</td><td>");
121 print_modtime(ctx.repo); 121 print_modtime(ctx.repo);