From 6dae1687b5fd4dd7ee104079da0df906fe393263 Mon Sep 17 00:00:00 2001 From: Marco Paland Date: Fri, 14 Sep 2018 13:48:27 +0200 Subject: [PATCH] fix(printf): fix negative argument precision Fixes #25 --- printf.c | 3 ++- test/test_suite.cpp | 3 +++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/printf.c b/printf.c index 50af8932..d71665f4 100644 --- a/printf.c +++ b/printf.c @@ -464,7 +464,8 @@ static int _vsnprintf(out_fct_type out, char* buffer, const size_t maxlen, const precision = _atoi(&format); } else if (*format == '*') { - precision = (unsigned int)va_arg(va, int); + const int prec = (int)va_arg(va, int); + precision = prec > 0 ? (unsigned int)prec : 0U; format++; } } diff --git a/test/test_suite.cpp b/test/test_suite.cpp index 05b95f70..e693851a 100644 --- a/test/test_suite.cpp +++ b/test/test_suite.cpp @@ -1226,6 +1226,9 @@ TEST_CASE("misc", "[]" ) { test::sprintf(buffer, "%.*f", 2, 0.33333333); REQUIRE(!strcmp(buffer, "0.33")); + test::sprintf(buffer, "%.*d", -1, 1); + REQUIRE(!strcmp(buffer, "1")); + test::sprintf(buffer, "%.3s", "foobar"); REQUIRE(!strcmp(buffer, "foo"));