diff options
| author | Sebastian Thiel <byronimo@gmail.com> | 2015-12-14 19:19:19 +0100 | 
|---|---|---|
| committer | Sebastian Thiel <byronimo@gmail.com> | 2015-12-14 19:19:19 +0100 | 
| commit | 4f1110bd9b00cb8c1ea07c3aafe9cde89b3dbf9b (patch) | |
| tree | 7e721e4e57feea022699cb667a074ee46c3374e6 /git/objects/tree.py | |
| parent | 0de827a0e63850517aa93c576c25a37104954dba (diff) | |
| download | gitpython-4f1110bd9b00cb8c1ea07c3aafe9cde89b3dbf9b.tar.gz | |
fix(tree): show that fixing Tree.cache is not possible
The problem is that a per-tree modification API cannot work properly, as the sorting is based
on full paths of all entries within the repository. This feat can only be achieved by the index,
which to my knowledge already does it correctly.
The only fix is to remove the misleading API entirely, which will happen in the next commit.
Related to #369
Diffstat (limited to 'git/objects/tree.py')
| -rw-r--r-- | git/objects/tree.py | 52 | 
1 files changed, 29 insertions, 23 deletions
| diff --git a/git/objects/tree.py b/git/objects/tree.py index e7d579d0..4f853f92 100644 --- a/git/objects/tree.py +++ b/git/objects/tree.py @@ -35,33 +35,42 @@ def git_cmp(t1, t2):      if min_cmp:          return min_cmp -    return len_b - len_a +    return len_a - len_b -if PY3: -    # taken from https://wiki.python.org/moin/HowTo/Sorting#The_Old_Way_Using_the_cmp_Parameter -    class CmpToKey(object): -        __slots__ = 'obj' -        def __init__(self, obj, *args): -            self.obj = obj +def merge_sort(a, cmp): +    if len(a) < 2: +        return -        def __lt__(self, other): -            return git_cmp(self.obj, other.obj) < 0 +    mid = len(a) // 2 +    lefthalf = a[:mid] +    righthalf = a[mid:] -        def __gt__(self, other): -            return git_cmp(self.obj, other.obj) > 0 +    merge_sort(lefthalf, cmp) +    merge_sort(righthalf, cmp) -        def __eq__(self, other): -            return git_cmp(self.obj, other.obj) == 0 +    i = 0 +    j = 0 +    k = 0 -        def __le__(self, other): -            return git_cmp(self.obj, other.obj) <= 0 +    while i < len(lefthalf) and j < len(righthalf): +        if cmp(lefthalf[i], righthalf[j]) <= 0: +            a[k] = lefthalf[i] +            i = i + 1 +        else: +            a[k] = righthalf[j] +            j = j + 1 +        k = k + 1 -        def __ge__(self, other): -            return git_cmp(self.obj, other.obj) >= 0 +    while i < len(lefthalf): +        a[k] = lefthalf[i] +        i = i + 1 +        k = k + 1 -        def __ne__(self, other): -            return git_cmp(self.obj, other.obj) != 0 +    while j < len(righthalf): +        a[k] = righthalf[j] +        j = j + 1 +        k = k + 1  class TreeModifier(object): @@ -90,10 +99,7 @@ class TreeModifier(object):          It may be called several times, but be aware that each call will cause          a sort operation          :return self:""" -        if PY3: -            self._cache.sort(key=CmpToKey) -        else: -            self._cache.sort(cmp=git_cmp) +        merge_sort(self._cache, git_cmp)          return self      #} END interface | 
