X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/3c32fe07717f27fc891b66ccd06057fb810d03ad..97b3d252629a8a3b9d356c2532dec7611438e4b9:/cgit.h diff --git a/cgit.h b/cgit.h index cb2f176..f10ba05 100644 --- a/cgit.h +++ b/cgit.h @@ -15,6 +15,7 @@ #include #include #include +#include #include #include @@ -47,6 +48,15 @@ typedef void (*configfn)(const char *name, const char *value); typedef void (*filepair_fn)(struct diff_filepair *pair); typedef void (*linediff_fn)(char *line, int len); +struct cgit_filter { + char *cmd; + char **argv; + int old_stdout; + int pipe_fh[2]; + int pid; + int exitstatus; +}; + struct cgit_repo { char *url; char *name; @@ -61,7 +71,10 @@ struct cgit_repo { int snapshots; int enable_log_filecount; int enable_log_linecount; + int max_stats; time_t mtime; + struct cgit_filter *commit_filter; + struct cgit_filter *source_filter; }; struct cgit_repolist { @@ -120,6 +133,7 @@ struct cgit_query { char *name; char *mimetype; char *url; + char *period; int ofs; int nohead; char *sort; @@ -133,6 +147,8 @@ struct cgit_config { char *css; char *favicon; char *footer; + char *head_include; + char *header; char *index_header; char *index_info; char *logo; @@ -151,6 +167,7 @@ struct cgit_config { int cache_repo_ttl; int cache_root_ttl; int cache_static_ttl; + int embedded; int enable_index_links; int enable_log_filecount; int enable_log_linecount; @@ -160,12 +177,16 @@ struct cgit_config { int max_lock_attempts; int max_msg_len; int max_repodesc_len; + int max_stats; int nocache; + int noheader; int renamelimit; int snapshots; int summary_branches; int summary_log; int summary_tags; + struct cgit_filter *commit_filter; + struct cgit_filter *source_filter; }; struct cgit_page { @@ -175,7 +196,10 @@ struct cgit_page { char *mimetype; char *charset; char *filename; + char *etag; char *title; + int status; + char *statusmsg; }; struct cgit_context { @@ -218,7 +242,8 @@ extern void *cgit_free_commitinfo(struct commitinfo *info); extern int cgit_diff_files(const unsigned char *old_sha1, const unsigned char *new_sha1, - linediff_fn fn); + unsigned long *old_size, unsigned long *new_size, + int *binary, linediff_fn fn); extern void cgit_diff_tree(const unsigned char *old_sha1, const unsigned char *new_sha1, @@ -236,5 +261,8 @@ extern const char *cgit_repobasename(const char *reponame); extern int cgit_parse_snapshots_mask(const char *str); +extern int cgit_open_filter(struct cgit_filter *filter); +extern int cgit_close_filter(struct cgit_filter *filter); + #endif /* CGIT_H */