[libc-commits] [libc] [wip] [libc] Implement vasprintf (PR #98824)
Joseph Huber via libc-commits
libc-commits at lists.llvm.org
Fri Jul 19 09:02:51 PDT 2024
================
@@ -0,0 +1,77 @@
+//===-- Implementation of vasprintf -----------------------------*- C++ -*-===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#include "src/stdio/vasprintf.h"
+
+#include "src/__support/OSUtil/io.h"
+#include "src/__support/arg_list.h"
+#include "src/stdio/printf.h"
+#include "src/stdio/printf_core/core_structs.h"
+#include "src/stdio/printf_core/printf_main.h"
+#include "src/stdio/printf_core/writer.h"
+#include <stdarg.h>
+#include <stdio.h>
+#include <stdlib.h> // malloc, realloc, free
+
+namespace LIBC_NAMESPACE {
+
+namespace {
+
+LIBC_INLINE int resize_overflow_hook(cpp::string_view new_str, void *target) {
+ printf_core::WriteBuffer *wb =
+ reinterpret_cast<printf_core::WriteBuffer *>(target);
+ size_t NewSize = new_str.size() + wb->buff_cur;
+ char *TmpBuf =
+ static_cast<char *>(realloc(wb->buff, NewSize + 1)); // +1 for null
+ if (TmpBuf == nullptr) {
+ return printf_core::FILE_WRITE_ERROR;
+ }
+ wb->buff = TmpBuf;
+ inline_memcpy(wb->buff + wb->buff_cur, new_str.data(), new_str.size());
+ wb->buff_cur = NewSize;
+ wb->buff_len = NewSize;
+ return printf_core::WRITE_OK;
+}
+
+} // namespace
+
+inline constexpr uint8_t defaultBufferSize = 200;
+
+LLVM_LIBC_FUNCTION(int, vasprintf,
+ (char **__restrict ret, const char *format, va_list vlist)) {
+ internal::ArgList args(vlist); // This holder class allows for easier copying
+ // and pointer semantics, as well as handling
+ // destruction automatically.
+ auto InitBuff = static_cast<char *>(malloc(defaultBufferSize));
+ if (InitBuff == nullptr)
+ return printf_core::FILE_WRITE_ERROR;
----------------
jhuber6 wrote:
Standard says that the value of the string is undefined, but we could probably set it to `nullptr` as well.
https://github.com/llvm/llvm-project/pull/98824
More information about the libc-commits
mailing list