mirror of
https://gerrit.googlesource.com/git-repo
synced 2025-01-06 16:14:25 +00:00
0a389e94de
If `repo start foo` fails due to uncommitted and unmergeable changes in a single project, we have switched half of the projects over to the new target branches, but didn't on the one that failed to move. This change improves the situation by doing three things differently: - We keep going when we encounter an error, so other projects that can successfully switch still switch. - We ignore projects whose current branch is already on the requested name; they are logically already setup. - We checkout the branch if it already exists, rather than trying to recreate the branch. Bug: REPO-22 Signed-off-by: Shawn O. Pearce <sop@google.com>
60 lines
1.7 KiB
Python
60 lines
1.7 KiB
Python
#
|
|
# Copyright (C) 2008 The Android Open Source Project
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
import sys
|
|
from command import Command
|
|
from git_command import git
|
|
|
|
class Start(Command):
|
|
common = True
|
|
helpSummary = "Start a new branch for development"
|
|
helpUsage = """
|
|
%prog <newbranchname> [<project>...]
|
|
|
|
This subcommand starts a new branch of development that is automatically
|
|
pulled from a remote branch.
|
|
|
|
It is equivalent to the following git commands:
|
|
|
|
"git branch --track <newbranchname> m/<codeline>",
|
|
or
|
|
"git checkout --track -b <newbranchname> m/<codeline>".
|
|
|
|
All three forms set up the config entries that repo bases some of its
|
|
processing on. Use %prog or git branch or checkout with --track to ensure
|
|
the configuration data is set up properly.
|
|
|
|
"""
|
|
|
|
def Execute(self, opt, args):
|
|
if not args:
|
|
self.Usage()
|
|
|
|
nb = args[0]
|
|
if not git.check_ref_format('heads/%s' % nb):
|
|
print >>sys.stderr, "error: '%s' is not a valid name" % nb
|
|
sys.exit(1)
|
|
|
|
err = []
|
|
for project in self.GetProjects(args[1:]):
|
|
if not project.StartBranch(nb):
|
|
err.append(project)
|
|
|
|
if err:
|
|
err.sort()
|
|
for p in err:
|
|
print >>sys.stderr, "error: cannot start in %s" % p.relpath
|
|
sys.exit(1)
|