]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
2005-04-14 Ulrich Drepper <drepper@redhat.com>
authorRoland McGrath <roland@gnu.org>
Fri, 15 Apr 2005 05:46:43 +0000 (05:46 +0000)
committerRoland McGrath <roland@gnu.org>
Fri, 15 Apr 2005 05:46:43 +0000 (05:46 +0000)
[BZ #851]
* posix/execvp.c (execvp): Use file name including path when
trying to run it with shell.
* posix/Makefile: Add rules to build and run tst-execvp3.
* posix/tst-execvp3.c: New file.

posix/Makefile
posix/execvp.c
posix/tst-execvp3.c [new file with mode: 0644]

index 7f9f7bbd1d9f3b1e399021f002b8ae80cb9be677..6bccab98318194bce166ce1b1e93fd9dc3110c06 100644 (file)
@@ -86,7 +86,8 @@ tests         := tstgetopt testfnm runtests runptests      \
                   tst-getaddrinfo2 bug-glob1 bug-glob2 tst-sysconf \
                   tst-execvp1 tst-execvp2 tst-execlp1 tst-execlp2 \
                   tst-execv1 tst-execv2 tst-execl1 tst-execl2 \
-                  tst-execve1 tst-execve2 tst-execle1 tst-execle2
+                  tst-execve1 tst-execve2 tst-execle1 tst-execle2 \
+                  tst-execvp3
 xtests         := bug-ga2
 ifeq (yes,$(build-shared))
 test-srcs      := globtest
@@ -190,6 +191,7 @@ tst-rxspencer-ENV = LOCPATH=$(common-objpfx)localedata
 tst-pcre-ARGS = PCRE.tests
 tst-boost-ARGS = BOOST.tests
 bug-glob1-ARGS = "$(objpfx)"
+tst-execvp3-ARGS = --test-dir=$(objpfx)
 
 testcases.h: TESTS TESTS2C.sed
        sed -f TESTS2C.sed < $< > $@T
index 9809769701e75376fb749ccebdaf899254bbd076..6f4e4b8566cae138b423b483f167f42ae647090c 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 1991,92,1995-99,2002,2004 Free Software Foundation, Inc.
+/* Copyright (C) 1991,92,1995-99,2002,2004,2005 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -133,14 +133,14 @@ execvp (file, argv)
          else
            startp = (char *) memcpy (name - (p - path), path, p - path);
 
-         /* Try to execute this name.  If it works, execv will not return.  */
+         /* Try to execute this name.  If it works, execve will not return. */
          __execve (startp, argv, __environ);
 
          if (errno == ENOEXEC)
            {
              if (script_argv == NULL)
                {
-                 script_argv = allocate_scripts_argv (file, argv);
+                 script_argv = allocate_scripts_argv (startp, argv);
                  if (script_argv == NULL)
                    {
                      /* A possible EACCES error is not as important as
diff --git a/posix/tst-execvp3.c b/posix/tst-execvp3.c
new file mode 100644 (file)
index 0000000..5ebc879
--- /dev/null
@@ -0,0 +1,42 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+#include <sys/stat.h>
+
+
+static void do_prepare (void);
+#define PREPARE(argc, argv) do_prepare ()
+static int do_test (void);
+#define TEST_FUNCTION do_test ()
+
+#include "../test-skeleton.c"
+
+
+static char *fname;
+
+static void
+do_prepare (void)
+{
+  int fd = create_temp_file ("testscript", &fname);
+  dprintf (fd, "echo foo\n");
+  fchmod (fd, 0700);
+  close (fd);
+}
+
+
+static int
+do_test (void)
+{
+  if  (setenv ("PATH", test_dir, 1) != 0)
+    {
+      puts ("setenv failed");
+      return 1;
+    }
+
+  char *argv[] = { fname, NULL };
+  execvp (basename (fname), argv);
+
+  /* If we come here, the execvp call failed.  */
+  return 1;
+}