aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndroid Build Coastguard Worker <android-build-coastguard-worker@google.com>2023-04-20 23:13:13 +0000
committerAndroid Build Coastguard Worker <android-build-coastguard-worker@google.com>2023-04-20 23:13:13 +0000
commit8bbfdf2fca7197a0eccfef7b6fc27c590a44e7f7 (patch)
treed4e95b4855b772d7cf850fb6ab34420b47f7d803
parent8d725eb70bd9f15b4277c724f47aeaad23052478 (diff)
parent13465c3acf0f54b612fe593dd96fe7680ffb3516 (diff)
downloadpdfium-android14-release.tar.gz
Change-Id: If236638d61b41781ca786654ff0fc1c2d3f86b3b
-rw-r--r--core/fxcrt/widestring.cpp13
1 files changed, 4 insertions, 9 deletions
diff --git a/core/fxcrt/widestring.cpp b/core/fxcrt/widestring.cpp
index 10a31c3fa..4e51a85d9 100644
--- a/core/fxcrt/widestring.cpp
+++ b/core/fxcrt/widestring.cpp
@@ -287,18 +287,13 @@ static_assert(sizeof(WideString) <= sizeof(wchar_t*),
WideString WideString::FormatV(const wchar_t* format, va_list argList) {
va_list argListCopy;
va_copy(argListCopy, argList);
- int maxLen = vswprintf(nullptr, 0, format, argListCopy);
+ auto guess = GuessSizeForVSWPrintf(format, argListCopy);
va_end(argListCopy);
- if (maxLen <= 0) {
- va_copy(argListCopy, argList);
- auto guess = GuessSizeForVSWPrintf(format, argListCopy);
- va_end(argListCopy);
-
- if (!guess.has_value())
- return WideString();
- maxLen = pdfium::base::checked_cast<int>(guess.value());
+ if (!guess.has_value()) {
+ return WideString();
}
+ int maxLen = pdfium::base::checked_cast<int>(guess.value());
while (maxLen < 32 * 1024) {
va_copy(argListCopy, argList);