diff options
| author | Vincent Driessen <me@nvie.com> | 2016-04-19 21:44:06 +0200 | 
|---|---|---|
| committer | Vincent Driessen <me@nvie.com> | 2016-04-19 21:44:06 +0200 | 
| commit | 0d7a40f603412be7e1046b500057b08558d9d250 (patch) | |
| tree | 08bd832e8e48ce190f9d6b9714852b497bb6ff2b /git/repo/base.py | |
| parent | 4adafc5a99947301ca0ce40511991d6d54c57a41 (diff) | |
| parent | 8da7852780a62d52c3d5012b89a4b15ecf989881 (diff) | |
| download | gitpython-0d7a40f603412be7e1046b500057b08558d9d250.tar.gz | |
Merge pull request #411 from nvie/enrich-incremental-blame-output
Enrich incremental blame output
Diffstat (limited to 'git/repo/base.py')
| -rw-r--r-- | git/repo/base.py | 22 | 
1 files changed, 16 insertions, 6 deletions
| diff --git a/git/repo/base.py b/git/repo/base.py index f74e0b59..0274c0a7 100644 --- a/git/repo/base.py +++ b/git/repo/base.py @@ -60,12 +60,15 @@ from git.compat import (  import os  import sys  import re +from collections import namedtuple  DefaultDBType = GitCmdObjectDB  if sys.version_info[:2] < (2, 5):     # python 2.4 compatiblity      DefaultDBType = GitCmdObjectDB  # END handle python 2.4 +BlameEntry = namedtuple('BlameEntry', ['commit', 'linenos', 'orig_path', 'orig_linenos']) +  __all__ = ('Repo', ) @@ -661,10 +664,10 @@ class Repo(object):          """Iterator for blame information for the given file at the given revision.          Unlike .blame(), this does not return the actual file's contents, only -        a stream of (commit, range) tuples. +        a stream of BlameEntry tuples.          :parm rev: revision specifier, see git-rev-parse for viable options. -        :return: lazy iterator of (git.Commit, range) tuples, where the commit +        :return: lazy iterator of BlameEntry tuples, where the commit                   indicates the commit to blame for the line, and range                   indicates a span of line numbers in the resulting file. @@ -678,9 +681,10 @@ class Repo(object):          while True:              line = next(stream)  # when exhausted, casues a StopIteration, terminating this function -            hexsha, _, lineno, num_lines = line.split() +            hexsha, orig_lineno, lineno, num_lines = line.split()              lineno = int(lineno)              num_lines = int(num_lines) +            orig_lineno = int(orig_lineno)              if hexsha not in commits:                  # Now read the next few lines and build up a dict of properties                  # for this commit @@ -696,6 +700,7 @@ class Repo(object):                      props[tag] = value                      if tag == b'filename':                          # "filename" formally terminates the entry for --incremental +                        orig_filename = value                          break                  c = Commit(self, hex_to_bin(hexsha), @@ -710,9 +715,14 @@ class Repo(object):              else:                  # Discard the next line (it's a filename end tag)                  line = next(stream) -                assert line.startswith(b'filename'), 'Unexpected git blame output' - -            yield commits[hexsha], range(lineno, lineno + num_lines) +                tag, value = line.split(b' ', 1) +                assert tag == b'filename', 'Unexpected git blame output' +                orig_filename = value + +            yield BlameEntry(commits[hexsha], +                             range(lineno, lineno + num_lines), +                             safe_decode(orig_filename), +                             range(orig_lineno, orig_lineno + num_lines))      def blame(self, rev, file, incremental=False, **kwargs):          """The blame information for the given file at the given revision. | 
