]> git.eshelyaron.com Git - emacs.git/commitdiff
New command 'package-update-all'
authorLars Ingebrigtsen <larsi@gnus.org>
Thu, 12 May 2022 01:59:16 +0000 (03:59 +0200)
committerLars Ingebrigtsen <larsi@gnus.org>
Thu, 12 May 2022 01:59:39 +0000 (03:59 +0200)
* lisp/emacs-lisp/package.el (package-update-all): New function
(bug#19146).
(package--updateable-packages): Factored out...
(package-update): ... from here.

doc/emacs/package.texi
etc/NEWS
lisp/emacs-lisp/package.el

index fc2a093ec426ab2a6ed025f77a845c4726e2b6eb..eb4f5b0edab401d292c75dd571a55eff0d77cf0c 100644 (file)
@@ -329,12 +329,14 @@ version of the package, a newer version is also installed.
 
 @findex package-install
 @findex package-update
+@findex package-update-all
   Packages are most conveniently installed using the package menu
 (@pxref{Package Menu}), but you can also use the command @kbd{M-x
 package-install}.  This prompts for the name of a package with the
 @samp{available} status, then downloads and installs it.  Similarly,
 if you want to update a package, you can use the @kbd{M-x
-package-update} command.
+package-update} command, and if you just want to update all the
+packages, you can use the @kbd{M-x package-update-all} command.
 
 @cindex package requirements
   A package may @dfn{require} certain other packages to be installed,
index d9777eecd60a823c81c672d6273144e14ce34f56..672260ca82b8372c83411454270088ca9a115121 100644 (file)
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -829,6 +829,10 @@ this includes "binary" buffers like 'archive-mode' and 'image-mode'.
 
 ** Package
 
++++
+*** New command 'package-update-all'.
+This command allows updating all packages without any queries.
+
 +++
 *** New command 'package-update'.
 This command allows you to upgrade packages without using 'M-x
index c1e14a4acb511e3f508b498663fb4c489ca051e0..72b22a65566de0cf03eb3d39faf20d14820e7a36 100644 (file)
@@ -2140,26 +2140,44 @@ to install it but still mark it as selected."
 (defun package-update (name)
   "Update package NAME if a newer version exists."
   (interactive
-   (progn
-     ;; Initialize the package system to get the list of package
-     ;; symbols for completion.
-     (package--archives-initialize)
-     (list (completing-read
-            "Update package: "
-            (mapcar
-             #'car
-             (seq-filter
-              (lambda (elt)
-                (let ((available
-                       (assq (car elt) package-archive-contents)))
-                  (and available
-                       (version-list-<
-                        (package-desc-priority-version (cadr elt))
-                        (package-desc-priority-version (cadr available))))))
-              package-alist))
-            nil t))))
-  (package-delete (cadr (assq (intern name) package-alist)) 'force)
-  (package-install (intern name) 'dont-select))
+   (list (completing-read
+          "Update package: " (package--updateable-packages) nil t)))
+  (let ((package (if (symbolp name)
+                     name
+                   (intern name))))
+    (package-delete (cadr (assq package package-alist)) 'force)
+    (package-install package 'dont-select)))
+
+(defun package--updateable-packages ()
+  ;; Initialize the package system to get the list of package
+  ;; symbols for completion.
+  (package--archives-initialize)
+  (mapcar
+   #'car
+   (seq-filter
+    (lambda (elt)
+      (let ((available
+             (assq (car elt) package-archive-contents)))
+        (and available
+             (version-list-<
+              (package-desc-priority-version (cadr elt))
+              (package-desc-priority-version (cadr available))))))
+    package-alist)))
+
+(defun package-update-all (&optional inhibit-queries)
+  "Upgrade all packages."
+  (interactive "P")
+  (let ((updateable (package--updateable-packages)))
+    (if (not updateable)
+        (message "No packages to update")
+      (when (and (not inhibit-queries)
+                 (not (yes-or-no-p
+                       (if (length= updateable 1)
+                           "One package to update.  Do it? "
+                         (format "%s packages to update.  Do it?"
+                                 (length updateable))))))
+        (user-error "Updating aborted"))
+      (mapc #'package-update updateable))))
 
 (defun package-strip-rcs-id (str)
   "Strip RCS version ID from the version string STR.