make printshowfile more generic and like other functions - stagit-gopher - A git gopher frontend. (mirror) HTML git clone git://bitreich.org/stagit-gopher/ git://enlrupgkhuxnvlhsf6lc3fziv5h2hhfrinws65d7roiv6bfj7d652fid.onion/stagit-gopher/ DIR Log DIR Files DIR Refs DIR Tags DIR README DIR LICENSE --- DIR commit 5578784dda58fd79556bdc937e64f179d7ce5ea9 DIR parent ce535ae1afda4af825cc81af9b4f32a5dd09d73b HTML Author: Hiltjo Posthuma <hiltjo@codemadness.org> Date: Tue, 23 Feb 2016 20:37:17 +0100 make printshowfile more generic and like other functions Diffstat: M TODO | 2 ++ M stagit.c | 29 ++++++++++++++--------------- 2 files changed, 16 insertions(+), 15 deletions(-) --- DIR diff --git a/TODO b/TODO @@ -1,3 +1,5 @@ +check path truncation? snprintf(), strlcpy. + performance: - optimize git_diff_get_stats. - speed up generating files. DIR diff --git a/stagit.c b/stagit.c @@ -340,7 +340,7 @@ printcommit(FILE *fp, struct commitinfo *ci) } void -printshowfile(struct commitinfo *ci) +printshowfile(FILE *fp, struct commitinfo *ci) { const git_diff_delta *delta; const git_diff_hunk *hunk; @@ -348,18 +348,8 @@ printshowfile(struct commitinfo *ci) git_patch *patch; git_buf statsbuf; size_t ndeltas, nhunks, nhunklines; - FILE *fp; size_t i, j, k; - char path[PATH_MAX]; - snprintf(path, sizeof(path), "commit/%s.html", ci->oid); - /* check if file exists if so skip it */ - if (!access(path, F_OK)) - return; - - fp = efopen(path, "w"); - writeheader(fp); - fputs("<pre>", fp); printcommit(fp, ci); memset(&statsbuf, 0, sizeof(statsbuf)); @@ -424,9 +414,6 @@ printshowfile(struct commitinfo *ci) } git_buf_free(&statsbuf); - fputs("</pre>\n", fp); - writefooter(fp); - fclose(fp); return; } @@ -437,6 +424,8 @@ writelog(FILE *fp, const git_oid *oid) git_revwalk *w = NULL; git_oid id; size_t len; + char path[PATH_MAX]; + FILE *fpfile; git_revwalk_new(&w, repo); git_revwalk_push(w, oid); @@ -479,8 +468,18 @@ writelog(FILE *fp, const git_oid *oid) fputs("</td></tr>\n", fp); relpath = "../"; - printshowfile(ci); + snprintf(path, sizeof(path), "commit/%s.html", ci->oid); + /* check if file exists if so skip it */ + if (access(path, F_OK)) { + fpfile = efopen(path, "w"); + writeheader(fpfile); + fputs("<pre>", fpfile); + printshowfile(fpfile, ci); + fputs("</pre>\n", fpfile); + writefooter(fpfile); + fclose(fpfile); + } commitinfo_free(ci); } fputs("</tbody></table>", fp);