diff options
author | Paul Smith <psmith@gnu.org> | 2005-04-13 03:16:33 +0000 |
---|---|---|
committer | Paul Smith <psmith@gnu.org> | 2005-04-13 03:16:33 +0000 |
commit | 49ee105c685cb84bc3057e8b7666fc0cc7090047 (patch) | |
tree | 178eec81c5e39f56db9ca4b513376b3e1c5d35bf /dep.h | |
parent | 3daf8df6ee835b9edcc068af33ae97910bb8d934 (diff) | |
download | gunmake-49ee105c685cb84bc3057e8b7666fc0cc7090047.tar.gz |
Fix performance degradation introduced by the second expansion feature.
I did this by adding intelligence into the algorithm such that the
second expansion was only actually performed when the prerequisite list
contained at least one "$", so we knew it is actually needed.
Without this we were using up a LOT more memory, since every single
target (even ones never used by make) had their file variables
initialized. This also used a lot more CPU, since we needed to create
and populate a new variable hash table for every target.
There is one issue remaining with this feature: it leaks memory. In
pattern_search() we now initialize the file variables for every pattern
target, which allocates a hash table, etc. However, sometimes we
recursively invoke pattern_search() (for intermediate files) with an
automatic variable (alloca() I believe) as the file. When that function
returns, obviously, the file variable hash memory is lost.
Diffstat (limited to 'dep.h')
-rw-r--r-- | dep.h | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -40,6 +40,7 @@ struct dep struct file *file; unsigned int changed : 8; unsigned int ignore_mtime : 1; + unsigned int need_2nd_expansion : 1; }; |