Commit graph

100 commits

Author SHA1 Message Date
Russell Black
b8f0799ce8 Passing t into keymap function 2015-01-03 13:53:38 -07:00
Russell Black
1ae2236854 :bind-keymap - bind a key prefix to an autoloaded package keymap 2014-12-31 17:02:25 -07:00
Sean Allred
5a5aeca797 Do not quote lambda expressions
http://emacs.stackexchange.com/a/3596

Quoting lambda expressions is at best redundant and at worst
detrimental; this commit removes all use of the sharp-quote to reduce
confusion.
2014-12-19 23:12:47 -05:00
John Wiegley
f8db1f1740 Merge pull request from YoungFrog/fixautoloads
Don't add autoload for existing commands
GitHub-reference: https://github.com/jwiegley/use-package/issues/138
2014-12-17 15:53:42 -06:00
Peter Hoeg
b3bf1b2587 Check if package-archives are valid when pinning 2014-12-18 04:34:49 +08:00
Nicolas Richard
a2b23f8326 Don't add autoload for existing commands 2014-12-17 18:30:50 +01:00
Peter Hoeg
435d4b4078 pure cleanup 2014-12-17 05:45:53 +08:00
Peter Hoeg
fe7fe61528 support for pinning package to archive 2014-12-11 14:44:27 +08:00
John Wiegley
6570447a05 Merge pull request from Silex/master
Fix "compiling" typo
GitHub-reference: https://github.com/jwiegley/use-package/issues/125
2014-09-18 21:33:08 +01:00
Justin Talbott
e8ce1b20ca add :bind* keyword for bind-key* 2014-09-16 16:39:21 -04:00
Philippe Vaucher
f07ecde5a1 Fix "compiling" typo 2014-09-16 18:34:42 +02:00
Thomas Frössman
351c102010 Display which package that has compile errors 2014-09-14 12:57:44 +02:00
Jonas Bernoulli
31bb0cde56 assume the declare-function macro exists
Since `declare-function' was added in Emacs 23.1 (five years ago), we
don't need to assert that it is defined.  If the assertion was without
any problems there would be no harm in keeping it, but unfortunately it
causes a compile warning.  Because `declare-function' is a macro with
always expands to `nil' the value of (fboundp 'declare-function) ends
up being unused.
2014-09-07 14:43:56 +02:00
Thomas Frössman
1c82b2377f Don't abort compiling if package loading fails 2014-05-17 10:48:20 +02:00
John Wiegley
a4939e7ef3 Revert "Merge pull request from alexko/master"
This reverts commit 8c04377608, reversing
changes made to a9ba368fa7.
GitHub-reference: https://github.com/jwiegley/use-package/issues/104
2014-05-08 13:25:39 -05:00
John Wiegley
8c04377608 Merge pull request from alexko/master
if package can't be located, treat it the same way as disabled
GitHub-reference: https://github.com/jwiegley/use-package/issues/104
2014-05-07 12:24:10 -05:00
Alex Kosorukoff
6d02a320f6 if package can't be located, treat it the same way as disabled
There will be a message "Unable to locate <package-name>" in the log.
2014-05-06 20:38:14 -07:00
Nicolas Richard
4e80d29daf Eval backquote earlier and support non-`progn' lists
* use-package.el (use-package-plist-get): add optional args: `eval-backquote'
  and `no-progn' to control how arguments are retrieved.
  (use-package-plist-get-value): remove this function
  (use-package): replace calls to old function to modified function.

Fixes issue https://github.com/jwiegley/use-package/issues/94.

Rationale :
- use-package-plist-get-value was just another layer for no good reason,
  and IMO its name was totally unclear.
- we now eval-as-backquote earlier, allowing constructs like:
(let ((my-list-of-commands-in-foo '(foo1 foo2)))
  (use-package foo :commands ,@my-list-of-commands-in-foo))
2014-05-05 12:14:53 +02:00
Nicolas Richard
0ab0d77691 Add new option use-package-idle-interval
* use-package.el (use-package-idle-interval): new defcustom
(use-package-start-idle-timer): use it
(use-package-idle-eval): use it
* README.md: document it

This addresses bug https://github.com/jwiegley/use-package/issues/77
2014-03-17 16:22:43 +01:00
François Févotte
6b30c15823 :idle-priority keyword to change the running order of idle functions
Lower-priority idle functions are run first. Idle functions with no
specified priority default to 5 and all functions with the same priority
are run in the order in which they are evaluated, meaning the behaviour
is backwards compatible.

Updated documentation as well.
2014-03-17 10:03:06 +01:00
Jonas Bernoulli
f32d24350c use-package-font-lock-keywords: add use-package-with-elapsed-timer 2014-03-09 18:59:06 +01:00
Jonas Bernoulli
2d7ecd867a use-package-with-elapsed-timer: add declare indent rule 2014-03-09 18:55:54 +01:00
Jonas Bernoulli
ea3a475d0b use-package-with-elapsed-timer: respect option at runtime
Previously the option `use-package-verbose' was consulted at macro
expansion time, and as a result customizing the option did nothing,
without also recompiling `use-package.el'.
2014-03-09 18:53:05 +01:00
Nicolas Richard
dd937c4e36 Move tests to separate file 2014-02-12 22:30:12 +01:00
Nicolas Richard
2676ff5d95 Allow multiple forms after keywords
* use-package.el (use-package-mplist-get):
(use-package-plist-get):
(use-package-mplist-keys): new functions

(plist-get-value):
(use-package): use new functions

(plist-keys): remove function

The idea is to allow a modified kind of plist where keys are all
keywords that appear in the list, and values are the intermediary
elements. If a keyword is present but it's another keyword just after it
(like (use-package :defer :config (setq foo 'bar))), its associated
value will be t. If a keyword is not present, its value associated value
will be nil. Otherwise the value will be the list of elements between
the keyword and the next keyword.
2014-02-10 18:57:27 +01:00
Adam Spiers
8f7e878caf add 'use-package-' prefix to 'with-elapsed-timer'
Fixes https://github.com/jwiegley/use-package/issues/35.
2014-01-06 17:22:39 +00:00
Adam Spiers
2dbee4cd75 fix DRY violation by only having documentation in one place
The documentation in README.md was previously identical to that
in the Commentary section of use-package.el, modulo the following
differences:

  - No elisp comment ";; " prefix
  - Code blocks indented 4 columns not 2, as required by Markdown
  - Elisp symbols marked in backtick delimiters for monospace, not
    emacs backtick/forward tick pairs.

Unfortunately due to this duplication, sometimes only one of the
two files got updated, so they got out of sync.  With us all being
human, this is likely to continue to happen as long as the
duplication exists ;-)  Therefore since most users are likely to
encounter README.md before the elisp, and bearing in mind that
Markdown is a much more flexible format for documentation than
elisp comments (richer formatting, can be exported to numerous
other formats etc.), it is better to replace the docs in
use-package.el with a pointer to the README.md.
2014-01-06 13:57:55 +00:00
Adam Spiers
75206228dd allow :mode and :interpreter to accept a string
Fixes https://github.com/jwiegley/use-package/issues/72.
2013-12-16 13:57:32 +00:00
Jonas Bernoulli
d588d0b382 use-package: use defun as lisp-indent-function
When `use-package' is called with only one keyword it is useful to
write:

(use-package foo :init
  (progn
    ... long lines ...))

instead of

(use-package foo
  :init (progn
  	  ... *too* long lines ...))

or

(use-package foo
  :init
  (progn
    ... long lines ...))

Even when there are multiple keywords or when one never wants to format
the calls to `use-package' as in the first example the use of `defun'
does not really pose a problem.
2013-12-10 00:44:11 +01:00
John Wiegley
c3704ac36e Add a :demand directive, to override deferred loading ()
GitHub-reference: https://github.com/jwiegley/use-package/issues/65
2013-12-04 19:44:09 -06:00
John Wiegley
9d395a4019 fboundp is a function, not a variable
Fixes https://github.com/jwiegley/use-package/issues/68
2013-12-04 13:31:25 -06:00
Dave Abrahams
f3e9e871a6 Backward compatibility with emacs-22.1
This change supports the emacs that ships with MacOS X, the last version not encumbered by GPLv3.
2013-12-02 10:44:28 -08:00
John Wiegley
90ca8adc41 Default use-package-verbose to nil 2013-12-02 03:06:27 -07:00
Philippe Vaucher
c7560f7be7 Remove el-get support 2013-11-05 10:32:21 +01:00
Ting-Yu Lin
36cf13ef47 Add :pre-load to use-package-keywords
The :pre-load keyword cannot be used unless it is in
`use-package-keywords' list.
2013-10-26 00:11:31 +08:00
Phil Hudson
a116fc2136 Properly enable runtime dependency for :idle stanza (issue)
See issue https://github.com/jwiegley/use-package/issues/60.
GitHub-reference: https://github.com/jwiegley/use-package/issues/60
2013-10-15 17:53:58 +01:00
Noam Postavsky
94072fba77 remove extra comma (added by 026c46c) 2013-10-14 12:59:41 -04:00
Noam Postavsky
026c46c057 let with-elapsed-timer return last form 2013-10-12 14:26:50 -04:00
Noam Postavsky
3d871c7994 make `with-elapsed-timer' hygienic 2013-10-12 14:26:50 -04:00
Noam Postavsky
61fd933807 with-elapsed-timer: only check verbosity once 2013-10-12 14:26:50 -04:00
Noam Postavsky
29abf59bad macroexpand not needed
Since lambda thunking replaced quoting in a76d167.

To see why, observe that cases 3 and 4 disassemble to identical code.
The difference between cases 1 and 2 shows why the macroexpand was
needed originally.

(defmacro test-quote (name-string)
  `(eval-after-load "foo"
     `(with-elapsed-timer ,(format "Configuring package %s" name-string)
        (message "test-quote"))))

(defmacro test-expand-quote (name-string)
  `(eval-after-load "foo"
     ,(macroexpand-all
       `(with-elapsed-timer ,(format "Configuring package %s" name-string)
          (message "test-expand-quote")))))

(defmacro test-lambda (name-string)
  `(eval-after-load "foo"
     `(,(lambda ()
          (with-elapsed-timer ,(format "Configuring package %s" name-string)
            (message "test-lambda"))))))

(defmacro test-expand-lambda (name-string)
  `(eval-after-load "foo"
     `(,(lambda ()
          ,(macroexpand-all
            `(with-elapsed-timer ,(format "Configuring package %s" name-string)
               (message "test-lambda")))))))

(disassemble (lambda () (test-quote "testing...")))
(disassemble (lambda () (test-expand-quote "testing...")))
(disassemble (lambda () (test-lambda "testing...")))
(disassemble (lambda () (test-expand-lambda "testing...")))
2013-10-12 14:25:38 -04:00
Noam Postavsky
119a30f2ba cl not needed since flet was removed in 82903da 2013-10-12 13:14:21 -04:00
John Wiegley
901272a8c7 Merge pull request from phillord/first-keyword
Add a ":first" keyword for those occasions that it's necessary.
GitHub-reference: https://github.com/jwiegley/use-package/issues/42
2013-10-07 14:28:30 -07:00
Noam Postavsky
8c1c572857 use plist-get-value for all non-sexp args 2013-09-25 22:44:01 -04:00
Noam Postavsky
dd20db220d plist-get-value treats arg as backquoted
This allows use of variables or even arbitrary expressions to construct
use-package arguments:

(use-package some-package
  :mode ,mode-spec
  :bind (,binding
         ,@more-bindings
         ,@(cl-loop for i from ?a to ?z
                    collect `(,(string i) . nifty-function))))
2013-09-25 22:36:10 -04:00
Nicolas Dudebout
818c78f466 Removes plist-get-sexp
This function was not working as advertised.
Then `funcall` was evaluated too early and all the benefits of late evaluation for autoloads was lost.
Furthermore, this function was not really needed in the first place:

```
(use-package foo
  :config my-foo-function)
```

can easily be replaced by the following:

```
(use-package foo
  :config (my-foo-function))
```
2013-09-25 14:02:29 -04:00
Nicolas Dudebout
fd8af80f08 Enables using variables and functions as arguments
This change an extra level on indirection for two cases:

+ when an association or an alist is required, it is possible to pass a
variable containing an association or an alist
+ when a sexp to be evaluated is required, it is possible to pass a
function instead
2013-09-24 12:23:08 -04:00
Noam Postavsky
c6d79d2cb4 pass name (not name-string) to eval-after-load
Fixes https://github.com/jwiegley/use-package/issues/52: the :config block would be triggered when loading a config
file with the same name as the package and again when loading the
package itself.
2013-09-16 13:59:16 -04:00
Ting-Yu Lin
bbf2b5034b Fix highlight use-package for Emacs snapshot
The commit 57f80d4 fixed the highlight by following the regexp as for
require. However in Emacs truck, it only highlights first part of the
package name.

This change follows the regexp for require on emacs truck. See line
2327 on font-lock.el in the following patch.
http://bzr.savannah.gnu.org/lh/emacs/trunk/revision/111821
2013-09-13 21:38:02 +08:00
Noam Postavsky
57f80d4ff1 highlight use-package before typing package name
This follow the same pattern as the highlighting for provide and require
from `lisp-font-lock-keywords-2' in font-lock.el
2013-09-03 21:55:38 -04:00