aboutsummaryrefslogtreecommitdiffstats
path: root/ui-summary.c
diff options
context:
space:
mode:
authorLars Hjemli <hjemli@gmail.com>2009-08-09 13:46:34 +0200
committerLars Hjemli <hjemli@gmail.com>2009-08-09 13:46:34 +0200
commitdb8b8cb9467625cb8d9ecb67863aa67590e59cc0 (patch)
treed27644fc1b98ec6365e74f3ba40c19f78f8a287f /ui-summary.c
parentMerge branch 'lh/plugins' (diff)
parentAdd 'about-filter' and 'repo.about-filter' options (diff)
downloadcgit-db8b8cb9467625cb8d9ecb67863aa67590e59cc0.tar.xz
cgit-db8b8cb9467625cb8d9ecb67863aa67590e59cc0.zip
Merge branch 'lh/about'
Conflicts: cgit.h
Diffstat (limited to 'ui-summary.c')
-rw-r--r--ui-summary.c28
1 files changed, 22 insertions, 6 deletions
diff --git a/ui-summary.c b/ui-summary.c
index ede4a62..a2c018e 100644
--- a/ui-summary.c
+++ b/ui-summary.c
@@ -66,11 +66,27 @@ void cgit_print_summary()
html("</table>");
}
-void cgit_print_repo_readme()
+void cgit_print_repo_readme(char *path)
{
- if (ctx.repo->readme) {
- html("<div id='summary'>");
- html_include(ctx.repo->readme);
- html("</div>");
- }
+ char *slash, *tmp;
+
+ if (!ctx.repo->readme)
+ return;
+
+ if (path) {
+ slash = strrchr(ctx.repo->readme, '/');
+ if (!slash)
+ return;
+ tmp = xmalloc(slash - ctx.repo->readme + 1 + strlen(path) + 1);
+ strncpy(tmp, ctx.repo->readme, slash - ctx.repo->readme + 1);
+ strcpy(tmp + (slash - ctx.repo->readme + 1), path);
+ } else
+ tmp = ctx.repo->readme;
+ html("<div id='summary'>");
+ if (ctx.repo->about_filter)
+ cgit_open_filter(ctx.repo->about_filter);
+ html_include(tmp);
+ if (ctx.repo->about_filter)
+ cgit_close_filter(ctx.repo->about_filter);
+ html("</div>");
}