Jeff Smith <[email protected]> writes:
> Signed-off-by: Jeff Smith <[email protected]>
> ---
> builtin.h | 2 --
> builtin/blame.c | 28 ----------------------------
> builtin/cat-file.c | 1 +
> diff.c | 23 +++++++++++++++++++++++
> diff.h | 7 +++++++
> 5 files changed, 31 insertions(+), 30 deletions(-)
This change makes sense regardless of your primary goal of the
series. It was not good that one builtin borrowing a helper from
another. The common helper should live outside builtin/ as a common
code, and in this case, diff.[ch] may be an OK place for it.
>
> diff --git a/builtin.h b/builtin.h
> index 9e4a898..498ac80 100644
> --- a/builtin.h
> +++ b/builtin.h
> @@ -25,8 +25,6 @@ struct fmt_merge_msg_opts {
> extern int fmt_merge_msg(struct strbuf *in, struct strbuf *out,
> struct fmt_merge_msg_opts *);
>
> -extern int textconv_object(const char *path, unsigned mode, const struct
> object_id *oid, int oid_valid, char **buf, unsigned long *buf_size);
> -
> extern int is_builtin(const char *s);
>
> extern int cmd_add(int argc, const char **argv, const char *prefix);
> diff --git a/builtin/blame.c b/builtin/blame.c
> index 42c56eb..c419981 100644
> --- a/builtin/blame.c
> +++ b/builtin/blame.c
> @@ -147,34 +147,6 @@ static int diff_hunks(mmfile_t *file_a, mmfile_t *file_b,
> }
>
> /*
> - * Prepare diff_filespec and convert it using diff textconv API
> - * if the textconv driver exists.
> - * Return 1 if the conversion succeeds, 0 otherwise.
> - */
> -int textconv_object(const char *path,
> - unsigned mode,
> - const struct object_id *oid,
> - int oid_valid,
> - char **buf,
> - unsigned long *buf_size)
> -{
> - struct diff_filespec *df;
> - struct userdiff_driver *textconv;
> -
> - df = alloc_filespec(path);
> - fill_filespec(df, oid->hash, oid_valid, mode);
> - textconv = get_textconv(df);
> - if (!textconv) {
> - free_filespec(df);
> - return 0;
> - }
> -
> - *buf_size = fill_textconv(textconv, df, buf);
> - free_filespec(df);
> - return 1;
> -}
> -
> -/*
> * Given an origin, prepare mmfile_t structure to be used by the
> * diff machinery
> */
> diff --git a/builtin/cat-file.c b/builtin/cat-file.c
> index 1890d7a..79a2c82 100644
> --- a/builtin/cat-file.c
> +++ b/builtin/cat-file.c
> @@ -5,6 +5,7 @@
> */
> #include "cache.h"
> #include "builtin.h"
> +#include "diff.h"
> #include "parse-options.h"
> #include "userdiff.h"
> #include "streaming.h"
> diff --git a/diff.c b/diff.c
> index 11eef1c..a62e989 100644
> --- a/diff.c
> +++ b/diff.c
> @@ -5270,6 +5270,29 @@ size_t fill_textconv(struct userdiff_driver *driver,
> return size;
> }
>
> +int textconv_object(const char *path,
> + unsigned mode,
> + const struct object_id *oid,
> + int oid_valid,
> + char **buf,
> + unsigned long *buf_size)
> +{
> + struct diff_filespec *df;
> + struct userdiff_driver *textconv;
> +
> + df = alloc_filespec(path);
> + fill_filespec(df, oid->hash, oid_valid, mode);
> + textconv = get_textconv(df);
> + if (!textconv) {
> + free_filespec(df);
> + return 0;
> + }
> +
> + *buf_size = fill_textconv(textconv, df, buf);
> + free_filespec(df);
> + return 1;
> +}
> +
> void setup_diff_pager(struct diff_options *opt)
> {
> /*
> diff --git a/diff.h b/diff.h
> index 5be1ee7..52ebd54 100644
> --- a/diff.h
> +++ b/diff.h
> @@ -385,6 +385,13 @@ extern size_t fill_textconv(struct userdiff_driver
> *driver,
> */
> extern struct userdiff_driver *get_textconv(struct diff_filespec *one);
>
> +/*
> + * Prepare diff_filespec and convert it using diff textconv API
> + * if the textconv driver exists.
> + * Return 1 if the conversion succeeds, 0 otherwise.
> + */
> +extern int textconv_object(const char *path, unsigned mode, const struct
> object_id *oid, int oid_valid, char **buf, unsigned long *buf_size);
> +
> extern int parse_rename_score(const char **cp_p);
>
> extern long parse_algorithm_value(const char *value);