|
|
escape HTML in paths - stagit - static git page generator |
|
|
 |
git clone git://git.codemadness.org/stagit (git://git.codemadness.org) |
|
|
 |
Log |
|
|
 |
Files |
|
|
 |
Refs |
|
|
 |
README |
|
|
 |
LICENSE |
|
|
|
--- |
|
|
 |
commit 028c7526bac907c91ef8afc6c3ae0f6d424bd229 |
|
|
 |
parent bb1d06eb204b1d1135fcddccd14f6306abcd7f72 |
|
|
 |
Author: Hiltjo Posthuma <hiltjo@codemadness.org> (mailto://) |
application/vnd.lotus-organizer |
|
|
Date: Sat, 16 Mar 2019 13:07:58 +0100 |
|
|
|
|
|
|
|
escape HTML in paths |
|
|
|
|
|
|
|
- escape paths in diff line. |
|
|
|
- escape path in anchor href attribute in files.html |
|
|
|
|
|
|
|
Diffstat: |
|
|
|
M stagit.c | 16 ++++++++++++---- |
|
|
|
|
|
|
|
1 file changed, 12 insertions(+), 4 deletions(-) |
|
|
|
--- |
|
|
 |
diff --git a/stagit.c b/stagit.c |
|
|
|
@@ -532,9 +532,15 @@ printshowfile(FILE *fp, struct commitinfo *ci) |
|
|
|
for (i = 0; i < ci->ndeltas; i++) { |
|
|
|
patch = ci->deltas[i]->patch; |
|
|
|
delta = git_patch_get_delta(patch); |
|
|
|
- fprintf(fp, "<b>diff --git a/<a id=\"h%zu\" href=\"%sfile/%s.html\">%s</a> b/<a href=\"%sfile/%s.html\">%s</a></b>\n", |
|
|
|
- i, relpath, delta->old_file.path, delta->old_file.path, |
|
|
|
- relpath, delta->new_file.path, delta->new_file.path); |
|
|
|
+ fprintf(fp, "<b>diff --git a/<a id=\"h%zu\" href=\"%sfile/", i, relpath); |
|
|
|
+ xmlencode(fp, delta->old_file.path, strlen(delta->old_file.path)); |
|
|
|
+ fputs(".html\">", fp); |
|
|
|
+ xmlencode(fp, delta->old_file.path, strlen(delta->old_file.path)); |
|
|
|
+ fprintf(fp, "</a> b/<a href=\"%sfile/", relpath); |
|
|
|
+ xmlencode(fp, delta->new_file.path, strlen(delta->new_file.path)); |
|
|
|
+ fprintf(fp, ".html\">"); |
|
|
|
+ xmlencode(fp, delta->new_file.path, strlen(delta->new_file.path)); |
|
|
|
+ fprintf(fp, "</a></b>\n"); |
|
|
|
|
|
|
|
/* check binary data */ |
|
|
|
if (delta->flags & GIT_DIFF_FLAG_BINARY) { |
|
|
|
@@ -881,7 +887,9 @@ writefilestree(FILE *fp, git_tree *tree, const char *path) |
|
|
|
|
|
|
|
fputs("<tr><td>", fp); |
|
|
|
fputs(filemode(git_tree_entry_filemode(entry)), fp); |
|
|
|
- fprintf(fp, "</td><td><a href=\"%s%s\">", relpath, filepath); |
|
|
|
+ fprintf(fp, "</td><td><a href=\"%s", relpath); |
|
|
|
+ xmlencode(fp, filepath, strlen(filepath)); |
|
|
|
+ fputs("\">", fp); |
|
|
|
xmlencode(fp, entrypath, strlen(entrypath)); |
|
|
|
fputs("</a></td><td class=\"num\" align=\"right\">", fp); |
|
|
|
if (lc > 0) |
|