author | Lars Hjemli <hjemli@gmail.com> | 2007-11-11 20:57:21 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2007-11-11 20:57:21 (UTC) |
commit | d267d88c9cb1fb4a45120b86e410ab604626c6bb (patch) (unidiff) | |
tree | 55ee3a76da83a6272e446f5201928fe1753ea30d | |
parent | 1b7c5b2e0b918e9452694aace7c19194683989a8 (diff) | |
download | cgit-d267d88c9cb1fb4a45120b86e410ab604626c6bb.zip cgit-d267d88c9cb1fb4a45120b86e410ab604626c6bb.tar.gz cgit-d267d88c9cb1fb4a45120b86e410ab604626c6bb.tar.bz2 |
Add support for "robots" meta-tag
With this change, cgit will start to generate the "robots" meta-tag, using
a default value of "index, nofollow".
The default value can be modified with a new cgitrc variable, "robots".
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
-rw-r--r-- | cgit.h | 1 | ||||
-rw-r--r-- | cgitrc | 5 | ||||
-rw-r--r-- | shared.c | 3 | ||||
-rw-r--r-- | ui-shared.c | 2 |
4 files changed, 11 insertions, 0 deletions
@@ -118,48 +118,49 @@ struct refinfo { | |||
118 | struct reflist { | 118 | struct reflist { |
119 | struct refinfo **refs; | 119 | struct refinfo **refs; |
120 | int alloc; | 120 | int alloc; |
121 | int count; | 121 | int count; |
122 | }; | 122 | }; |
123 | 123 | ||
124 | extern const char *cgit_version; | 124 | extern const char *cgit_version; |
125 | 125 | ||
126 | extern struct repolist cgit_repolist; | 126 | extern struct repolist cgit_repolist; |
127 | extern struct repoinfo *cgit_repo; | 127 | extern struct repoinfo *cgit_repo; |
128 | extern int cgit_cmd; | 128 | extern int cgit_cmd; |
129 | 129 | ||
130 | extern char *cgit_root_title; | 130 | extern char *cgit_root_title; |
131 | extern char *cgit_css; | 131 | extern char *cgit_css; |
132 | extern char *cgit_logo; | 132 | extern char *cgit_logo; |
133 | extern char *cgit_index_header; | 133 | extern char *cgit_index_header; |
134 | extern char *cgit_index_info; | 134 | extern char *cgit_index_info; |
135 | extern char *cgit_logo_link; | 135 | extern char *cgit_logo_link; |
136 | extern char *cgit_module_link; | 136 | extern char *cgit_module_link; |
137 | extern char *cgit_agefile; | 137 | extern char *cgit_agefile; |
138 | extern char *cgit_virtual_root; | 138 | extern char *cgit_virtual_root; |
139 | extern char *cgit_script_name; | 139 | extern char *cgit_script_name; |
140 | extern char *cgit_cache_root; | 140 | extern char *cgit_cache_root; |
141 | extern char *cgit_repo_group; | 141 | extern char *cgit_repo_group; |
142 | extern char *cgit_robots; | ||
142 | 143 | ||
143 | extern int cgit_nocache; | 144 | extern int cgit_nocache; |
144 | extern int cgit_snapshots; | 145 | extern int cgit_snapshots; |
145 | extern int cgit_enable_index_links; | 146 | extern int cgit_enable_index_links; |
146 | extern int cgit_enable_log_filecount; | 147 | extern int cgit_enable_log_filecount; |
147 | extern int cgit_enable_log_linecount; | 148 | extern int cgit_enable_log_linecount; |
148 | extern int cgit_max_lock_attempts; | 149 | extern int cgit_max_lock_attempts; |
149 | extern int cgit_cache_root_ttl; | 150 | extern int cgit_cache_root_ttl; |
150 | extern int cgit_cache_repo_ttl; | 151 | extern int cgit_cache_repo_ttl; |
151 | extern int cgit_cache_dynamic_ttl; | 152 | extern int cgit_cache_dynamic_ttl; |
152 | extern int cgit_cache_static_ttl; | 153 | extern int cgit_cache_static_ttl; |
153 | extern int cgit_cache_max_create_time; | 154 | extern int cgit_cache_max_create_time; |
154 | extern int cgit_summary_log; | 155 | extern int cgit_summary_log; |
155 | extern int cgit_summary_tags; | 156 | extern int cgit_summary_tags; |
156 | extern int cgit_summary_branches; | 157 | extern int cgit_summary_branches; |
157 | 158 | ||
158 | extern int cgit_max_msg_len; | 159 | extern int cgit_max_msg_len; |
159 | extern int cgit_max_repodesc_len; | 160 | extern int cgit_max_repodesc_len; |
160 | extern int cgit_max_commit_count; | 161 | extern int cgit_max_commit_count; |
161 | 162 | ||
162 | extern int cgit_query_has_symref; | 163 | extern int cgit_query_has_symref; |
163 | extern int cgit_query_has_sha1; | 164 | extern int cgit_query_has_sha1; |
164 | 165 | ||
165 | extern char *cgit_querystring; | 166 | extern char *cgit_querystring; |
@@ -1,34 +1,39 @@ | |||
1 | ## | 1 | ## |
2 | ## cgitrc: template for /etc/cgitrc | 2 | ## cgitrc: template for /etc/cgitrc |
3 | ## | 3 | ## |
4 | 4 | ||
5 | 5 | ||
6 | ## Uncomment and set to 1 to deactivate caching of generated pages. Mostly | 6 | ## Uncomment and set to 1 to deactivate caching of generated pages. Mostly |
7 | ## usefull for testing. | 7 | ## usefull for testing. |
8 | #nocache=0 | 8 | #nocache=0 |
9 | 9 | ||
10 | 10 | ||
11 | ## This variable can be used to override the default value for "robots" | ||
12 | ## meta-tag. If unset, the meta-tag isn't generated. | ||
13 | #robots=index, nofollow | ||
14 | |||
15 | |||
11 | ## Set allowed snapshot types by default. Can be overridden per repo | 16 | ## Set allowed snapshot types by default. Can be overridden per repo |
12 | # can be any combination of zip/tar.gz/tar.bz2/tar | 17 | # can be any combination of zip/tar.gz/tar.bz2/tar |
13 | #snapshots=0 | 18 | #snapshots=0 |
14 | 19 | ||
15 | 20 | ||
16 | ## Enable/disable extra links to summary/log/tree per repo on index page | 21 | ## Enable/disable extra links to summary/log/tree per repo on index page |
17 | #enable-index-links=0 | 22 | #enable-index-links=0 |
18 | 23 | ||
19 | 24 | ||
20 | ## Enable/disable display of 'number of files changed' in log view | 25 | ## Enable/disable display of 'number of files changed' in log view |
21 | #enable-log-filecount=0 | 26 | #enable-log-filecount=0 |
22 | 27 | ||
23 | 28 | ||
24 | ## Enable/disable display of 'number of lines changed' in log view | 29 | ## Enable/disable display of 'number of lines changed' in log view |
25 | #enable-log-linecount=0 | 30 | #enable-log-linecount=0 |
26 | 31 | ||
27 | 32 | ||
28 | ## Enable/disable display of HEAD shortlog in summary view. Set it to maximum | 33 | ## Enable/disable display of HEAD shortlog in summary view. Set it to maximum |
29 | ## number of commits that should be displayed | 34 | ## number of commits that should be displayed |
30 | #summary-log=0 | 35 | #summary-log=0 |
31 | 36 | ||
32 | 37 | ||
33 | ## Restrict the number of branches printed in summary view. Set to 0 to | 38 | ## Restrict the number of branches printed in summary view. Set to 0 to |
34 | ## print all branches. | 39 | ## print all branches. |
@@ -5,48 +5,49 @@ | |||
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 | ||
11 | struct repolist cgit_repolist; | 11 | struct repolist cgit_repolist; |
12 | struct repoinfo *cgit_repo; | 12 | struct repoinfo *cgit_repo; |
13 | int cgit_cmd; | 13 | int cgit_cmd; |
14 | 14 | ||
15 | const char *cgit_version = CGIT_VERSION; | 15 | const char *cgit_version = CGIT_VERSION; |
16 | 16 | ||
17 | char *cgit_root_title = "Git repository browser"; | 17 | char *cgit_root_title = "Git repository browser"; |
18 | char *cgit_css = "/cgit.css"; | 18 | char *cgit_css = "/cgit.css"; |
19 | char *cgit_logo = "/git-logo.png"; | 19 | char *cgit_logo = "/git-logo.png"; |
20 | char *cgit_index_header = NULL; | 20 | char *cgit_index_header = NULL; |
21 | char *cgit_index_info = NULL; | 21 | char *cgit_index_info = NULL; |
22 | char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/"; | 22 | char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/"; |
23 | char *cgit_module_link = "./?repo=%s&page=commit&id=%s"; | 23 | char *cgit_module_link = "./?repo=%s&page=commit&id=%s"; |
24 | char *cgit_agefile = "info/web/last-modified"; | 24 | char *cgit_agefile = "info/web/last-modified"; |
25 | char *cgit_virtual_root = NULL; | 25 | char *cgit_virtual_root = NULL; |
26 | char *cgit_script_name = CGIT_SCRIPT_NAME; | 26 | char *cgit_script_name = CGIT_SCRIPT_NAME; |
27 | char *cgit_cache_root = CGIT_CACHE_ROOT; | 27 | char *cgit_cache_root = CGIT_CACHE_ROOT; |
28 | char *cgit_repo_group = NULL; | 28 | char *cgit_repo_group = NULL; |
29 | char *cgit_robots = "index, nofollow"; | ||
29 | 30 | ||
30 | int cgit_nocache = 0; | 31 | int cgit_nocache = 0; |
31 | int cgit_snapshots = 0; | 32 | int cgit_snapshots = 0; |
32 | int cgit_enable_index_links = 0; | 33 | int cgit_enable_index_links = 0; |
33 | int cgit_enable_log_filecount = 0; | 34 | int cgit_enable_log_filecount = 0; |
34 | int cgit_enable_log_linecount = 0; | 35 | int cgit_enable_log_linecount = 0; |
35 | int cgit_max_lock_attempts = 5; | 36 | int cgit_max_lock_attempts = 5; |
36 | int cgit_cache_root_ttl = 5; | 37 | int cgit_cache_root_ttl = 5; |
37 | int cgit_cache_repo_ttl = 5; | 38 | int cgit_cache_repo_ttl = 5; |
38 | int cgit_cache_dynamic_ttl = 5; | 39 | int cgit_cache_dynamic_ttl = 5; |
39 | int cgit_cache_static_ttl = -1; | 40 | int cgit_cache_static_ttl = -1; |
40 | int cgit_cache_max_create_time = 5; | 41 | int cgit_cache_max_create_time = 5; |
41 | int cgit_summary_log = 0; | 42 | int cgit_summary_log = 0; |
42 | int cgit_summary_tags = 0; | 43 | int cgit_summary_tags = 0; |
43 | int cgit_summary_branches = 0; | 44 | int cgit_summary_branches = 0; |
44 | int cgit_renamelimit = -1; | 45 | int cgit_renamelimit = -1; |
45 | 46 | ||
46 | int cgit_max_msg_len = 60; | 47 | int cgit_max_msg_len = 60; |
47 | int cgit_max_repodesc_len = 60; | 48 | int cgit_max_repodesc_len = 60; |
48 | int cgit_max_commit_count = 50; | 49 | int cgit_max_commit_count = 50; |
49 | 50 | ||
50 | int cgit_query_has_symref = 0; | 51 | int cgit_query_has_symref = 0; |
51 | int cgit_query_has_sha1 = 0; | 52 | int cgit_query_has_sha1 = 0; |
52 | 53 | ||
@@ -176,48 +177,50 @@ void cgit_global_config_cb(const char *name, const char *value) | |||
176 | else if (!strcmp(name, "cache-root-ttl")) | 177 | else if (!strcmp(name, "cache-root-ttl")) |
177 | cgit_cache_root_ttl = atoi(value); | 178 | cgit_cache_root_ttl = atoi(value); |
178 | else if (!strcmp(name, "cache-repo-ttl")) | 179 | else if (!strcmp(name, "cache-repo-ttl")) |
179 | cgit_cache_repo_ttl = atoi(value); | 180 | cgit_cache_repo_ttl = atoi(value); |
180 | else if (!strcmp(name, "cache-static-ttl")) | 181 | else if (!strcmp(name, "cache-static-ttl")) |
181 | cgit_cache_static_ttl = atoi(value); | 182 | cgit_cache_static_ttl = atoi(value); |
182 | else if (!strcmp(name, "cache-dynamic-ttl")) | 183 | else if (!strcmp(name, "cache-dynamic-ttl")) |
183 | cgit_cache_dynamic_ttl = atoi(value); | 184 | cgit_cache_dynamic_ttl = atoi(value); |
184 | else if (!strcmp(name, "max-message-length")) | 185 | else if (!strcmp(name, "max-message-length")) |
185 | cgit_max_msg_len = atoi(value); | 186 | cgit_max_msg_len = atoi(value); |
186 | else if (!strcmp(name, "max-repodesc-length")) | 187 | else if (!strcmp(name, "max-repodesc-length")) |
187 | cgit_max_repodesc_len = atoi(value); | 188 | cgit_max_repodesc_len = atoi(value); |
188 | else if (!strcmp(name, "max-commit-count")) | 189 | else if (!strcmp(name, "max-commit-count")) |
189 | cgit_max_commit_count = atoi(value); | 190 | cgit_max_commit_count = atoi(value); |
190 | else if (!strcmp(name, "summary-log")) | 191 | else if (!strcmp(name, "summary-log")) |
191 | cgit_summary_log = atoi(value); | 192 | cgit_summary_log = atoi(value); |
192 | else if (!strcmp(name, "summary-branches")) | 193 | else if (!strcmp(name, "summary-branches")) |
193 | cgit_summary_branches = atoi(value); | 194 | cgit_summary_branches = atoi(value); |
194 | else if (!strcmp(name, "summary-tags")) | 195 | else if (!strcmp(name, "summary-tags")) |
195 | cgit_summary_tags = atoi(value); | 196 | cgit_summary_tags = atoi(value); |
196 | else if (!strcmp(name, "agefile")) | 197 | else if (!strcmp(name, "agefile")) |
197 | cgit_agefile = xstrdup(value); | 198 | cgit_agefile = xstrdup(value); |
198 | else if (!strcmp(name, "renamelimit")) | 199 | else if (!strcmp(name, "renamelimit")) |
199 | cgit_renamelimit = atoi(value); | 200 | cgit_renamelimit = atoi(value); |
201 | else if (!strcmp(name, "robots")) | ||
202 | cgit_robots = xstrdup(value); | ||
200 | else if (!strcmp(name, "repo.group")) | 203 | else if (!strcmp(name, "repo.group")) |
201 | cgit_repo_group = xstrdup(value); | 204 | cgit_repo_group = xstrdup(value); |
202 | else if (!strcmp(name, "repo.url")) | 205 | else if (!strcmp(name, "repo.url")) |
203 | cgit_repo = add_repo(value); | 206 | cgit_repo = add_repo(value); |
204 | else if (!strcmp(name, "repo.name")) | 207 | else if (!strcmp(name, "repo.name")) |
205 | cgit_repo->name = xstrdup(value); | 208 | cgit_repo->name = xstrdup(value); |
206 | else if (cgit_repo && !strcmp(name, "repo.path")) | 209 | else if (cgit_repo && !strcmp(name, "repo.path")) |
207 | cgit_repo->path = trim_end(value, '/'); | 210 | cgit_repo->path = trim_end(value, '/'); |
208 | else if (cgit_repo && !strcmp(name, "repo.desc")) | 211 | else if (cgit_repo && !strcmp(name, "repo.desc")) |
209 | cgit_repo->desc = xstrdup(value); | 212 | cgit_repo->desc = xstrdup(value); |
210 | else if (cgit_repo && !strcmp(name, "repo.owner")) | 213 | else if (cgit_repo && !strcmp(name, "repo.owner")) |
211 | cgit_repo->owner = xstrdup(value); | 214 | cgit_repo->owner = xstrdup(value); |
212 | else if (cgit_repo && !strcmp(name, "repo.defbranch")) | 215 | else if (cgit_repo && !strcmp(name, "repo.defbranch")) |
213 | cgit_repo->defbranch = xstrdup(value); | 216 | cgit_repo->defbranch = xstrdup(value); |
214 | else if (cgit_repo && !strcmp(name, "repo.snapshots")) | 217 | else if (cgit_repo && !strcmp(name, "repo.snapshots")) |
215 | cgit_repo->snapshots = cgit_snapshots & cgit_parse_snapshots_mask(value); /* XXX: &? */ | 218 | cgit_repo->snapshots = cgit_snapshots & cgit_parse_snapshots_mask(value); /* XXX: &? */ |
216 | else if (cgit_repo && !strcmp(name, "repo.enable-log-filecount")) | 219 | else if (cgit_repo && !strcmp(name, "repo.enable-log-filecount")) |
217 | cgit_repo->enable_log_filecount = cgit_enable_log_filecount * atoi(value); | 220 | cgit_repo->enable_log_filecount = cgit_enable_log_filecount * atoi(value); |
218 | else if (cgit_repo && !strcmp(name, "repo.enable-log-linecount")) | 221 | else if (cgit_repo && !strcmp(name, "repo.enable-log-linecount")) |
219 | cgit_repo->enable_log_linecount = cgit_enable_log_linecount * atoi(value); | 222 | cgit_repo->enable_log_linecount = cgit_enable_log_linecount * atoi(value); |
220 | else if (cgit_repo && !strcmp(name, "repo.module-link")) | 223 | else if (cgit_repo && !strcmp(name, "repo.module-link")) |
221 | cgit_repo->module_link= xstrdup(value); | 224 | cgit_repo->module_link= xstrdup(value); |
222 | else if (cgit_repo && !strcmp(name, "repo.readme") && value != NULL) { | 225 | else if (cgit_repo && !strcmp(name, "repo.readme") && value != NULL) { |
223 | if (*value == '/') | 226 | if (*value == '/') |
diff --git a/ui-shared.c b/ui-shared.c index 5192800..2f771da 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
@@ -343,48 +343,50 @@ void cgit_print_age(time_t t, time_t max_relative, char *format) | |||
343 | } | 343 | } |
344 | if (secs < TM_YEAR * 2) { | 344 | if (secs < TM_YEAR * 2) { |
345 | htmlf("<span class='age-months'>%.0f months</span>", | 345 | htmlf("<span class='age-months'>%.0f months</span>", |
346 | secs * 1.0 / TM_MONTH); | 346 | secs * 1.0 / TM_MONTH); |
347 | return; | 347 | return; |
348 | } | 348 | } |
349 | htmlf("<span class='age-years'>%.0f years</span>", | 349 | htmlf("<span class='age-years'>%.0f years</span>", |
350 | secs * 1.0 / TM_YEAR); | 350 | secs * 1.0 / TM_YEAR); |
351 | } | 351 | } |
352 | 352 | ||
353 | void cgit_print_docstart(char *title, struct cacheitem *item) | 353 | void cgit_print_docstart(char *title, struct cacheitem *item) |
354 | { | 354 | { |
355 | html("Content-Type: text/html; charset=" PAGE_ENCODING "\n"); | 355 | html("Content-Type: text/html; charset=" PAGE_ENCODING "\n"); |
356 | htmlf("Last-Modified: %s\n", http_date(item->st.st_mtime)); | 356 | htmlf("Last-Modified: %s\n", http_date(item->st.st_mtime)); |
357 | htmlf("Expires: %s\n", http_date(item->st.st_mtime + | 357 | htmlf("Expires: %s\n", http_date(item->st.st_mtime + |
358 | ttl_seconds(item->ttl))); | 358 | ttl_seconds(item->ttl))); |
359 | html("\n"); | 359 | html("\n"); |
360 | html(cgit_doctype); | 360 | html(cgit_doctype); |
361 | html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n"); | 361 | html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n"); |
362 | html("<head>\n"); | 362 | html("<head>\n"); |
363 | html("<title>"); | 363 | html("<title>"); |
364 | html_txt(title); | 364 | html_txt(title); |
365 | html("</title>\n"); | 365 | html("</title>\n"); |
366 | htmlf("<meta name='generator' content='cgit %s'/>\n", cgit_version); | 366 | htmlf("<meta name='generator' content='cgit %s'/>\n", cgit_version); |
367 | if (cgit_robots && *cgit_robots) | ||
368 | htmlf("<meta name='robots' content='%s'/>\n", cgit_robots); | ||
367 | html("<link rel='stylesheet' type='text/css' href='"); | 369 | html("<link rel='stylesheet' type='text/css' href='"); |
368 | html_attr(cgit_css); | 370 | html_attr(cgit_css); |
369 | html("'/>\n"); | 371 | html("'/>\n"); |
370 | html("</head>\n"); | 372 | html("</head>\n"); |
371 | html("<body>\n"); | 373 | html("<body>\n"); |
372 | } | 374 | } |
373 | 375 | ||
374 | void cgit_print_docend() | 376 | void cgit_print_docend() |
375 | { | 377 | { |
376 | html("</td>\n</tr>\n</table>\n</body>\n</html>\n"); | 378 | html("</td>\n</tr>\n</table>\n</body>\n</html>\n"); |
377 | } | 379 | } |
378 | 380 | ||
379 | int print_branch_option(const char *refname, const unsigned char *sha1, | 381 | int print_branch_option(const char *refname, const unsigned char *sha1, |
380 | int flags, void *cb_data) | 382 | int flags, void *cb_data) |
381 | { | 383 | { |
382 | char *name = (char *)refname; | 384 | char *name = (char *)refname; |
383 | html_option(name, name, cgit_query_head); | 385 | html_option(name, name, cgit_query_head); |
384 | return 0; | 386 | return 0; |
385 | } | 387 | } |
386 | 388 | ||
387 | int print_archive_ref(const char *refname, const unsigned char *sha1, | 389 | int print_archive_ref(const char *refname, const unsigned char *sha1, |
388 | int flags, void *cb_data) | 390 | int flags, void *cb_data) |
389 | { | 391 | { |
390 | struct tag *tag; | 392 | struct tag *tag; |