In 480a59ba60 (*printf-posix: ISO C 23: Support size specifiers 'wN' and
'wfN'., 2023-03-24), a major refactoring hides a bug in the conversion
of the code handling Windows' `%I64*` family of `printf()` formats:
before the refactoring, the `64` part was skipped (as desired), but
afterwards that part is not skipped and therefore the `6` is mistaken
for a conversion character. Which is invalid, of course, causing the
code to error out.

Fix this by skipping the `64` part again.

This bug was uncovered by the Git for Windows project when `gettext`
v0.22.3 switched to the gnulib code as work horse of the
`libintl_vsnprintf()` function.

Signed-off-by: Johannes Schindelin <johannes.schinde...@gmx.de>
---
Published-As: 
https://github.com/dscho/gnulib/releases/tag/fix-printf-I64-regression-v1
Fetch-It-Via: git fetch https://github.com/dscho/gnulib 
fix-printf-I64-regression-v1

 lib/printf-parse.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/lib/printf-parse.c b/lib/printf-parse.c
index d3f2c3cb5d..6741ee5ff4 100644
--- a/lib/printf-parse.c
+++ b/lib/printf-parse.c
@@ -555,7 +555,7 @@ PRINTF_PARSE (const CHAR_T *format, DIRECTIVES *d, 
arguments *a)
                     unsigned_type = TYPE_ULONGINT;
                     pointer_type = TYPE_COUNT_LONGINT_POINTER;
                   }
-                cp++;
+                cp += 3;
               }
 #endif


base-commit: 5c8fc31ab5db3372739a7ae9bf579cef946408ad
--
2.43.0.rc1.windows.1

Reply via email to