cmake-mode.el: Add help for variables/properties/complete. Factorize.

This commit is contained in:
Philipp Möller 2014-01-29 17:48:21 +01:00 committed by Brad King
parent 7cc21e9ab8
commit 9d35f7c49a
1 changed files with 80 additions and 46 deletions

View File

@ -291,31 +291,47 @@ optional argument topic will be appended to the argument list."
(cmake-command-run "--help-command-list") (cmake-command-run "--help-command-list")
) )
(defvar cmake-help-command-history nil "Topic read history.") (defvar cmake-commands '() "List of available topics for --help-command.")
(defvar cmake-help-commands '() "List of available topics for --help-command.") (defvar cmake-help-command-history nil "Command read history.")
(defun cmake-command-list-as-list () (defvar cmake-modules '() "List of available topics for --help-module.")
"Run cmake --help-command-list and return a list where each element is a cmake command." (defvar cmake-help-module-history nil "Module read history.")
(let ((temp-buffer-name "*CMake Commands Temporary*")) (defvar cmake-variables '() "List of available topics for --help-variable.")
(save-window-excursion (defvar cmake-help-variable-history nil "Variable read history.")
(cmake-command-run "--help-command-list" nil temp-buffer-name) (defvar cmake-properties '() "List of available topics for --help-property.")
(with-current-buffer temp-buffer-name (defvar cmake-help-property-history nil "Property read history.")
(cdr (split-string (buffer-substring-no-properties (point-min) (point-max)) "\n" t))))) (defvar cmake-help-complete-history nil "Complete help read history.")
(defvar cmake-string-to-list-symbol
'(("command" cmake-commands cmake-help-command-history)
("module" cmake-modules cmake-help-module-history)
("variable" cmake-variables cmake-help-variable-history)
("property" cmake-properties cmake-help-property-history)
))
(defun cmake-get-list (listname)
"If the value of LISTVAR is nil, run cmake --help-LISTNAME-list
and store the result as a list in LISTVAR."
(let ((listvar (car (cdr (assoc listname cmake-string-to-list-symbol)))))
(if (not (symbol-value listvar))
(let ((temp-buffer-name "*CMake Temporary*"))
(save-window-excursion
(cmake-command-run (concat "--help-" listname "-list") nil temp-buffer-name)
(with-current-buffer temp-buffer-name
(set listvar (cdr (split-string (buffer-substring-no-properties (point-min) (point-max)) "\n" t))))))
(symbol-value listvar)
))
) )
(require 'thingatpt) (require 'thingatpt)
;;;###autoload (defun cmake-help-type (type)
(defun cmake-get-command ()
"Gets the topic from the minibuffer input. The default is the word the cursor is on."
(let* ((default-entry (word-at-point)) (let* ((default-entry (word-at-point))
(history (car (cdr (cdr (assoc type cmake-string-to-list-symbol)))))
(input (completing-read (input (completing-read
"CMake command: " ; prompt (format "CMake %s: " type) ; prompt
((lambda () (cmake-get-list type) ; completions
(if cmake-help-commands cmake-help-commands
(setq cmake-help-commands (cmake-command-list-as-list))))) ; completions
nil ; predicate nil ; predicate
t ; require-match t ; require-match
default-entry ; initial-input default-entry ; initial-input
'cmake-help-command-history ; command history history
))) )))
(if (string= input "") (if (string= input "")
(error "No argument given") (error "No argument given")
@ -324,41 +340,59 @@ optional argument topic will be appended to the argument list."
;;;###autoload ;;;###autoload
(defun cmake-help-command () (defun cmake-help-command ()
"Prints out the help message corresponding to the command the cursor is on." "Prints out the help message for the command the cursor is on."
(interactive) (interactive)
(cmake-command-run "--help-command" (downcase (cmake-get-command)) "*CMake Help*")) (cmake-command-run "--help-command" (cmake-help-type "command") "*CMake Help*"))
(defvar cmake-help-module-history nil "Module read history.") ;;;###autoload
(defvar cmake-help-modules '() "List of available topics for --help-module.") (defun cmake-help-module ()
"Prints out the help message for the module the cursor is on."
(interactive)
(cmake-command-run "--help-module" (cmake-help-type "module") "*CMake Help*"))
(defun cmake-module-list () ;;;###autoload
(let ((temp-buffer-name "*CMake Modules Temporary*")) (defun cmake-help-variable ()
(save-window-excursion "Prints out the help message for the variable the cursor is on."
(cmake-command-run "--help-module-list" nil temp-buffer-name) (interactive)
(with-current-buffer temp-buffer-name (cmake-command-run "--help-variable" (cmake-help-type "variable") "*CMake Help*"))
(cdr (split-string (buffer-substring-no-properties (point-min) (point-max)) "\n" t)))))
)
(defun cmake-get-module () ;;;###autoload
(let ((input (completing-read (defun cmake-help-property ()
"CMake module: " ; prompt "Prints out the help message for the property the cursor is on."
((lambda () (interactive)
(if cmake-help-modules cmake-help-modules (cmake-command-run "--help-property" (cmake-help-type "property") "*CMake Help*"))
(setq cmake-help-modules (cmake-module-list))))) ; completions
nil ; predicate ;;;###autoload
t ; require-match (defun cmake-help ()
nil ; initial-input "Queries for any of the four available help topics and prints out the approriate page."
'cmake-help-module-history ; module history (interactive)
))) (let* ((default-entry (word-at-point))
(command-list (cmake-get-list "command"))
(variable-list (cmake-get-list "variable"))
(module-list (cmake-get-list "module"))
(property-list (cmake-get-list "property"))
(all-words (append command-list variable-list module-list property-list))
(input (completing-read
"CMake command/module/variable/property: " ; prompt
all-words ; completions
nil ; predicate
t ; require-match
default-entry ; initial-input
'cmake-help-complete-history
)))
(if (string= input "") (if (string= input "")
(error "No argument given") (error "No argument given")
input) (if (member input command-list)
)) (cmake-command-run "--help-command" input "*CMake Help*")
(if (member input variable-list)
(defun cmake-help-module () (cmake-command-run "--help-variable" input "*CMake Help*")
"Prints out the help message corresponding to the given module." (if (member input module-list)
(interactive) (cmake-command-run "--help-module" input "*CMake Help*")
(cmake-command-run "--help-module" (cmake-get-module) "*CMake Module Help*")) (if (member input property-list)
(cmake-command-run "--help-property" input "*CMake Help*")
(error "Not a know help topic.") ; this really should not happen
))))))
)
;;;###autoload ;;;###autoload
(progn (progn