Provide better emacs integration.

The new emacs integration is simpler, does not save the current file
before reformatting and ensures that emacs does not scroll as a result
of formatting.

Also explicitly set the style in clang-format tests to make them more
robust.

llvm-svn: 179372
This commit is contained in:
Daniel Jasper 2013-04-12 10:12:01 +00:00
parent 664ec5d7a8
commit 92a3130509
3 changed files with 15 additions and 35 deletions

View File

@ -1,5 +1,5 @@
// RUN: grep -Ev "// *[A-Z-]+:" %s > %t.cpp
// RUN: clang-format -i %t.cpp
// RUN: clang-format -style=LLVM -i %t.cpp
// RUN: FileCheck -strict-whitespace -input-file=%t.cpp %s
// CHECK: {{^int\ \*i;}}

View File

@ -1,5 +1,5 @@
// RUN: grep -Ev "// *[A-Z-]+:" %s > %t.cpp
// RUN: clang-format -offset=2 -length=0 -offset=28 -length=0 -i %t.cpp
// RUN: clang-format -style=LLVM -offset=2 -length=0 -offset=28 -length=0 -i %t.cpp
// RUN: FileCheck -strict-whitespace -input-file=%t.cpp %s
// CHECK: {{^int\ \*i;$}}
int*i;

View File

@ -10,38 +10,18 @@
;; 'style' and 'binary' below.
(defun clang-format-region ()
(interactive)
(let ((orig-file buffer-file-name)
(let ((orig-window-start (window-start))
(orig-point (point))
(orig-mark (mark t))
(orig-mark-active mark-active)
(binary "clang-format")
(style "LLVM")
replacement-text replaced beg end)
(basic-save-buffer)
(save-restriction
(widen)
(if mark-active
(setq beg (1- (region-beginning))
end (1- (region-end)))
(setq beg (1- (line-beginning-position))
end (1- (line-end-position))))
(with-temp-buffer
(call-process
binary orig-file '(t nil) t
"-offset" (number-to-string beg)
"-length" (number-to-string (- end beg))
"-style" style)
(setq replacement-text
(buffer-substring-no-properties (point-min) (point-max))))
(unless (string= replacement-text
(buffer-substring-no-properties (point-min) (point-max)))
(delete-region (point-min) (point-max))
(insert replacement-text)
(setq replaced t)))
(ignore-errors
(when orig-mark
(push-mark orig-mark)
(when orig-mark-active
(activate-mark)
(setq deactivate-mark nil)))
(goto-char orig-point))))
(style "LLVM"))
(if mark-active
(setq beg (1- (region-beginning))
end (1- (region-end)))
(setq beg (1- (line-beginning-position))
end (1- (line-end-position))))
(call-process-region (point-min) (point-max) "clang-format" t t nil
"-offset" (number-to-string beg)
"-length" (number-to-string (- end beg))
"-style" style)
(goto-char orig-point)
(set-window-start (selected-window) orig-window-start)))