|
|
@ -34,58 +34,9 @@ |
|
|
|
|
|
|
|
|
(prelude-require-packages '(guru-mode)) |
|
|
(prelude-require-packages '(guru-mode)) |
|
|
|
|
|
|
|
|
(defun prelude-ido-goto-symbol (&optional symbol-list) |
|
|
|
|
|
"Refresh imenu and jump to a place in the buffer using Ido." |
|
|
|
|
|
(interactive) |
|
|
|
|
|
(unless (featurep 'imenu) |
|
|
|
|
|
(require 'imenu nil t)) |
|
|
|
|
|
(cond |
|
|
|
|
|
((not symbol-list) |
|
|
|
|
|
(let ((ido-mode ido-mode) |
|
|
|
|
|
(ido-enable-flex-matching |
|
|
|
|
|
(if (boundp 'ido-enable-flex-matching) |
|
|
|
|
|
ido-enable-flex-matching t)) |
|
|
|
|
|
name-and-pos symbol-names position) |
|
|
|
|
|
(unless ido-mode |
|
|
|
|
|
(ido-mode 1) |
|
|
|
|
|
(setq ido-enable-flex-matching t)) |
|
|
|
|
|
(while (progn |
|
|
|
|
|
(imenu--cleanup) |
|
|
|
|
|
(setq imenu--index-alist nil) |
|
|
|
|
|
(prelude-ido-goto-symbol (imenu--make-index-alist)) |
|
|
|
|
|
(setq selected-symbol |
|
|
|
|
|
(ido-completing-read "Symbol? " symbol-names)) |
|
|
|
|
|
(string= (car imenu--rescan-item) selected-symbol))) |
|
|
|
|
|
(unless (and (boundp 'mark-active) mark-active) |
|
|
|
|
|
(push-mark nil t nil)) |
|
|
|
|
|
(setq position (cdr (assoc selected-symbol name-and-pos))) |
|
|
|
|
|
(cond |
|
|
|
|
|
((overlayp position) |
|
|
|
|
|
(goto-char (overlay-start position))) |
|
|
|
|
|
(t |
|
|
|
|
|
(goto-char position))) |
|
|
|
|
|
(recenter))) |
|
|
|
|
|
((listp symbol-list) |
|
|
|
|
|
(dolist (symbol symbol-list) |
|
|
|
|
|
(let (name position) |
|
|
|
|
|
(cond |
|
|
|
|
|
((and (listp symbol) (imenu--subalist-p symbol)) |
|
|
|
|
|
(prelude-ido-goto-symbol symbol)) |
|
|
|
|
|
((listp symbol) |
|
|
|
|
|
(setq name (car symbol)) |
|
|
|
|
|
(setq position (cdr symbol))) |
|
|
|
|
|
((stringp symbol) |
|
|
|
|
|
(setq name symbol) |
|
|
|
|
|
(setq position |
|
|
|
|
|
(get-text-property 1 'org-imenu-marker symbol)))) |
|
|
|
|
|
(unless (or (null position) (null name) |
|
|
|
|
|
(string= (car imenu--rescan-item) name)) |
|
|
|
|
|
(add-to-list 'symbol-names (substring-no-properties name)) |
|
|
|
|
|
(add-to-list 'name-and-pos (cons (substring-no-properties name) position)))))))) |
|
|
|
|
|
|
|
|
|
|
|
;; add a shortcut for prelude-ido-goto-symbol |
|
|
;; add a shortcut for prelude-ido-goto-symbol |
|
|
(eval-after-load 'prelude-mode |
|
|
(eval-after-load 'prelude-mode |
|
|
'(define-key prelude-mode-map (kbd "C-c i") 'prelude-ido-goto-symbol)) |
|
|
|
|
|
|
|
|
') |
|
|
|
|
|
|
|
|
(defun prelude-local-comment-auto-fill () |
|
|
(defun prelude-local-comment-auto-fill () |
|
|
(set (make-local-variable 'comment-auto-fill-only-comments) t)) |
|
|
(set (make-local-variable 'comment-auto-fill-only-comments) t)) |
|
|
|