Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/make make(1): make InitVarMake simpler and document ...



details:   https://anonhg.NetBSD.org/src/rev/ab5b10463bde
branches:  trunk
changeset: 1015620:ab5b10463bde
user:      rillig <rillig%NetBSD.org@localhost>
date:      Tue Oct 27 18:12:15 2020 +0000

description:
make(1): make InitVarMake simpler and document its intention

diffstat:

 usr.bin/make/main.c |  43 +++++++++++++++++++------------------------
 1 files changed, 19 insertions(+), 24 deletions(-)

diffs (75 lines):

diff -r b4efff338a65 -r ab5b10463bde usr.bin/make/main.c
--- a/usr.bin/make/main.c       Tue Oct 27 17:36:17 2020 +0000
+++ b/usr.bin/make/main.c       Tue Oct 27 18:12:15 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: main.c,v 1.405 2020/10/27 17:36:17 rillig Exp $        */
+/*     $NetBSD: main.c,v 1.406 2020/10/27 18:12:15 rillig Exp $        */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -118,7 +118,7 @@
 #include "trace.h"
 
 /*     "@(#)main.c     8.3 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: main.c,v 1.405 2020/10/27 17:36:17 rillig Exp $");
+MAKE_RCSID("$NetBSD: main.c,v 1.406 2020/10/27 18:12:15 rillig Exp $");
 #if defined(MAKE_NATIVE) && !defined(lint)
 __COPYRIGHT("@(#) Copyright (c) 1988, 1989, 1990, 1993 "
            "The Regents of the University of California.  "
@@ -1095,31 +1095,26 @@
        opts.create = Lst_New();
 }
 
+/* Initialize MAKE and .MAKE to the path of the executable, so that it can be
+ * found by execvp(3) and the shells, even after a chdir.
+ *
+ * If it's a relative path and contains a '/', resolve it to an absolute path.
+ * Otherwise keep it as is, assuming it will be found in the PATH. */
 static void
-InitVarMake(char **argv)
+InitVarMake(const char *argv0)
 {
-       char mdpath[MAXPATHLEN];
-       const char *p1;
+       const char *make = argv0;
 
-       if (argv[0][0] == '/' || strchr(argv[0], '/') == NULL) {
-               /*
-                * Leave alone if it is an absolute path, or if it does
-                * not contain a '/' in which case we need to find it in
-                * the path, like execvp(3) and the shells do.
-                */
-               p1 = argv[0];
-       } else {
-               struct stat sb;
-               /*
-                * A relative path, canonicalize it.
-                */
-               p1 = cached_realpath(argv[0], mdpath);
-               if (!p1 || *p1 != '/' || stat(p1, &sb) < 0) {
-                       p1 = argv[0];           /* realpath failed */
-               }
+       if (argv0[0] != '/' && strchr(argv0, '/') != NULL) {
+               char pathbuf[MAXPATHLEN];
+               const char *abs = cached_realpath(argv0, pathbuf);
+               struct stat st;
+               if (abs != NULL && abs[0] == '/' && stat(make, &st) == 0)
+                       make = abs;
        }
-       Var_Set("MAKE", p1, VAR_GLOBAL);
-       Var_Set(".MAKE", p1, VAR_GLOBAL);
+
+       Var_Set("MAKE", make, VAR_GLOBAL);
+       Var_Set(".MAKE", make, VAR_GLOBAL);
 }
 
 static void
@@ -1370,7 +1365,7 @@
         *      MFLAGS also gets initialized empty, for compatibility.
         */
        Parse_Init();
-       InitVarMake(argv);
+       InitVarMake(argv[0]);
        Var_Set(MAKEFLAGS, "", VAR_GLOBAL);
        Var_Set(MAKEOVERRIDES, "", VAR_GLOBAL);
        Var_Set("MFLAGS", "", VAR_GLOBAL);



Home | Main Index | Thread Index | Old Index