From 032721c75dfa024e6b76269df8285909fdf04130 Mon Sep 17 00:00:00 2001 From: Explorer09 Date: Mon, 12 Aug 2024 23:45:58 +0800 Subject: [PATCH] Improve DynamicMeter_getUiName() string length logic Use 'size_t' for 'uiName' length variable and use String_safeStrncpy() for copying strings. Using 'size_t' for string length prevents a "-Wshorten-64-to-32" warning which is enabled by default in Clang 19. --- DynamicMeter.c | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/DynamicMeter.c b/DynamicMeter.c index 605474f83b..d0f20a2728 100644 --- a/DynamicMeter.c +++ b/DynamicMeter.c @@ -105,12 +105,13 @@ static void DynamicMeter_getUiName(const Meter* this, char* name, size_t length) if (meter) { const char* uiName = meter->caption; if (uiName) { - int len = strlen(uiName); - if (len > 2 && uiName[len - 2] == ':') - len -= 2; - xSnprintf(name, length, "%.*s", len, uiName); + size_t uiNameLen = strlen(uiName); + if (uiNameLen > 2 && uiName[uiNameLen - 2] == ':') + uiNameLen -= 2; + + String_safeStrncpy(name, uiName, MINIMUM(length, uiNameLen + 1)); } else { - xSnprintf(name, length, "%s", meter->name); + String_safeStrncpy(name, meter->name, length); } } }