mirror of
git://git.sv.gnu.org/emacs.git
synced 2025-12-15 10:30:25 -08:00
Do not scrape :ignored-files for dependencies
* lisp/emacs-lisp/package-vc.el (package-vc--unpack-1): If a file matches the ignored packages in :ignored-files, do not install any dependencies it lists.
This commit is contained in:
parent
35bb629eca
commit
68318dfd16
1 changed files with 25 additions and 13 deletions
|
|
@ -501,7 +501,8 @@ This includes downloading missing dependencies, generating
|
|||
autoloads, generating a package description file (used to
|
||||
identify a package as a VC package later on), building
|
||||
documentation and marking the package as installed."
|
||||
(let (missing)
|
||||
(let ((pkg-spec (package-vc--desc->spec pkg-desc))
|
||||
missing)
|
||||
;; Remove any previous instance of PKG-DESC from `package-alist'
|
||||
(let ((pkgs (assq (package-desc-name pkg-desc) package-alist)))
|
||||
(when pkgs
|
||||
|
|
@ -510,17 +511,29 @@ documentation and marking the package as installed."
|
|||
;; In case the package was installed directly from source, the
|
||||
;; dependency list wasn't know beforehand, and they might have
|
||||
;; to be installed explicitly.
|
||||
(let ((deps '()))
|
||||
(let ((ignored-files
|
||||
(if (plist-get pkg-spec :ignored-files)
|
||||
(mapconcat
|
||||
(lambda (ignore)
|
||||
(wildcard-to-regexp
|
||||
(if (string-match-p "\\`/" ignore)
|
||||
(concat pkg-dir ignore)
|
||||
(concat "*/" ignore))))
|
||||
(plist-get pkg-spec :ignored-files)
|
||||
"\\|")
|
||||
regexp-unmatchable))
|
||||
(deps '()))
|
||||
(dolist (file (directory-files pkg-dir t "\\.el\\'" t))
|
||||
(with-temp-buffer
|
||||
(insert-file-contents file)
|
||||
(when-let* ((require-lines (lm-header-multiline "package-requires")))
|
||||
(thread-last
|
||||
(mapconcat #'identity require-lines " ")
|
||||
package-read-from-string
|
||||
package--prepare-dependencies
|
||||
(nconc deps)
|
||||
(setq deps)))))
|
||||
(unless (string-match-p ignored-files file)
|
||||
(with-temp-buffer
|
||||
(insert-file-contents file)
|
||||
(when-let* ((require-lines (lm-header-multiline "package-requires")))
|
||||
(thread-last
|
||||
(mapconcat #'identity require-lines " ")
|
||||
package-read-from-string
|
||||
package--prepare-dependencies
|
||||
(nconc deps)
|
||||
(setq deps))))))
|
||||
(dolist (dep deps)
|
||||
(cl-callf version-to-list (cadr dep)))
|
||||
(setf missing (package-vc-install-dependencies (delete-dups deps)))
|
||||
|
|
@ -529,8 +542,7 @@ documentation and marking the package as installed."
|
|||
missing)))
|
||||
|
||||
(let ((default-directory (file-name-as-directory pkg-dir))
|
||||
(pkg-file (expand-file-name (package--description-file pkg-dir) pkg-dir))
|
||||
(pkg-spec (package-vc--desc->spec pkg-desc)))
|
||||
(pkg-file (expand-file-name (package--description-file pkg-dir) pkg-dir)))
|
||||
;; Generate autoloads
|
||||
(let* ((name (package-desc-name pkg-desc))
|
||||
(auto-name (format "%s-autoloads.el" name))
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue