summaryrefslogtreecommitdiffstats
path: root/src/engine/SCons
diff options
context:
space:
mode:
authorSteven Knight <knight@baldmt.com>2002-01-29 13:38:31 (GMT)
committerSteven Knight <knight@baldmt.com>2002-01-29 13:38:31 (GMT)
commitce7092c12926b8cd2c0df191a68bb5d1f2693f45 (patch)
tree8f8627b6bd4afedd996514b3d7aec580b7c8aab3 /src/engine/SCons
parentdc36fb89f35ecbaf2efa843946d20cf1d030f5b8 (diff)
downloadSCons-ce7092c12926b8cd2c0df191a68bb5d1f2693f45.zip
SCons-ce7092c12926b8cd2c0df191a68bb5d1f2693f45.tar.gz
SCons-ce7092c12926b8cd2c0df191a68bb5d1f2693f45.tar.bz2
Performance improvement: avoid recomputing signatures.
Diffstat (limited to 'src/engine/SCons')
-rw-r--r--src/engine/SCons/Node/FS.py14
-rw-r--r--src/engine/SCons/Node/NodeTests.py6
-rw-r--r--src/engine/SCons/Node/__init__.py5
-rw-r--r--src/engine/SCons/Taskmaster.py15
-rw-r--r--src/engine/SCons/TaskmasterTests.py3
5 files changed, 18 insertions, 25 deletions
diff --git a/src/engine/SCons/Node/FS.py b/src/engine/SCons/Node/FS.py
index 7c19b81..f28ac1f 100644
--- a/src/engine/SCons/Node/FS.py
+++ b/src/engine/SCons/Node/FS.py
@@ -501,19 +501,7 @@ class File(Entry):
else:
return 0
- def set_bsig(self, bsig):
- """Set the build signature for this file, updating the
- .sconsign entry."""
- Entry.set_bsig(self, bsig)
- self.set_sconsign()
-
- def set_csig(self, csig):
- """Set the content signature for this file, updating the
- .sconsign entry."""
- Entry.set_csig(self, csig)
- self.set_sconsign()
-
- def set_sconsign(self):
+ def store_sigs(self):
"""Update a file's .sconsign entry with its current info."""
self.dir.sconsign().set(self.name, self.get_timestamp(),
self.get_bsig(), self.get_csig())
diff --git a/src/engine/SCons/Node/NodeTests.py b/src/engine/SCons/Node/NodeTests.py
index 9dc2105..d2b1840 100644
--- a/src/engine/SCons/Node/NodeTests.py
+++ b/src/engine/SCons/Node/NodeTests.py
@@ -257,6 +257,12 @@ class NodeTestCase(unittest.TestCase):
node.set_csig('zzz')
assert node.get_csig() == 'zzz'
+ def test_store_sigs(self):
+ """Test calling the method to store signatures
+ """
+ node = SCons.Node.Node()
+ node.store_sigs()
+
def test_set_precious(self):
"""Test setting a Node's precious value
"""
diff --git a/src/engine/SCons/Node/__init__.py b/src/engine/SCons/Node/__init__.py
index 504c6d1..a992e06 100644
--- a/src/engine/SCons/Node/__init__.py
+++ b/src/engine/SCons/Node/__init__.py
@@ -173,6 +173,11 @@ class Node:
"""Set the signature of the node's content."""
self.csig = csig
+ def store_sigs(self):
+ """Make the signatures permanent (that is, store them in the
+ .sconsign file or equivalent)."""
+ pass
+
def set_precious(self, precious = 1):
"""Set the Node's precious value."""
self.precious = precious
diff --git a/src/engine/SCons/Taskmaster.py b/src/engine/SCons/Taskmaster.py
index 7ac594b..b247029 100644
--- a/src/engine/SCons/Taskmaster.py
+++ b/src/engine/SCons/Taskmaster.py
@@ -57,11 +57,10 @@ class Task:
def __init__(self, tm, targets, top):
self.tm = tm
self.targets = targets
- self.bsig = {}
self.top = top
def execute(self):
- if not self.targets[0].get_state() == SCons.Node.up_to_date:
+ if self.targets[0].get_state() != SCons.Node.up_to_date:
self.targets[0].build()
def get_target(self):
@@ -69,14 +68,6 @@ class Task:
"""
return self.targets[0]
- def set_bsig(self, target, bsig):
- """Set the task's (*not* the target's) build signature
- for this target.
-
- This will be used later to update the target's actual
- build signature *if* the build succeeds."""
- self.bsig[target] = bsig
-
def set_tstates(self, state):
"""Set all of the target nodes's states."""
for t in self.targets:
@@ -93,7 +84,7 @@ class Task:
if self.targets[0].get_state() == SCons.Node.executing:
self.set_tstates(SCons.Node.executed)
for t in self.targets:
- t.set_bsig(self.bsig[t])
+ t.store_sigs()
parents = {}
for p in reduce(lambda x, y: x + y.get_parents(), self.targets, []):
parents[p] = 1
@@ -140,7 +131,7 @@ class Task:
state = SCons.Node.up_to_date
for t in self.targets:
bsig = self.tm.calc.bsig(t)
- self.set_bsig(t, bsig)
+ t.set_bsig(bsig)
if not self.tm.calc.current(t, bsig):
state = SCons.Node.executing
self.set_tstates(state)
diff --git a/src/engine/SCons/TaskmasterTests.py b/src/engine/SCons/TaskmasterTests.py
index 799f8cf..cc97f0d 100644
--- a/src/engine/SCons/TaskmasterTests.py
+++ b/src/engine/SCons/TaskmasterTests.py
@@ -74,6 +74,9 @@ class Node:
def set_csig(self, csig):
self.csig = csig
+
+ def store_sigs(self):
+ pass
def children_are_executed(self):
return reduce(lambda x,y: ((y.get_state() == SCons.Node.executed