From 86783a69c22e7d8434d1d3d94a95134510d5239c Mon Sep 17 00:00:00 2001 From: Robert Scott Date: Sun, 16 Jan 2022 23:09:14 +0000 Subject: [PATCH] libredirect: add support for mktemp --- pkgs/build-support/libredirect/libredirect.c | 16 ++++++++++++++++ pkgs/build-support/libredirect/test.c | 4 ++++ 2 files changed, 20 insertions(+) diff --git a/pkgs/build-support/libredirect/libredirect.c b/pkgs/build-support/libredirect/libredirect.c index 07eca43810ca..1222d2ee75c6 100644 --- a/pkgs/build-support/libredirect/libredirect.c +++ b/pkgs/build-support/libredirect/libredirect.c @@ -459,3 +459,19 @@ WRAPPER(char *, mkdtemp)(char *template) return template; } WRAPPER_DEF(mkdtemp) + +WRAPPER(char *, mktemp)(char *template) +{ + char * (*mktemp_real) (char *template) = LOOKUP_REAL(mktemp); + char buf[PATH_MAX]; + char * rewritten = rewrite_non_const(template, buf); + char * retval = mktemp_real(rewritten); + if (retval == NULL) { + return retval; + }; + if (rewritten != template) { + copy_temp_wildcard(template, rewritten, 0); + } + return template; +} +WRAPPER_DEF(mktemp) diff --git a/pkgs/build-support/libredirect/test.c b/pkgs/build-support/libredirect/test.c index 012e4aa4b283..144e6d3d66dd 100644 --- a/pkgs/build-support/libredirect/test.c +++ b/pkgs/build-support/libredirect/test.c @@ -121,6 +121,10 @@ int main(int argc, char *argv[]) assert(mkdtemp(buf) == buf); assert_mktemp_path(TESTDIR "/temp", "", buf); + strncpy(buf, TESTDIR "/tempXXXXXX", PATH_MAX); + assert(mktemp(buf) == buf); + assert_mktemp_path(TESTDIR "/temp", "", buf); + test_spawn(); test_system();