blob: 7198e6d3e6714500e000a38b3a2f95edcb4c1eba [file] [log] [blame]
# Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""Sync the Chrome source code used by Chrome OS to the specified directory."""
import functools
from chromite.lib import commandline
from chromite.lib import cros_build_lib
from chromite.lib import gclient
from chromite.lib import osutils
def GetParser():
"""Creates the argparse parser."""
parser = commandline.ArgumentParser(description=__doc__)
version = parser.add_mutually_exclusive_group()
version.add_argument('--tag', help='Sync to specified Chrome release',
dest='version')
version.add_argument('--revision', help='Sync to specified SVN revision',
type=int, dest='version')
parser.add_argument('--internal', help='Sync internal version of Chrome',
action='store_true', default=False)
parser.add_argument('--pdf', help='Sync PDF source code',
action='store_true', default=False)
parser.add_argument('--reset', help='Revert local changes',
action='store_true', default=False)
parser.add_argument('--gclient', help=commandline.argparse.SUPPRESS,
default='gclient')
parser.add_argument('chrome_root', help='Directory to sync chrome in')
return parser
def main(argv):
parser = GetParser()
options = parser.parse_args(argv)
# Revert any lingering local changes.
if not osutils.SafeMakedirs(options.chrome_root) and options.reset:
try:
gclient.Revert(options.gclient, options.chrome_root)
except cros_build_lib.RunCommandError:
osutils.RmDir(options.chrome_root)
osutils.SafeMakedirs(options.chrome_root)
# Sync new Chrome.
gclient.WriteConfigFile(options.gclient, options.chrome_root,
options.internal, options.pdf, options.version)
sync_fn = functools.partial(
gclient.Sync, options.gclient, options.chrome_root, reset=options.reset)
# Sync twice when run with --reset, which implies 'gclient sync -D'.
#
# There's a bug with 'gclient sync -D' that gets hit when the location of a
# dependency checkout (in the DEPS file) is moved to a path that contains
# (in a directory fashion) its old path. E.g., when Blink is moved from
# Webkit/Source/ to Webkit/. When this happens, a 'gclient sync -D' will
# blow away Webkit/Source/ after the sync, since it is no longer in the
# DEPS file, leaving the Blink checkout missing a Source/ subdirectory.
#
# This bug also gets hit the other way around - E.g., if Blink moves from
# Webkit/ to Webkit/Source/.
#
# To work around this, we sync twice, so that any directories deleted by
# the first sync will be restored in the second.
#
# TODO(rcui): Remove this workaround when the bug is fixed in gclient, or
# replace with a more sophisticated solution that syncs twice only when any
# paths in the DEPS file cannot be found after initial sync.
if options.reset:
sync_fn()
sync_fn()
return 0