Merge branch 'ld/p4-import-labels'
Correct "git p4 --detect-labels" so that it does not fail to create a tag that points at a commit that is also being imported. * ld/p4-import-labels: git-p4: fix P4 label import for unprocessed commits git-p4: do not terminate creating tag for unknown commit git-p4: failing test for ignoring invalid p4 labels
This commit is contained in:
25
git-p4.py
25
git-p4.py
@ -2329,8 +2329,11 @@ class P4Sync(Command, P4UserMap):
|
||||
else:
|
||||
return "%s <a@b>" % userid
|
||||
|
||||
# Stream a p4 tag
|
||||
def streamTag(self, gitStream, labelName, labelDetails, commit, epoch):
|
||||
""" Stream a p4 tag.
|
||||
commit is either a git commit, or a fast-import mark, ":<p4commit>"
|
||||
"""
|
||||
|
||||
if verbose:
|
||||
print "writing tag %s for commit %s" % (labelName, commit)
|
||||
gitStream.write("tag %s\n" % labelName)
|
||||
@ -2381,7 +2384,7 @@ class P4Sync(Command, P4UserMap):
|
||||
self.clientSpecDirs.update_client_spec_path_cache(files)
|
||||
|
||||
self.gitStream.write("commit %s\n" % branch)
|
||||
# gitStream.write("mark :%s\n" % details["change"])
|
||||
self.gitStream.write("mark :%s\n" % details["change"])
|
||||
self.committedChanges.add(int(details["change"]))
|
||||
committer = ""
|
||||
if author not in self.users:
|
||||
@ -2500,13 +2503,19 @@ class P4Sync(Command, P4UserMap):
|
||||
if change.has_key('change'):
|
||||
# find the corresponding git commit; take the oldest commit
|
||||
changelist = int(change['change'])
|
||||
gitCommit = read_pipe(["git", "rev-list", "--max-count=1",
|
||||
"--reverse", ":/\[git-p4:.*change = %d\]" % changelist])
|
||||
if len(gitCommit) == 0:
|
||||
print "could not find git commit for changelist %d" % changelist
|
||||
else:
|
||||
gitCommit = gitCommit.strip()
|
||||
if changelist in self.committedChanges:
|
||||
gitCommit = ":%d" % changelist # use a fast-import mark
|
||||
commitFound = True
|
||||
else:
|
||||
gitCommit = read_pipe(["git", "rev-list", "--max-count=1",
|
||||
"--reverse", ":/\[git-p4:.*change = %d\]" % changelist], ignore_error=True)
|
||||
if len(gitCommit) == 0:
|
||||
print "importing label %s: could not find git commit for changelist %d" % (name, changelist)
|
||||
else:
|
||||
commitFound = True
|
||||
gitCommit = gitCommit.strip()
|
||||
|
||||
if commitFound:
|
||||
# Convert from p4 time format
|
||||
try:
|
||||
tmwhen = time.strptime(labelDetails['Update'], "%Y/%m/%d %H:%M:%S")
|
||||
|
Reference in New Issue
Block a user