database: do not redundantly mark specs concrete
Speed up reads by not traversing each spec recursively when marking them concrete.
This commit is contained in:
parent
6fe931ccb1
commit
52508e6ee7
@ -795,7 +795,7 @@ def invalid_record(hash_key, error):
|
||||
# do it *while* we're constructing specs,it causes hashes to be
|
||||
# cached prematurely.
|
||||
for hash_key, rec in data.items():
|
||||
rec.spec._mark_concrete()
|
||||
rec.spec._mark_root_concrete()
|
||||
|
||||
self._data = data
|
||||
|
||||
|
@ -2538,6 +2538,13 @@ def concretize(self, tests=False):
|
||||
else:
|
||||
self._old_concretize(tests)
|
||||
|
||||
def _mark_root_concrete(self, value=True):
|
||||
"""Mark just this spec (not dependencies) concrete."""
|
||||
if (not value) and self.concrete and self.package.installed:
|
||||
return
|
||||
self._normal = value
|
||||
self._concrete = value
|
||||
|
||||
def _mark_concrete(self, value=True):
|
||||
"""Mark this spec and its dependencies as concrete.
|
||||
|
||||
@ -2545,10 +2552,7 @@ def _mark_concrete(self, value=True):
|
||||
unless there is a need to force a spec to be concrete.
|
||||
"""
|
||||
for s in self.traverse():
|
||||
if (not value) and s.concrete and s.package.installed:
|
||||
continue
|
||||
s._normal = value
|
||||
s._concrete = value
|
||||
s._mark_root_concrete(value)
|
||||
|
||||
def concretized(self, tests=False):
|
||||
"""This is a non-destructive version of concretize().
|
||||
|
Loading…
Reference in New Issue
Block a user