Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(6)

Unified Diff: gclient.py

Issue 8135019: Move all mutations into a specific place. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/tools/depot_tools
Patch Set: Created 9 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | tests/gclient_test.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: gclient.py
diff --git a/gclient.py b/gclient.py
index ed64354f1b1043007f442bc4428b3e5e996e4e22..fd665f91af539e89167d4cd9fddc09f10010415f 100644
--- a/gclient.py
+++ b/gclient.py
@@ -258,8 +258,28 @@ class Dependency(gclient_utils.WorkItem, DependencySettings):
# This dependency had its hook run
self._hooks_ran = False
- # Setup self.requirements and find any other dependency who would have self
- # as a requirement.
+ if not self.name and self.parent:
+ raise gclient_utils.Error('Dependency without name')
+
+ def setup_requirements(self):
M-A Ruel 2011/10/05 00:40:52 ok you can laugh at me for splitting it again.
+ """Setup self.requirements and find any other dependency who would have self
+ as a requirement.
Dirk Pranke 2011/10/06 19:34:29 Nit: document the return value? It's not obvious t
M-A Ruel 2011/10/06 20:44:19 documented
+ """
+ if self.name in [s.name for s in self.parent.dependencies]:
+ raise gclient_utils.Error(
+ 'The same name "%s" appears multiple times in the deps section' %
+ self.name)
+ if self.should_process:
+ sibblings = [d for d in self.root.subtree(False) if d.name == self.name]
Dirk Pranke 2011/10/06 19:34:29 Nit: there's only one "b" in "siblings". Here and
M-A Ruel 2011/10/06 20:44:19 fixed
+ for sibbling in sibblings:
+ if self.url != sibbling.url:
+ raise gclient_utils.Error(
+ 'Dependency %s specified more than once:\n %s\nvs\n %s' %
+ (self.name, sibbling.hierarchy(), self.hierarchy()))
+ # In theory we could keep it as a shadow of the other one. In
+ # practice, simply ignore it.
+ logging.warn('Won\'t process duplicate dependency %s' % sibbling)
+ return False
# self.parent is implicitly a requirement. This will be recursive by
# definition.
@@ -298,9 +318,7 @@ class Dependency(gclient_utils.WorkItem, DependencySettings):
# Step 2: Find any requirements self may impose.
if obj.name.startswith(posixpath.join(self.name, '')):
obj.add_requirement(self.name)
-
- if not self.name and self.parent:
- raise gclient_utils.Error('Dependency without name')
+ return True
def LateOverride(self, url):
"""Resolves the parsed url from url.
@@ -416,8 +434,6 @@ class Dependency(gclient_utils.WorkItem, DependencySettings):
else:
deps.update(os_deps)
- self._deps_hooks.extend(local_scope.get('hooks', []))
-
# If a line is in custom_deps, but not in the solution, we want to append
# this line to the solution.
for d in self.custom_deps:
@@ -437,31 +453,21 @@ class Dependency(gclient_utils.WorkItem, DependencySettings):
deps = rel_deps
# Convert the deps into real Dependency.
+ deps_to_add = []
for name, url in deps.iteritems():
- if name in [s.name for s in self._dependencies]:
- raise gclient_utils.Error(
- 'The same name "%s" appears multiple times in the deps section' %
- name)
should_process = self.recursion_limit and self.should_process
- if should_process:
- tree = dict((d.name, d) for d in self.root.subtree(False))
- if name in tree:
- if url == tree[name].url:
- logging.info('Won\'t process duplicate dependency %s' % tree[name])
- # In theory we could keep it as a shadow of the other one. In
- # practice, simply ignore it.
- #should_process = False
- continue
- else:
- raise gclient_utils.Error(
- 'Dependency %s specified more than once:\n %s\nvs\n %s' %
- (name, tree[name].hierarchy(), self.hierarchy()))
- self._dependencies.append(
- Dependency(
- self, name, url, None, None, None, None,
- self.deps_file, should_process))
- self._deps_parsed = True
- logging.debug('Loaded: %s' % str(self))
+ deps_to_add.append(Dependency(
+ self, name, url, None, None, None, None,
+ self.deps_file, should_process))
+ self.add_dependencies_and_close(deps_to_add, local_scope.get('hooks', []))
+ logging.info('ParseDepsFile(%s) done' % self.name)
+
+ def add_dependencies_and_close(self, deps_to_add, hooks):
Dirk Pranke 2011/10/06 19:34:29 does it make sense to make this a locked method? O
M-A Ruel 2011/10/06 20:44:19 Yes and that's the purpose. The lock must be kept
Dirk Pranke 2011/10/06 20:50:46 Well, there's nothing in setup_requirements that c
M-A Ruel 2011/10/06 20:57:35 Yes there is something. setup_requirements() does
+ """Adds the dependencies, hooks and mark the parsing as done."""
+ for dep in deps_to_add:
+ if dep.setup_requirements():
+ self.add_dependency(dep)
+ self._mark_as_parsed(hooks)
Dirk Pranke 2011/10/06 20:50:46 I thought I had mentioned this in the earlier emai
M-A Ruel 2011/10/06 20:57:35 If I'd do that, I'd have to add this call at the o
# Arguments number differs from overridden method
# pylint: disable=W0221
@@ -632,7 +638,17 @@ class Dependency(gclient_utils.WorkItem, DependencySettings):
if j.should_process:
yield j
+ @gclient_utils.lockedmethod
+ def add_dependency(self, new_dep):
+ self._dependencies.append(new_dep)
+
+ @gclient_utils.lockedmethod
+ def _mark_as_parsed(self, new_hooks):
+ self._deps_hooks.extend(new_hooks)
+ self._deps_parsed = True
+
@property
+ @gclient_utils.lockedmethod
def dependencies(self):
return tuple(self._dependencies)
@@ -765,13 +781,11 @@ solutions = [
exec(content, config_dict)
except SyntaxError, e:
gclient_utils.SyntaxErrorToError('.gclient', e)
+
+ deps_to_add = []
for s in config_dict.get('solutions', []):
try:
- tree = dict((d.name, d) for d in self.root.subtree(False))
- if s['name'] in tree:
- raise gclient_utils.Error(
- 'Dependency %s specified more than once in .gclient' % s['name'])
- self._dependencies.append(Dependency(
+ deps_to_add.append(Dependency(
self, s['name'], s['url'],
s.get('safesync_url', None),
s.get('managed', True),
@@ -782,9 +796,8 @@ solutions = [
except KeyError:
raise gclient_utils.Error('Invalid .gclient file. Solution is '
'incomplete: %s' % s)
- # .gclient can have hooks.
- self._deps_hooks = config_dict.get('hooks', [])
- self._deps_parsed = True
+ self.add_dependencies_and_close(deps_to_add, config_dict.get('hooks', []))
+ logging.info('SetConfig() done')
def SaveConfig(self):
gclient_utils.FileWrite(os.path.join(self.root_dir,
« no previous file with comments | « no previous file | tests/gclient_test.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698