From c5acb2f351e8758a6e192936964fcb6f0c15ded4 Mon Sep 17 00:00:00 2001 From: Enno Rehling Date: Sat, 1 Dec 2018 19:54:07 +0100 Subject: [PATCH] add a printf function to sbstring (about time) --- src/util/strings.c | 20 ++++++++++++++++++++ src/util/strings.h | 1 + src/util/strings.test.c | 26 ++++++++++++++++++++++++++ 3 files changed, 47 insertions(+) diff --git a/src/util/strings.c b/src/util/strings.c index 0ee0bd79c..7b9a9c6ef 100644 --- a/src/util/strings.c +++ b/src/util/strings.c @@ -260,6 +260,26 @@ char *str_strdup(const char *s) { #endif } +void sbs_printf(struct sbstring *sbs, const char *format, ...) +{ + size_t size = sbs->size - (sbs->end - sbs->begin); + + if (size > 0) { + va_list argp; + va_start(argp, format); + int bytes = vsnprintf(sbs->end, size, format, argp); + if (bytes > 0) { + if ((size_t)bytes >= size) { + bytes = size - 1; + /* terminate truncated output */ + sbs->end[bytes] = '\0'; + } + sbs->end += bytes; + } + va_end(argp); + } +} + void sbs_init(struct sbstring *sbs, char *buffer, size_t size) { assert(sbs); diff --git a/src/util/strings.h b/src/util/strings.h index 1e98a0968..d5bdd7e2f 100644 --- a/src/util/strings.h +++ b/src/util/strings.h @@ -49,6 +49,7 @@ extern "C" { char *end; } sbstring; + void sbs_printf(struct sbstring *sbs, const char *format, ...); void sbs_init(struct sbstring *sbs, char *buffer, size_t size); void sbs_adopt(struct sbstring *sbs, char *buffer, size_t size); void sbs_strcat(struct sbstring *sbs, const char *str); diff --git a/src/util/strings.test.c b/src/util/strings.test.c index 5b8db0473..47137a792 100644 --- a/src/util/strings.test.c +++ b/src/util/strings.test.c @@ -226,6 +226,31 @@ static void test_sbs_substr(CuTest * tc) CuAssertIntEquals(tc, 'A', buffer[9]); } +static void test_sbs_printf(CuTest * tc) +{ + char buffer[10]; + sbstring sbs; + + sbs_init(&sbs, buffer, sizeof(buffer)); + sbs_printf(&sbs, "%s %d", "1234", 5678); + CuAssertStrEquals(tc, "1234 5678", buffer); + + sbs_init(&sbs, buffer, sizeof(buffer)); + sbs_printf(&sbs, "%s", "12345"); + sbs_printf(&sbs, "%d", 6789); + CuAssertStrEquals(tc, "123456789", buffer); + + sbs_init(&sbs, buffer, sizeof(buffer)); + sbs_printf(&sbs, "%s", "1234567890"); + CuAssertStrEquals(tc, "123456789", buffer); + + sbs_init(&sbs, buffer, sizeof(buffer)); + sbs_printf(&sbs, "%d", 123456789); + CuAssertStrEquals(tc, "123456789", buffer); + sbs_printf(&sbs, "%s", "Hodor"); + CuAssertStrEquals(tc, "123456789", buffer); +} + CuSuite *get_strings_suite(void) { CuSuite *suite = CuSuiteNew(); @@ -240,5 +265,6 @@ CuSuite *get_strings_suite(void) SUITE_ADD_TEST(suite, test_sbstring); SUITE_ADD_TEST(suite, test_sbs_strcat); SUITE_ADD_TEST(suite, test_sbs_substr); + SUITE_ADD_TEST(suite, test_sbs_printf); return suite; }