Show More
@@ -49,6 +49,28 def checkforbidden(l): | |||||
49 | _("'\\n' and '\\r' disallowed in filenames: %r") % f) |
|
49 | _("'\\n' and '\\r' disallowed in filenames: %r") % f) | |
50 |
|
50 | |||
51 |
|
51 | |||
|
52 | # apply the changes collected during the bisect loop to our addlist | |||
|
53 | # return a delta suitable for addrevision | |||
|
54 | def addlistdelta(addlist, x): | |||
|
55 | # for large addlist arrays, building a new array is cheaper | |||
|
56 | # than repeatedly modifying the existing one | |||
|
57 | currentposition = 0 | |||
|
58 | newaddlist = array.array('c') | |||
|
59 | ||||
|
60 | for start, end, content in x: | |||
|
61 | newaddlist += addlist[currentposition:start] | |||
|
62 | if content: | |||
|
63 | newaddlist += array.array('c', content) | |||
|
64 | ||||
|
65 | currentposition = end | |||
|
66 | ||||
|
67 | newaddlist += addlist[currentposition:] | |||
|
68 | ||||
|
69 | deltatext = "".join(struct.pack(">lll", start, end, len(content)) | |||
|
70 | + content for start, end, content in x) | |||
|
71 | return deltatext, newaddlist | |||
|
72 | ||||
|
73 | ||||
52 | class manifest(revlog.revlog): |
|
74 | class manifest(revlog.revlog): | |
53 | def __init__(self, opener): |
|
75 | def __init__(self, opener): | |
54 | # we expect to deal with not more than four revs at a time, |
|
76 | # we expect to deal with not more than four revs at a time, | |
@@ -140,27 +162,6 class manifest(revlog.revlog): | |||||
140 |
|
162 | |||
141 | def add(self, map, transaction, link, p1=None, p2=None, |
|
163 | def add(self, map, transaction, link, p1=None, p2=None, | |
142 | changed=None): |
|
164 | changed=None): | |
143 | # apply the changes collected during the bisect loop to our addlist |
|
|||
144 | # return a delta suitable for addrevision |
|
|||
145 | def addlistdelta(addlist, x): |
|
|||
146 | # for large addlist arrays, building a new array is cheaper |
|
|||
147 | # than repeatedly modifying the existing one |
|
|||
148 | currentposition = 0 |
|
|||
149 | newaddlist = array.array('c') |
|
|||
150 |
|
||||
151 | for start, end, content in x: |
|
|||
152 | newaddlist += addlist[currentposition:start] |
|
|||
153 | if content: |
|
|||
154 | newaddlist += array.array('c', content) |
|
|||
155 |
|
||||
156 | currentposition = end |
|
|||
157 |
|
||||
158 | newaddlist += addlist[currentposition:] |
|
|||
159 |
|
||||
160 | deltatext = "".join(struct.pack(">lll", start, end, len(content)) |
|
|||
161 | + content for start, end, content in x) |
|
|||
162 | return deltatext, newaddlist |
|
|||
163 |
|
||||
164 | # if we're using the cache, make sure it is valid and |
|
165 | # if we're using the cache, make sure it is valid and | |
165 | # parented by the same node we're diffing against |
|
166 | # parented by the same node we're diffing against | |
166 | if not (changed and p1 and (p1 in self._mancache)): |
|
167 | if not (changed and p1 and (p1 in self._mancache)): |
General Comments 0
You need to be logged in to leave comments.
Login now