--- guile/test-suite/standalone/test-unwind.c 2006-01-29 01:23:27.000000000 +0100 +++ guile/test-suite/standalone/test-unwind.c 2008-03-13 14:11:20.000000000 +0100 @@ -1,8 +1,55 @@ +/* Copyright (C) 2004, 2005, 2008 Free Software Foundation, Inc. + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#if HAVE_CONFIG_H +# include +#endif + +/* This blob per the Autoconf manual (under "Particular Functions"), updated + to match that of Gnulib. */ +#ifndef alloca +# if HAVE_ALLOCA_H +# include +# elif defined __GNUC__ +# define alloca __builtin_alloca +# elif defined _AIX +# define alloca __alloca +# elif defined _MSC_VER +# include +# define alloca _alloca +# else +# include +# ifdef __cplusplus +extern "C" +# endif +void *alloca (size_t); +# endif +#endif + #include #include #include #include +#ifdef HAVE_STRING_H +# include +#endif + + void set_flag (void *data); void func1 (void); void func2 (void); @@ -170,7 +217,17 @@ delete_file (void *data) void check_ports () { - char filename[] = "/tmp/check-ports.XXXXXX"; +#define FILENAME_TEMPLATE "/check-ports.XXXXXX" + char *filename; + const char *tmpdir = getenv ("TMPDIR"); + + if (tmpdir == NULL) + tmpdir = "/tmp"; + + filename = (char *) alloca (strlen (tmpdir) + + sizeof (FILENAME_TEMPLATE) + 1); + strcpy (filename, tmpdir); + strcat (filename, FILENAME_TEMPLATE); if (mktemp (filename) == NULL) exit (1); @@ -205,6 +262,7 @@ check_ports () } } scm_dynwind_end (); +#undef FILENAME_TEMPLATE } void --- guile/test-suite/tests/socket.test 2007-06-26 00:36:43.000000000 +0200 +++ guile/test-suite/tests/socket.test 2008-03-13 14:44:29.000000000 +0100 @@ -1,6 +1,6 @@ ;;;; socket.test --- test socket functions -*- scheme -*- ;;;; -;;;; Copyright (C) 2004, 2005, 2006, 2007 Free Software Foundation, Inc. +;;;; Copyright (C) 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. ;;;; ;;;; This library is free software; you can redistribute it and/or ;;;; modify it under the terms of the GNU Lesser General Public @@ -174,6 +174,15 @@ ;;; AF_UNIX sockets and `make-socket-address' ;;; +(define (temp-file-path) + ;; Return a temporary file path that honors `$TMPDIR', which `tmpnam' + ;; doesn't do. + (let ((dir (or (getenv "TMPDIR") "/tmp"))) + (string-append dir "/guile-test-socket-" + (number->string (current-time)) "-" + (number->string (random 100000))))) + + (if (defined? 'AF_UNIX) (with-test-prefix "AF_UNIX/SOCK_DGRAM" @@ -181,7 +190,7 @@ (let ((server-socket (socket AF_UNIX SOCK_DGRAM 0)) (server-bound? #f) - (path (tmpnam))) + (path (temp-file-path))) (pass-if "bind" (catch 'system-error @@ -196,7 +205,7 @@ (pass-if "bind/sockaddr" (let* ((sock (socket AF_UNIX SOCK_STREAM 0)) - (path (tmpnam)) + (path (temp-file-path)) (sockaddr (make-socket-address AF_UNIX path))) (catch 'system-error (lambda () @@ -233,7 +242,7 @@ (server-bound? #f) (server-listening? #f) (server-pid #f) - (path (tmpnam))) + (path (temp-file-path))) (pass-if "bind" (catch 'system-error @@ -248,7 +257,7 @@ (pass-if "bind/sockaddr" (let* ((sock (socket AF_UNIX SOCK_STREAM 0)) - (path (tmpnam)) + (path (temp-file-path)) (sockaddr (make-socket-address AF_UNIX path))) (catch 'system-error (lambda ()