]> granicus.if.org Git - clang/commitdiff
clang-format: Smarter replacement in the vim integration.
authorDaniel Jasper <djasper@google.com>
Sun, 21 Jul 2013 10:45:33 +0000 (10:45 +0000)
committerDaniel Jasper <djasper@google.com>
Sun, 21 Jul 2013 10:45:33 +0000 (10:45 +0000)
With this fix, only changed regions will be replaced in vim's buffer.
Thereby, marks should mostly be left intact. Furthermore, this is a
better fix for the performance problem in conjunction with
'foldmethod=syntax' (see r186660).

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@186789 91177308-0d34-0410-b5e6-96231b3b80d8

tools/clang-format/clang-format.py

index 866baf50f104f166b2949c2cbd3aed7ca9ab4f10..bf84ed0f5cfd0799a7b52dbaae0e0fd44acc45f4 100644 (file)
@@ -17,6 +17,7 @@
 # It operates on the current, potentially unsaved buffer and does not create
 # or save any files. To revert a formatting, just undo.
 
+import difflib
 import json
 import subprocess
 import sys
@@ -67,10 +68,8 @@ else:
   lines = stdout.split('\n')
   output = json.loads(lines[0])
   lines = lines[1:]
-  if '\n'.join(lines) != text:
-    common_length = min(len(buf), len(lines))
-    buf[:common_length] = lines[:common_length]
-    for line in lines[len(buf):]:
-      buf.append(line)
-    del buf[len(lines):]
-    vim.command('goto %d' % (output['Cursor'] + 1))
+  sequence = difflib.SequenceMatcher(None, vim.current.buffer, lines)
+  for op in sequence.get_opcodes():
+    if op[0] is not 'equal':
+      vim.current.buffer[op[1]:op[2]] = lines[op[3]:op[4]]
+  vim.command('goto %d' % (output['Cursor'] + 1))