Commit 496b2258 authored by Mike Frysinger's avatar Mike Frysinger Committed by LUCI CQ

repo: update to v2.14

Change-Id: I60ed3a0c67d6dbc5c06afde928b7138d0837e8ac
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/tools/depot_tools/+/2837647
Auto-Submit: Mike Frysinger <vapier@chromium.org>
Reviewed-by: 's avatarStephane Belmon <sbelmon@google.com>
Commit-Queue: Stephane Belmon <sbelmon@google.com>
parent b8848852
...@@ -147,7 +147,7 @@ if not REPO_REV: ...@@ -147,7 +147,7 @@ if not REPO_REV:
REPO_REV = 'stable' REPO_REV = 'stable'
# increment this whenever we make important changes to this script # increment this whenever we make important changes to this script
VERSION = (2, 12) VERSION = (2, 14)
# increment this if the MAINTAINER_KEYS block is modified # increment this if the MAINTAINER_KEYS block is modified
KEYRING_VERSION = (2, 3) KEYRING_VERSION = (2, 3)
...@@ -275,6 +275,13 @@ def GetParser(gitc_init=False): ...@@ -275,6 +275,13 @@ def GetParser(gitc_init=False):
usage = 'repo init [options] [-u] url' usage = 'repo init [options] [-u] url'
parser = optparse.OptionParser(usage=usage) parser = optparse.OptionParser(usage=usage)
InitParser(parser, gitc_init=gitc_init)
return parser
def InitParser(parser, gitc_init=False):
"""Setup the CLI parser."""
# NB: Keep in sync with command.py:_CommonOptions().
# Logging. # Logging.
group = parser.add_option_group('Logging options') group = parser.add_option_group('Logging options')
...@@ -293,6 +300,20 @@ def GetParser(gitc_init=False): ...@@ -293,6 +300,20 @@ def GetParser(gitc_init=False):
help='manifest branch or revision (use HEAD for default)') help='manifest branch or revision (use HEAD for default)')
group.add_option('-m', '--manifest-name', group.add_option('-m', '--manifest-name',
help='initial manifest file', metavar='NAME.xml') help='initial manifest file', metavar='NAME.xml')
group.add_option('-g', '--groups', default='default',
help='restrict manifest projects to ones with specified '
'group(s) [default|all|G1,G2,G3|G4,-G5,-G6]',
metavar='GROUP')
group.add_option('-p', '--platform', default='auto',
help='restrict manifest projects to ones with a specified '
'platform group [auto|all|none|linux|darwin|...]',
metavar='PLATFORM')
group.add_option('--submodules', action='store_true',
help='sync any submodules associated with the manifest repo')
# Options that only affect manifest project, and not any of the projects
# specified in the manifest itself.
group = parser.add_option_group('Manifest (only) checkout options')
cbr_opts = ['--current-branch'] cbr_opts = ['--current-branch']
# The gitc-init subcommand allocates -c itself, but a lot of init users # The gitc-init subcommand allocates -c itself, but a lot of init users
# want -c, so try to satisfy both as best we can. # want -c, so try to satisfy both as best we can.
...@@ -301,9 +322,23 @@ def GetParser(gitc_init=False): ...@@ -301,9 +322,23 @@ def GetParser(gitc_init=False):
group.add_option(*cbr_opts, group.add_option(*cbr_opts,
dest='current_branch_only', action='store_true', dest='current_branch_only', action='store_true',
help='fetch only current manifest branch from server') help='fetch only current manifest branch from server')
group.add_option('--no-tags',
dest='tags', default=True, action='store_false',
help="don't fetch tags in the manifest")
# These are fundamentally different ways of structuring the checkout.
group = parser.add_option_group('Checkout modes')
group.add_option('--mirror', action='store_true', group.add_option('--mirror', action='store_true',
help='create a replica of the remote repositories ' help='create a replica of the remote repositories '
'rather than a client working directory') 'rather than a client working directory')
group.add_option('--archive', action='store_true',
help='checkout an archive instead of a git repository for '
'each project. See git archive.')
group.add_option('--worktree', action='store_true',
help='use git-worktree to manage projects')
# These are fundamentally different ways of structuring the checkout.
group = parser.add_option_group('Project checkout optimizations')
group.add_option('--reference', group.add_option('--reference',
help='location of mirror directory', metavar='DIR') help='location of mirror directory', metavar='DIR')
group.add_option('--dissociate', action='store_true', group.add_option('--dissociate', action='store_true',
...@@ -314,38 +349,27 @@ def GetParser(gitc_init=False): ...@@ -314,38 +349,27 @@ def GetParser(gitc_init=False):
group.add_option('--partial-clone', action='store_true', group.add_option('--partial-clone', action='store_true',
help='perform partial clone (https://git-scm.com/' help='perform partial clone (https://git-scm.com/'
'docs/gitrepository-layout#_code_partialclone_code)') 'docs/gitrepository-layout#_code_partialclone_code)')
group.add_option('--no-partial-clone', action='store_false',
help='disable use of partial clone (https://git-scm.com/'
'docs/gitrepository-layout#_code_partialclone_code)')
group.add_option('--partial-clone-exclude', action='store',
help='exclude the specified projects (a comma-delimited '
'project names) from partial clone (https://git-scm.com'
'/docs/gitrepository-layout#_code_partialclone_code)')
group.add_option('--clone-filter', action='store', default='blob:none', group.add_option('--clone-filter', action='store', default='blob:none',
help='filter for use with --partial-clone ' help='filter for use with --partial-clone '
'[default: %default]') '[default: %default]')
group.add_option('--worktree', action='store_true',
help=optparse.SUPPRESS_HELP)
group.add_option('--archive', action='store_true',
help='checkout an archive instead of a git repository for '
'each project. See git archive.')
group.add_option('--submodules', action='store_true',
help='sync any submodules associated with the manifest repo')
group.add_option('--use-superproject', action='store_true', default=None, group.add_option('--use-superproject', action='store_true', default=None,
help='use the manifest superproject to sync projects') help='use the manifest superproject to sync projects')
group.add_option('--no-use-superproject', action='store_false', group.add_option('--no-use-superproject', action='store_false',
dest='use_superproject', dest='use_superproject',
help='disable use of manifest superprojects') help='disable use of manifest superprojects')
group.add_option('-g', '--groups', default='default',
help='restrict manifest projects to ones with specified '
'group(s) [default|all|G1,G2,G3|G4,-G5,-G6]',
metavar='GROUP')
group.add_option('-p', '--platform', default='auto',
help='restrict manifest projects to ones with a specified '
'platform group [auto|all|none|linux|darwin|...]',
metavar='PLATFORM')
group.add_option('--clone-bundle', action='store_true', group.add_option('--clone-bundle', action='store_true',
help='enable use of /clone.bundle on HTTP/HTTPS ' help='enable use of /clone.bundle on HTTP/HTTPS '
'(default if not --partial-clone)') '(default if not --partial-clone)')
group.add_option('--no-clone-bundle', group.add_option('--no-clone-bundle',
dest='clone_bundle', action='store_false', dest='clone_bundle', action='store_false',
help='disable use of /clone.bundle on HTTP/HTTPS (default if --partial-clone)') help='disable use of /clone.bundle on HTTP/HTTPS (default if --partial-clone)')
group.add_option('--no-tags',
dest='tags', default=True, action='store_false',
help="don't fetch tags in the manifest")
# Tool. # Tool.
group = parser.add_option_group('repo Version options') group = parser.add_option_group('repo Version options')
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment