From: John Wiegley Date: Fri, 22 Jun 2012 10:02:38 +0000 (-0500) Subject: More updates to support el-get X-Git-Tag: emacs-29.0.90~1306^2~15^2~472 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=28c6509148b3e2c5f895b22f17e2582d31daab56;p=emacs.git More updates to support el-get --- diff --git a/lisp/use-package/use-package.el b/lisp/use-package/use-package.el index 768df4f003a..f70396195a3 100644 --- a/lisp/use-package/use-package.el +++ b/lisp/use-package/use-package.el @@ -271,6 +271,11 @@ :type 'boolean :group 'use-package) +(defcustom use-package-debug nil + "Whether to report more information, mostly regarding el-get" + :type 'boolean + :group 'use-package) + (defmacro with-elapsed-timer (text &rest forms) `(let ((now ,(if use-package-verbose '(current-time)))) @@ -330,8 +335,8 @@ `(not (member nil (mapcar #'featurep (quote ,requires)))) `(featurep (quote ,requires))))) - (name-string (if (stringp name) name - (symbol-name name)))) + (name-string (if (stringp name) name (symbol-name name))) + (name-symbol (if (stringp name) (intern name) name))) (unless (plist-get args :disabled) (if diminish-var @@ -395,27 +400,41 @@ `(require ',name nil t))) ,(when (boundp 'el-get-sources) - (unless (plist-get args :name) - (nconc args (list :name name-string))) - - (unless (plist-get args :type) - (setq args (use-package-discover-el-get-type args))) - - (when (plist-get args :type) - (setq args - (mapcar #'(lambda (arg) - (cond - ((eq arg :config) - :after) - ((eq arg :requires) - :depends) - (t - arg))) - args)) - - (nconc args (list :symbol (intern name-string))) - - `(push (quote ,args) el-get-sources))) + (require 'el-get) + + (let ((recipe (ignore-errors + (el-get-read-recipe name-symbol)))) + (if (null recipe) + (if use-package-debug + (message "No el-get recipe found for package `%s'" + name-symbol)) + (setq args + (mapcar #'(lambda (arg) + (cond + ((eq arg :config) + :after) + ((eq arg :requires) + :depends) + (t + arg))) + args)) + + (nconc args (list :symbol (intern name-string))) + + (let ((elem args)) + (while elem + (unless (plist-get recipe (car elem)) + (plist-put recipe (car elem) (cadr elem))) + (setq elem (cddr elem)))) + + (unless (plist-get recipe :name) + (nconc recipe (list :name name-string))) + + (unless (plist-get recipe :type) + (setq recipe (use-package-discover-el-get-type recipe))) + + (ignore + (setq el-get-sources (cons recipe el-get-sources)))))) ,(if (or commands (plist-get args :defer)) (let (form)