]>
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)
16 static void print_url(char *base
, char *suffix
)
20 if (ctx
.repo
->enable_log_filecount
)
22 if (ctx
.repo
->enable_log_linecount
)
27 if (suffix
&& *suffix
)
28 base
= fmt("%s/%s", base
, suffix
);
29 htmlf("<tr><td colspan='%d'><a href='", columns
);
33 html("</a></td></tr>\n");
36 static void print_urls(char *txt
, char *suffix
)
42 if (ctx
.repo
->enable_log_filecount
)
44 if (ctx
.repo
->enable_log_linecount
)
49 while (h
&& *h
== ' ')
54 while (t
&& *t
&& *t
!= ' ')
59 htmlf("<tr class='nohover'><td colspan='%d'> </td></tr>", columns
);
60 htmlf("<tr><th class='left' colspan='%d'>Clone</th></tr>\n", columns
);
68 void cgit_print_summary()
72 if (ctx
.repo
->enable_log_filecount
)
74 if (ctx
.repo
->enable_log_linecount
)
77 html("<table summary='repository info' class='list nowrap'>");
78 cgit_print_branches(ctx
.cfg
.summary_branches
);
79 htmlf("<tr class='nohover'><td colspan='%d'> </td></tr>", columns
);
80 cgit_print_tags(ctx
.cfg
.summary_tags
);
81 if (ctx
.cfg
.summary_log
> 0) {
82 htmlf("<tr class='nohover'><td colspan='%d'> </td></tr>", columns
);
83 cgit_print_log(ctx
.qry
.head
, 0, ctx
.cfg
.summary_log
, NULL
,
86 if (ctx
.repo
->clone_url
)
87 print_urls(expand_macros(ctx
.repo
->clone_url
), NULL
);
88 else if (ctx
.cfg
.clone_prefix
)
89 print_urls(ctx
.cfg
.clone_prefix
, ctx
.repo
->url
);
93 void cgit_print_repo_readme(char *path
)
95 char *slash
, *tmp
, *colon
, *ref
;
97 if (!ctx
.repo
->readme
|| !(*ctx
.repo
->readme
))
102 /* Check if the readme is tracked in the git repo. */
103 colon
= strchr(ctx
.repo
->readme
, ':');
104 if (colon
&& strlen(colon
) > 1) {
106 ref
= ctx
.repo
->readme
;
107 ctx
.repo
->readme
= colon
+ 1;
108 if (!(*ctx
.repo
->readme
))
112 /* Prepend repo path to relative readme path unless tracked. */
113 if (!ref
&& *ctx
.repo
->readme
!= '/')
114 ctx
.repo
->readme
= xstrdup(fmt("%s/%s", ctx
.repo
->path
,
117 /* If a subpath is specified for the about page, make it relative
118 * to the directory containing the configured readme.
121 slash
= strrchr(ctx
.repo
->readme
, '/');
127 tmp
= xmalloc(slash
- ctx
.repo
->readme
+ 1 + strlen(path
) + 1);
128 strncpy(tmp
, ctx
.repo
->readme
, slash
- ctx
.repo
->readme
+ 1);
129 strcpy(tmp
+ (slash
- ctx
.repo
->readme
+ 1), path
);
131 tmp
= ctx
.repo
->readme
;
133 /* Print the calculated readme, either from the git repo or from the
134 * filesystem, while applying the about-filter.
136 html("<div id='summary'>");
137 if (ctx
.repo
->about_filter
)
138 cgit_open_filter(ctx
.repo
->about_filter
);
140 cgit_print_file(tmp
, ref
);
143 if (ctx
.repo
->about_filter
)
144 cgit_close_filter(ctx
.repo
->about_filter
);