From: John Wiegley Date: Thu, 30 Nov 2017 06:20:43 +0000 (-0800) Subject: Restructure some code X-Git-Tag: emacs-29.0.90~1306^2~15^2~223 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=35f46f7b42a3a282a8b00492120031b82e1391f7;p=emacs.git Restructure some code --- diff --git a/lisp/use-package/use-package.el b/lisp/use-package/use-package.el index b07f205adc7..8d44d37e0af 100644 --- a/lisp/use-package/use-package.el +++ b/lisp/use-package/use-package.el @@ -729,31 +729,32 @@ If the package is installed, its entry is removed from "(an unquoted symbol name)"))))))) (defun use-package-ensure-elpa (name ensure state context &optional no-refresh) - (let ((package (or (when (eq ensure t) (use-package-as-symbol name)) + (let ((package (or (and (eq ensure t) (use-package-as-symbol name)) ensure))) (when package (require 'package) (or (package-installed-p package) - (not (or - ;; Contexts in which the confirmation prompt is - ;; bypassed. - (member context '(:byte-compile :ensure :config)) - (y-or-n-p (format "Install package %S?" package)))) + ;; Contexts in which the confirmation prompt is bypassed. + (not (or (member context '(:byte-compile :ensure :config)) + (y-or-n-p (format "Install package %S?" package)))) (condition-case-unless-debug err - (progn - (when (assoc package (bound-and-true-p package-pinned-packages)) + (let ((pinned (assoc package (bound-and-true-p + package-pinned-packages)))) + (when pinned (package-read-all-archive-contents)) - (cond ((assoc package package-archive-contents) - (package-install package) - t) - (t - (package-refresh-contents) - (when (assoc package - (bound-and-true-p package-pinned-packages)) - (package-read-all-archive-contents)) - (package-install package)))) - (error (message "Error: Cannot load %s: %S" name err) - nil)))))) + (if (assoc package package-archive-contents) + (package-install package) + (package-refresh-contents) + (when pinned + (package-read-all-archive-contents)) + (package-install package)) + t) + (error + (ignore + (display-warning 'use-package + (format "Failed to install %s: %s" + name (error-message-string err)) + :error)))))))) (defun use-package-handler/:ensure (name keyword ensure rest state) (let* ((body (use-package-process-keywords name rest