-rw-r--r-- | cmd.c | 9 | ||||
-rw-r--r-- | ui-shared.c | 53 |
2 files changed, 59 insertions, 3 deletions
@@ -15,16 +15,24 @@ | |||
15 | #include "ui-patch.h" | 15 | #include "ui-patch.h" |
16 | #include "ui-refs.h" | 16 | #include "ui-refs.h" |
17 | #include "ui-repolist.h" | 17 | #include "ui-repolist.h" |
18 | #include "ui-snapshot.h" | 18 | #include "ui-snapshot.h" |
19 | #include "ui-summary.h" | 19 | #include "ui-summary.h" |
20 | #include "ui-tag.h" | 20 | #include "ui-tag.h" |
21 | #include "ui-tree.h" | 21 | #include "ui-tree.h" |
22 | 22 | ||
23 | static void about_fn(struct cgit_context *ctx) | ||
24 | { | ||
25 | if (ctx->repo) | ||
26 | cgit_print_repo_readme(); | ||
27 | else | ||
28 | cgit_print_site_readme(); | ||
29 | } | ||
30 | |||
23 | static void blob_fn(struct cgit_context *ctx) | 31 | static void blob_fn(struct cgit_context *ctx) |
24 | { | 32 | { |
25 | cgit_print_blob(ctx->qry.sha1, ctx->qry.path); | 33 | cgit_print_blob(ctx->qry.sha1, ctx->qry.path); |
26 | } | 34 | } |
27 | 35 | ||
28 | static void commit_fn(struct cgit_context *ctx) | 36 | static void commit_fn(struct cgit_context *ctx) |
29 | { | 37 | { |
30 | cgit_print_commit(ctx->qry.sha1); | 38 | cgit_print_commit(ctx->qry.sha1); |
@@ -79,16 +87,17 @@ static void tree_fn(struct cgit_context *ctx) | |||
79 | } | 87 | } |
80 | 88 | ||
81 | #define def_cmd(name, want_repo, want_layout) \ | 89 | #define def_cmd(name, want_repo, want_layout) \ |
82 | {#name, name##_fn, want_repo, want_layout} | 90 | {#name, name##_fn, want_repo, want_layout} |
83 | 91 | ||
84 | struct cgit_cmd *cgit_get_cmd(struct cgit_context *ctx) | 92 | struct cgit_cmd *cgit_get_cmd(struct cgit_context *ctx) |
85 | { | 93 | { |
86 | static struct cgit_cmd cmds[] = { | 94 | static struct cgit_cmd cmds[] = { |
95 | def_cmd(about, 0, 1), | ||
87 | def_cmd(blob, 1, 0), | 96 | def_cmd(blob, 1, 0), |
88 | def_cmd(commit, 1, 1), | 97 | def_cmd(commit, 1, 1), |
89 | def_cmd(diff, 1, 1), | 98 | def_cmd(diff, 1, 1), |
90 | def_cmd(log, 1, 1), | 99 | def_cmd(log, 1, 1), |
91 | def_cmd(patch, 1, 0), | 100 | def_cmd(patch, 1, 0), |
92 | def_cmd(refs, 1, 1), | 101 | def_cmd(refs, 1, 1), |
93 | def_cmd(repolist, 0, 0), | 102 | def_cmd(repolist, 0, 0), |
94 | def_cmd(snapshot, 1, 0), | 103 | def_cmd(snapshot, 1, 0), |
diff --git a/ui-shared.c b/ui-shared.c index 83758f7..d08ede9 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
@@ -109,16 +109,59 @@ char *cgit_currurl() | |||
109 | else if (ctx.qry.page) | 109 | else if (ctx.qry.page) |
110 | return fmt("%s/%s/%s/", ctx.cfg.virtual_root, ctx.qry.repo, ctx.qry.page); | 110 | return fmt("%s/%s/%s/", ctx.cfg.virtual_root, ctx.qry.repo, ctx.qry.page); |
111 | else if (ctx.qry.repo) | 111 | else if (ctx.qry.repo) |
112 | return fmt("%s/%s/", ctx.cfg.virtual_root, ctx.qry.repo); | 112 | return fmt("%s/%s/", ctx.cfg.virtual_root, ctx.qry.repo); |
113 | else | 113 | else |
114 | return fmt("%s/", ctx.cfg.virtual_root); | 114 | return fmt("%s/", ctx.cfg.virtual_root); |
115 | } | 115 | } |
116 | 116 | ||
117 | static void site_url(char *page, char *search) | ||
118 | { | ||
119 | char *delim = "?"; | ||
120 | |||
121 | if (ctx.cfg.virtual_root) { | ||
122 | html_attr(ctx.cfg.virtual_root); | ||
123 | if (ctx.cfg.virtual_root[strlen(ctx.cfg.virtual_root) - 1] != '/') | ||
124 | html("/"); | ||
125 | } else | ||
126 | html(ctx.cfg.script_name); | ||
127 | |||
128 | if (page) { | ||
129 | htmlf("?p=%s", page); | ||
130 | delim = "&"; | ||
131 | } | ||
132 | if (search) { | ||
133 | html(delim); | ||
134 | html("q="); | ||
135 | html_attr(search); | ||
136 | } | ||
137 | } | ||
138 | |||
139 | static void site_link(char *page, char *name, char *title, char *class, | ||
140 | char *search) | ||
141 | { | ||
142 | html("<a"); | ||
143 | if (title) { | ||
144 | html(" title='"); | ||
145 | html_attr(title); | ||
146 | html("'"); | ||
147 | } | ||
148 | if (class) { | ||
149 | html(" class='"); | ||
150 | html_attr(class); | ||
151 | html("'"); | ||
152 | } | ||
153 | html(" href='"); | ||
154 | site_url(page, search); | ||
155 | html("'>"); | ||
156 | html_txt(name); | ||
157 | html("</a>"); | ||
158 | } | ||
159 | |||
117 | static char *repolink(char *title, char *class, char *page, char *head, | 160 | static char *repolink(char *title, char *class, char *page, char *head, |
118 | char *path) | 161 | char *path) |
119 | { | 162 | { |
120 | char *delim = "?"; | 163 | char *delim = "?"; |
121 | 164 | ||
122 | html("<a"); | 165 | html("<a"); |
123 | if (title) { | 166 | if (title) { |
124 | html(" title='"); | 167 | html(" title='"); |
@@ -526,16 +569,20 @@ void cgit_print_pageheader(struct cgit_context *ctx) | |||
526 | cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, | 569 | cgit_log_link("log", NULL, hc(cmd, "log"), ctx->qry.head, |
527 | NULL, NULL, 0, NULL, NULL); | 570 | NULL, NULL, 0, NULL, NULL); |
528 | cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, | 571 | cgit_tree_link("tree", NULL, hc(cmd, "tree"), ctx->qry.head, |
529 | ctx->qry.sha1, NULL); | 572 | ctx->qry.sha1, NULL); |
530 | cgit_commit_link("commit", NULL, hc(cmd, "commit"), | 573 | cgit_commit_link("commit", NULL, hc(cmd, "commit"), |
531 | ctx->qry.head, ctx->qry.sha1); | 574 | ctx->qry.head, ctx->qry.sha1); |
532 | cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, | 575 | cgit_diff_link("diff", NULL, hc(cmd, "diff"), ctx->qry.head, |
533 | ctx->qry.sha1, ctx->qry.sha2, NULL); | 576 | ctx->qry.sha1, ctx->qry.sha2, NULL); |
577 | if (ctx->repo->readme) | ||
578 | reporevlink("about", "about", NULL, | ||
579 | hc(cmd, "about"), ctx->qry.head, NULL, | ||
580 | NULL); | ||
534 | html("</td><td class='form'>"); | 581 | html("</td><td class='form'>"); |
535 | html("<form class='right' method='get' action='"); | 582 | html("<form class='right' method='get' action='"); |
536 | if (ctx->cfg.virtual_root) | 583 | if (ctx->cfg.virtual_root) |
537 | html_attr(cgit_fileurl(ctx->qry.repo, "log", | 584 | html_attr(cgit_fileurl(ctx->qry.repo, "log", |
538 | ctx->qry.path, NULL)); | 585 | ctx->qry.path, NULL)); |
539 | html("'>\n"); | 586 | html("'>\n"); |
540 | add_hidden_formfields(1, 0, "log"); | 587 | add_hidden_formfields(1, 0, "log"); |
541 | html("<select name='qt'>\n"); | 588 | html("<select name='qt'>\n"); |
@@ -544,19 +591,19 @@ void cgit_print_pageheader(struct cgit_context *ctx) | |||
544 | html_option("committer", "committer", ctx->qry.grep); | 591 | html_option("committer", "committer", ctx->qry.grep); |
545 | html("</select>\n"); | 592 | html("</select>\n"); |
546 | html("<input class='txt' type='text' size='10' name='q' value='"); | 593 | html("<input class='txt' type='text' size='10' name='q' value='"); |
547 | html_attr(ctx->qry.search); | 594 | html_attr(ctx->qry.search); |
548 | html("'/>\n"); | 595 | html("'/>\n"); |
549 | html("<input type='submit' value='search'/>\n"); | 596 | html("<input type='submit' value='search'/>\n"); |
550 | html("</form>\n"); | 597 | html("</form>\n"); |
551 | } else { | 598 | } else { |
552 | html("<a class='active' href='"); | 599 | site_link(NULL, "index", NULL, hc(cmd, "repolist"), NULL); |
553 | html_attr(cgit_rooturl()); | 600 | if (ctx->cfg.root_readme) |
554 | html("'>index</a>\n"); | 601 | site_link("about", "about", NULL, hc(cmd, "about"), NULL); |
555 | html("</td><td class='form'>"); | 602 | html("</td><td class='form'>"); |
556 | html("<form method='get' action='"); | 603 | html("<form method='get' action='"); |
557 | html_attr(cgit_rooturl()); | 604 | html_attr(cgit_rooturl()); |
558 | html("'>\n"); | 605 | html("'>\n"); |
559 | html("<input type='text' name='q' size='10' value='"); | 606 | html("<input type='text' name='q' size='10' value='"); |
560 | html_attr(ctx->qry.search); | 607 | html_attr(ctx->qry.search); |
561 | html("'/>\n"); | 608 | html("'/>\n"); |
562 | html("<input type='submit' value='search'/>\n"); | 609 | html("<input type='submit' value='search'/>\n"); |