On Wed, Nov 16 2022, Michael J Gruber wrote: > When `git notes` prepares the template it adds an empty newline between > the comment header and the content: > >> >> # >> # Write/edit the notes for the following object: >> >> # commit 0f3c55d4c2b7864bffb2d92278eff08d0b2e083f >> # etc > > This is wrong structurally because that newline is part of the comment, > too, and thus should be commented. Also, it throws off some positioning > strategies of editors and plugins, and it differs from how we do commit > templates. > > Change this to follow the standard set by `git commit`: I don't mind the consistency here, but what does "wrong structurally" mean? Doesn't the usual removing of duplicate newlines make this amount to the same? >> # >> # Write/edit the notes for the following object: >> # >> # commit 0f3c55d4c2b7864bffb2d92278eff08d0b2e083f >> > > Tests pass unchanged after this code change. Because it did change something and we've got bad test coverage, or just because it's really a stylistic change? I don't mind it being a stylistic change, but the proposed commit doesn't really make that clear, and leaves one wondering about potential missing test coverage etc. > Signed-off-by: Michael J Gruber <git@xxxxxxxxx> > --- > builtin/notes.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/builtin/notes.c b/builtin/notes.c > index be51f69225..80d9dfd25c 100644 > --- a/builtin/notes.c > +++ b/builtin/notes.c > @@ -181,7 +181,7 @@ static void prepare_note_data(const struct object_id *object, struct note_data * > strbuf_addch(&buf, '\n'); > strbuf_add_commented_lines(&buf, "\n", strlen("\n")); > strbuf_add_commented_lines(&buf, _(note_template), strlen(_(note_template))); > - strbuf_addch(&buf, '\n'); > + strbuf_add_commented_lines(&buf, "\n", strlen("\n")); > write_or_die(fd, buf.buf, buf.len); Nothing new as the pre-image shows, but I wondered why not just add a "#\n", before I remembered core.commentChar, so this is correct.