mirror of
https://gitea.quitesimple.org/crtxcr/cgitsb
synced 2024-11-23 00:12:10 +01:00
html: html_ntxt with no ellipsis
For implementing a ui-blame page, there is need for a function that outputs a selection from a block of text, transformed for HTML output, but with no further modifications or additions. Signed-off-by: Jeff Smith <whydoubt@gmail.com> Reviewed-by: John Keeping <john@keeping.me.uk>
This commit is contained in:
parent
3b485cc542
commit
70787254b2
32
html.c
32
html.c
@ -124,29 +124,20 @@ void html_vtxtf(const char *format, va_list ap)
|
|||||||
|
|
||||||
void html_txt(const char *txt)
|
void html_txt(const char *txt)
|
||||||
{
|
{
|
||||||
const char *t = txt;
|
if (txt)
|
||||||
while (t && *t) {
|
html_ntxt(txt, strlen(txt));
|
||||||
int c = *t;
|
|
||||||
if (c == '<' || c == '>' || c == '&') {
|
|
||||||
html_raw(txt, t - txt);
|
|
||||||
if (c == '>')
|
|
||||||
html(">");
|
|
||||||
else if (c == '<')
|
|
||||||
html("<");
|
|
||||||
else if (c == '&')
|
|
||||||
html("&");
|
|
||||||
txt = t + 1;
|
|
||||||
}
|
|
||||||
t++;
|
|
||||||
}
|
|
||||||
if (t != txt)
|
|
||||||
html(txt);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void html_ntxt(int len, const char *txt)
|
ssize_t html_ntxt(const char *txt, size_t len)
|
||||||
{
|
{
|
||||||
const char *t = txt;
|
const char *t = txt;
|
||||||
while (t && *t && len--) {
|
ssize_t slen;
|
||||||
|
|
||||||
|
if (len > SSIZE_MAX)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
slen = (ssize_t) len;
|
||||||
|
while (t && *t && slen--) {
|
||||||
int c = *t;
|
int c = *t;
|
||||||
if (c == '<' || c == '>' || c == '&') {
|
if (c == '<' || c == '>' || c == '&') {
|
||||||
html_raw(txt, t - txt);
|
html_raw(txt, t - txt);
|
||||||
@ -162,8 +153,7 @@ void html_ntxt(int len, const char *txt)
|
|||||||
}
|
}
|
||||||
if (t != txt)
|
if (t != txt)
|
||||||
html_raw(txt, t - txt);
|
html_raw(txt, t - txt);
|
||||||
if (len < 0)
|
return slen;
|
||||||
html("...");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void html_attrf(const char *fmt, ...)
|
void html_attrf(const char *fmt, ...)
|
||||||
|
2
html.h
2
html.h
@ -19,7 +19,7 @@ __attribute__((format (printf,1,2)))
|
|||||||
extern void html_attrf(const char *format,...);
|
extern void html_attrf(const char *format,...);
|
||||||
|
|
||||||
extern void html_txt(const char *txt);
|
extern void html_txt(const char *txt);
|
||||||
extern void html_ntxt(int len, const char *txt);
|
extern ssize_t html_ntxt(const char *txt, size_t len);
|
||||||
extern void html_attr(const char *txt);
|
extern void html_attr(const char *txt);
|
||||||
extern void html_url_path(const char *txt);
|
extern void html_url_path(const char *txt);
|
||||||
extern void html_url_arg(const char *txt);
|
extern void html_url_arg(const char *txt);
|
||||||
|
@ -329,7 +329,8 @@ void cgit_print_repolist(void)
|
|||||||
repourl = cgit_repourl(ctx.repo->url);
|
repourl = cgit_repourl(ctx.repo->url);
|
||||||
html_link_open(repourl, NULL, NULL);
|
html_link_open(repourl, NULL, NULL);
|
||||||
free(repourl);
|
free(repourl);
|
||||||
html_ntxt(ctx.cfg.max_repodesc_len, ctx.repo->desc);
|
if (html_ntxt(ctx.repo->desc, ctx.cfg.max_repodesc_len) < 0)
|
||||||
|
html("...");
|
||||||
html_link_close();
|
html_link_close();
|
||||||
html("</td><td>");
|
html("</td><td>");
|
||||||
if (ctx.cfg.enable_index_owner) {
|
if (ctx.cfg.enable_index_owner) {
|
||||||
|
Loading…
Reference in New Issue
Block a user