diff options
author | Lars Hjemli <hjemli@gmail.com> | 2008-10-05 17:16:48 +0200 |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2008-10-05 17:16:48 +0200 |
commit | c6bea0375aa7898ea3229483741944303740801e (patch) | |
tree | 249000a4b85dbab2a7067042f9d835bc0a5e5f8f /html.c | |
parent | Merge branch 'lh/escape-urls' (diff) | |
parent | ui-repolist + ui-shared: Use cgit_summary_link() (diff) | |
download | cgit-pink-c6bea0375aa7898ea3229483741944303740801e.tar.gz cgit-pink-c6bea0375aa7898ea3229483741944303740801e.zip |
Merge branch 'lh/escape-urls'
* lh/escape-urls: ui-repolist + ui-shared: Use cgit_summary_link() ui-shared.c: add cgit_summary_link() ui-shared.c: use html_url_path() in repolink() html.c: add html_url_path
Diffstat (limited to '')
-rw-r--r-- | html.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/html.c b/html.c index 167127f..d7d9fd7 100644 --- a/html.c +++ b/html.c @@ -128,6 +128,22 @@ void html_attr(char *txt) html(txt); } +void html_url_path(char *txt) +{ + char *t = txt; + while(t && *t){ + int c = *t; + if (c=='"' || c=='#' || c=='\'' || c=='?') { + write(htmlfd, txt, t - txt); + write(htmlfd, fmt("%%%2x", c), 3); + txt = t+1; + } + t++; + } + if (t!=txt) + html(txt); +} + void html_url_arg(char *txt) { char *t = txt; |