Emacs config utilizing prelude as a base
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

146 lines
5.0 KiB

13 years ago
13 years ago
12 years ago
  1. ;;; prelude-programming.el --- Emacs Prelude: prog-mode configuration
  2. ;;
  3. ;; Copyright © 2011-2013 Bozhidar Batsov
  4. ;;
  5. ;; Author: Bozhidar Batsov <bozhidar@batsov.com>
  6. ;; URL: https://github.com/bbatsov/prelude
  7. ;; Version: 1.0.0
  8. ;; Keywords: convenience
  9. ;; This file is not part of GNU Emacs.
  10. ;;; Commentary:
  11. ;; Some basic prog-mode configuration and programming related utilities.
  12. ;;; License:
  13. ;; This program is free software; you can redistribute it and/or
  14. ;; modify it under the terms of the GNU General Public License
  15. ;; as published by the Free Software Foundation; either version 3
  16. ;; of the License, or (at your option) any later version.
  17. ;;
  18. ;; This program is distributed in the hope that it will be useful,
  19. ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
  20. ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  21. ;; GNU General Public License for more details.
  22. ;;
  23. ;; You should have received a copy of the GNU General Public License
  24. ;; along with GNU Emacs; see the file COPYING. If not, write to the
  25. ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
  26. ;; Boston, MA 02110-1301, USA.
  27. ;;; Code:
  28. (prelude-require-packages '(guru-mode))
  29. (defun prelude-ido-goto-symbol (&optional symbol-list)
  30. "Refresh imenu and jump to a place in the buffer using Ido."
  31. (interactive)
  32. (unless (featurep 'imenu)
  33. (require 'imenu nil t))
  34. (cond
  35. ((not symbol-list)
  36. (let ((ido-mode ido-mode)
  37. (ido-enable-flex-matching
  38. (if (boundp 'ido-enable-flex-matching)
  39. ido-enable-flex-matching t))
  40. name-and-pos symbol-names position)
  41. (unless ido-mode
  42. (ido-mode 1)
  43. (setq ido-enable-flex-matching t))
  44. (while (progn
  45. (imenu--cleanup)
  46. (setq imenu--index-alist nil)
  47. (prelude-ido-goto-symbol (imenu--make-index-alist))
  48. (setq selected-symbol
  49. (ido-completing-read "Symbol? " symbol-names))
  50. (string= (car imenu--rescan-item) selected-symbol)))
  51. (unless (and (boundp 'mark-active) mark-active)
  52. (push-mark nil t nil))
  53. (setq position (cdr (assoc selected-symbol name-and-pos)))
  54. (cond
  55. ((overlayp position)
  56. (goto-char (overlay-start position)))
  57. (t
  58. (goto-char position)))
  59. (recenter)))
  60. ((listp symbol-list)
  61. (dolist (symbol symbol-list)
  62. (let (name position)
  63. (cond
  64. ((and (listp symbol) (imenu--subalist-p symbol))
  65. (prelude-ido-goto-symbol symbol))
  66. ((listp symbol)
  67. (setq name (car symbol))
  68. (setq position (cdr symbol)))
  69. ((stringp symbol)
  70. (setq name symbol)
  71. (setq position
  72. (get-text-property 1 'org-imenu-marker symbol))))
  73. (unless (or (null position) (null name)
  74. (string= (car imenu--rescan-item) name))
  75. (add-to-list 'symbol-names (substring-no-properties name))
  76. (add-to-list 'name-and-pos (cons (substring-no-properties name) position))))))))
  77. ;; add a shortcut for prelude-ido-goto-symbol
  78. (eval-after-load 'prelude-mode
  79. '(define-key prelude-mode-map (kbd "C-c i") 'prelude-ido-goto-symbol))
  80. (defun prelude-local-comment-auto-fill ()
  81. (set (make-local-variable 'comment-auto-fill-only-comments) t))
  82. (defun prelude-font-lock-comment-annotations ()
  83. "Highlight a bunch of well known comment annotations.
  84. This functions should be added to the hooks of major modes for programming."
  85. (font-lock-add-keywords
  86. nil '(("\\<\\(\\(FIX\\(ME\\)?\\|TODO\\|OPTIMIZE\\|HACK\\|REFACTOR\\):\\)"
  87. 1 font-lock-warning-face t))))
  88. ;; show the name of the current function definition in the modeline
  89. (require 'which-func)
  90. (which-function-mode 1)
  91. ;; in Emacs 24 programming major modes generally derive from a common
  92. ;; mode named prog-mode; for others, we'll arrange for our mode
  93. ;; defaults function to run prelude-prog-mode-hook directly. To
  94. ;; augment and/or counteract these defaults your own function
  95. ;; to prelude-prog-mode-hook, using:
  96. ;;
  97. ;; (add-hook 'prelude-prog-mode-hook 'my-prog-mode-defaults t)
  98. ;;
  99. ;; (the final optional t sets the *append* argument)
  100. ;; smart curly braces
  101. (sp-pair "{" nil :post-handlers
  102. '(((lambda (&rest _ignored)
  103. (prelude-smart-open-line-above)) "RET")))
  104. ;; enlist a more liberal guru
  105. (setq guru-warn-only t)
  106. (defun prelude-prog-mode-defaults ()
  107. "Default coding hook, useful with any programming language."
  108. (when (and (executable-find ispell-program-name)
  109. prelude-flyspell)
  110. (flyspell-prog-mode))
  111. (when prelude-guru
  112. (guru-mode +1))
  113. (smartparens-mode +1)
  114. (prelude-enable-whitespace)
  115. (prelude-local-comment-auto-fill)
  116. (prelude-font-lock-comment-annotations))
  117. (setq prelude-prog-mode-hook 'prelude-prog-mode-defaults)
  118. (add-hook 'prog-mode-hook (lambda ()
  119. (run-hooks 'prelude-prog-mode-hook)))
  120. ;; enable on-the-fly syntax checking
  121. (if (fboundp 'global-flycheck-mode)
  122. (global-flycheck-mode +1)
  123. (add-hook 'prog-mode-hook 'flycheck-mode))
  124. (provide 'prelude-programming)
  125. ;;; prelude-programming.el ends here