Make rollback work with locally imported branches

Signed-off-by: Simon Hausmann <shausman@trolltech.com>
This commit is contained in:
Simon Hausmann 2007-05-23 20:07:57 +02:00
parent 65d2ade95e
commit 0c66a78393

View File

@ -136,18 +136,28 @@ class P4RollBack(Command):
def __init__(self): def __init__(self):
Command.__init__(self) Command.__init__(self)
self.options = [ self.options = [
optparse.make_option("--verbose", dest="verbose", action="store_true") optparse.make_option("--verbose", dest="verbose", action="store_true"),
optparse.make_option("--local", dest="rollbackLocalBranches", action="store_true")
] ]
self.description = "A tool to debug the multi-branch import. Don't use :)" self.description = "A tool to debug the multi-branch import. Don't use :)"
self.verbose = False self.verbose = False
self.rollbackLocalBranches = False
def run(self, args): def run(self, args):
if len(args) != 1: if len(args) != 1:
return False return False
maxChange = int(args[0]) maxChange = int(args[0])
for line in mypopen("git rev-parse --symbolic --remotes").readlines():
if line.startswith("p4/") and line != "p4/HEAD\n": if self.rollbackLocalBranches:
ref = "refs/remotes/" + line[:-1] refPrefix = "refs/heads/"
lines = mypopen("git rev-parse --symbolic --branches").readlines()
else:
refPrefix = "refs/remotes/"
lines = mypopen("git rev-parse --symbolic --remotes").readlines()
for line in lines:
if self.rollbackLocalBranches or (line.startswith("p4/") and line != "p4/HEAD\n"):
ref = refPrefix + line[:-1]
log = extractLogMessageFromGitCommit(ref) log = extractLogMessageFromGitCommit(ref)
depotPath, change = extractDepotPathAndChangeFromGitLog(log) depotPath, change = extractDepotPathAndChangeFromGitLog(log)
changed = False changed = False