c4fb0432ae
GitOrigin-RevId: 3fc1143a04da49a92c3663813c6a0c1e8ccd477f
151 lines
6.1 KiB
EmacsLisp
151 lines
6.1 KiB
EmacsLisp
;;; google-c-style.el --- Google's C/C++ style for c-mode
|
|
|
|
;; Keywords: c, tools
|
|
|
|
;; google-c-style.el is Copyright (C) 2008 Google Inc. All Rights Reserved.
|
|
;;
|
|
;; It is free software; you can redistribute it and/or modify it under the
|
|
;; terms of either:
|
|
;;
|
|
;; a) the GNU General Public License as published by the Free Software
|
|
;; Foundation; either version 1, or (at your option) any later version, or
|
|
;;
|
|
;; b) the "Artistic License".
|
|
|
|
;;; Commentary:
|
|
|
|
;; Provides the google C/C++ coding style. You may wish to add
|
|
;; `google-set-c-style' to your `c-mode-common-hook' after requiring this
|
|
;; file. For example:
|
|
;;
|
|
;; (add-hook 'c-mode-common-hook 'google-set-c-style)
|
|
;;
|
|
;; If you want the RETURN key to go to the next line and space over
|
|
;; to the right place, add this to your .emacs right after the load-file:
|
|
;;
|
|
;; (add-hook 'c-mode-common-hook 'google-make-newline-indent)
|
|
|
|
;;; Code:
|
|
|
|
;; For some reason 1) c-backward-syntactic-ws is a macro and 2) under Emacs 22
|
|
;; bytecode cannot call (unexpanded) macros at run time:
|
|
(eval-when-compile (require 'cc-defs))
|
|
|
|
;; Wrapper function needed for Emacs 21 and XEmacs (Emacs 22 offers the more
|
|
;; elegant solution of composing a list of lineup functions or quantities with
|
|
;; operators such as "add")
|
|
(defun google-c-lineup-expression-plus-4 (langelem)
|
|
"Indents to the beginning of the current C expression plus 4 spaces.
|
|
|
|
This implements title \"Function Declarations and Definitions\"
|
|
of the Google C++ Style Guide for the case where the previous
|
|
line ends with an open parenthese.
|
|
|
|
\"Current C expression\", as per the Google Style Guide and as
|
|
clarified by subsequent discussions, means the whole expression
|
|
regardless of the number of nested parentheses, but excluding
|
|
non-expression material such as \"if(\" and \"for(\" control
|
|
structures.
|
|
|
|
Suitable for inclusion in `c-offsets-alist'."
|
|
(save-excursion
|
|
(back-to-indentation)
|
|
;; Go to beginning of *previous* line:
|
|
(c-backward-syntactic-ws)
|
|
(back-to-indentation)
|
|
(cond
|
|
;; We are making a reasonable assumption that if there is a control
|
|
;; structure to indent past, it has to be at the beginning of the line.
|
|
((looking-at "\\(\\(if\\|for\\|while\\)\\s *(\\)")
|
|
(goto-char (match-end 1)))
|
|
;; For constructor initializer lists, the reference point for line-up is
|
|
;; the token after the initial colon.
|
|
((looking-at ":\\s *")
|
|
(goto-char (match-end 0))))
|
|
(vector (+ 4 (current-column)))))
|
|
|
|
;;;###autoload
|
|
(defconst google-c-style
|
|
`((c-recognize-knr-p . nil)
|
|
(c-enable-xemacs-performance-kludge-p . t) ; speed up indentation in XEmacs
|
|
(c-basic-offset . 2)
|
|
(indent-tabs-mode . nil)
|
|
(c-comment-only-line-offset . 0)
|
|
(c-hanging-braces-alist . ((defun-open after)
|
|
(defun-close before after)
|
|
(class-open after)
|
|
(class-close before after)
|
|
(inexpr-class-open after)
|
|
(inexpr-class-close before)
|
|
(namespace-open after)
|
|
(inline-open after)
|
|
(inline-close before after)
|
|
(block-open after)
|
|
(block-close . c-snug-do-while)
|
|
(extern-lang-open after)
|
|
(extern-lang-close after)
|
|
(statement-case-open after)
|
|
(substatement-open after)))
|
|
(c-hanging-colons-alist . ((case-label)
|
|
(label after)
|
|
(access-label after)
|
|
(member-init-intro before)
|
|
(inher-intro)))
|
|
(c-hanging-semi&comma-criteria
|
|
. (c-semi&comma-no-newlines-for-oneline-inliners
|
|
c-semi&comma-inside-parenlist
|
|
c-semi&comma-no-newlines-before-nonblanks))
|
|
(c-indent-comments-syntactically-p . t)
|
|
(comment-column . 40)
|
|
(c-indent-comment-alist . ((other . (space . 2))))
|
|
(c-cleanup-list . (brace-else-brace
|
|
brace-elseif-brace
|
|
brace-catch-brace
|
|
empty-defun-braces
|
|
defun-close-semi
|
|
list-close-comma
|
|
scope-operator))
|
|
(c-offsets-alist . ((arglist-intro google-c-lineup-expression-plus-4)
|
|
(func-decl-cont . ++)
|
|
(member-init-intro . ++)
|
|
(inher-intro . ++)
|
|
(comment-intro . 0)
|
|
(arglist-close . c-lineup-arglist)
|
|
(topmost-intro . 0)
|
|
(block-open . 0)
|
|
(inline-open . 0)
|
|
(substatement-open . 0)
|
|
(statement-cont
|
|
.
|
|
(,(when (fboundp 'c-no-indent-after-java-annotations)
|
|
'c-no-indent-after-java-annotations)
|
|
,(when (fboundp 'c-lineup-assignments)
|
|
'c-lineup-assignments)
|
|
++))
|
|
(label . /)
|
|
(case-label . +)
|
|
(statement-case-open . +)
|
|
(statement-case-intro . +) ; case w/o {
|
|
(access-label . /)
|
|
(innamespace . 0))))
|
|
"Google C/C++ Programming Style.")
|
|
|
|
;;;###autoload
|
|
(defun google-set-c-style ()
|
|
"Set the current buffer's c-style to Google C/C++ Programming
|
|
Style. Meant to be added to `c-mode-common-hook'."
|
|
(interactive)
|
|
(make-local-variable 'c-tab-always-indent)
|
|
(setq c-tab-always-indent t)
|
|
(c-add-style "Google" google-c-style t))
|
|
|
|
;;;###autoload
|
|
(defun google-make-newline-indent ()
|
|
"Sets up preferred newline behavior. Not set by default. Meant
|
|
to be added to `c-mode-common-hook'."
|
|
(interactive)
|
|
(define-key c-mode-base-map "\C-m" 'newline-and-indent)
|
|
(define-key c-mode-base-map [ret] 'newline-and-indent))
|
|
|
|
(provide 'google-c-style)
|
|
;;; google-c-style.el ends here
|