Update clang-format emacs integration.

- Remove free variables
- Add function clang-format-buffer, e.g. for before-save-hooks
- Wrap restoring windows in an unwind-protect

Patch by Stephen Gildea!

llvm-svn: 181766
This commit is contained in:
Daniel Jasper 2013-05-14 08:48:24 +00:00
parent c28380a094
commit 6e3506f212
1 changed files with 31 additions and 17 deletions

View File

@ -7,25 +7,39 @@
;; (global-set-key [C-M-tab] 'clang-format-region)
;;
;; Depending on your configuration and coding style, you might need to modify
;; 'style' and 'binary' below.
(defun clang-format-region ()
(interactive)
;; 'style' in clang-format, below.
;; *Location of the clang-format binary. If it is on your PATH, a full path name
;; need not be specified.
(defvar clang-format-binary "clang-format")
(defun clang-format-region ()
"Use clang-format to format the currently active region."
(interactive)
(let ((beg (if mark-active
(region-beginning)
(min (line-beginning-position) (1- (point-max)))))
(end (if mark-active
(region-end)
(line-end-position))))
(clang-format beg end)))
(defun clang-format-buffer ()
"Use clang-format to format the current buffer."
(clang-format (point-min) (point-max)))
(defun clang-format (begin end)
"Use clang-format to format the code between BEGIN and END."
(let* ((orig-windows (get-buffer-window-list (current-buffer)))
(orig-window-starts (mapcar #'window-start orig-windows))
(orig-point (point))
(binary "clang-format")
(style "LLVM"))
(if mark-active
(setq beg (region-beginning)
end (region-end))
(setq beg (min (line-beginning-position) (1- (point-max)))
end (line-end-position)))
(call-process-region (point-min) (point-max) binary t t nil
"-offset" (number-to-string (1- beg))
"-length" (number-to-string (- end beg))
(unwind-protect
(call-process-region (point-min) (point-max) clang-format-binary t t nil
"-offset" (number-to-string (1- begin))
"-length" (number-to-string (- end begin))
"-style" style)
(goto-char orig-point)
(dotimes (index (length orig-windows))
(set-window-start (nth index orig-windows)
(nth index orig-window-starts)))))
(nth index orig-window-starts))))))