| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  | ;;; fuel-xref.el -- showing cross-reference info | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-12 22:25:57 -04:00
										 |  |  |  | ;; Copyright (C) 2008, 2009, 2010 Jose Antonio Ortega Ruiz | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  | ;; See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ;; Author: Jose Antonio Ortega Ruiz <jao@gnu.org> | 
					
						
							|  |  |  |  | ;; Keywords: languages, fuel, factor | 
					
						
							|  |  |  |  | ;; Start date: Sat Dec 20, 2008 22:00 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ;;; Comentary: | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ;; A mode and utilities for showing cross-reference information. | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ;;; Code: | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  | (require 'fuel-edit) | 
					
						
							|  |  |  |  | (require 'fuel-completion) | 
					
						
							| 
									
										
										
										
											2009-01-05 01:08:45 -05:00
										 |  |  |  | (require 'fuel-help) | 
					
						
							| 
									
										
										
										
											2008-12-21 11:33:53 -05:00
										 |  |  |  | (require 'fuel-eval) | 
					
						
							|  |  |  |  | (require 'fuel-popup) | 
					
						
							| 
									
										
										
										
											2010-08-12 22:25:57 -04:00
										 |  |  |  | (require 'fuel-menu) | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  | (require 'fuel-base) | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  | (require 'factor-mode) | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | (require 'button) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |  | 
					
						
							|  |  |  |  | ;;; Customization: | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  | ;;;###autoload | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  | (defgroup fuel-xref nil | 
					
						
							|  |  |  |  |   "FUEL's cross-referencing engine." | 
					
						
							|  |  |  |  |   :group 'fuel) | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 12:39:59 -05:00
										 |  |  |  | (defcustom fuel-xref-follow-link-to-word-p t | 
					
						
							|  |  |  |  |   "Whether, when following a link to a caller, we position the
 | 
					
						
							|  |  |  |  | cursor at the first ocurrence of the used word."
 | 
					
						
							|  |  |  |  |   :group 'fuel-xref | 
					
						
							|  |  |  |  |   :type 'boolean) | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  | (defcustom fuel-xref-follow-link-method nil | 
					
						
							|  |  |  |  |   "How new buffers are opened when following a crossref link." | 
					
						
							|  |  |  |  |   :group 'fuel-xref | 
					
						
							|  |  |  |  |   :type '(choice (const :tag "Other window" window) | 
					
						
							|  |  |  |  |                  (const :tag "Other frame" frame) | 
					
						
							|  |  |  |  |                  (const :tag "Current window" nil))) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defface fuel-xref-link-face '((t (:inherit link))) | 
					
						
							|  |  |  |  |   "Highlighting links in cross-reference buffers." | 
					
						
							|  |  |  |  |   :group 'fuel-xref | 
					
						
							|  |  |  |  |   :group 'fuel-faces | 
					
						
							|  |  |  |  |   :group 'fuel) | 
					
						
							| 
									
										
										
										
											2009-01-22 03:55:39 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  | (defvar-local fuel-xref--word nil) | 
					
						
							| 
									
										
										
										
											2008-12-21 11:33:53 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  |  | 
					
						
							|  |  |  |  | ;;; Buttons: | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (define-button-type 'fuel-xref--button-type | 
					
						
							|  |  |  |  |   'action 'fuel-xref--follow-link | 
					
						
							|  |  |  |  |   'follow-link t | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  |   'face 'fuel-xref-link-face) | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-xref--follow-link (button) | 
					
						
							|  |  |  |  |   (let ((file (button-get button 'file)) | 
					
						
							|  |  |  |  |         (line (button-get button 'line))) | 
					
						
							|  |  |  |  |     (when (not file) | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  |       (error "No file for this ref (it's probably a primitive)")) | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  |     (when (not (file-readable-p file)) | 
					
						
							|  |  |  |  |       (error "File '%s' is not readable" file)) | 
					
						
							| 
									
										
										
										
											2008-12-21 12:39:59 -05:00
										 |  |  |  |     (let ((word fuel-xref--word)) | 
					
						
							| 
									
										
										
										
											2009-01-22 03:55:39 -05:00
										 |  |  |  |       (fuel-edit--visit-file file fuel-xref-follow-link-method) | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  |       (when (numberp line) | 
					
						
							|  |  |  |  |         (goto-char (point-min)) | 
					
						
							|  |  |  |  |         (forward-line (1- line))) | 
					
						
							| 
									
										
										
										
											2008-12-21 12:39:59 -05:00
										 |  |  |  |       (when (and word fuel-xref-follow-link-to-word-p) | 
					
						
							| 
									
										
										
										
											2009-01-22 03:55:39 -05:00
										 |  |  |  |         (and (re-search-forward (format "\\_<%s\\_>" word) | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  |                                 (factor-end-of-defun-pos) | 
					
						
							| 
									
										
										
										
											2009-01-22 03:55:39 -05:00
										 |  |  |  |                                 t) | 
					
						
							| 
									
										
										
										
											2008-12-21 12:39:59 -05:00
										 |  |  |  |              (goto-char (match-beginning 0))))))) | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |  | 
					
						
							|  |  |  |  | ;;; The xref buffer: | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  | (defun fuel-xref--eval<x--y> (arg word context) | 
					
						
							|  |  |  |  |   "A helper for the very common task of calling an ( x -- y ) factor word." | 
					
						
							|  |  |  |  |   (let ((cmd (list :fuel* (list (list arg word)) context))) | 
					
						
							|  |  |  |  |     (fuel-eval--retort-result (fuel-eval--send/wait cmd)))) | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  | (defun fuel-xref--buffer () | 
					
						
							|  |  |  |  |   (or (get-buffer "*fuel xref*") | 
					
						
							| 
									
										
										
										
											2014-11-04 22:42:07 -05:00
										 |  |  |  |       (with-current-buffer (get-buffer-create "*fuel xref*") | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  |         (fuel-xref-mode) | 
					
						
							|  |  |  |  |         (fuel-popup-mode) | 
					
						
							|  |  |  |  |         (current-buffer)))) | 
					
						
							| 
									
										
										
										
											2008-12-21 12:39:59 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  | (defun fuel-xref--pluralize-count (count item) | 
					
						
							|  |  |  |  |   (let ((fmt (if (= count 1) "%d %s" "%d %ss"))) | 
					
						
							|  |  |  |  |     (format fmt count item))) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-xref--insert-link (title file line-num) | 
					
						
							|  |  |  |  |   (insert-text-button title | 
					
						
							|  |  |  |  |                       :type 'fuel-xref--button-type | 
					
						
							|  |  |  |  |                       'help-echo (format "File: %s (%s)" file line-num) | 
					
						
							|  |  |  |  |                       'file file | 
					
						
							|  |  |  |  |                       'line line-num)) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-xref--insert-word (word vocab file line-num) | 
					
						
							|  |  |  |  |   (insert "  ") | 
					
						
							|  |  |  |  |   (fuel-xref--insert-link word file line-num) | 
					
						
							|  |  |  |  |   (insert (if line-num (format " line %s" line-num) | 
					
						
							|  |  |  |  |             " primitive")) | 
					
						
							|  |  |  |  |   (newline)) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-xref--insert-vocab-words (vocab-def xrefs) | 
					
						
							|  |  |  |  |   (destructuring-bind (vocab file) vocab-def | 
					
						
							|  |  |  |  |     (insert "in ") | 
					
						
							|  |  |  |  |     (fuel-xref--insert-link (or vocab "unknown vocabs") file 1) | 
					
						
							|  |  |  |  |     (let ((count-str (fuel-xref--pluralize-count (length xrefs) "word"))) | 
					
						
							|  |  |  |  |       (insert (format " %s:\n" count-str)))) | 
					
						
							|  |  |  |  |   (dolist (xref xrefs) | 
					
						
							|  |  |  |  |     (apply 'fuel-xref--insert-word xref)) | 
					
						
							|  |  |  |  |   (newline)) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-xref--display-word-groups (search-str cc xref-groups) | 
					
						
							|  |  |  |  |   "Should be called in a with-current-buffer context" | 
					
						
							| 
									
										
										
										
											2008-12-21 11:33:53 -05:00
										 |  |  |  |   (let ((inhibit-read-only t) | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  |         (title-str (format "Words %s %s:\n\n" cc search-str))) | 
					
						
							|  |  |  |  |     (erase-buffer) | 
					
						
							|  |  |  |  |     (insert (propertize title-str 'font-lock-face 'bold)) | 
					
						
							|  |  |  |  |     (dolist (group xref-groups) | 
					
						
							|  |  |  |  |       (apply 'fuel-xref--insert-vocab-words group))) | 
					
						
							|  |  |  |  |   (goto-char (point-min)) | 
					
						
							|  |  |  |  |   (message "") | 
					
						
							|  |  |  |  |   (fuel-popup--display (current-buffer))) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-xref--display-vocabs (search-str cc xrefs) | 
					
						
							|  |  |  |  |   "Should be called in a with-current-buffer context" | 
					
						
							|  |  |  |  |   (put-text-property 0 (length search-str) 'font-lock-face 'bold search-str) | 
					
						
							|  |  |  |  |   (let* ((inhibit-read-only t) | 
					
						
							|  |  |  |  |          (xrefs (remove-if (lambda (el) (not (nth 2 el))) xrefs)) | 
					
						
							|  |  |  |  |          (count-str (fuel-xref--pluralize-count (length xrefs) "vocab")) | 
					
						
							|  |  |  |  |          (title-str (format "%s %s %s:\n\n" count-str cc search-str))) | 
					
						
							|  |  |  |  |     (erase-buffer) | 
					
						
							|  |  |  |  |     (insert title-str) | 
					
						
							|  |  |  |  |     (loop for (vocab _ file line-num) in xrefs do | 
					
						
							|  |  |  |  |           (insert "  ") | 
					
						
							|  |  |  |  |           (fuel-xref--insert-link vocab file line-num) | 
					
						
							|  |  |  |  |           (newline))) | 
					
						
							|  |  |  |  |   (goto-char (point-min)) | 
					
						
							|  |  |  |  |   (message "") | 
					
						
							|  |  |  |  |   (fuel-popup--display (current-buffer))) | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-22 17:25:17 -05:00
										 |  |  |  | (defun fuel-xref--callers (word) | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  |   (fuel-xref--eval<x--y> (list :quote word) 'fuel-callers-xref "")) | 
					
						
							| 
									
										
										
										
											2009-01-22 17:25:17 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  | (defun fuel-xref--show-callers (word) | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  |   (let ((res (fuel-xref--callers word))) | 
					
						
							|  |  |  |  |     (with-current-buffer (fuel-xref--buffer) | 
					
						
							|  |  |  |  |       (setq fuel-xref--word word) | 
					
						
							|  |  |  |  |       (fuel-xref--display-word-groups word "calling" res)))) | 
					
						
							| 
									
										
										
										
											2009-01-22 17:25:17 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-xref--word-callers-files (word) | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  |   (mapcar 'cadar (fuel-xref--callers word))) | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-xref--show-callees (word) | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  |   (let ((res (fuel-xref--eval<x--y> (list :quote word) 'fuel-callees-xref ""))) | 
					
						
							|  |  |  |  |     (with-current-buffer (fuel-xref--buffer) | 
					
						
							|  |  |  |  |       (setq fuel-xref--word nil) | 
					
						
							|  |  |  |  |       (fuel-xref--display-word-groups word "used by" res)))) | 
					
						
							| 
									
										
										
										
											2009-01-03 20:36:58 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-xref--apropos (str) | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  |   (let ((res (fuel-xref--eval<x--y> str 'fuel-apropos-xref ""))) | 
					
						
							|  |  |  |  |     (with-current-buffer (fuel-xref--buffer) | 
					
						
							|  |  |  |  |       (setq fuel-xref--word nil) | 
					
						
							|  |  |  |  |       (fuel-xref--display-word-groups str "containing" res)))) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-xref--show-vocab-words (vocab) | 
					
						
							|  |  |  |  |   (let ((res (fuel-xref--eval<x--y> vocab 'fuel-vocab-xref vocab))) | 
					
						
							|  |  |  |  |     (with-current-buffer (fuel-xref--buffer) | 
					
						
							|  |  |  |  |       (setq fuel-xref--word nil) | 
					
						
							|  |  |  |  |       (fuel-xref--display-word-groups vocab "in vocabulary" res)))) | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-22 15:13:38 -05:00
										 |  |  |  | (defun fuel-xref--show-vocab-usage (vocab) | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  |   (let ((res (fuel-xref--eval<x--y> vocab 'fuel-vocab-usage-xref ""))) | 
					
						
							|  |  |  |  |     (with-current-buffer (fuel-xref--buffer) | 
					
						
							|  |  |  |  |       (setq fuel-xref--word nil) | 
					
						
							|  |  |  |  |       (fuel-xref--display-vocabs vocab "using" res)))) | 
					
						
							| 
									
										
										
										
											2009-01-22 15:13:38 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-xref--show-vocab-uses (vocab) | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  |   (let ((res (fuel-xref--eval<x--y> vocab 'fuel-vocab-uses-xref ""))) | 
					
						
							|  |  |  |  |     (with-current-buffer (fuel-xref--buffer) | 
					
						
							|  |  |  |  |       (setq fuel-xref--word nil) | 
					
						
							|  |  |  |  |       (fuel-xref--display-vocabs vocab "used by" res)))) | 
					
						
							| 
									
										
										
										
											2009-01-22 15:13:38 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  |  | 
					
						
							|  |  |  |  | ;;; User commands: | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defvar fuel-xref--word-history nil) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-show-callers (&optional arg) | 
					
						
							| 
									
										
										
										
											2009-01-22 15:13:38 -05:00
										 |  |  |  |   "Show a list of callers of word or vocabulary at point.
 | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  | With prefix argument, ask for word."
 | 
					
						
							|  |  |  |  |   (interactive "P") | 
					
						
							|  |  |  |  |   (let ((word (if arg (fuel-completion--read-word "Find callers for: " | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  |                                                   (factor-symbol-at-point) | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  |                                                   fuel-xref--word-history) | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  |                 (factor-symbol-at-point)))) | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  |     (when word | 
					
						
							| 
									
										
										
										
											2009-01-22 15:13:38 -05:00
										 |  |  |  |       (message "Looking up %s's users ..." word) | 
					
						
							|  |  |  |  |       (if (and (not arg) | 
					
						
							|  |  |  |  |                (fuel-edit--looking-at-vocab)) | 
					
						
							|  |  |  |  |           (fuel-xref--show-vocab-usage word) | 
					
						
							|  |  |  |  |         (fuel-xref--show-callers word))))) | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-show-callees (&optional arg) | 
					
						
							| 
									
										
										
										
											2009-01-22 15:13:38 -05:00
										 |  |  |  |   "Show a list of callers of word or vocabulary at point.
 | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  | With prefix argument, ask for word."
 | 
					
						
							|  |  |  |  |   (interactive "P") | 
					
						
							|  |  |  |  |   (let ((word (if arg (fuel-completion--read-word "Find callees for: " | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  |                                                   (factor-symbol-at-point) | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  |                                                   fuel-xref--word-history) | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  |                 (factor-symbol-at-point)))) | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  |     (when word | 
					
						
							|  |  |  |  |       (message "Looking up %s's callees ..." word) | 
					
						
							| 
									
										
										
										
											2009-01-22 15:13:38 -05:00
										 |  |  |  |       (if (and (not arg) | 
					
						
							|  |  |  |  |                (fuel-edit--looking-at-vocab)) | 
					
						
							|  |  |  |  |           (fuel-xref--show-vocab-uses word) | 
					
						
							|  |  |  |  |         (fuel-xref--show-callees word))))) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defvar fuel-xref--vocab-history nil) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-vocab-uses (&optional arg) | 
					
						
							|  |  |  |  |   "Show a list of vocabularies used by a given one.
 | 
					
						
							|  |  |  |  | With prefix argument, force reload of vocabulary list."
 | 
					
						
							|  |  |  |  |   (interactive "P") | 
					
						
							|  |  |  |  |   (let ((vocab (fuel-completion--read-vocab arg | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  |                                             (factor-symbol-at-point) | 
					
						
							| 
									
										
										
										
											2009-01-22 15:13:38 -05:00
										 |  |  |  |                                             fuel-xref--vocab-history))) | 
					
						
							|  |  |  |  |     (fuel-xref--show-vocab-uses vocab))) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-vocab-usage (&optional arg) | 
					
						
							|  |  |  |  |   "Show a list of vocabularies that use a given one.
 | 
					
						
							|  |  |  |  | With prefix argument, force reload of vocabulary list."
 | 
					
						
							|  |  |  |  |   (interactive "P") | 
					
						
							|  |  |  |  |   (let ((vocab (fuel-completion--read-vocab arg | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  |                                             (factor-symbol-at-point) | 
					
						
							| 
									
										
										
										
											2009-01-22 15:13:38 -05:00
										 |  |  |  |                                             fuel-xref--vocab-history))) | 
					
						
							|  |  |  |  |     (fuel-xref--show-vocab-usage vocab))) | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-apropos (str) | 
					
						
							|  |  |  |  |   "Show a list of words containing the given substring." | 
					
						
							|  |  |  |  |   (interactive "MFind words containing: ") | 
					
						
							|  |  |  |  |   (message "Looking up %s's references ..." str) | 
					
						
							|  |  |  |  |   (fuel-xref--apropos str)) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | (defun fuel-show-file-words (&optional arg) | 
					
						
							|  |  |  |  |   "Show a list of words in current file.
 | 
					
						
							|  |  |  |  | With prefix argument, ask for the vocab."
 | 
					
						
							|  |  |  |  |   (interactive "P") | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  |   (let ((vocab (or (and (not arg) (factor-find-in)) | 
					
						
							| 
									
										
										
										
											2009-02-05 04:28:57 -05:00
										 |  |  |  |                    (fuel-completion--read-vocab nil)))) | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  |     (when vocab | 
					
						
							| 
									
										
										
										
											2014-11-05 19:20:19 -05:00
										 |  |  |  |       (fuel-xref--show-vocab-words vocab)))) | 
					
						
							| 
									
										
										
										
											2009-01-08 12:47:17 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  |  | 
					
						
							|  |  |  |  | ;;; Xref mode: | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-05 01:08:45 -05:00
										 |  |  |  | (defun fuel-xref-show-help () | 
					
						
							|  |  |  |  |   (interactive) | 
					
						
							|  |  |  |  |   (let ((fuel-help-always-ask nil)) | 
					
						
							|  |  |  |  |     (fuel-help))) | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  | ;;;###autoload | 
					
						
							|  |  |  |  | (define-derived-mode fuel-xref-mode fundamental-mode "FUEL Xref" | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  |   "Mode for displaying FUEL cross-reference information.
 | 
					
						
							|  |  |  |  | \\{fuel-xref-mode-map}"
 | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  |   :syntax-table factor-mode-syntax-table | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  |   (buffer-disable-undo) | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   (suppress-keymap fuel-xref-mode-map) | 
					
						
							|  |  |  |  |   (set-keymap-parent fuel-xref-mode-map button-buffer-map) | 
					
						
							|  |  |  |  |   (define-key fuel-xref-mode-map "h" 'fuel-xref-show-help) | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  |   (setq buffer-read-only t)) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |  | 
					
						
							|  |  |  |  | (provide 'fuel-xref) | 
					
						
							| 
									
										
										
										
											2013-05-05 00:48:12 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-20 19:43:28 -05:00
										 |  |  |  | ;;; fuel-xref.el ends here |