Show More
@@ -313,6 +313,8 class linelog(object): | |||||
313 | appendinst = self._program.append |
|
313 | appendinst = self._program.append | |
314 |
|
314 | |||
315 | # insert |
|
315 | # insert | |
|
316 | blineinfos = [] | |||
|
317 | bappend = blineinfos.append | |||
316 | if b1 < b2: |
|
318 | if b1 < b2: | |
317 | # Determine the jump target for the JGE at the start of |
|
319 | # Determine the jump target for the JGE at the start of | |
318 | # the new block. |
|
320 | # the new block. | |
@@ -321,9 +323,12 class linelog(object): | |||||
321 | appendinst(_jl(rev, tgt)) |
|
323 | appendinst(_jl(rev, tgt)) | |
322 | for linenum in pycompat.xrange(b1, b2): |
|
324 | for linenum in pycompat.xrange(b1, b2): | |
323 | if _internal_blines is None: |
|
325 | if _internal_blines is None: | |
|
326 | bappend(lineinfo(rev, linenum, programlen())) | |||
324 | appendinst(_line(rev, linenum)) |
|
327 | appendinst(_line(rev, linenum)) | |
325 | else: |
|
328 | else: | |
326 |
|
|
329 | newrev, newlinenum = _internal_blines[linenum] | |
|
330 | bappend(lineinfo(newrev, newlinenum, programlen())) | |||
|
331 | appendinst(_line(newrev, newlinenum)) | |||
327 | # delete |
|
332 | # delete | |
328 | if a1 < a2: |
|
333 | if a1 < a2: | |
329 | if a2 > len(ar.lines): |
|
334 | if a2 > len(ar.lines): | |
@@ -342,6 +347,7 class linelog(object): | |||||
342 | endaddr = ar.lines[a2 - 1]._offset + 1 |
|
347 | endaddr = ar.lines[a2 - 1]._offset + 1 | |
343 | appendinst(_jge(rev, endaddr)) |
|
348 | appendinst(_jge(rev, endaddr)) | |
344 | # copy instruction from a1 |
|
349 | # copy instruction from a1 | |
|
350 | a1instpc = programlen() | |||
345 | appendinst(a1inst) |
|
351 | appendinst(a1inst) | |
346 | # if a1inst isn't a jump or EOF, then we need to add an unconditional |
|
352 | # if a1inst isn't a jump or EOF, then we need to add an unconditional | |
347 | # jump back into the program here. |
|
353 | # jump back into the program here. | |
@@ -349,12 +355,18 class linelog(object): | |||||
349 | appendinst(_jump(0, a1info._offset + 1)) |
|
355 | appendinst(_jump(0, a1info._offset + 1)) | |
350 | # Patch instruction at a1, which makes our patch live. |
|
356 | # Patch instruction at a1, which makes our patch live. | |
351 | self._program[a1info._offset] = _jump(0, oldproglen) |
|
357 | self._program[a1info._offset] = _jump(0, oldproglen) | |
352 | # For compat with the C version, re-annotate rev so that |
|
358 | ||
353 | # self.annotateresult is cromulent.. We could fix up the |
|
359 | # Update self._lastannotate in place. This serves as a cache to avoid | |
354 | # annotateresult in place (which is how the C version works), |
|
360 | # expensive "self.annotate" in this function, when "replacelines" is | |
355 | # but for now we'll pass on that and see if it matters in |
|
361 | # used continuously. | |
356 | # practice. |
|
362 | if len(self._lastannotate.lines) > a1: | |
357 | self.annotate(max(self._lastannotate.rev, rev)) |
|
363 | self._lastannotate.lines[a1]._offset = a1instpc | |
|
364 | else: | |||
|
365 | assert isinstance(a1inst, _eof) | |||
|
366 | self._lastannotate._eof = a1instpc | |||
|
367 | self._lastannotate.lines[a1:a2] = blineinfos | |||
|
368 | self._lastannotate.rev = max(self._lastannotate.rev, rev) | |||
|
369 | ||||
358 | if rev > self._maxrev: |
|
370 | if rev > self._maxrev: | |
359 | self._maxrev = rev |
|
371 | self._maxrev = rev | |
360 |
|
372 |
General Comments 0
You need to be logged in to leave comments.
Login now