Show More
@@ -68,16 +68,21 class GitChangeset(BaseChangeset): | |||||
68 | def branch(self): |
|
68 | def branch(self): | |
69 | # TODO: Cache as we walk (id <-> branch name mapping) |
|
69 | # TODO: Cache as we walk (id <-> branch name mapping) | |
70 | refs = self.repository._repo.get_refs() |
|
70 | refs = self.repository._repo.get_refs() | |
71 | heads = [(key[len('refs/heads/'):], val) for key, val in refs.items() |
|
71 | heads = {} | |
72 | if key.startswith('refs/heads/')] |
|
72 | for key, val in refs.items(): | |
|
73 | for ref_key in ['refs/heads/', 'refs/remotes/origin/']: | |||
|
74 | if key.startswith(ref_key): | |||
|
75 | n = key[len(ref_key):] | |||
|
76 | if n not in ['HEAD']: | |||
|
77 | heads[n] = val | |||
73 |
|
78 | |||
74 | for name, id in heads: |
|
79 | for name, id in heads.iteritems(): | |
75 | walker = self.repository._repo.object_store.get_graph_walker([id]) |
|
80 | walker = self.repository._repo.object_store.get_graph_walker([id]) | |
76 | while True: |
|
81 | while True: | |
77 | id = walker.next() |
|
82 | id_ = walker.next() | |
78 | if not id: |
|
83 | if not id_: | |
79 | break |
|
84 | break | |
80 | if id == self.id: |
|
85 | if id_ == self.id: | |
81 | return safe_unicode(name) |
|
86 | return safe_unicode(name) | |
82 | raise ChangesetError("This should not happen... Have you manually " |
|
87 | raise ChangesetError("This should not happen... Have you manually " | |
83 | "change id of the changeset?") |
|
88 | "change id of the changeset?") | |
@@ -92,6 +97,7 class GitChangeset(BaseChangeset): | |||||
92 | return path |
|
97 | return path | |
93 |
|
98 | |||
94 | def _get_id_for_path(self, path): |
|
99 | def _get_id_for_path(self, path): | |
|
100 | ||||
95 | # FIXME: Please, spare a couple of minutes and make those codes cleaner; |
|
101 | # FIXME: Please, spare a couple of minutes and make those codes cleaner; | |
96 | if not path in self._paths: |
|
102 | if not path in self._paths: | |
97 | path = path.strip('/') |
|
103 | path = path.strip('/') | |
@@ -103,24 +109,23 class GitChangeset(BaseChangeset): | |||||
103 | splitted = path.split('/') |
|
109 | splitted = path.split('/') | |
104 | dirs, name = splitted[:-1], splitted[-1] |
|
110 | dirs, name = splitted[:-1], splitted[-1] | |
105 | curdir = '' |
|
111 | curdir = '' | |
|
112 | ||||
|
113 | # initially extract things from root dir | |||
|
114 | for item, stat, id in tree.iteritems(): | |||
|
115 | if curdir: | |||
|
116 | name = '/'.join((curdir, item)) | |||
|
117 | else: | |||
|
118 | name = item | |||
|
119 | self._paths[name] = id | |||
|
120 | self._stat_modes[name] = stat | |||
|
121 | ||||
106 | for dir in dirs: |
|
122 | for dir in dirs: | |
107 | if curdir: |
|
123 | if curdir: | |
108 | curdir = '/'.join((curdir, dir)) |
|
124 | curdir = '/'.join((curdir, dir)) | |
109 | else: |
|
125 | else: | |
110 | curdir = dir |
|
126 | curdir = dir | |
111 | #if curdir in self._paths: |
|
|||
112 | ## This path have been already traversed |
|
|||
113 | ## Update tree and continue |
|
|||
114 | #tree = self.repository._repo[self._paths[curdir]] |
|
|||
115 | #continue |
|
|||
116 | dir_id = None |
|
127 | dir_id = None | |
117 | for item, stat, id in tree.iteritems(): |
|
128 | for item, stat, id in tree.iteritems(): | |
118 | if curdir: |
|
|||
119 | item_path = '/'.join((curdir, item)) |
|
|||
120 | else: |
|
|||
121 | item_path = item |
|
|||
122 | self._paths[item_path] = id |
|
|||
123 | self._stat_modes[item_path] = stat |
|
|||
124 | if dir == item: |
|
129 | if dir == item: | |
125 | dir_id = id |
|
130 | dir_id = id | |
126 | if dir_id: |
|
131 | if dir_id: | |
@@ -130,6 +135,8 class GitChangeset(BaseChangeset): | |||||
130 | raise ChangesetError('%s is not a directory' % curdir) |
|
135 | raise ChangesetError('%s is not a directory' % curdir) | |
131 | else: |
|
136 | else: | |
132 | raise ChangesetError('%s have not been found' % curdir) |
|
137 | raise ChangesetError('%s have not been found' % curdir) | |
|
138 | ||||
|
139 | # cache all items from the given traversed tree | |||
133 | for item, stat, id in tree.iteritems(): |
|
140 | for item, stat, id in tree.iteritems(): | |
134 | if curdir: |
|
141 | if curdir: | |
135 | name = '/'.join((curdir, item)) |
|
142 | name = '/'.join((curdir, item)) | |
@@ -137,6 +144,7 class GitChangeset(BaseChangeset): | |||||
137 | name = item |
|
144 | name = item | |
138 | self._paths[name] = id |
|
145 | self._paths[name] = id | |
139 | self._stat_modes[name] = stat |
|
146 | self._stat_modes[name] = stat | |
|
147 | ||||
140 | if not path in self._paths: |
|
148 | if not path in self._paths: | |
141 | raise NodeDoesNotExistError("There is no file nor directory " |
|
149 | raise NodeDoesNotExistError("There is no file nor directory " | |
142 | "at the given path %r at revision %r" |
|
150 | "at the given path %r at revision %r" |
General Comments 0
You need to be logged in to leave comments.
Login now