summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbosk <>2011-04-29 15:27:39 +0000
committerbosk <>2011-04-29 15:27:39 +0000
commit1c298e2da94cf042d0911415c0079e125f96fb9e (patch)
tree7195e3533a19a39c21711123a993e356020a4d5c
parent43210ff7d539841c5c7b000761f6bf52ffa3bd90 (diff)
downloadmake-1c298e2da94cf042d0911415c0079e125f96fb9e.tar.gz
Delay caching of the file name in eval_makefile() until after all the
expansions and searches are complete. This fixes an assertion in a situation where the MAKEFILES variable contains a file path that contains tilde.
-rw-r--r--ChangeLog5
-rw-r--r--read.c15
2 files changed, 14 insertions, 6 deletions
diff --git a/ChangeLog b/ChangeLog
index 7d2155ac..e365f6bb 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2011-04-29 Boris Kolpackov <boris@codesynthesis.com>
+
+ * read.c (eval_makefile): Delay caching of the file name until after
+ all the expansions and searches.
+
2011-04-17 David A. Wheeler <dwheeler@dwheeler.com>
* doc/make.texi (Reading Makefiles): Document "!=".
diff --git a/read.c b/read.c
index c13ead87..299c2e5d 100644
--- a/read.c
+++ b/read.c
@@ -324,8 +324,7 @@ eval_makefile (const char *filename, int flags)
char *expanded = 0;
int makefile_errno;
- filename = strcache_add (filename);
- ebuf.floc.filenm = filename;
+ ebuf.floc.filenm = filename; /* Use the original file name. */
ebuf.floc.lineno = 1;
if (ISDB (DB_VERBOSE))
@@ -369,13 +368,17 @@ eval_makefile (const char *filename, int flags)
"/", filename);
ebuf.fp = fopen (included, "r");
if (ebuf.fp)
- {
- filename = strcache_add (included);
- break;
- }
+ {
+ filename = included;
+ break;
+ }
}
}
+ /* Now we have the final name for this makefile. Enter it into
+ the cache. */
+ filename = strcache_add (filename);
+
/* Add FILENAME to the chain of read makefiles. */
deps = alloc_dep ();
deps->next = read_makefiles;