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): replace Dir_Destroy with SearchPath_Free



details:   https://anonhg.NetBSD.org/src/rev/f23ed6666e2b
branches:  trunk
changeset: 978670:f23ed6666e2b
user:      rillig <rillig%NetBSD.org@localhost>
date:      Sat Nov 28 22:56:01 2020 +0000

description:
make(1): replace Dir_Destroy with SearchPath_Free

The function Dir_Destroy is an implementation detail of the cached
directories, and it should not be exported to the other modules.  The
search paths, on the other hand, are the high-level API that may be used
by the other modules, as the concept of search paths is documented in
the manual page.

diffstat:

 usr.bin/make/dir.c     |  29 +++++++++++++++++++++++------
 usr.bin/make/dir.h     |   4 ++--
 usr.bin/make/nonints.h |  10 +++++++++-
 usr.bin/make/parse.c   |  20 ++++++++++----------
 usr.bin/make/suff.c    |  21 +++++++++------------
 5 files changed, 53 insertions(+), 31 deletions(-)

diffs (265 lines):

diff -r 8a462c842ef6 -r f23ed6666e2b usr.bin/make/dir.c
--- a/usr.bin/make/dir.c        Sat Nov 28 22:53:06 2020 +0000
+++ b/usr.bin/make/dir.c        Sat Nov 28 22:56:01 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: dir.c,v 1.224 2020/11/28 22:13:56 rillig Exp $ */
+/*     $NetBSD: dir.c,v 1.225 2020/11/28 22:56:01 rillig Exp $ */
 
 /*
  * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -136,7 +136,7 @@
 #include "job.h"
 
 /*     "@(#)dir.c      8.2 (Berkeley) 1/2/94"  */
-MAKE_RCSID("$NetBSD: dir.c,v 1.224 2020/11/28 22:13:56 rillig Exp $");
+MAKE_RCSID("$NetBSD: dir.c,v 1.225 2020/11/28 22:56:01 rillig Exp $");
 
 #define DIR_DEBUG0(text) DEBUG0(DIR, text)
 #define DIR_DEBUG1(fmt, arg1) DEBUG1(DIR, fmt, arg1)
@@ -229,6 +229,8 @@
        HashTable_Init(&odirs->table);
 }
 
+static void Dir_Destroy(void *);
+
 #ifdef CLEANUP
 static void
 OpenDirs_Done(OpenDirs *odirs)
@@ -366,7 +368,7 @@
 void
 Dir_Init(void)
 {
-       dirSearchPath = Lst_New();
+       dirSearchPath = SearchPath_New();
        OpenDirs_Init(&openDirs);
        HashTable_Init(&mtimes);
        HashTable_Init(&lmtimes);
@@ -854,10 +856,12 @@
                        if (*end == '/')
                                *end = '\0';
 
-                       partPath = Lst_New();
+                       partPath = SearchPath_New();
                        (void)Dir_AddDir(partPath, dirpath);
                        DirExpandPath(cp + 1, partPath, expansions);
                        Lst_Free(partPath);
+                       /* XXX: Should the dirs in partPath be freed here?
+                        * It's not obvious whether to free them or not. */
                }
        }
 
@@ -1475,7 +1479,7 @@
 SearchPath *
 Dir_CopyDirSearchPath(void)
 {
-       SearchPath *path = Lst_New();
+       SearchPath *path = SearchPath_New();
        SearchPathNode *ln;
        for (ln = dirSearchPath->first; ln != NULL; ln = ln->next) {
                CachedDir *dir = ln->datum;
@@ -1532,7 +1536,7 @@
  * Input:
  *     dirp            The directory descriptor to nuke
  */
-void
+static void
 Dir_Destroy(void *dirp)
 {
        CachedDir *dir = dirp;
@@ -1547,6 +1551,19 @@
        }
 }
 
+/* Free the search path and all directories mentioned in it. */
+void
+SearchPath_Free(SearchPath *path)
+{
+       SearchPathNode *ln;
+
+       for (ln = path->first; ln != NULL; ln = ln->next) {
+               CachedDir *dir = ln->datum;
+               Dir_Destroy(dir);
+       }
+       Lst_Free(path);
+}
+
 /* Clear out all elements from the given search path.
  * The path is set to the empty list but is not destroyed. */
 void
diff -r 8a462c842ef6 -r f23ed6666e2b usr.bin/make/dir.h
--- a/usr.bin/make/dir.h        Sat Nov 28 22:53:06 2020 +0000
+++ b/usr.bin/make/dir.h        Sat Nov 28 22:56:01 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: dir.h,v 1.36 2020/11/28 22:13:56 rillig Exp $  */
+/*     $NetBSD: dir.h,v 1.37 2020/11/28 22:56:01 rillig Exp $  */
 
 /*
  * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -85,6 +85,7 @@
                                 * Not sure what happens when .CURDIR is
                                 * assigned a new value; see Parse_DoVar. */
     int refCount;              /* Number of SearchPaths with this directory */
+    /* TODO: Log the reference counting; see Dir_Expand, partPath. */
     int hits;                  /* The number of times a file in this
                                 * directory has been found */
     HashSet files;             /* The files in the directory. */
@@ -107,7 +108,6 @@
 void SearchPath_AddAll(SearchPath *, SearchPath *);
 void Dir_PrintDirectories(void);
 void SearchPath_Print(SearchPath *);
-void Dir_Destroy(void *);
 SearchPath *Dir_CopyDirSearchPath(void);
 
 /* Stripped-down variant of struct stat. */
diff -r 8a462c842ef6 -r f23ed6666e2b usr.bin/make/nonints.h
--- a/usr.bin/make/nonints.h    Sat Nov 28 22:53:06 2020 +0000
+++ b/usr.bin/make/nonints.h    Sat Nov 28 22:56:01 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nonints.h,v 1.162 2020/11/16 21:48:18 rillig Exp $     */
+/*     $NetBSD: nonints.h,v 1.163 2020/11/28 22:56:01 rillig Exp $     */
 
 /*-
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -96,6 +96,14 @@
 void Cond_restore_depth(unsigned int);
 unsigned int Cond_save_depth(void);
 
+/* dir.c; see also dir.h */
+
+MAKE_INLINE SearchPath *
+SearchPath_New(void)
+{ return Lst_New(); }
+
+void SearchPath_Free(SearchPath *);
+
 /* for.c */
 int For_Eval(const char *);
 Boolean For_Accum(const char *);
diff -r 8a462c842ef6 -r f23ed6666e2b usr.bin/make/parse.c
--- a/usr.bin/make/parse.c      Sat Nov 28 22:53:06 2020 +0000
+++ b/usr.bin/make/parse.c      Sat Nov 28 22:56:01 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: parse.c,v 1.458 2020/11/28 22:13:56 rillig Exp $       */
+/*     $NetBSD: parse.c,v 1.459 2020/11/28 22:56:01 rillig Exp $       */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -117,7 +117,7 @@
 #include "pathnames.h"
 
 /*     "@(#)parse.c    8.3 (Berkeley) 3/19/94" */
-MAKE_RCSID("$NetBSD: parse.c,v 1.458 2020/11/28 22:13:56 rillig Exp $");
+MAKE_RCSID("$NetBSD: parse.c,v 1.459 2020/11/28 22:56:01 rillig Exp $");
 
 /* types and constants */
 
@@ -1205,11 +1205,11 @@
         * use Dir_Destroy in the destruction of the path as the
         * Dir module could have added a directory to the path...
         */
-       SearchPath *emptyPath = Lst_New();
+       SearchPath *emptyPath = SearchPath_New();
 
        Dir_Expand(line, emptyPath, curTargs);
 
-       Lst_Destroy(emptyPath, Dir_Destroy);
+       SearchPath_Free(emptyPath);
     } else {
        /*
         * No wildcards, but we want to avoid code duplication,
@@ -3111,9 +3111,9 @@
 Parse_Init(void)
 {
     mainNode = NULL;
-    parseIncPath = Lst_New();
-    sysIncPath = Lst_New();
-    defSysIncPath = Lst_New();
+    parseIncPath = SearchPath_New();
+    sysIncPath = SearchPath_New();
+    defSysIncPath = SearchPath_New();
     Vector_Init(&includes, sizeof(IFile));
 #ifdef CLEANUP
     targCmds = Lst_New();
@@ -3127,9 +3127,9 @@
 #ifdef CLEANUP
     Lst_Destroy(targCmds, free);
     assert(targets == NULL);
-    Lst_Destroy(defSysIncPath, Dir_Destroy);
-    Lst_Destroy(sysIncPath, Dir_Destroy);
-    Lst_Destroy(parseIncPath, Dir_Destroy);
+    SearchPath_Free(defSysIncPath);
+    SearchPath_Free(sysIncPath);
+    SearchPath_Free(parseIncPath);
     assert(includes.len == 0);
     Vector_Done(&includes);
 #endif
diff -r 8a462c842ef6 -r f23ed6666e2b usr.bin/make/suff.c
--- a/usr.bin/make/suff.c       Sat Nov 28 22:53:06 2020 +0000
+++ b/usr.bin/make/suff.c       Sat Nov 28 22:56:01 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: suff.c,v 1.314 2020/11/28 22:13:56 rillig Exp $        */
+/*     $NetBSD: suff.c,v 1.315 2020/11/28 22:56:01 rillig Exp $        */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -114,7 +114,7 @@
 #include "dir.h"
 
 /*     "@(#)suff.c     8.4 (Berkeley) 3/21/94" */
-MAKE_RCSID("$NetBSD: suff.c,v 1.314 2020/11/28 22:13:56 rillig Exp $");
+MAKE_RCSID("$NetBSD: suff.c,v 1.315 2020/11/28 22:56:01 rillig Exp $");
 
 #define SUFF_DEBUG0(text) DEBUG0(SUFF, text)
 #define SUFF_DEBUG1(fmt, arg1) DEBUG1(SUFF, fmt, arg1)
@@ -368,7 +368,7 @@
     Lst_Free(suff->ref);
     Lst_Free(suff->children);
     Lst_Free(suff->parents);
-    Lst_Destroy(suff->searchPath, Dir_Destroy);
+    SearchPath_Free(suff->searchPath);
 
     free(suff->name);
     free(suff);
@@ -436,7 +436,7 @@
 
     suff->name = bmake_strdup(name);
     suff->nameLen = strlen(suff->name);
-    suff->searchPath = Lst_New();
+    suff->searchPath = SearchPath_New();
     suff->children = Lst_New();
     suff->parents = Lst_New();
     suff->ref = Lst_New();
@@ -835,11 +835,8 @@
 {
     SuffixListNode *ln;
     char *flags;
-    SearchPath *inIncludes; /* Cumulative .INCLUDES path */
-    SearchPath *inLibs;            /* Cumulative .LIBS path */
-
-    inIncludes = Lst_New();
-    inLibs = Lst_New();
+    SearchPath *inIncludes = SearchPath_New(); /* Cumulative .INCLUDES path */
+    SearchPath *inLibs = SearchPath_New();     /* Cumulative .LIBS path */
 
     for (ln = sufflist->first; ln != NULL; ln = ln->next) {
        Suffix *suff = ln->datum;
@@ -854,7 +851,7 @@
 #endif
            SearchPath_AddAll(suff->searchPath, dirSearchPath);
        } else {
-           Lst_Destroy(suff->searchPath, Dir_Destroy);
+           SearchPath_Free(suff->searchPath);
            suff->searchPath = Dir_CopyDirSearchPath();
        }
     }
@@ -867,8 +864,8 @@
     Var_Set(".LIBS", flags, VAR_GLOBAL);
     free(flags);
 
-    Lst_Destroy(inIncludes, Dir_Destroy);
-    Lst_Destroy(inLibs, Dir_Destroy);
+    SearchPath_Free(inIncludes);
+    SearchPath_Free(inLibs);
 }
 
 /*



Home | Main Index | Thread Index | Old Index