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

Unified Diff: recipe_modules/gclient/config.py

Issue 1917433002: Generalize patch_project to patch root conversion. (Closed) Base URL: https://chromium.googlesource.com/chromium/tools/depot_tools.git@master
Patch Set: -line long Created 4 years, 8 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 | « recipe_modules/gclient/api.py ('k') | recipe_modules/rietveld/api.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: recipe_modules/gclient/config.py
diff --git a/recipe_modules/gclient/config.py b/recipe_modules/gclient/config.py
index c300edd506d54e52808063ac576d6ba3c322bcbe..1803a17bfc86ceea252b69163f91b95e3d55acbf 100644
--- a/recipe_modules/gclient/config.py
+++ b/recipe_modules/gclient/config.py
@@ -63,6 +63,20 @@ def BaseConfig(USE_MIRROR=True, GIT_MODE=False, CACHE_DIR=None,
parent_got_revision_mapping = Dict(hidden=True),
delete_unversioned_trees = Single(bool, empty_val=True, required=False),
+ # Maps patch_project to (solution/path, revision).
+ # - solution/path is then used to apply patches as patch root in
+ # bot_update.
+ # - if revision is given, it's passed verbatim to bot_update for
+ # corresponding dependency.
+ # This is essentially a whitelist of which projects inside a solution
+ # can be patched automatically by bot_update based on PATCH_PROJECT
+ # property.
+ # For example, bare chromium solution has this entry in patch_projects
+ # 'angle/angle': ('src/third_party/angle', 'HEAD')
+ # then a patch to Angle project can be applied to a chromium src's
+ # checkout after first updating Angle's repo to its master's HEAD.
+ patch_projects = Dict(value_type=tuple, hidden=True),
+
# Check out refs/branch-heads.
# TODO (machenbach): Only implemented for bot_update atm.
with_branch_heads = Single(
@@ -73,6 +87,8 @@ def BaseConfig(USE_MIRROR=True, GIT_MODE=False, CACHE_DIR=None,
GIT_MODE = Static(bool(GIT_MODE)),
USE_MIRROR = Static(bool(USE_MIRROR)),
+ # TODO(tandrii): remove PATCH_PROJECT field.
+ # DON'T USE THIS. WILL BE REMOVED.
PATCH_PROJECT = Static(str(PATCH_PROJECT), hidden=True),
BUILDSPEC_VERSION= Static(BUILDSPEC_VERSION, hidden=True),
)
@@ -146,18 +162,10 @@ def chromium_bare(c):
p['parent_got_v8_revision'] = 'v8_revision'
p['parent_got_webrtc_revision'] = 'webrtc_revision'
- # Patch project revisions are applied whenever patch_project is set. E.g. if
- # a v8 stand-alone patch is sent to a chromium trybot, patch_project is v8
- # and can be used to sync v8 to HEAD instead of the pinned chromium
- # version.
- patch_project_revisions = {
- 'v8': ('src/v8', 'HEAD'),
- }
-
- patch_revision = patch_project_revisions.get(c.PATCH_PROJECT)
- # TODO(phajdan.jr): Move to proper repo and add coverage.
- if patch_revision: # pragma: no cover
- c.revisions[patch_revision[0]] = patch_revision[1]
+ p = c.patch_projects
+ p['v8'] = ('src/v8', 'HEAD')
+ p['angle/angle'] = ('src/third_party/angle', None)
+ p['blink'] = ('src/third_party/WebKit', None)
@config_ctx(includes=['chromium_bare'])
def chromium_empty(c):
@@ -538,6 +546,10 @@ def infra(c):
soln.url = 'https://chromium.googlesource.com/infra/infra.git'
c.got_revision_mapping['infra'] = 'got_revision'
+ p = c.patch_projects
+ p['luci-py'] = ('infra/luci', 'HEAD')
+ p['recipes-py'] = ('infra/recipes-py', 'HEAD')
+
@config_ctx(config_vars={'GIT_MODE': True})
def infra_internal(c): # pragma: no cover
soln = c.solutions.add()
@@ -572,6 +584,7 @@ def luci_py(c):
# luci-py is checked out as part of infra just to have appengine
# pre-installed, as that's what luci-py PRESUBMIT relies on.
c.revisions['infra'] = 'origin/master'
+ # TODO(tandrii): make use of c.patch_projects.
c.revisions['infra/luci'] = (
gclient_api.RevisionFallbackChain('origin/master'))
m = c.got_revision_mapping
@@ -581,6 +594,7 @@ def luci_py(c):
@config_ctx(includes=['infra'])
def recipes_py(c):
c.revisions['infra'] = 'origin/master'
+ # TODO(tandrii): make use of c.patch_projects.
c.revisions['infra/recipes-py'] = (
gclient_api.RevisionFallbackChain('origin/master'))
m = c.got_revision_mapping
@@ -634,6 +648,7 @@ def angle_top_of_tree(c): # pragma: no cover
Sets up ToT instead of the DEPS-pinned revision for ANGLE.
"""
+ # TODO(tandrii): I think patch_projects in bare_chromium fixed this.
c.solutions[0].revision = 'HEAD'
c.revisions['src/third_party/angle'] = 'HEAD'
« no previous file with comments | « recipe_modules/gclient/api.py ('k') | recipe_modules/rietveld/api.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698