Re: [PATCH 6/8] diff: use emit_line_0 once per line

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Stefan,

On Fri, 10 Aug 2018, Stefan Beller wrote:

> All lines that use emit_line_0 multiple times per line, are combined
> into a single call to emit_line_0, making use of the 'set' argument.
> 
> Signed-off-by: Stefan Beller <sbeller@xxxxxxxxxx>
> Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx>
> ---
>  diff.c | 26 ++++++++++++--------------
>  1 file changed, 12 insertions(+), 14 deletions(-)
> 
> diff --git a/diff.c b/diff.c
> index 5eea5edca50..01095a59d3d 100644
> --- a/diff.c
> +++ b/diff.c
> @@ -629,10 +629,7 @@ static void emit_line_0(struct diff_options *o,
>  	int nofirst;
>  	FILE *file = o->file;
>  
> -	if (first)
> -		fputs(diff_line_prefix(o), file);
> -	else if (!len)
> -		return;
> +	fputs(diff_line_prefix(o), file);

How about separating this into its own "now that `first` is no longer
`NULL`, skip this" patch?

I found it a bit hard to review this diff, primarily because this hunk
would logically make more sense after the other hunks.


>  	if (len == 0) {
>  		has_trailing_newline = (first == '\n');
> @@ -652,13 +649,17 @@ static void emit_line_0(struct diff_options *o,
>  	if (len || !nofirst) {
>  		if (reverse && want_color(o->use_color))
>  			fputs(GIT_COLOR_REVERSE, file);
> -		if (set_sign && set_sign[0])
> -			fputs(set_sign, file);
> +		if (set_sign || set)
> +			fputs(set_sign ? set_sign : set, file);

Wait, what? Why is `set` all of a sudden also applying to `first`?

I would have expected `set_sign` to apply to `first`, and `set` to the
rest of the line.

>  		if (first && !nofirst)
>  			fputc(first, file);
> -		if (set)
> -			fputs(set, file);
> -		fwrite(line, len, 1, file);
> +		if (len) {
> +			if (set_sign && set && set != set_sign)
> +				fputs(reset, file);
> +			if (set)
> +				fputs(set, file);

That sounds as if `set == set_sign` would duplicate the `set`. How about
this instead?

			if (set && set != set_sign) {
				if (set_sign)
					fputs(reset, file);
				fputs(set, file);
			}

The rest looks good to me.

Thank you,
Dscho

> +			fwrite(line, len, 1, file);
> +		}
>  		fputs(reset, file);
>  	}
>  	if (has_trailing_carriage_return)
> @@ -1204,16 +1205,13 @@ static void emit_line_ws_markup(struct diff_options *o,
>  	if (!ws && !set_sign)
>  		emit_line_0(o, set, NULL, 0, reset, sign, line, len);
>  	else if (!ws) {
> -		/* Emit just the prefix, then the rest. */
> -		emit_line_0(o, set_sign, NULL, !!set_sign, reset, sign, "", 0);
> -		emit_line_0(o, set, NULL, 0, reset, 0, line, len);
> +		emit_line_0(o, set_sign, set, !!set_sign, reset, sign, line, len);
>  	} else if (blank_at_eof)
>  		/* Blank line at EOF - paint '+' as well */
>  		emit_line_0(o, ws, NULL, 0, reset, sign, line, len);
>  	else {
>  		/* Emit just the prefix, then the rest. */
> -		emit_line_0(o, set_sign ? set_sign : set, NULL, !!set_sign, reset,
> -			    sign, "", 0);
> +		emit_line_0(o, set_sign, set, !!set_sign, reset, sign, "", 0);
>  		ws_check_emit(line, len, ws_rule,
>  			      o->file, set, reset, ws);
>  	}
> -- 
> 2.18.0.865.gffc8e1a3cd6-goog
> 
> 



[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux