diff options
Diffstat (limited to 'include/git2/diff.h')
| -rw-r--r-- | include/git2/diff.h | 85 | 
1 files changed, 85 insertions, 0 deletions
| diff --git a/include/git2/diff.h b/include/git2/diff.h index f855f52ba..571f0c887 100644 --- a/include/git2/diff.h +++ b/include/git2/diff.h @@ -1072,6 +1072,91 @@ GIT_EXTERN(int) git_diff_buffers(  	git_diff_line_cb line_cb,  	void *payload); +/** + * This is an opaque structure which is allocated by `git_diff_get_stats`. + * You are responsible for releasing the object memory when done, using the + * `git_diff_stats_free()` function. + */ +typedef struct git_diff_stats git_diff_stats; + +/** + * Formatting options for diff stats + */ +typedef enum { +	/** No stats*/ +	GIT_DIFF_STATS_NONE = 0, + +	/** Full statistics, equivalent of `--stat` */ +	GIT_DIFF_STATS_FULL = (1u << 0), + +	/** Short statistics, equivalent of `--shortstat` */ +	GIT_DIFF_STATS_SHORT = (1u << 1), + +	/** Number statistics, equivalent of `--numstat` */ +	GIT_DIFF_STATS_NUMBER = (1u << 2), + +	/** Extended header information such as creations, renames and mode changes, equivalent of `--summary` */ +	GIT_DIFF_STATS_INCLUDE_SUMMARY = (1u << 3), +} git_diff_stats_format_t; + +/** + * Accumlate diff statistics for all patches. + * + * @param out Structure containg the diff statistics. + * @param diff A git_diff generated by one of the above functions. + * @return 0 on success; non-zero on error + */ +GIT_EXTERN(int) git_diff_get_stats( +	git_diff_stats **out, +	git_diff *diff); + +/** + * Get the total number of files changed in a diff + * + * @param stats A `git_diff_stats` generated by one of the above functions. + * @return total number of files changed in the diff + */ +GIT_EXTERN(size_t) git_diff_stats_files_changed( +	const git_diff_stats *stats); + +/** + * Get the total number of insertions in a diff + * + * @param stats A `git_diff_stats` generated by one of the above functions. + * @return total number of insertions in the diff + */ +GIT_EXTERN(size_t) git_diff_stats_insertions( +	const git_diff_stats *stats); + +/** + * Get the total number of deletions in a diff + * + * @param stats A `git_diff_stats` generated by one of the above functions. + * @return total number of deletions in the diff + */ +GIT_EXTERN(size_t) git_diff_stats_deletions( +	const git_diff_stats *stats); + +/** + * Print diff statistics to a `git_buf`. + * + * @param out buffer to store the formatted diff statistics in. + * @param stats A `git_diff_stats` generated by one of the above functions. + * @param format Formatting option. + * @return 0 on success; non-zero on error + */ +GIT_EXTERN(int) git_diff_stats_to_buf( +	git_buf *out, +	const git_diff_stats *stats, +	git_diff_stats_format_t format); + +/** + * Deallocate a `git_diff_stats`. + * + * @param stats The previously created statistics object; + * cannot be used after free. + */ +GIT_EXTERN(void) git_diff_stats_free(git_diff_stats *stats);  GIT_END_DECL | 
