Re: [PATCH] Allow custom "comment char"

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

 



Ralf Thielow <ralf.thielow@xxxxxxxxx> writes:

> From: Junio C Hamano <gitster@xxxxxxxxx>
>
> Some users do want to write a line that begin with a pound sign, #,
> in their commit log message.  Many tracking system recognise
> a token of #<bugid> form, for example.
>
> The support we offer these use cases is not very friendly to the end
> users.  They have a choice between
>
>  - Don't do it.  Avoid such a line by rewrapping or indenting; and
>
>  - Use --cleanup=whitespace but remove all the hint lines we add.
>
> Give them a way to set a custom comment char, e.g.
>
>     $ git -c core.commentchar="%" commit
>
> so that they do not have to do either of the two workarounds.
>
> Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx>
> Signed-off-by: Ralf Thielow <ralf.thielow@xxxxxxxxx>
> ---

It would have helped if you said you finished the NEEDSWORK: in
builtin/branch.c in the earlier draft with strbuf_commented_*
functions ;-)

Looks like a good progress overall, except for nits here and there.

> diff --git a/builtin/notes.c b/builtin/notes.c
> index 453457a..5e84e35 100644
> --- a/builtin/notes.c
> +++ b/builtin/notes.c
> @@ -92,10 +92,7 @@ static const char * const git_notes_get_ref_usage[] = {
>  };
>  
>  static const char note_template[] =
> -	"\n"
> -	"#\n"
> -	"# Write/edit the notes for the following object:\n"
> -	"#\n";
> +	"Write/edit the notes for the following object:";

I think this (and its use site that manually adds "\n#\n") is a
symptom of strbuf_commented_add*() function not designed right.
When it iterates over lines and adds each of them in a commented out
form, it could check if the line is an empty one and refrain from
adding a trailing SP if that is the case.  Then this can become

    "\nWrite/edit the notes...\n\n";

You have to create the "\n" blank line at the beginning manually,
but that is logically outside the commented out block, so it is not
a problem.

> @@ -181,11 +172,16 @@ static void create_note(const unsigned char *object, struct msg_arg *msg,
>  			write_or_die(fd, msg->buf.buf, msg->buf.len);
>  		else if (prev && !append_only)
>  			write_note_data(fd, prev);
> -		write_or_die(fd, note_template, strlen(note_template));
> +
> +		strbuf_addf(&buf, "\n%c\n", comment_line_char);
> +		strbuf_commented_addstr(&buf, note_template);
> +		strbuf_addf(&buf, "\n%c\n", comment_line_char);
> +		write_or_die(fd, buf.buf, buf.len);

> diff --git a/builtin/tag.c b/builtin/tag.c
> index 9c3e067..e1b72be 100644
> --- a/builtin/tag.c
> +++ b/builtin/tag.c
> @@ -246,19 +246,13 @@ static int do_sign(struct strbuf *buffer)
>  }
>  
>  static const char tag_template[] =
> -	N_("\n"
> -	"#\n"
> -	"# Write a tag message\n"
> -	"# Lines starting with '#' will be ignored.\n"
> -	"#\n");
> +	N_("Write a tag message\n"
> +	"Lines starting with '%c' will be ignored.");
> ...
> +			else
> +				strbuf_commented_addf(&buf, _(tag_template_nocleanup), comment_line_char);
> +			strbuf_addf(&buf, "\n%c\n", comment_line_char);
> +			write_or_die(fd, buf.buf, buf.len);

Same here.

> diff --git a/git-submodule.sh b/git-submodule.sh
> index 22ec5b6..1b8d95f 100755
> --- a/git-submodule.sh
> +++ b/git-submodule.sh
> @@ -975,13 +975,19 @@ cmd_summary() {
>  		echo
>  	done |
>  	if test -n "$for_status"; then
> +		comment_char=`git config core.commentchar`
> +		if [ ! -n "$comment_char" ]; then
> +			comment_char='#'
> +		elif [ ${#comment_char} -gt 1 ]; then

Not portable, I think.

> +		echo "$comment_char"
> +		sed -e "s|^|$comment_char |" -e "s|^$comment_char $|$comment_char|"

Can $comment_char be a '|'?

> diff --git a/strbuf.c b/strbuf.c
> index 9a373be..8af4b4f 100644
> --- a/strbuf.c
> +++ b/strbuf.c
> @@ -204,6 +204,44 @@ void strbuf_addf(struct strbuf *sb, const char *fmt, ...)
>  	va_end(ap);
>  }
>  
> +void strbuf_commented_addstr(struct strbuf *sb, const char *s)
> +{
> +	struct strbuf buf = STRBUF_INIT;
> +	struct strbuf prefix = STRBUF_INIT;
> +
> +	strbuf_addf(&prefix, "%c ", comment_line_char);
> +	strbuf_addstr(&buf, s);
> +	strbuf_add_lines(sb, prefix.buf, buf.buf, buf.len);
> +
> +	// remove additional '\n' added by strbuf_add_lines()

No C++ comments.
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[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]