From 2fe6110d710b71b90f90c84bfa8eaf6b129eb0a6 Mon Sep 17 00:00:00 2001 From: Artur Malabarba Date: Mon, 12 Jan 2015 23:26:58 -0200 Subject: [PATCH] * emacs-lisp/package.el (package-dir-info): New function. Find package information for a directory. The return result is a `package-desc'. --- lisp/ChangeLog | 2 ++ lisp/emacs-lisp/package.el | 18 ++++++++++++++++++ 2 files changed, 20 insertions(+) diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 93796e67a3d..dce08a42255 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -3,6 +3,8 @@ * emacs-lisp/package.el (package--read-pkg-desc): New function. Read a `define-package' form in current buffer. Return the pkg-desc, with desc-kind set to KIND. + (package-dir-info): New function. Find package information for a + directory. The return result is a `package-desc'. 2015-01-16 Jorgen Schaefer diff --git a/lisp/emacs-lisp/package.el b/lisp/emacs-lisp/package.el index d5906675596..77b15c104ef 100644 --- a/lisp/emacs-lisp/package.el +++ b/lisp/emacs-lisp/package.el @@ -1281,6 +1281,24 @@ The return result is a `package-desc'." (package--read-pkg-desc 'tar) (kill-buffer (current-buffer)))))) +(defun package-dir-info () + "Find package information for a directory. +The return result is a `package-desc'." + (cl-assert (derived-mode-p 'dired-mode)) + (let* ((desc-file (package--description-file default-directory))) + (if (file-readable-p desc-file) + (with-temp-buffer + (insert-file-contents desc-file) + (package--read-pkg-desc 'dir)) + (let ((files (directory-files default-directory t "\\.el\\'" t)) + info) + (while files + (with-temp-buffer + (insert-file-contents (pop files)) + (if (setq info (ignore-errors (package-buffer-info))) + (setq files nil) + (setf (package-desc-kind info) 'dir)))))))) + (defun package--read-pkg-desc (kind) "Read a `define-package' form in current buffer. Return the pkg-desc, with desc-kind set to KIND." -- 2.11.4.GIT