summaryrefslogtreecommitdiff
path: root/lisp/finder.el
diff options
context:
space:
mode:
authorChong Yidong <cyd@stupidchicken.com>2010-08-30 21:53:46 -0400
committerChong Yidong <cyd@stupidchicken.com>2010-08-30 21:53:46 -0400
commit187d3296ae0549b978420786e7079ff426a13574 (patch)
tree3b70f67dbf3c414ac464f4e5110200270e2c9343 /lisp/finder.el
parent14721afcd6ed26ccd35264b0e99b3e8da7837f2e (diff)
downloademacs-187d3296ae0549b978420786e7079ff426a13574.tar.gz
Fix several Package Menu and Finder bugs.
* finder.el: Load finder-inf using `require'. (finder-list-matches): Sorting by status is now the default. (finder-compile-keywords): Simpify printing. * emacs-lisp/package.el (package--read-archive-file): Just use `read', to avoid copying an additional string. (package-menu-mode): Set header-line-format here. (package-menu-refresh, package-menu-revert): Signal an error if not in the Package Menu. (package-menu-package-list): New var. (package--generate-package-list): Operate on the current buffer; don't assume that it is *Packages*, since the user may rename it. Allow persistent package listings and sort keys using package-menu-package-list and package-menu-package-sort-key. (package-menu--version-predicate): Fix version calculation. (package-menu-sort-by-column): Don't select the window. (package--list-packages): Create the *Packages* buffer. Set package-menu-package-list-key. (list-packages): Sorting by status is now the default. (package-buffer-info): Use match-string-no-properties. (define-package): Add a &rest argument for future proofing, but don't use it yet. (package-install-from-buffer, package-install-buffer-internal): Merged into a single function, package-install-from-buffer. (package-install-file): Caller changed. Also, fix headers for hfy-cmap.el and ps-print.el.
Diffstat (limited to 'lisp/finder.el')
-rw-r--r--lisp/finder.el22
1 files changed, 6 insertions, 16 deletions
diff --git a/lisp/finder.el b/lisp/finder.el
index 0e16b9aa44a..0c12a08d104 100644
--- a/lisp/finder.el
+++ b/lisp/finder.el
@@ -32,10 +32,8 @@
(require 'package)
(require 'lisp-mnt)
-(require 'find-func) ;for find-library(-suffixes)
-;; Use `load' rather than `require' so that it doesn't get loaded
-;; during byte-compilation (at which point it might be missing).
-(load "finder-inf" t t)
+(require 'find-func) ;for find-library(-suffixes)
+(require 'finder-inf nil t)
;; These are supposed to correspond to top-level customization groups,
;; says rms.
@@ -234,17 +232,10 @@ from; the default is `load-path'."
(search-backward " ")
(insert "(setq package--builtins '(\n")
(dolist (package package--builtins)
- (insert " (")
- (prin1 (car package) (current-buffer))
- (insert " .\n [")
- (let ((desc (cdr package)))
- (prin1 (aref desc 0) (current-buffer))
- (insert " ")
- (prin1 (aref desc 1) (current-buffer))
- (insert " ")
- (prin1 (aref desc 2) (current-buffer)))
- (insert "])\n"))
- (insert " ))\n\n")
+ (insert " ")
+ (prin1 package (current-buffer))
+ (insert "\n"))
+ (insert "))\n\n")
;; Insert hash table.
(insert "(setq finder-keywords-hash\n ")
(prin1 finder-keywords-hash (current-buffer))
@@ -325,7 +316,6 @@ not `finder-known-keywords'."
(packages (gethash id finder-keywords-hash)))
(unless packages
(error "No packages matching key `%s'" key))
- (setq package-menu-sort-key nil)
(package--list-packages packages)))
(define-button-type 'finder-xref 'action #'finder-goto-xref)