From bcda4011918a88064d35908b089a3300e187245a Mon Sep 17 00:00:00 2001 From: Alexander Golubev Date: Sat, 16 Mar 2024 19:05:22 +0300 Subject: Fix TQString::sprintf() not calling va_end() in case of bad cformat Also rearrange code a bit so it would be obvious that the function doesn't return a dangling reference. Signed-off-by: Alexander Golubev --- src/tools/qstring.cpp | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) (limited to 'src/tools') diff --git a/src/tools/qstring.cpp b/src/tools/qstring.cpp index 26e9b61cd..28b9c520c 100644 --- a/src/tools/qstring.cpp +++ b/src/tools/qstring.cpp @@ -2619,13 +2619,12 @@ TQString &TQString::sprintf(const char *cformat, ...) if ( !cformat || !*cformat ) { // TQt 1.x compat *this = fromLatin1( "" ); - return *this; + } else { + vsprintf(cformat, ap); } - TQString &s = vsprintf(cformat, ap); - va_end(ap); - return s; + return *this; } TQString &TQString::vsprintf( const char* cformat, va_list ap ) -- cgit v1.2.1