doomemacs/modules/lang/cc/config.el

190 lines
6 KiB
EmacsLisp
Raw Normal View History

;;; lang/cc/config.el --- c, c++, and obj-c -*- lexical-binding: t; -*-
2015-06-15 09:06:10 +02:00
(def-package! cc-mode
2015-06-15 09:06:10 +02:00
:commands (c-mode c++-mode objc-mode java-mode)
:mode ("\\.mm" . objc-mode)
2015-06-15 09:06:10 +02:00
:init
(setq-default c-basic-offset tab-width)
2017-06-23 18:13:33 +02:00
(defun +cc--c++-header-file-p ()
(and buffer-file-name
(equal (file-name-extension buffer-file-name) "h")
(or (file-exists-p (expand-file-name
(concat (file-name-sans-extension buffer-file-name)
".cpp")))
(when-let (file (car-safe (projectile-get-other-files
buffer-file-name
(projectile-current-project-files))))
(equal (file-name-extension file) "cpp")))))
(defun +cc--objc-header-file-p ()
(and buffer-file-name
(equal (file-name-extension buffer-file-name) "h")
(re-search-forward "@\\<interface\\>" magic-mode-regexp-match-limit t)))
;; Auto-detect C++/Obj-C header files
(push (cons #'+cc--c++-header-file-p 'c++-mode) magic-mode-alist)
(push (cons #'+cc--objc-header-file-p 'objc-mode) magic-mode-alist)
:config
(setq c-tab-always-indent nil
c-electric-flag nil)
2015-06-15 09:06:10 +02:00
(set! :electric '(c-mode c++-mode objc-mode java-mode)
2017-02-20 20:55:21 -05:00
:chars '(?\n ?\}))
2017-02-19 18:57:16 -05:00
(set! :company-backend
2017-02-19 18:57:16 -05:00
'(c-mode c++-mode objc-mode)
2017-04-17 02:19:20 -04:00
'(company-irony-c-headers company-irony))
2017-06-23 18:13:33 +02:00
(add-hook 'c-mode-common-hook #'rainbow-delimiters-mode)
(add-hook 'c-mode-hook #'highlight-numbers-mode) ; fontify numbers in C
(add-hook 'c++-mode-hook #'+cc|extra-fontify-c++) ; fontify C++11 string literals
(sp-with-modes '(c-mode c++-mode objc-mode java-mode)
2017-02-19 18:57:16 -05:00
(sp-local-pair "<" ">" :when '(+cc-sp-point-is-template-p +cc-sp-point-after-include-p))
(sp-local-pair "/*" "*/" :post-handlers '(("||\n[i]" "RET") ("| " "SPC")))
;; Doxygen blocks
(sp-local-pair "/**" "*/" :post-handlers '(("||\n[i]" "RET") ("||\n[i]" "SPC")))
(sp-local-pair "/*!" "*/" :post-handlers '(("||\n[i]" "RET") ("[d-1]< | " "SPC"))))
;; Improve indentation of inline lambdas in C++11
(advice-add #'c-lineup-arglist :around #'+cc*lineup-arglist)
2017-02-19 18:57:16 -05:00
;; C/C++ style settings
(c-toggle-electric-state -1)
(c-toggle-auto-newline -1)
(c-set-offset 'substatement-open '0) ; brackets should be at same indentation level as the statements they open
(c-set-offset 'inline-open '+)
(c-set-offset 'block-open '+)
(c-set-offset 'brace-list-open '+) ; all "opens" should be indented by the c-indent-level
(c-set-offset 'case-label '+) ; indent case labels by c-indent-level, too
(c-set-offset 'access-label '-)
(c-set-offset 'arglist-intro '+)
(c-set-offset 'arglist-close '0)
(defun +cc--c-lineup-inclass (_langelem)
2017-05-23 21:25:24 +02:00
(if (memq major-mode '(c-mode c++-mode))
(let ((inclass (assq 'inclass c-syntactic-context)))
(save-excursion
(goto-char (c-langelem-pos inclass))
(if (or (looking-at "struct")
(looking-at "typedef struct"))
'+
'++)))
'+))
(c-set-offset 'inclass #'+cc--c-lineup-inclass)
2017-02-19 18:57:16 -05:00
;; Certain mappings interfere with smartparens and custom bindings,
;; so unbind them
(map! :map c-mode-map
2017-02-19 18:57:16 -05:00
"DEL" nil
"#" #'self-insert-command
"{" #'self-insert-command
"}" #'self-insert-command
"/" #'self-insert-command
"*" #'self-insert-command
";" #'self-insert-command
"," #'self-insert-command
":" #'self-insert-command
"(" #'self-insert-command
")" #'self-insert-command
2017-02-19 18:57:16 -05:00
:map c++-mode-map
"}" nil
2017-06-23 18:13:33 +02:00
;; Smartparens and cc-mode both try to autoclose angle-brackets
;; intelligently. The result isn't very intelligent (causes redundant
;; characters), so just do it ourselves.
2017-02-19 18:57:16 -05:00
"<" nil
:map (c-mode-base-map c++-mode-map)
:i ">" #'+cc/autoclose->-maybe))
2017-02-19 18:57:16 -05:00
(def-package! modern-cpp-font-lock
:commands modern-c++-font-lock-mode
:init (add-hook 'c++-mode-hook #'modern-c++-font-lock-mode))
2017-02-19 18:57:16 -05:00
(def-package! irony
:after cc-mode
2017-05-25 20:11:24 +02:00
:commands irony-install-server
:preface
(setq irony-server-install-prefix (concat doom-etc-dir "irony-server/"))
:init
(defun +cc|init-irony-mode ()
2017-06-23 18:13:33 +02:00
(when (and (memq major-mode '(c-mode c++-mode objc-mode))
(file-directory-p irony-server-install-prefix))
(irony-mode +1)))
(add-hook 'c-mode-common-hook #'+cc|init-irony-mode)
:config
(add-hook! 'irony-mode-hook #'(irony-eldoc flycheck-mode))
2017-06-23 18:13:33 +02:00
(defun +cc|init-c++11-clang-options ()
2016-06-08 14:43:40 -04:00
(make-local-variable 'irony-additional-clang-options)
2017-06-23 18:13:33 +02:00
(cl-pushnew "-std=c++11" irony-additional-clang-options :test 'equal))
(add-hook 'c++-mode-hook #'+cc|init-c++11-clang-options)
2017-04-08 23:37:40 -04:00
(map! :map irony-mode-map
[remap completion-at-point] #'counsel-irony
[remap complete-symbol] #'counsel-irony))
(def-package! irony-eldoc :after irony)
(def-package! flycheck-irony
:when (featurep! :feature syntax-checker)
:after irony
:config (flycheck-irony-setup))
;;
2017-02-19 18:57:16 -05:00
;; Tools
;;
(def-package! disaster :commands disaster)
2017-02-19 18:57:16 -05:00
;;
;; Major modes
;;
(def-package! cmake-mode
2017-02-19 18:57:16 -05:00
:mode "CMakeLists\\.txt$"
:config
(set! :company-backend 'cmake-mode '(company-cmake company-yasnippet)))
2015-06-15 09:06:10 +02:00
(def-package! cuda-mode :mode "\\.cuh?$")
2015-06-15 09:06:10 +02:00
(def-package! opencl-mode :mode "\\.cl$")
(def-package! demangle-mode
:commands demangle-mode
:init (add-hook 'llvm-mode-hook #'demangle-mode))
2017-07-06 12:44:03 +02:00
(def-package! glsl-mode
:mode "\\.glsl$"
:mode "\\.vert$"
:mode "\\.frag$"
:mode "\\.geom$")
;;
;; Plugins
;;
(when (featurep! :completion company)
(def-package! company-cmake :after cmake-mode)
(def-package! company-irony :after irony)
(def-package! company-irony-c-headers :after company-irony)
(def-package! company-glsl
:when (featurep! :completion company)
:after glsl-mode
:config
(if (executable-find "glslangValidator")
(warn "glsl-mode: couldn't find glslangValidator, disabling company-glsl")
(set! :company-backend 'glsl-mode '(company-glsl)))))