|
diff --git a/cgit.c b/cgit.c index 9305d0a..ed2be64 100644 --- a/ cgit.c+++ b/ cgit.c |
|
@@ -229,48 +229,50 @@ static void querystring_cb(const char *name, const char *value) |
229 | ctx.qry.head = xstrdup(value); |
229 | ctx.qry.head = xstrdup(value); |
230 | ctx.qry.has_symref = 1; |
230 | ctx.qry.has_symref = 1; |
231 | } else if (!strcmp(name, "id")) { |
231 | } else if (!strcmp(name, "id")) { |
232 | ctx.qry.sha1 = xstrdup(value); |
232 | ctx.qry.sha1 = xstrdup(value); |
233 | ctx.qry.has_sha1 = 1; |
233 | ctx.qry.has_sha1 = 1; |
234 | } else if (!strcmp(name, "id2")) { |
234 | } else if (!strcmp(name, "id2")) { |
235 | ctx.qry.sha2 = xstrdup(value); |
235 | ctx.qry.sha2 = xstrdup(value); |
236 | ctx.qry.has_sha1 = 1; |
236 | ctx.qry.has_sha1 = 1; |
237 | } else if (!strcmp(name, "ofs")) { |
237 | } else if (!strcmp(name, "ofs")) { |
238 | ctx.qry.ofs = atoi(value); |
238 | ctx.qry.ofs = atoi(value); |
239 | } else if (!strcmp(name, "path")) { |
239 | } else if (!strcmp(name, "path")) { |
240 | ctx.qry.path = trim_end(value, '/'); |
240 | ctx.qry.path = trim_end(value, '/'); |
241 | } else if (!strcmp(name, "name")) { |
241 | } else if (!strcmp(name, "name")) { |
242 | ctx.qry.name = xstrdup(value); |
242 | ctx.qry.name = xstrdup(value); |
243 | } else if (!strcmp(name, "mimetype")) { |
243 | } else if (!strcmp(name, "mimetype")) { |
244 | ctx.qry.mimetype = xstrdup(value); |
244 | ctx.qry.mimetype = xstrdup(value); |
245 | } else if (!strcmp(name, "s")){ |
245 | } else if (!strcmp(name, "s")){ |
246 | ctx.qry.sort = xstrdup(value); |
246 | ctx.qry.sort = xstrdup(value); |
247 | } else if (!strcmp(name, "showmsg")) { |
247 | } else if (!strcmp(name, "showmsg")) { |
248 | ctx.qry.showmsg = atoi(value); |
248 | ctx.qry.showmsg = atoi(value); |
249 | } else if (!strcmp(name, "period")) { |
249 | } else if (!strcmp(name, "period")) { |
250 | ctx.qry.period = xstrdup(value); |
250 | ctx.qry.period = xstrdup(value); |
251 | } else if (!strcmp(name, "ss")) { |
251 | } else if (!strcmp(name, "ss")) { |
252 | ctx.qry.ssdiff = atoi(value); |
252 | ctx.qry.ssdiff = atoi(value); |
| |
253 | } else if (!strcmp(name, "all")) { |
| |
254 | ctx.qry.show_all = atoi(value); |
253 | } |
255 | } |
254 | } |
256 | } |
255 | |
257 | |
256 | char *xstrdupn(const char *str) |
258 | char *xstrdupn(const char *str) |
257 | { |
259 | { |
258 | return (str ? xstrdup(str) : NULL); |
260 | return (str ? xstrdup(str) : NULL); |
259 | } |
261 | } |
260 | |
262 | |
261 | static void prepare_context(struct cgit_context *ctx) |
263 | static void prepare_context(struct cgit_context *ctx) |
262 | { |
264 | { |
263 | memset(ctx, 0, sizeof(*ctx)); |
265 | memset(ctx, 0, sizeof(*ctx)); |
264 | ctx->cfg.agefile = "info/web/last-modified"; |
266 | ctx->cfg.agefile = "info/web/last-modified"; |
265 | ctx->cfg.nocache = 0; |
267 | ctx->cfg.nocache = 0; |
266 | ctx->cfg.cache_size = 0; |
268 | ctx->cfg.cache_size = 0; |
267 | ctx->cfg.cache_dynamic_ttl = 5; |
269 | ctx->cfg.cache_dynamic_ttl = 5; |
268 | ctx->cfg.cache_max_create_time = 5; |
270 | ctx->cfg.cache_max_create_time = 5; |
269 | ctx->cfg.cache_repo_ttl = 5; |
271 | ctx->cfg.cache_repo_ttl = 5; |
270 | ctx->cfg.cache_root = CGIT_CACHE_ROOT; |
272 | ctx->cfg.cache_root = CGIT_CACHE_ROOT; |
271 | ctx->cfg.cache_root_ttl = 5; |
273 | ctx->cfg.cache_root_ttl = 5; |
272 | ctx->cfg.cache_scanrc_ttl = 15; |
274 | ctx->cfg.cache_scanrc_ttl = 15; |
273 | ctx->cfg.cache_static_ttl = -1; |
275 | ctx->cfg.cache_static_ttl = -1; |
274 | ctx->cfg.css = "/cgit.css"; |
276 | ctx->cfg.css = "/cgit.css"; |
275 | ctx->cfg.logo = "/cgit.png"; |
277 | ctx->cfg.logo = "/cgit.png"; |
276 | ctx->cfg.local_time = 0; |
278 | ctx->cfg.local_time = 0; |
|
|
diff --git a/cgit.h b/cgit.h index cd4af72..478aebb 100644 --- a/ cgit.h+++ b/ cgit.h |
|
@@ -124,48 +124,49 @@ struct reflist { |
124 | int count; |
124 | int count; |
125 | }; |
125 | }; |
126 | |
126 | |
127 | struct cgit_query { |
127 | struct cgit_query { |
128 | int has_symref; |
128 | int has_symref; |
129 | int has_sha1; |
129 | int has_sha1; |
130 | char *raw; |
130 | char *raw; |
131 | char *repo; |
131 | char *repo; |
132 | char *page; |
132 | char *page; |
133 | char *search; |
133 | char *search; |
134 | char *grep; |
134 | char *grep; |
135 | char *head; |
135 | char *head; |
136 | char *sha1; |
136 | char *sha1; |
137 | char *sha2; |
137 | char *sha2; |
138 | char *path; |
138 | char *path; |
139 | char *name; |
139 | char *name; |
140 | char *mimetype; |
140 | char *mimetype; |
141 | char *url; |
141 | char *url; |
142 | char *period; |
142 | char *period; |
143 | int ofs; |
143 | int ofs; |
144 | int nohead; |
144 | int nohead; |
145 | char *sort; |
145 | char *sort; |
146 | int showmsg; |
146 | int showmsg; |
147 | int ssdiff; |
147 | int ssdiff; |
| |
148 | int show_all; |
148 | }; |
149 | }; |
149 | |
150 | |
150 | struct cgit_config { |
151 | struct cgit_config { |
151 | char *agefile; |
152 | char *agefile; |
152 | char *cache_root; |
153 | char *cache_root; |
153 | char *clone_prefix; |
154 | char *clone_prefix; |
154 | char *css; |
155 | char *css; |
155 | char *favicon; |
156 | char *favicon; |
156 | char *footer; |
157 | char *footer; |
157 | char *head_include; |
158 | char *head_include; |
158 | char *header; |
159 | char *header; |
159 | char *index_header; |
160 | char *index_header; |
160 | char *index_info; |
161 | char *index_info; |
161 | char *logo; |
162 | char *logo; |
162 | char *logo_link; |
163 | char *logo_link; |
163 | char *module_link; |
164 | char *module_link; |
164 | char *robots; |
165 | char *robots; |
165 | char *root_title; |
166 | char *root_title; |
166 | char *root_desc; |
167 | char *root_desc; |
167 | char *root_readme; |
168 | char *root_readme; |
168 | char *script_name; |
169 | char *script_name; |
169 | char *section; |
170 | char *section; |
170 | char *virtual_root; |
171 | char *virtual_root; |
171 | int cache_size; |
172 | int cache_size; |
|
|
diff --git a/ui-atom.c b/ui-atom.c index 808b2d0..9f049ae 100644 --- a/ ui-atom.c+++ b/ ui-atom.c |
|
@@ -64,49 +64,51 @@ void add_entry(struct commit *commit, char *host) |
64 | htmlf("<id>%s</id>\n", hex); |
64 | htmlf("<id>%s</id>\n", hex); |
65 | html("<content type='text'>\n"); |
65 | html("<content type='text'>\n"); |
66 | html_txt(info->msg); |
66 | html_txt(info->msg); |
67 | html("</content>\n"); |
67 | html("</content>\n"); |
68 | html("<content type='xhtml'>\n"); |
68 | html("<content type='xhtml'>\n"); |
69 | html("<div xmlns='http://www.w3.org/1999/xhtml'>\n"); |
69 | html("<div xmlns='http://www.w3.org/1999/xhtml'>\n"); |
70 | html("<pre>\n"); |
70 | html("<pre>\n"); |
71 | html_txt(info->msg); |
71 | html_txt(info->msg); |
72 | html("</pre>\n"); |
72 | html("</pre>\n"); |
73 | html("</div>\n"); |
73 | html("</div>\n"); |
74 | html("</content>\n"); |
74 | html("</content>\n"); |
75 | html("</entry>\n"); |
75 | html("</entry>\n"); |
76 | cgit_free_commitinfo(info); |
76 | cgit_free_commitinfo(info); |
77 | } |
77 | } |
78 | |
78 | |
79 | |
79 | |
80 | void cgit_print_atom(char *tip, char *path, int max_count) |
80 | void cgit_print_atom(char *tip, char *path, int max_count) |
81 | { |
81 | { |
82 | char *host; |
82 | char *host; |
83 | const char *argv[] = {NULL, tip, NULL, NULL, NULL}; |
83 | const char *argv[] = {NULL, tip, NULL, NULL, NULL}; |
84 | struct commit *commit; |
84 | struct commit *commit; |
85 | struct rev_info rev; |
85 | struct rev_info rev; |
86 | int argc = 2; |
86 | int argc = 2; |
87 | |
87 | |
88 | if (!tip) |
88 | if (ctx.qry.show_all) |
| |
89 | argv[1] = "--all"; |
| |
90 | else if (!tip) |
89 | argv[1] = ctx.qry.head; |
91 | argv[1] = ctx.qry.head; |
90 | |
92 | |
91 | if (path) { |
93 | if (path) { |
92 | argv[argc++] = "--"; |
94 | argv[argc++] = "--"; |
93 | argv[argc++] = path; |
95 | argv[argc++] = path; |
94 | } |
96 | } |
95 | |
97 | |
96 | init_revisions(&rev, NULL); |
98 | init_revisions(&rev, NULL); |
97 | rev.abbrev = DEFAULT_ABBREV; |
99 | rev.abbrev = DEFAULT_ABBREV; |
98 | rev.commit_format = CMIT_FMT_DEFAULT; |
100 | rev.commit_format = CMIT_FMT_DEFAULT; |
99 | rev.verbose_header = 1; |
101 | rev.verbose_header = 1; |
100 | rev.show_root_diff = 0; |
102 | rev.show_root_diff = 0; |
101 | rev.max_count = max_count; |
103 | rev.max_count = max_count; |
102 | setup_revisions(argc, argv, &rev, NULL); |
104 | setup_revisions(argc, argv, &rev, NULL); |
103 | prepare_revision_walk(&rev); |
105 | prepare_revision_walk(&rev); |
104 | |
106 | |
105 | host = cgit_hosturl(); |
107 | host = cgit_hosturl(); |
106 | ctx.page.mimetype = "text/xml"; |
108 | ctx.page.mimetype = "text/xml"; |
107 | ctx.page.charset = "utf-8"; |
109 | ctx.page.charset = "utf-8"; |
108 | cgit_print_http_headers(&ctx); |
110 | cgit_print_http_headers(&ctx); |
109 | html("<feed xmlns='http://www.w3.org/2005/Atom'>\n"); |
111 | html("<feed xmlns='http://www.w3.org/2005/Atom'>\n"); |
110 | html("<title>"); |
112 | html("<title>"); |
111 | html_txt(ctx.repo->name); |
113 | html_txt(ctx.repo->name); |
112 | html("</title>\n"); |
114 | html("</title>\n"); |
|