[libc-commits] [libc] [libc] implement mkstemp (PR #199220)
Michael Jones via libc-commits
libc-commits at lists.llvm.org
Tue May 26 13:59:06 PDT 2026
================
@@ -0,0 +1,70 @@
+//===-- Implementation of mkstemp -----------------------------------------===//
+//
+// 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/stdlib/mkstemp.h"
+#include "hdr/errno_macros.h"
+#include "hdr/fcntl_macros.h"
+#include "src/__support/CPP/string_view.h"
+#include "src/__support/OSUtil/linux/syscall_wrappers/getrandom.h"
+#include "src/__support/OSUtil/linux/syscall_wrappers/open.h"
+#include "src/__support/common.h"
+#include "src/__support/libc_errno.h"
+#include "src/__support/macros/config.h"
+#include "src/__support/macros/null_check.h"
+
+namespace LIBC_NAMESPACE_DECL {
+
+LLVM_LIBC_FUNCTION(int, mkstemp, (char *tmpl)) {
+ LIBC_CRASH_ON_NULLPTR(tmpl);
+
+ cpp::string_view str_view(tmpl);
+ size_t count = 0;
+ size_t len = str_view.size();
+
+ for (size_t i = len; i > 0; i--) {
+ if (str_view[i - 1] != 'X')
+ break;
+ count++;
+ }
+
+ if (count < 6) {
+ libc_errno = EINVAL;
+ return -1;
+ }
+
+ char *suffix = tmpl + len - count;
+
+ const char charset[] = "QWERTYUIOPASDFGHJKLZXCVBNM"
+ "qwertyuiopasdfghjklzxcvbnm"
+ "1234567890"
+ "._-";
----------------
michaelrj-google wrote:
for clarity, please sort these alphabetically. Also add a comment on where we got this character set from.
https://github.com/llvm/llvm-project/pull/199220
More information about the libc-commits
mailing list