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