Merge branch 'master' of git://repo.or.cz/fast-export
This commit is contained in:
		@ -153,7 +153,11 @@ def extractSettingsGitLog(log):
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
            values[key] = val
 | 
					            values[key] = val
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    values['depot-paths'] = values.get("depot-paths").split(',')
 | 
					    paths = values.get("depot-paths")
 | 
				
			||||||
 | 
					    if not paths:
 | 
				
			||||||
 | 
					        paths = values.get("depot-path")
 | 
				
			||||||
 | 
					    if paths:
 | 
				
			||||||
 | 
					        values['depot-paths'] = paths.split(',')
 | 
				
			||||||
    return values
 | 
					    return values
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def gitBranchExists(branch):
 | 
					def gitBranchExists(branch):
 | 
				
			||||||
@ -273,6 +277,8 @@ class P4Submit(Command):
 | 
				
			|||||||
        self.origin = ""
 | 
					        self.origin = ""
 | 
				
			||||||
        self.directSubmit = False
 | 
					        self.directSubmit = False
 | 
				
			||||||
        self.trustMeLikeAFool = False
 | 
					        self.trustMeLikeAFool = False
 | 
				
			||||||
 | 
					        self.verbose = False
 | 
				
			||||||
 | 
					        self.isWindows = (platform.system() == "Windows")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self.logSubstitutions = {}
 | 
					        self.logSubstitutions = {}
 | 
				
			||||||
        self.logSubstitutions["<enter description here>"] = "%log%"
 | 
					        self.logSubstitutions["<enter description here>"] = "%log%"
 | 
				
			||||||
@ -394,6 +400,8 @@ class P4Submit(Command):
 | 
				
			|||||||
        if not self.directSubmit:
 | 
					        if not self.directSubmit:
 | 
				
			||||||
            logMessage = extractLogMessageFromGitCommit(id)
 | 
					            logMessage = extractLogMessageFromGitCommit(id)
 | 
				
			||||||
            logMessage = logMessage.replace("\n", "\n\t")
 | 
					            logMessage = logMessage.replace("\n", "\n\t")
 | 
				
			||||||
 | 
					            if self.isWindows:
 | 
				
			||||||
 | 
					                logMessage = logMessage.replace("\n", "\r\n")
 | 
				
			||||||
            logMessage = logMessage.strip()
 | 
					            logMessage = logMessage.strip()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        template = read_pipe("p4 change -o")
 | 
					        template = read_pipe("p4 change -o")
 | 
				
			||||||
@ -440,6 +448,8 @@ class P4Submit(Command):
 | 
				
			|||||||
                    tmpFile.close()
 | 
					                    tmpFile.close()
 | 
				
			||||||
                    os.remove(fileName)
 | 
					                    os.remove(fileName)
 | 
				
			||||||
                    submitTemplate = message[:message.index(separatorLine)]
 | 
					                    submitTemplate = message[:message.index(separatorLine)]
 | 
				
			||||||
 | 
					                    if self.isWindows:
 | 
				
			||||||
 | 
					                        submitTemplate = submitTemplate.replace("\r\n", "\n")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            if response == "y" or response == "yes":
 | 
					            if response == "y" or response == "yes":
 | 
				
			||||||
               if self.dryRun:
 | 
					               if self.dryRun:
 | 
				
			||||||
@ -475,9 +485,6 @@ class P4Submit(Command):
 | 
				
			|||||||
                   % (fileName, fileName))
 | 
					                   % (fileName, fileName))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def run(self, args):
 | 
					    def run(self, args):
 | 
				
			||||||
        # make gitdir absolute so we can cd out into the perforce checkout
 | 
					 | 
				
			||||||
        os.environ["GIT_DIR"] = gitdir
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if len(args) == 0:
 | 
					        if len(args) == 0:
 | 
				
			||||||
            self.master = currentGitBranch()
 | 
					            self.master = currentGitBranch()
 | 
				
			||||||
            if len(self.master) == 0 or not gitBranchExists("refs/heads/%s" % self.master):
 | 
					            if len(self.master) == 0 or not gitBranchExists("refs/heads/%s" % self.master):
 | 
				
			||||||
@ -488,12 +495,27 @@ class P4Submit(Command):
 | 
				
			|||||||
            return False
 | 
					            return False
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        depotPath = ""
 | 
					        depotPath = ""
 | 
				
			||||||
        settings = None
 | 
					        parent = 0
 | 
				
			||||||
        if gitBranchExists("p4"):
 | 
					        while parent < 65535:
 | 
				
			||||||
            settings = extractSettingsGitLog(extractLogMessageFromGitCommit("p4"))
 | 
					            commit = "HEAD~%s" % parent
 | 
				
			||||||
        if len(depotPath) == 0 and gitBranchExists("origin"):
 | 
					            log = extractLogMessageFromGitCommit(commit)
 | 
				
			||||||
            settings = extractSettingsGitLog(extractLogMessageFromGitCommit("origin"))
 | 
					            settings = extractSettingsGitLog(log)
 | 
				
			||||||
        depotPaths = settings['depot-paths']
 | 
					            if not settings.has_key("depot-paths"):
 | 
				
			||||||
 | 
					                parent = parent + 1
 | 
				
			||||||
 | 
					                continue
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            depotPath = settings['depot-paths'][0]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            if len(self.origin) == 0:
 | 
				
			||||||
 | 
					                names = read_pipe_lines("git name-rev '--refs=refs/remotes/p4/*' '%s'" % commit)
 | 
				
			||||||
 | 
					                if len(names) > 0:
 | 
				
			||||||
 | 
					                    # strip away the beginning of 'HEAD~42 refs/remotes/p4/foo'
 | 
				
			||||||
 | 
					                    self.origin = names[0].strip()[len(commit) + 1:]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            break
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if self.verbose:
 | 
				
			||||||
 | 
					            print "Origin branch is " + self.origin
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if len(depotPath) == 0:
 | 
					        if len(depotPath) == 0:
 | 
				
			||||||
            print "Internal error: cannot locate perforce depot path from existing branches"
 | 
					            print "Internal error: cannot locate perforce depot path from existing branches"
 | 
				
			||||||
@ -524,12 +546,6 @@ class P4Submit(Command):
 | 
				
			|||||||
        if response == "y" or response == "yes":
 | 
					        if response == "y" or response == "yes":
 | 
				
			||||||
            system("p4 sync ...")
 | 
					            system("p4 sync ...")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if len(self.origin) == 0:
 | 
					 | 
				
			||||||
            if gitBranchExists("p4"):
 | 
					 | 
				
			||||||
                self.origin = "p4"
 | 
					 | 
				
			||||||
            else:
 | 
					 | 
				
			||||||
                self.origin = "origin"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if self.reset:
 | 
					        if self.reset:
 | 
				
			||||||
            self.firstTime = True
 | 
					            self.firstTime = True
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -896,10 +912,6 @@ class P4Sync(Command):
 | 
				
			|||||||
            return p [p.strip().rfind("/") + 1:]
 | 
					            return p [p.strip().rfind("/") + 1:]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def getBranchMapping(self):
 | 
					    def getBranchMapping(self):
 | 
				
			||||||
 | 
					 | 
				
			||||||
        ## FIXME - what's a P4 projectName ?
 | 
					 | 
				
			||||||
        self.projectName = self.guessProjectName()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        for info in p4CmdList("branches"):
 | 
					        for info in p4CmdList("branches"):
 | 
				
			||||||
            details = p4Cmd("branch -o %s" % info["branch"])
 | 
					            details = p4Cmd("branch -o %s" % info["branch"])
 | 
				
			||||||
            viewIdx = 0
 | 
					            viewIdx = 0
 | 
				
			||||||
@ -911,9 +923,10 @@ class P4Sync(Command):
 | 
				
			|||||||
                    continue
 | 
					                    continue
 | 
				
			||||||
                source = paths[0]
 | 
					                source = paths[0]
 | 
				
			||||||
                destination = paths[1]
 | 
					                destination = paths[1]
 | 
				
			||||||
                if source.startswith(self.depotPath) and destination.startswith(self.depotPath):
 | 
					                ## HACK
 | 
				
			||||||
                    source = source[len(self.depotPath):-4]
 | 
					                if source.startswith(self.depotPaths[0]) and destination.startswith(self.depotPaths[0]):
 | 
				
			||||||
                    destination = destination[len(self.depotPath):-4]
 | 
					                    source = source[len(self.depotPaths[0]):-4]
 | 
				
			||||||
 | 
					                    destination = destination[len(self.depotPaths[0]):-4]
 | 
				
			||||||
                    if destination not in self.knownBranches:
 | 
					                    if destination not in self.knownBranches:
 | 
				
			||||||
                        self.knownBranches[destination] = source
 | 
					                        self.knownBranches[destination] = source
 | 
				
			||||||
                    if source not in self.knownBranches:
 | 
					                    if source not in self.knownBranches:
 | 
				
			||||||
@ -932,7 +945,7 @@ class P4Sync(Command):
 | 
				
			|||||||
            line = line.strip()
 | 
					            line = line.strip()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            ## only import to p4/
 | 
					            ## only import to p4/
 | 
				
			||||||
            if not line.startswith('p4/'):
 | 
					            if not line.startswith('p4/') or line == "p4/HEAD":
 | 
				
			||||||
                continue
 | 
					                continue
 | 
				
			||||||
            branch = line
 | 
					            branch = line
 | 
				
			||||||
            if self.importIntoRemotes:
 | 
					            if self.importIntoRemotes:
 | 
				
			||||||
@ -967,7 +980,7 @@ class P4Sync(Command):
 | 
				
			|||||||
                    print "creating %s" % remoteHead
 | 
					                    print "creating %s" % remoteHead
 | 
				
			||||||
                update = True
 | 
					                update = True
 | 
				
			||||||
            else:
 | 
					            else:
 | 
				
			||||||
                settings =  extractSettingsGitLog(extractLogMessageFromGitCommit(remoteHead))
 | 
					                settings = extractSettingsGitLog(extractLogMessageFromGitCommit(remoteHead))
 | 
				
			||||||
                if settings.has_key('change') > 0:
 | 
					                if settings.has_key('change') > 0:
 | 
				
			||||||
                    if settings['depot-paths'] == original['depot-paths']:
 | 
					                    if settings['depot-paths'] == original['depot-paths']:
 | 
				
			||||||
                        originP4Change = int(original['change'])
 | 
					                        originP4Change = int(original['change'])
 | 
				
			||||||
@ -1012,7 +1025,7 @@ class P4Sync(Command):
 | 
				
			|||||||
        if self.importIntoRemotes:
 | 
					        if self.importIntoRemotes:
 | 
				
			||||||
            self.refPrefix = "refs/remotes/p4/"
 | 
					            self.refPrefix = "refs/remotes/p4/"
 | 
				
			||||||
        else:
 | 
					        else:
 | 
				
			||||||
            self.refPrefix = "refs/heads/"
 | 
					            self.refPrefix = "refs/heads/p4/"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if self.syncWithOrigin and self.hasOrigin:
 | 
					        if self.syncWithOrigin and self.hasOrigin:
 | 
				
			||||||
            if not self.silent:
 | 
					            if not self.silent:
 | 
				
			||||||
@ -1020,7 +1033,7 @@ class P4Sync(Command):
 | 
				
			|||||||
            system("git fetch origin")
 | 
					            system("git fetch origin")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if len(self.branch) == 0:
 | 
					        if len(self.branch) == 0:
 | 
				
			||||||
            self.branch = self.refPrefix + "p4/master"
 | 
					            self.branch = self.refPrefix + "master"
 | 
				
			||||||
            if gitBranchExists("refs/heads/p4") and self.importIntoRemotes:
 | 
					            if gitBranchExists("refs/heads/p4") and self.importIntoRemotes:
 | 
				
			||||||
                system("git update-ref %s refs/heads/p4" % self.branch)
 | 
					                system("git update-ref %s refs/heads/p4" % self.branch)
 | 
				
			||||||
                system("git branch -D p4");
 | 
					                system("git branch -D p4");
 | 
				
			||||||
@ -1061,18 +1074,20 @@ class P4Sync(Command):
 | 
				
			|||||||
                    else:
 | 
					                    else:
 | 
				
			||||||
                        paths = []
 | 
					                        paths = []
 | 
				
			||||||
                        for (prev, cur) in zip(self.previousDepotPaths, depotPaths):
 | 
					                        for (prev, cur) in zip(self.previousDepotPaths, depotPaths):
 | 
				
			||||||
                            for i in range(0, max(len(cur), len(prev))):
 | 
					                            for i in range(0, min(len(cur), len(prev))):
 | 
				
			||||||
                                if cur[i] <> prev[i]:
 | 
					                                if cur[i] <> prev[i]:
 | 
				
			||||||
 | 
					                                    i = i - 1
 | 
				
			||||||
                                    break
 | 
					                                    break
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                            paths.append (cur[:i])
 | 
					                            paths.append (cur[:i + 1])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                        self.previousDepotPaths = paths
 | 
					                        self.previousDepotPaths = paths
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            if p4Change > 0:
 | 
					            if p4Change > 0:
 | 
				
			||||||
                self.depotPaths = sorted(self.previousDepotPaths)
 | 
					                self.depotPaths = sorted(self.previousDepotPaths)
 | 
				
			||||||
                self.changeRange = "@%s,#head" % p4Change
 | 
					                self.changeRange = "@%s,#head" % p4Change
 | 
				
			||||||
                self.initialParent = parseRevision(self.branch)
 | 
					                if not self.detectBranches:
 | 
				
			||||||
 | 
					                    self.initialParent = parseRevision(self.branch)
 | 
				
			||||||
                if not self.silent and not self.detectBranches:
 | 
					                if not self.silent and not self.detectBranches:
 | 
				
			||||||
                    print "Performing incremental import into %s git branch" % self.branch
 | 
					                    print "Performing incremental import into %s git branch" % self.branch
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -1127,7 +1142,11 @@ class P4Sync(Command):
 | 
				
			|||||||
            self.getLabels();
 | 
					            self.getLabels();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if self.detectBranches:
 | 
					        if self.detectBranches:
 | 
				
			||||||
            self.getBranchMapping();
 | 
					            ## FIXME - what's a P4 projectName ?
 | 
				
			||||||
 | 
					            self.projectName = self.guessProjectName()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            if not self.hasOrigin:
 | 
				
			||||||
 | 
					                self.getBranchMapping();
 | 
				
			||||||
            if self.verbose:
 | 
					            if self.verbose:
 | 
				
			||||||
                print "p4-git branches: %s" % self.p4BranchesInGit
 | 
					                print "p4-git branches: %s" % self.p4BranchesInGit
 | 
				
			||||||
                print "initial parents: %s" % self.initialParents
 | 
					                print "initial parents: %s" % self.initialParents
 | 
				
			||||||
@ -1319,6 +1338,7 @@ class P4Rebase(Command):
 | 
				
			|||||||
        self.options = [ ]
 | 
					        self.options = [ ]
 | 
				
			||||||
        self.description = ("Fetches the latest revision from perforce and "
 | 
					        self.description = ("Fetches the latest revision from perforce and "
 | 
				
			||||||
                            + "rebases the current work (branch) against it")
 | 
					                            + "rebases the current work (branch) against it")
 | 
				
			||||||
 | 
					        self.verbose = False
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def run(self, args):
 | 
					    def run(self, args):
 | 
				
			||||||
        sync = P4Sync()
 | 
					        sync = P4Sync()
 | 
				
			||||||
@ -1359,12 +1379,17 @@ class P4Clone(P4Sync):
 | 
				
			|||||||
            sys.exit(1)
 | 
					            sys.exit(1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        depotPaths = args
 | 
					        depotPaths = args
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if not self.cloneDestination and len(depotPaths) > 1:
 | 
				
			||||||
 | 
					            self.cloneDestination = depotPaths[-1]
 | 
				
			||||||
 | 
					            depotPaths = depotPaths[:-1]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        for p in depotPaths:
 | 
					        for p in depotPaths:
 | 
				
			||||||
            if not p.startswith("//"):
 | 
					            if not p.startswith("//"):
 | 
				
			||||||
                return False
 | 
					                return False
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if not self.cloneDestination:
 | 
					        if not self.cloneDestination:
 | 
				
			||||||
            self.cloneDestination = self.defaultDestination()
 | 
					            self.cloneDestination = self.defaultDestination(args)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        print "Importing from %s into %s" % (', '.join(depotPaths), self.cloneDestination)
 | 
					        print "Importing from %s into %s" % (', '.join(depotPaths), self.cloneDestination)
 | 
				
			||||||
        os.makedirs(self.cloneDestination)
 | 
					        os.makedirs(self.cloneDestination)
 | 
				
			||||||
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user