Mercurial > hg
comparison mercurial/pure/bdiff.py @ 36146:29dd37a418aa
bdiff: write a native version of splitnewlines
./hg perfunidiff mercurial/manifest.py 0 --count 500 --profile before:
! wall 0.309280 comb 0.350000 user 0.290000 sys 0.060000 (best of 32)
./hg perfunidiff mercurial/manifest.py 0 --count 500 --profile after:
! wall 0.241572 comb 0.260000 user 0.240000 sys 0.020000 (best of 39)
so it's about 20% faster. I hate Python. I wish we could usefully
write this in Rust, but it doesn't look like that's realistic without
using the cpython crate, which I'd still like to avoid.
Differential Revision: https://phab.mercurial-scm.org/D1973
author | Augie Fackler <augie@google.com> |
---|---|
date | Thu, 25 Jan 2018 21:16:28 -0500 |
parents | 5326e4ef1dab |
children | 8b7973d40a01 |
comparison
equal
deleted
inserted
replaced
36145:4f3e989536c3 | 36146:29dd37a418aa |
---|---|
88 text = re.sub('[ \t\r]+', '', text) | 88 text = re.sub('[ \t\r]+', '', text) |
89 else: | 89 else: |
90 text = re.sub('[ \t\r]+', ' ', text) | 90 text = re.sub('[ \t\r]+', ' ', text) |
91 text = text.replace(' \n', '\n') | 91 text = text.replace(' \n', '\n') |
92 return text | 92 return text |
93 | |
94 def splitnewlines(text): | |
95 '''like str.splitlines, but only split on newlines.''' | |
96 lines = [l + '\n' for l in text.split('\n')] | |
97 if lines: | |
98 if lines[-1] == '\n': | |
99 lines.pop() | |
100 else: | |
101 lines[-1] = lines[-1][:-1] | |
102 return lines |