]>
git.cameronkatri.com Git - cgit.git/blob - ui-summary.c
1 /* ui-summary.c: functions for generating repo summary page
3 * Copyright (C) 2006 Lars Hjemli
4 * Copyright (C) 2010 Jason A. Donenfeld <Jason@zx2c4.com>
6 * Licensed under GNU General Public License v2
7 * (see COPYING for full license text)
11 #include "ui-summary.h"
17 static void print_url(char *base
, char *suffix
)
20 struct strbuf basebuf
= STRBUF_INIT
;
22 if (ctx
.repo
->enable_log_filecount
)
24 if (ctx
.repo
->enable_log_linecount
)
29 if (suffix
&& *suffix
) {
30 strbuf_addf(&basebuf
, "%s/%s", base
, suffix
);
33 htmlf("<tr><td colspan='%d'><a href='", columns
);
37 html("</a></td></tr>\n");
38 strbuf_release(&basebuf
);
41 static void print_urls(char *txt
, char *suffix
)
47 if (ctx
.repo
->enable_log_filecount
)
49 if (ctx
.repo
->enable_log_linecount
)
54 while (h
&& *h
== ' ')
59 while (t
&& *t
&& *t
!= ' ')
64 htmlf("<tr class='nohover'><td colspan='%d'> </td></tr>", columns
);
65 htmlf("<tr><th class='left' colspan='%d'>Clone</th></tr>\n", columns
);
73 void cgit_print_summary()
77 if (ctx
.repo
->enable_log_filecount
)
79 if (ctx
.repo
->enable_log_linecount
)
82 html("<table summary='repository info' class='list nowrap'>");
83 cgit_print_branches(ctx
.cfg
.summary_branches
);
84 htmlf("<tr class='nohover'><td colspan='%d'> </td></tr>", columns
);
85 cgit_print_tags(ctx
.cfg
.summary_tags
);
86 if (ctx
.cfg
.summary_log
> 0) {
87 htmlf("<tr class='nohover'><td colspan='%d'> </td></tr>", columns
);
88 cgit_print_log(ctx
.qry
.head
, 0, ctx
.cfg
.summary_log
, NULL
,
91 if (ctx
.repo
->clone_url
)
92 print_urls(expand_macros(ctx
.repo
->clone_url
), NULL
);
93 else if (ctx
.cfg
.clone_prefix
)
94 print_urls(ctx
.cfg
.clone_prefix
, ctx
.repo
->url
);
98 /* The caller must free filename and ref after calling this. */
99 void cgit_parse_readme(const char *readme
, const char *path
, char **filename
, char **ref
, struct cgit_repo
*repo
)
101 const char *slash
, *colon
;
102 char *resolved_base
, *resolved_full
;
107 if (!readme
|| !(*readme
))
110 /* Check if the readme is tracked in the git repo. */
111 colon
= strchr(readme
, ':');
112 if (colon
&& strlen(colon
) > 1) {
113 /* If it starts with a colon, we want to use
114 * the default branch */
115 if (colon
== readme
&& repo
->defbranch
)
116 *ref
= xstrdup(repo
->defbranch
);
118 *ref
= xstrndup(readme
, colon
- readme
);
122 /* Prepend repo path to relative readme path unless tracked. */
123 if (!(*ref
) && *readme
!= '/')
124 readme
= fmtalloc("%s/%s", repo
->path
, readme
);
126 /* If a subpath is specified for the about page, make it relative
127 * to the directory containing the configured readme. */
129 slash
= strrchr(readme
, '/');
135 *filename
= xmalloc(slash
- readme
+ 1 + strlen(path
) + 1);
136 strncpy(*filename
, readme
, slash
- readme
+ 1);
138 resolved_base
= realpath(*filename
, NULL
);
139 strcpy(*filename
+ (slash
- readme
+ 1), path
);
141 resolved_full
= realpath(*filename
, NULL
);
142 if (!(*ref
) && (!resolved_base
|| !resolved_full
|| strstr(resolved_full
, resolved_base
) != resolved_full
)) {
151 *filename
= xstrdup(readme
);
154 void cgit_print_repo_readme(char *path
)
156 char *filename
, *ref
;
157 cgit_parse_readme(ctx
.repo
->readme
, path
, &filename
, &ref
, ctx
.repo
);
162 /* Print the calculated readme, either from the git repo or from the
163 * filesystem, while applying the about-filter.
165 html("<div id='summary'>");
166 if (ctx
.repo
->about_filter
) {
167 ctx
.repo
->about_filter
->argv
[1] = filename
;
168 cgit_open_filter(ctx
.repo
->about_filter
);
171 cgit_print_file(filename
, ref
);
173 html_include(filename
);
174 if (ctx
.repo
->about_filter
) {
175 cgit_close_filter(ctx
.repo
->about_filter
);
176 ctx
.repo
->about_filter
->argv
[1] = NULL
;