On 17.01.2025 17:09, Junio C Hamano wrote: > Junio C Hamano <gitster@xxxxxxxxx> writes: > > >> So, my suggestion would be: > >> > >> t8002: fix unportable printf formatting directives > >> > >> In e7fb2ca945 (builtin/blame: fix out-of-bounds write with blank > >> boundary commits, 2025-01-10), we have introduced two new tests that > >> expect a certain amount of padding. This padding is generated via > >> printf using the "%0.s" formatting directive. That directive is > >> non-portable and not understood by for example mksh, breaking these > >> tests on platforms using that shell. > >> > >> Fix this issue by using "%${N}s" instead, which is already being > >> used in t5300 and thus portable enough for us. > > > > Is "%.0s" really not portable, or is it just mksh > > being a bit lacking? Contrary to other shells mksh does not have printf builtin: $ mksh -c 'type printf' printf is a tracked alias for /bin/printf so it uses printf from coreutils. This version however interprets "0" as a flag marking "s"/"c" conversion specifiers as not allowed: https://git.savannah.gnu.org/gitweb/?p=coreutils.git;a=blob;f=src/printf.c;h=2a73bb7fed892347eafb40f497ce5080f511fc9b;hb=v9.6#l586 > > "That directive non-portable ..." -> "Some implementations (e.g. > > one that is built into mksh) does not support the precision to be 0 > > (i.e. "%.0" before the "s" conversion)" > > > > Other than that, your version is easy to read and understand. Note that original version was "%0.s" in which there is some ambiguity whether "0" is a flag or field width and not "%.0s" in which "0" indeed would mean precision. > >>> - $(printf "%0.s " $(test_seq 11)) (<author@xxxxxxxxxxx> 2005-04-07 15:45:13 -0700 1) abbrev > >>> + $(printf "%11s" "") (<author@xxxxxxxxxxx> 2005-04-07 15:45:13 -0700 1) abbrev > >>> EOF > >>> git blame -b --abbrev=10 ^HEAD -- abbrev.t >actual && > >>> test_cmp expect actual > >> > >> Okay, makes sense. And as mentioned, we already have such a use of > >> printf in t5300, so it should be portable enough for our use case. > > > > Thanks for reviewing, and thanks, Jan, for noticing and fixing. > > Sorry, as Jan is not a list regular, perhaps I should have > communicated more carefully when I said "Thanks". > > The above message from me with "Thanks" does not mean that the patch > is now settled. There are suggested improvements pending that needs > to be incorporated before the patch becomes acceptable to our tree. > > Anybody can help that "further polishing as suggested" step, and > when the patch is left in limbo for too long, I might step in to do > it myself (when I have no other better things to do), but it is > customary around here that the original patch submitter does so. I was about to follow-up but didn't find time. Sorry it took so long. I will post v2 shortly.