diff options
Diffstat (limited to 'git-p4.py')
| -rwxr-xr-x | git-p4.py | 25 | 
1 files changed, 23 insertions, 2 deletions
| @@ -1167,6 +1167,15 @@ class P4UserMap:              self.users[output["User"]] = output["FullName"] + " <" + output["Email"] + ">"              self.emails[output["Email"]] = output["User"] +        mapUserConfigRegex = re.compile(r"^\s*(\S+)\s*=\s*(.+)\s*<(\S+)>\s*$", re.VERBOSE) +        for mapUserConfig in gitConfigList("git-p4.mapUser"): +            mapUser = mapUserConfigRegex.findall(mapUserConfig) +            if mapUser and len(mapUser[0]) == 3: +                user = mapUser[0][0] +                fullname = mapUser[0][1] +                email = mapUser[0][2] +                self.users[user] = fullname + " <" + email + ">" +                self.emails[email] = user          s = ''          for (key, val) in self.users.items(): @@ -2265,7 +2274,7 @@ class P4Sync(Command, P4UserMap):          self.useClientSpec_from_options = False          self.clientSpecDirs = None          self.tempBranches = [] -        self.tempBranchLocation = "git-p4-tmp" +        self.tempBranchLocation = "refs/git-p4-tmp"          self.largeFileSystem = None          if gitConfig('git-p4.largeFileSystem'): @@ -2318,6 +2327,15 @@ class P4Sync(Command, P4UserMap):              fnum = fnum + 1          return files +    def extractJobsFromCommit(self, commit): +        jobs = [] +        jnum = 0 +        while commit.has_key("job%s" % jnum): +            job = commit["job%s" % jnum] +            jobs.append(job) +            jnum = jnum + 1 +        return jobs +      def stripRepoPath(self, path, prefixes):          """When streaming files, this is called to map a p4 depot path             to where it should go in git.  The prefixes are either @@ -2656,13 +2674,14 @@ class P4Sync(Command, P4UserMap):              return True          hasPrefix = [p for p in self.branchPrefixes                          if p4PathStartsWith(path, p)] -        if hasPrefix and self.verbose: +        if not hasPrefix and self.verbose:              print('Ignoring file outside of prefix: {0}'.format(path))          return hasPrefix      def commit(self, details, files, branch, parent = ""):          epoch = details["time"]          author = details["user"] +        jobs = self.extractJobsFromCommit(details)          if self.verbose:              print('commit into {0}'.format(branch)) @@ -2690,6 +2709,8 @@ class P4Sync(Command, P4UserMap):          self.gitStream.write("data <<EOT\n")          self.gitStream.write(details["desc"]) +        if len(jobs) > 0: +            self.gitStream.write("\nJobs: %s" % (' '.join(jobs)))          self.gitStream.write("\n[git-p4: depot-paths = \"%s\": change = %s" %                               (','.join(self.branchPrefixes), details["change"]))          if len(details['options']) > 0: | 
