1
0
mirror of https://git.savannah.gnu.org/git/emacs.git synced 2025-01-04 11:40:22 +00:00

Add finder unknown keywords.

* finder.el (finder-unknown-keywords): New function.

* info.el (Info-finder-find-node): Use `finder-unknown-keywords'
to create a Finder node with unknown keywords.
This commit is contained in:
Juri Linkov 2010-03-14 23:28:52 +02:00
parent 88f4758e1c
commit 57938a7982
3 changed files with 48 additions and 2 deletions

View File

@ -1,3 +1,12 @@
2010-03-14 Juri Linkov <juri@jurta.org>
Add finder unknown keywords.
* finder.el (finder-unknown-keywords): New function.
* info.el (Info-finder-find-node): Use `finder-unknown-keywords'
to create a Finder node with unknown keywords.
2010-03-14 Juri Linkov <juri@jurta.org> 2010-03-14 Juri Linkov <juri@jurta.org>
* finder.el (finder-compile-keywords): Replace `princ' with * finder.el (finder-compile-keywords): Replace `princ' with

View File

@ -33,7 +33,6 @@
;; there doesn't seem to be any way to get completing-read to exit on ;; there doesn't seem to be any way to get completing-read to exit on
;; an EOL with no substring pending, which is what we'd want to end the loop. ;; an EOL with no substring pending, which is what we'd want to end the loop.
;; 2. Search by string in synopsis line? ;; 2. Search by string in synopsis line?
;; 3. Function to check finder-package-info for unknown keywords.
;;; Code: ;;; Code:
@ -230,6 +229,29 @@ no arguments compiles from `load-path'."
'(mouse-face highlight '(mouse-face highlight
help-echo finder-help-echo)))) help-echo finder-help-echo))))
(defun finder-unknown-keywords ()
"Return an alist of unknown keywords and number of their occurences.
Unknown are keywords that are present in `finder-package-info'
but absent in `finder-known-keywords'."
(let ((unknown-keywords-hash (make-hash-table)))
;; Prepare a hash where key is a keyword
;; and value is the number of keyword occurences.
(mapc (lambda (package)
(mapc (lambda (keyword)
(unless (assq keyword finder-known-keywords)
(puthash keyword
(1+ (gethash keyword unknown-keywords-hash 0))
unknown-keywords-hash)))
(nth 2 package)))
finder-package-info)
;; Make an alist from the hash and sort by the keyword name.
(sort (let (unknown-keywords-list)
(maphash (lambda (key value)
(push (cons key value) unknown-keywords-list))
unknown-keywords-hash)
unknown-keywords-list)
(lambda (a b) (string< (car a) (car b))))))
;;;###autoload ;;;###autoload
(defun finder-list-keywords () (defun finder-list-keywords ()
"Display descriptions of the keywords in the Finder buffer." "Display descriptions of the keywords in the Finder buffer."

View File

@ -3343,6 +3343,7 @@ Build a menu of the possible matches."
(defvar finder-known-keywords) (defvar finder-known-keywords)
(defvar finder-package-info) (defvar finder-package-info)
(declare-function find-library-name "find-func" (library)) (declare-function find-library-name "find-func" (library))
(declare-function finder-unknown-keywords "finder" ())
(declare-function lm-commentary "lisp-mnt" (&optional file)) (declare-function lm-commentary "lisp-mnt" (&optional file))
(defun Info-finder-find-node (filename nodename &optional no-going-back) (defun Info-finder-find-node (filename nodename &optional no-going-back)
@ -3361,7 +3362,21 @@ Build a menu of the possible matches."
(insert (format "* %-14s %s.\n" (insert (format "* %-14s %s.\n"
(concat (symbol-name keyword) "::") (concat (symbol-name keyword) "::")
(cdr assoc))))) (cdr assoc)))))
finder-known-keywords)) (cons '(unknown . "unknown keywords")
finder-known-keywords)))
((equal nodename "unknown")
;; Display unknown keywords
(insert (format "\n\^_\nFile: %s, Node: %s, Up: Top\n\n"
Info-finder-file nodename))
(insert "Finder Unknown Keywords\n")
(insert "***********************\n\n")
(insert "* Menu:\n\n")
(mapc
(lambda (assoc)
(insert (format "* %-14s %s.\n"
(concat (symbol-name (car assoc)) "::")
(cdr assoc))))
(finder-unknown-keywords)))
((string-match-p "\\.el\\'" nodename) ((string-match-p "\\.el\\'" nodename)
;; Display commentary section ;; Display commentary section
(insert (format "\n\^_\nFile: %s, Node: %s, Up: Top\n\n" (insert (format "\n\^_\nFile: %s, Node: %s, Up: Top\n\n"