summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--ui-atom.c6
-rw-r--r--ui-shared.c3
2 files changed, 6 insertions, 3 deletions
diff --git a/ui-atom.c b/ui-atom.c
index a6ea3ee..e5c31d9 100644
--- a/ui-atom.c
+++ b/ui-atom.c
@@ -7,123 +7,125 @@
7 */ 7 */
8 8
9#include "cgit.h" 9#include "cgit.h"
10#include "html.h" 10#include "html.h"
11#include "ui-shared.h" 11#include "ui-shared.h"
12 12
13void add_entry(struct commit *commit, char *host) 13void add_entry(struct commit *commit, char *host)
14{ 14{
15 char delim = '&'; 15 char delim = '&';
16 char *hex; 16 char *hex;
17 char *mail, *t, *t2; 17 char *mail, *t, *t2;
18 struct commitinfo *info; 18 struct commitinfo *info;
19 19
20 info = cgit_parse_commit(commit); 20 info = cgit_parse_commit(commit);
21 hex = sha1_to_hex(commit->object.sha1); 21 hex = sha1_to_hex(commit->object.sha1);
22 html("<entry>\n"); 22 html("<entry>\n");
23 html("<title>"); 23 html("<title>");
24 html_txt(info->subject); 24 html_txt(info->subject);
25 html("</title>\n"); 25 html("</title>\n");
26 html("<updated>"); 26 html("<updated>");
27 cgit_print_date(info->author_date, FMT_ATOMDATE, ctx.cfg.local_time); 27 cgit_print_date(info->author_date, FMT_ATOMDATE, ctx.cfg.local_time);
28 html("</updated>\n"); 28 html("</updated>\n");
29 html("<author>\n"); 29 html("<author>\n");
30 if (info->author) { 30 if (info->author) {
31 html("<name>"); 31 html("<name>");
32 html_txt(info->author); 32 html_txt(info->author);
33 html("</name>\n"); 33 html("</name>\n");
34 } 34 }
35 if (info->author_email) { 35 if (info->author_email) {
36 mail = xstrdup(info->author_email); 36 mail = xstrdup(info->author_email);
37 t = strchr(mail, '<'); 37 t = strchr(mail, '<');
38 if (t) 38 if (t)
39 t++; 39 t++;
40 else 40 else
41 t = mail; 41 t = mail;
42 t2 = strchr(t, '>'); 42 t2 = strchr(t, '>');
43 if (t2) 43 if (t2)
44 *t2 = '\0'; 44 *t2 = '\0';
45 html("<email>"); 45 html("<email>");
46 html_txt(t); 46 html_txt(t);
47 html("</email>\n"); 47 html("</email>\n");
48 free(mail); 48 free(mail);
49 } 49 }
50 html("</author>\n"); 50 html("</author>\n");
51 html("<published>"); 51 html("<published>");
52 cgit_print_date(info->author_date, FMT_ATOMDATE, ctx.cfg.local_time); 52 cgit_print_date(info->author_date, FMT_ATOMDATE, ctx.cfg.local_time);
53 html("</published>\n"); 53 html("</published>\n");
54 if (host) { 54 if (host) {
55 html("<link rel='alternate' type='text/html' href='http://"); 55 html("<link rel='alternate' type='text/html' href='");
56 html(cgit_httpscheme());
56 html_attr(host); 57 html_attr(host);
57 html_attr(cgit_pageurl(ctx.repo->url, "commit", NULL)); 58 html_attr(cgit_pageurl(ctx.repo->url, "commit", NULL));
58 if (ctx.cfg.virtual_root) 59 if (ctx.cfg.virtual_root)
59 delim = '?'; 60 delim = '?';
60 htmlf("%cid=%s", delim, hex); 61 htmlf("%cid=%s", delim, hex);
61 html("'/>\n"); 62 html("'/>\n");
62 } 63 }
63 htmlf("<id>%s</id>\n", hex); 64 htmlf("<id>%s</id>\n", hex);
64 html("<content type='text'>\n"); 65 html("<content type='text'>\n");
65 html_txt(info->msg); 66 html_txt(info->msg);
66 html("</content>\n"); 67 html("</content>\n");
67 html("<content type='xhtml'>\n"); 68 html("<content type='xhtml'>\n");
68 html("<div xmlns='http://www.w3.org/1999/xhtml'>\n"); 69 html("<div xmlns='http://www.w3.org/1999/xhtml'>\n");
69 html("<pre>\n"); 70 html("<pre>\n");
70 html_txt(info->msg); 71 html_txt(info->msg);
71 html("</pre>\n"); 72 html("</pre>\n");
72 html("</div>\n"); 73 html("</div>\n");
73 html("</content>\n"); 74 html("</content>\n");
74 html("</entry>\n"); 75 html("</entry>\n");
75 cgit_free_commitinfo(info); 76 cgit_free_commitinfo(info);
76} 77}
77 78
78 79
79void cgit_print_atom(char *tip, char *path, int max_count) 80void cgit_print_atom(char *tip, char *path, int max_count)
80{ 81{
81 char *host; 82 char *host;
82 const char *argv[] = {NULL, tip, NULL, NULL, NULL}; 83 const char *argv[] = {NULL, tip, NULL, NULL, NULL};
83 struct commit *commit; 84 struct commit *commit;
84 struct rev_info rev; 85 struct rev_info rev;
85 int argc = 2; 86 int argc = 2;
86 87
87 if (!tip) 88 if (!tip)
88 argv[1] = ctx.qry.head; 89 argv[1] = ctx.qry.head;
89 90
90 if (path) { 91 if (path) {
91 argv[argc++] = "--"; 92 argv[argc++] = "--";
92 argv[argc++] = path; 93 argv[argc++] = path;
93 } 94 }
94 95
95 init_revisions(&rev, NULL); 96 init_revisions(&rev, NULL);
96 rev.abbrev = DEFAULT_ABBREV; 97 rev.abbrev = DEFAULT_ABBREV;
97 rev.commit_format = CMIT_FMT_DEFAULT; 98 rev.commit_format = CMIT_FMT_DEFAULT;
98 rev.verbose_header = 1; 99 rev.verbose_header = 1;
99 rev.show_root_diff = 0; 100 rev.show_root_diff = 0;
100 rev.max_count = max_count; 101 rev.max_count = max_count;
101 setup_revisions(argc, argv, &rev, NULL); 102 setup_revisions(argc, argv, &rev, NULL);
102 prepare_revision_walk(&rev); 103 prepare_revision_walk(&rev);
103 104
104 host = cgit_hosturl(); 105 host = cgit_hosturl();
105 ctx.page.mimetype = "text/xml"; 106 ctx.page.mimetype = "text/xml";
106 ctx.page.charset = "utf-8"; 107 ctx.page.charset = "utf-8";
107 cgit_print_http_headers(&ctx); 108 cgit_print_http_headers(&ctx);
108 html("<feed xmlns='http://www.w3.org/2005/Atom'>\n"); 109 html("<feed xmlns='http://www.w3.org/2005/Atom'>\n");
109 html("<title>"); 110 html("<title>");
110 html_txt(ctx.repo->name); 111 html_txt(ctx.repo->name);
111 html("</title>\n"); 112 html("</title>\n");
112 html("<subtitle>"); 113 html("<subtitle>");
113 html_txt(ctx.repo->desc); 114 html_txt(ctx.repo->desc);
114 html("</subtitle>\n"); 115 html("</subtitle>\n");
115 if (host) { 116 if (host) {
116 html("<link rel='alternate' type='text/html' href='http://"); 117 html("<link rel='alternate' type='text/html' href='");
118 html(cgit_httpscheme());
117 html_attr(host); 119 html_attr(host);
118 html_attr(cgit_repourl(ctx.repo->url)); 120 html_attr(cgit_repourl(ctx.repo->url));
119 html("'/>\n"); 121 html("'/>\n");
120 } 122 }
121 while ((commit = get_revision(&rev)) != NULL) { 123 while ((commit = get_revision(&rev)) != NULL) {
122 add_entry(commit, host); 124 add_entry(commit, host);
123 free(commit->buffer); 125 free(commit->buffer);
124 commit->buffer = NULL; 126 commit->buffer = NULL;
125 free_commit_list(commit->parents); 127 free_commit_list(commit->parents);
126 commit->parents = NULL; 128 commit->parents = NULL;
127 } 129 }
128 html("</feed>\n"); 130 html("</feed>\n");
129} 131}
diff --git a/ui-shared.c b/ui-shared.c
index 749ea35..5ce2bc5 100644
--- a/ui-shared.c
+++ b/ui-shared.c
@@ -458,97 +458,98 @@ void cgit_print_age(time_t t, time_t max_relative, char *format)
458 } 458 }
459 if (secs < TM_YEAR * 2) { 459 if (secs < TM_YEAR * 2) {
460 htmlf("<span class='age-months'>%.0f months</span>", 460 htmlf("<span class='age-months'>%.0f months</span>",
461 secs * 1.0 / TM_MONTH); 461 secs * 1.0 / TM_MONTH);
462 return; 462 return;
463 } 463 }
464 htmlf("<span class='age-years'>%.0f years</span>", 464 htmlf("<span class='age-years'>%.0f years</span>",
465 secs * 1.0 / TM_YEAR); 465 secs * 1.0 / TM_YEAR);
466} 466}
467 467
468void cgit_print_http_headers(struct cgit_context *ctx) 468void cgit_print_http_headers(struct cgit_context *ctx)
469{ 469{
470 if (ctx->page.mimetype && ctx->page.charset) 470 if (ctx->page.mimetype && ctx->page.charset)
471 htmlf("Content-Type: %s; charset=%s\n", ctx->page.mimetype, 471 htmlf("Content-Type: %s; charset=%s\n", ctx->page.mimetype,
472 ctx->page.charset); 472 ctx->page.charset);
473 else if (ctx->page.mimetype) 473 else if (ctx->page.mimetype)
474 htmlf("Content-Type: %s\n", ctx->page.mimetype); 474 htmlf("Content-Type: %s\n", ctx->page.mimetype);
475 if (ctx->page.size) 475 if (ctx->page.size)
476 htmlf("Content-Length: %ld\n", ctx->page.size); 476 htmlf("Content-Length: %ld\n", ctx->page.size);
477 if (ctx->page.filename) 477 if (ctx->page.filename)
478 htmlf("Content-Disposition: inline; filename=\"%s\"\n", 478 htmlf("Content-Disposition: inline; filename=\"%s\"\n",
479 ctx->page.filename); 479 ctx->page.filename);
480 htmlf("Last-Modified: %s\n", http_date(ctx->page.modified)); 480 htmlf("Last-Modified: %s\n", http_date(ctx->page.modified));
481 htmlf("Expires: %s\n", http_date(ctx->page.expires)); 481 htmlf("Expires: %s\n", http_date(ctx->page.expires));
482 html("\n"); 482 html("\n");
483} 483}
484 484
485void cgit_print_docstart(struct cgit_context *ctx) 485void cgit_print_docstart(struct cgit_context *ctx)
486{ 486{
487 char *host = cgit_hosturl(); 487 char *host = cgit_hosturl();
488 html(cgit_doctype); 488 html(cgit_doctype);
489 html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n"); 489 html("<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>\n");
490 html("<head>\n"); 490 html("<head>\n");
491 html("<title>"); 491 html("<title>");
492 html_txt(ctx->page.title); 492 html_txt(ctx->page.title);
493 html("</title>\n"); 493 html("</title>\n");
494 htmlf("<meta name='generator' content='cgit %s'/>\n", cgit_version); 494 htmlf("<meta name='generator' content='cgit %s'/>\n", cgit_version);
495 if (ctx->cfg.robots && *ctx->cfg.robots) 495 if (ctx->cfg.robots && *ctx->cfg.robots)
496 htmlf("<meta name='robots' content='%s'/>\n", ctx->cfg.robots); 496 htmlf("<meta name='robots' content='%s'/>\n", ctx->cfg.robots);
497 html("<link rel='stylesheet' type='text/css' href='"); 497 html("<link rel='stylesheet' type='text/css' href='");
498 html_attr(ctx->cfg.css); 498 html_attr(ctx->cfg.css);
499 html("'/>\n"); 499 html("'/>\n");
500 if (ctx->cfg.favicon) { 500 if (ctx->cfg.favicon) {
501 html("<link rel='shortcut icon' href='"); 501 html("<link rel='shortcut icon' href='");
502 html_attr(ctx->cfg.favicon); 502 html_attr(ctx->cfg.favicon);
503 html("'/>\n"); 503 html("'/>\n");
504 } 504 }
505 if (host && ctx->repo) { 505 if (host && ctx->repo) {
506 html("<link rel='alternate' title='Atom feed' href='http://"); 506 html("<link rel='alternate' title='Atom feed' href='");
507 html(cgit_httpscheme());
507 html_attr(cgit_hosturl()); 508 html_attr(cgit_hosturl());
508 html_attr(cgit_fileurl(ctx->repo->url, "atom", ctx->qry.path, 509 html_attr(cgit_fileurl(ctx->repo->url, "atom", ctx->qry.path,
509 fmt("h=%s", ctx->qry.head))); 510 fmt("h=%s", ctx->qry.head)));
510 html("' type='application/atom+xml'/>"); 511 html("' type='application/atom+xml'/>");
511 } 512 }
512 html("</head>\n"); 513 html("</head>\n");
513 html("<body>\n"); 514 html("<body>\n");
514 if (ctx->cfg.header) 515 if (ctx->cfg.header)
515 html_include(ctx->cfg.header); 516 html_include(ctx->cfg.header);
516} 517}
517 518
518void cgit_print_docend() 519void cgit_print_docend()
519{ 520{
520 html("</div>"); 521 html("</div>");
521 if (ctx.cfg.footer) 522 if (ctx.cfg.footer)
522 html_include(ctx.cfg.footer); 523 html_include(ctx.cfg.footer);
523 else { 524 else {
524 htmlf("<div class='footer'>generated by cgit %s at ", 525 htmlf("<div class='footer'>generated by cgit %s at ",
525 cgit_version); 526 cgit_version);
526 cgit_print_date(time(NULL), FMT_LONGDATE, ctx.cfg.local_time); 527 cgit_print_date(time(NULL), FMT_LONGDATE, ctx.cfg.local_time);
527 html("</div>\n"); 528 html("</div>\n");
528 } 529 }
529 html("</body>\n</html>\n"); 530 html("</body>\n</html>\n");
530} 531}
531 532
532int print_branch_option(const char *refname, const unsigned char *sha1, 533int print_branch_option(const char *refname, const unsigned char *sha1,
533 int flags, void *cb_data) 534 int flags, void *cb_data)
534{ 535{
535 char *name = (char *)refname; 536 char *name = (char *)refname;
536 html_option(name, name, ctx.qry.head); 537 html_option(name, name, ctx.qry.head);
537 return 0; 538 return 0;
538} 539}
539 540
540int print_archive_ref(const char *refname, const unsigned char *sha1, 541int print_archive_ref(const char *refname, const unsigned char *sha1,
541 int flags, void *cb_data) 542 int flags, void *cb_data)
542{ 543{
543 struct tag *tag; 544 struct tag *tag;
544 struct taginfo *info; 545 struct taginfo *info;
545 struct object *obj; 546 struct object *obj;
546 char buf[256], *url; 547 char buf[256], *url;
547 unsigned char fileid[20]; 548 unsigned char fileid[20];
548 int *header = (int *)cb_data; 549 int *header = (int *)cb_data;
549 550
550 if (prefixcmp(refname, "refs/archives")) 551 if (prefixcmp(refname, "refs/archives"))
551 return 0; 552 return 0;
552 strncpy(buf, refname+14, sizeof(buf)); 553 strncpy(buf, refname+14, sizeof(buf));
553 obj = parse_object(sha1); 554 obj = parse_object(sha1);
554 if (!obj) 555 if (!obj)