unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* use-package.el -> Emacs core
@ 2015-11-10  0:02 John Wiegley
  2015-11-10  0:14 ` Dmitry Gutov
                   ` (6 more replies)
  0 siblings, 7 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10  0:02 UTC (permalink / raw)
  To: emacs-devel

I'd like to integrate use-package.el into Emacs core, as an alternative for
package management to those who do not rely on package.el. I know Stefan had
some reservation, but I think enough people have enjoyed its utility to be
worth including.

Are there any objections to moving this into core before the 25.1 freeze?

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:02 use-package.el -> Emacs core John Wiegley
@ 2015-11-10  0:14 ` Dmitry Gutov
  2015-11-10  0:31   ` John Wiegley
  2015-11-10  0:44 ` Artur Malabarba
                   ` (5 subsequent siblings)
  6 siblings, 1 reply; 95+ messages in thread
From: Dmitry Gutov @ 2015-11-10  0:14 UTC (permalink / raw)
  To: emacs-devel

On 11/10/2015 02:02 AM, John Wiegley wrote:

> Are there any objections to moving this into core before the 25.1 freeze?

Will it add a different way to install packages? Is that wise?

Were it only up to me, I'd just incorporate the features that work well 
with package.el.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:14 ` Dmitry Gutov
@ 2015-11-10  0:31   ` John Wiegley
  2015-11-10  0:40     ` Dmitry Gutov
                       ` (2 more replies)
  0 siblings, 3 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10  0:31 UTC (permalink / raw)
  To: Dmitry Gutov; +Cc: emacs-devel

>>>>> Dmitry Gutov <dgutov@yandex.ru> writes:

> Will it add a different way to install packages? Is that wise?

> Were it only up to me, I'd just incorporate the features that work well with
> package.el.

No, it does not install packages. There is a keyword, :ensure, which causes it
to use package.el to install a configured package if it is not already
present.

`use-package' is a macro to abstract a common pattern among .emacs files, such
as:

    (add-hook 'foo-init-hook 'some-function)
    (add-to-list 'auto-mode-alist '("\\.foo$" . foo-mode))
    (eval-after-load "foo-mode"
      '(progn
         (define-key foo-mode-map (kbd "C-c k") 'foo-hello)))

It abstracts the common cases I encountered in my use of 100+ Emacs packages,
and macroexpands to code that tries to minimize Emacs load time as much as
possible. It also adds features that would be cumbersome to do manually, such
as optionally installing an idle-timer so a package is always loaded if Emacs
has been idle for X seconds.

    (use-package foo-mode
      :mode "\\.foo$"
      :bind (:map foo-mode-map
             ("C-c k" . foo-hello))
      :init (add-hook 'foo-init-hook 'some-function))

There is a README with examples at:

    https://github.com/jwiegley/use-package

I also discuss it with Sacha Chua in a video:

    http://sachachua.com/blog/2015/04/john-wiegley-on-organizing-your-emacs-configuration-with-use-package/

John
    



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:31   ` John Wiegley
@ 2015-11-10  0:40     ` Dmitry Gutov
  2015-11-10  7:55     ` Oleh Krehel
  2015-11-10  8:49     ` use-package.el -> Emacs core João Távora
  2 siblings, 0 replies; 95+ messages in thread
From: Dmitry Gutov @ 2015-11-10  0:40 UTC (permalink / raw)
  To: emacs-devel

On 11/10/2015 02:31 AM, John Wiegley wrote:

> No, it does not install packages. There is a keyword, :ensure, which causes it
> to use package.el to install a configured package if it is not already
> present.

Um, yes. That part I'm aware of. :)

> `use-package' is a macro to abstract a common pattern among .emacs files, such
> as: ...

So you meant "who do not rely on package.el UI"?  That's entirely fine 
by me, I also use some of those common patterns.

Thanks.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:02 use-package.el -> Emacs core John Wiegley
  2015-11-10  0:14 ` Dmitry Gutov
@ 2015-11-10  0:44 ` Artur Malabarba
  2015-11-10  1:05   ` John Wiegley
  2015-11-10  1:37 ` use-package.el -> Emacs core Ted Zlatanov
                   ` (4 subsequent siblings)
  6 siblings, 1 reply; 95+ messages in thread
From: Artur Malabarba @ 2015-11-10  0:44 UTC (permalink / raw)
  To: emacs-devel

[-- Attachment #1: Type: text/plain, Size: 670 bytes --]

On 10 Nov 2015 12:02 am, "John Wiegley" <jwiegley@gmail.com> wrote:
>
> I'd like to integrate use-package.el into Emacs core, as an alternative
for
> package management to those who do not rely on package.el. I know Stefan
had
> some reservation, but I think enough people have enjoyed its utility to be
> worth including.

Alternative? I was under the impression that use-package was a way of
organising your package configurations in the init file (and ensuring that
they are installed), with installation/upgrading itself still being done
via package.el.
Did I get it wrong?

I too have seen many people praise use-package, and I think it would make a
fine addition.

[-- Attachment #2: Type: text/html, Size: 820 bytes --]

^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:44 ` Artur Malabarba
@ 2015-11-10  1:05   ` John Wiegley
  2015-11-10  1:24     ` Artur Malabarba
  0 siblings, 1 reply; 95+ messages in thread
From: John Wiegley @ 2015-11-10  1:05 UTC (permalink / raw)
  To: Artur Malabarba; +Cc: emacs-devel

>>>>> Artur Malabarba <bruce.connor.am@gmail.com> writes:

> Alternative? I was under the impression that use-package was a way of
> organising your package configurations in the init file (and ensuring that
> they are installed), with installation/upgrading itself still being done via
> package.el. Did I get it wrong?

I think I said it wrong by using the words "package management":

- package.el is for installing, upgrading, and removing packages, and for
  establishing autoloads and customization access to those packages.
  use-package does none of these things, although it is able to make use
  of package.el.

- use-package is for configuration only. The stuff you'd already write in
  init.el, only more declaratively. Nor does it seek to replace M-x customize,
  since the two work together rather nicely (this is what I do).

It was my error for making them seem as though they were on the same footing.
They are almost completely orthogonal. The two can live together in perfect
harmony; or, a user who makes no use of package.el can use use-package to
clean up configuration code that doesn't fit the customization interface.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  1:05   ` John Wiegley
@ 2015-11-10  1:24     ` Artur Malabarba
  2015-11-10  1:37       ` John Wiegley
  0 siblings, 1 reply; 95+ messages in thread
From: Artur Malabarba @ 2015-11-10  1:24 UTC (permalink / raw)
  To: emacs-devel

[-- Attachment #1: Type: text/plain, Size: 613 bytes --]

On 10 Nov 2015 1:05 am, "John Wiegley" <jwiegley@gmail.com> wrote:
> - use-package is for configuration only. The stuff you'd already write in
>   init.el, only more declaratively.

Ok, that's what I thought. Like I said, I'm in favour.

I suggest renaming it to something that starts with `package-'
(package-config perhaps). But it's just a suggestion.

I notice it has two dependencies that are not in core though, which would
have to be shed.

If it gets added, I'll probably have a look at its internals and ask your
permission to make some changes where there might be redundancy with
package.el internals.

[-- Attachment #2: Type: text/html, Size: 798 bytes --]

^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  1:24     ` Artur Malabarba
@ 2015-11-10  1:37       ` John Wiegley
  2015-11-10  3:20         ` Artur Malabarba
  0 siblings, 1 reply; 95+ messages in thread
From: John Wiegley @ 2015-11-10  1:37 UTC (permalink / raw)
  To: Artur Malabarba; +Cc: emacs-devel

>>>>> Artur Malabarba <bruce.connor.am@gmail.com> writes:

> I notice it has two dependencies that are not in core though, which would
> have to be shed.

bind-key.el would come with it, since it's a companion library. It provides a
convenience wrapper around both `define-key' and `kbd'. I suppose we ought to
discuss that separation if there are questions.

diminish.el is only loaded if available, although the fact that it's not in
core would indeed mean moving that support out of use-package and into an
external add-on. Fortunately, the use-package architecture makes this easy to
do.

I'd rather not rename to package-config, since it's not related to package.el,
and a strong association by name could get confusing.

> If it gets added, I'll probably have a look at its internals and ask your
> permission to make some changes where there might be redundancy with
> package.el internals.

Sure, though I'd be surprised if that were any code they shared.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:02 use-package.el -> Emacs core John Wiegley
  2015-11-10  0:14 ` Dmitry Gutov
  2015-11-10  0:44 ` Artur Malabarba
@ 2015-11-10  1:37 ` Ted Zlatanov
  2015-11-10  8:24 ` joakim
                   ` (3 subsequent siblings)
  6 siblings, 0 replies; 95+ messages in thread
From: Ted Zlatanov @ 2015-11-10  1:37 UTC (permalink / raw)
  To: emacs-devel

On Mon, 09 Nov 2015 16:02:33 -0800 John Wiegley <jwiegley@gmail.com> wrote: 

JW> I'd like to integrate use-package.el into Emacs core, as an alternative for
JW> package management to those who do not rely on package.el. I know Stefan had
JW> some reservation, but I think enough people have enjoyed its utility to be
JW> worth including.

JW> Are there any objections to moving this into core before the 25.1 freeze?

I think it's good. The prefix makes it clear it's not an interface to
the `package-*' functions.

Ted




^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  1:37       ` John Wiegley
@ 2015-11-10  3:20         ` Artur Malabarba
  2015-11-10  5:37           ` Kaushal Modi
  0 siblings, 1 reply; 95+ messages in thread
From: Artur Malabarba @ 2015-11-10  3:20 UTC (permalink / raw)
  To: emacs-devel

John Wiegley <jwiegley@gmail.com> writes:

>> I notice it has two dependencies that are not in core though, which would
>> have to be shed.
>
> bind-key.el would come with it, since it's a companion library. It provides a
> convenience wrapper around both `define-key' and `kbd'. I suppose we ought to
> discuss that separation if there are questions.

We can also just incorporate the necessary `bind-key' functionality into
subr.el. In particular, that `bind-key*' function is something I've seen
people ask about before.

> diminish.el is only loaded if available

All good then. I was deceived by that `(diminish "0.44")' in the
Package-Requires. :-)

> I'd rather not rename to package-config, since it's not related to package.el,
> and a strong association by name could get confusing.

Good point. 👍



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  3:20         ` Artur Malabarba
@ 2015-11-10  5:37           ` Kaushal Modi
  2015-11-10  6:07             ` John Wiegley
  2015-11-10 23:27             ` Stephen Leake
  0 siblings, 2 replies; 95+ messages in thread
From: Kaushal Modi @ 2015-11-10  5:37 UTC (permalink / raw)
  To: Bruce Connor, johnw; +Cc: Emacs developers

[-- Attachment #1: Type: text/plain, Size: 981 bytes --]

I use the use-package and bind-key packages in my config.

The use-package would be nice to have in the core but I think bind-key
should not be put into the core as it is.

The primary reason is that it creates duplication and thus confusion for
new users.

For define-key, we have

(define-key MAP KEY-VECTOR COMMAND)

whereas we have

(bind-key KEY-STRING COMMAND MAP)

Notice the shuffling of arguments and difference between the way the keys
are to be represented in the argument.

I see the benefits of bind-key*, bind-keys and bind-keys*, but I believe
that that should be merged with define-key.

The describe-personal-keybindings is useful. But how will it work as
expected if packages in the core started using bind-key macros. We then
need a robust means to distinguish between the default bindings and the
bindings in user config.

I don't have a proposal for the complete solution, but these are few things
that didn't feel right to me about putting bind-keys in core.

[-- Attachment #2: Type: text/html, Size: 1175 bytes --]

^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  5:37           ` Kaushal Modi
@ 2015-11-10  6:07             ` John Wiegley
  2015-11-10 23:27             ` Stephen Leake
  1 sibling, 0 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10  6:07 UTC (permalink / raw)
  To: Kaushal Modi; +Cc: Bruce Connor, Emacs developers

>>>>> Kaushal Modi <kaushal.modi@gmail.com> writes:

> For define-key, we have 
> (define-key MAP KEY-VECTOR COMMAND)
> whereas we have 
> (bind-key KEY-STRING COMMAND MAP)

Actually, it's:

    (bind-key KEY-STRING COMMAND [MAP])

Which is very close to:

    (global-set-key KEY-STRING COMMAND)

`define-key' is more familiar to developers, but I don't think it's what most
users use in their init.el when they want to bind keys.

I could see adding an optional map argument to `global-set-key', although one
of the nice things about `bind-key' is that it sets up the necessary data to
allow `describe-personal-keybindings' to work.

And then there is `bind-key*', for truly global bindings that override minor
modes; and `bind-keys', for binding many keys at once, potentially into
multiple keymaps. So there might be a good reason to introduce a new layer
with this module, specifically intended for user customization in init.el
files.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:31   ` John Wiegley
  2015-11-10  0:40     ` Dmitry Gutov
@ 2015-11-10  7:55     ` Oleh Krehel
  2015-11-10 11:52       ` Juanma Barranquero
  2015-11-10  8:49     ` use-package.el -> Emacs core João Távora
  2 siblings, 1 reply; 95+ messages in thread
From: Oleh Krehel @ 2015-11-10  7:55 UTC (permalink / raw)
  To: Dmitry Gutov; +Cc: emacs-devel

John Wiegley <jwiegley@gmail.com> writes:

> `use-package' is a macro to abstract a common pattern among .emacs files, such
> as:
>
>     (add-hook 'foo-init-hook 'some-function)
>     (add-to-list 'auto-mode-alist '("\\.foo$" . foo-mode))
>     (eval-after-load "foo-mode"
>       '(progn
>          (define-key foo-mode-map (kbd "C-c k") 'foo-hello)))
>
> It abstracts the common cases I encountered in my use of 100+ Emacs packages,
> and macroexpands to code that tries to minimize Emacs load time as much as
> possible. It also adds features that would be cumbersome to do manually, such
> as optionally installing an idle-timer so a package is always loaded if Emacs
> has been idle for X seconds.
>
>     (use-package foo-mode
>       :mode "\\.foo$"
>       :bind (:map foo-mode-map
>              ("C-c k" . foo-hello))
>       :init (add-hook 'foo-init-hook 'some-function))

I have some reservations for this. While I use use-package, I started
with it long after learning basic Elisp.  Essentially, use-package is a
black box that abstracts and creates new syntax.  Which is fine for
veteran users, since they have an idea of what it does.  But I think it
might be detrimental to new Elisp users. Using the first method, they
learn what `add-hook' is, what `add-to-list' is, what keymaps are etc.
These things are useful in all kinds of places, not just in the context
of setting up packages.

Concerning bind-key: if the functionality is useful, it should be merged
into `define-key', instead of adding yet another syntax for the same
thing.

One more concern that I see is the stability of use-package API. I
wouldn't want to add logic to my config to disable the built-in
use-package and install the new version to use a new feature.  This was
the case for CEDET for a long time, and it was a headache.

Having said all that, I'm against adding use-package to the core. It
would add potential headache without adding utility, since I don't see
any code in the core benefiting from re-using use-package.  I am for
augmenting `define-key' with `bind-key' features, though.





^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:02 use-package.el -> Emacs core John Wiegley
                   ` (2 preceding siblings ...)
  2015-11-10  1:37 ` use-package.el -> Emacs core Ted Zlatanov
@ 2015-11-10  8:24 ` joakim
  2015-11-11  0:29   ` Stephen Leake
  2015-11-10  8:44 ` Andreas Röhler
                   ` (2 subsequent siblings)
  6 siblings, 1 reply; 95+ messages in thread
From: joakim @ 2015-11-10  8:24 UTC (permalink / raw)
  To: emacs-devel

John Wiegley <jwiegley@gmail.com> writes:

> I'd like to integrate use-package.el into Emacs core, as an alternative for
> package management to those who do not rely on package.el. I know Stefan had
> some reservation, but I think enough people have enjoyed its utility to be
> worth including.
>
> Are there any objections to moving this into core before the 25.1 freeze?
>
> John
>

I use req-package, https://github.com/edvorg/req-package, which is
use-package with some additional features, like logging and load order
reordering. I think use-package would be a great addition to emacs core,
for people like me that like a clear and readable emacs
configuration. (I alse use the org-babel litterate mode for the emacs
init file for the same reasons.)
-- 
Joakim Verona



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:02 use-package.el -> Emacs core John Wiegley
                   ` (3 preceding siblings ...)
  2015-11-10  8:24 ` joakim
@ 2015-11-10  8:44 ` Andreas Röhler
  2015-11-10  9:29 ` Nicolas Petton
  2015-11-10 18:21 ` Stephen Leake
  6 siblings, 0 replies; 95+ messages in thread
From: Andreas Röhler @ 2015-11-10  8:44 UTC (permalink / raw)
  To: emacs-devel; +Cc: John Wiegley

  On 10.11.2015 01:02, John Wiegley wrote:
> I'd like to integrate use-package.el into Emacs core, as an alternative for
> package management to those who do not rely on package.el. I know Stefan had
> some reservation, but I think enough people have enjoyed its utility to be
> worth including.
>
> Are there any objections to moving this into core before the 25.1 freeze?
>
> John
>


Hi John,

as you know being your fan.
Nothing wrong with use-package AFAIU, but: please be careful, resist 
temptation :)

For several reasons being a maintainer implies some tragic, kind of 
offering if well-done,

all the best,

Andreas




^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:31   ` John Wiegley
  2015-11-10  0:40     ` Dmitry Gutov
  2015-11-10  7:55     ` Oleh Krehel
@ 2015-11-10  8:49     ` João Távora
  2015-11-10  8:57       ` Pedro Silva
  2 siblings, 1 reply; 95+ messages in thread
From: João Távora @ 2015-11-10  8:49 UTC (permalink / raw)
  To: jwiegley, Dmitry Gutov; +Cc: emacs-devel

Hi,

I'm reticent of this addition. In lisp (or anywhere else for that
matter), I don't like to learn new syntax unless the advantages are
clear. A perfect example would be cl's LOOP, which is it's own
mini-language which I've learned to love.

Of course adding use-package.el to Emacs wouldn't force me to use
it. However, as the maintainer of a few packages, I have to read users'
bug reports, and that mostly means I would have to learn
use-package.el's syntax, since users would more legitimately consider it
a proper way to install the packages I maintain.

Now, I see use-package.el as a `with-eval-after-load' replacement with
more bells and whistles. It appears to be weak in that sense: each of
those bells and whistles usually already has a nice concise way to
control in stock Emacs, so it's unfortunate that use-package.el
introduces new ones. And it doesn't even appear to save lines of
configuration code while at it, just someone shorter sexps. For example,
I don't see the benefit of replacing:

   (when window-system
     (with-eval-after-load 'foo
       ... more configuration
     ))

with

   (use-package foo
      :if window-system
      ... more configuration
      )

The generic example you gave for `foo-mode' is also not to convincing to
me. I would write it as

    (with-eval-after-load 'foo-mode
      (add-hook 'foo-init-hook 'some-function)
      (define-key foo-mode-map (kbd "C-c k") 'foo-hello))
    (add-to-list 'auto-mode-alist '("\\.foo$" . foo-mode))

Which is just as long, just as readable and less voodoo than
use-package. If I grep for "auto-mode-alist" in my configuration, I'm
sure to find who's setting it.

But perhaps I can be convinced otherwise or am missing something
fundamentally. Can you provide more examples of package configurations
where you definitely think it beats `with-eval-after-load' or other
alternatives? I'm guessing those would be examples that include
automatically installing a package (lazily?) from ELPA, but you tell me.

Thanks,
João



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  8:49     ` use-package.el -> Emacs core João Távora
@ 2015-11-10  8:57       ` Pedro Silva
  2015-11-10  9:45         ` João Távora
  0 siblings, 1 reply; 95+ messages in thread
From: Pedro Silva @ 2015-11-10  8:57 UTC (permalink / raw)
  To: emacs-devel

joaotavora@gmail.com (João Távora) writes:

> But perhaps I can be convinced otherwise or am missing something
> fundamentally. Can you provide more examples of package configurations
> where you definitely think it beats `with-eval-after-load' or other
> alternatives? I'm guessing those would be examples that include
> automatically installing a package (lazily?) from ELPA, but you tell me.

:ensure (automatic ELPA installation), :defer (lazy loading) and
:commands (autoloading) are the things I most use in `use-package'
that are not as easy to achieve with `with-eval-after-load'.

-- 
Pedro




^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:02 use-package.el -> Emacs core John Wiegley
                   ` (4 preceding siblings ...)
  2015-11-10  8:44 ` Andreas Röhler
@ 2015-11-10  9:29 ` Nicolas Petton
  2015-11-11  0:32   ` Stephen Leake
  2015-11-10 18:21 ` Stephen Leake
  6 siblings, 1 reply; 95+ messages in thread
From: Nicolas Petton @ 2015-11-10  9:29 UTC (permalink / raw)
  To: John Wiegley, emacs-devel

[-- Attachment #1: Type: text/plain, Size: 451 bytes --]

John Wiegley <jwiegley@gmail.com> writes:

> I'd like to integrate use-package.el into Emacs core, as an alternative for
> package management to those who do not rely on package.el. I know Stefan had
> some reservation, but I think enough people have enjoyed its utility to be
> worth including.
>
> Are there any objections to moving this into core before the 25.1
> freeze?

That's fine with me. use-package.el is already used by many people.

Nico

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 512 bytes --]

^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  8:57       ` Pedro Silva
@ 2015-11-10  9:45         ` João Távora
  2015-11-10 12:01           ` Phillip Lord
  0 siblings, 1 reply; 95+ messages in thread
From: João Távora @ 2015-11-10  9:45 UTC (permalink / raw)
  To: Pedro Silva; +Cc: emacs-devel

Pedro Silva <psilva@pedrosilva.pt> writes:

> :ensure (automatic ELPA installation), :defer (lazy loading) and
> :commands (autoloading) are the things I most use in `use-package'
> that are not as easy to achieve with `with-eval-after-load'.

Not as easy? Sure, more characters, but basically the same complexity. I
don't think it's worth a whole new language to be able to replace:

  (package-install 'foo)

with

  :ensure t

and

  (autoload 'foo-bar 'foo)
  (autoload 'foo-baz 'foo)

with

  :commands (foo-bar foo-baz)

or even 

  (run-with-idle-timer 5 nil 'require 'foo)

with

  :defer 5

Especially given that the use-package versions force the reader (or the
grepper) to look around for context, while the regular versions don't.

But perhaps I'm misinterpreting what these directives actually do, or
perhaps you can illustrate with some snippets of your own.

João






^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  7:55     ` Oleh Krehel
@ 2015-11-10 11:52       ` Juanma Barranquero
  2015-11-10 12:10         ` Oleh Krehel
  0 siblings, 1 reply; 95+ messages in thread
From: Juanma Barranquero @ 2015-11-10 11:52 UTC (permalink / raw)
  To: Oleh Krehel; +Cc: Emacs developers, Dmitry Gutov

[-- Attachment #1: Type: text/plain, Size: 671 bytes --]

On Tue, Nov 10, 2015 at 8:55 AM, Oleh Krehel <ohwoeowho@gmail.com> wrote:

> I have some reservations for this. While I use use-package, I started
> with it long after learning basic Elisp.  Essentially, use-package is a
> black box that abstracts and creates new syntax.  Which is fine for
> veteran users, since they have an idea of what it does.  But I think it
> might be detrimental to new Elisp users. Using the first method, they
> learn what `add-hook' is, what `add-to-list' is, what keymaps are etc.
> These things are useful in all kinds of places, not just in the context
> of setting up packages.

Wouldn't that be an argument against Customize, too?

    J

[-- Attachment #2: Type: text/html, Size: 860 bytes --]

^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  9:45         ` João Távora
@ 2015-11-10 12:01           ` Phillip Lord
  2015-11-10 13:37             ` João Távora
  0 siblings, 1 reply; 95+ messages in thread
From: Phillip Lord @ 2015-11-10 12:01 UTC (permalink / raw)
  To: João Távora; +Cc: Pedro Silva, emacs-devel

João Távora <joaotavora@gmail.com> writes:

> Pedro Silva <psilva@pedrosilva.pt> writes:
>
>> :ensure (automatic ELPA installation), :defer (lazy loading) and
>> :commands (autoloading) are the things I most use in `use-package'
>> that are not as easy to achieve with `with-eval-after-load'.
>
> Not as easy? Sure, more characters, but basically the same complexity. I
> don't think it's worth a whole new language to be able to replace:
>
>   (package-install 'foo)

> Especially given that the use-package versions force the reader (or the
> grepper) to look around for context, while the regular versions don't.

use-package introduces a single (documented) form. So, it's easy to
re-eval everything, and keeps all your code in one place. Trivial as
this sounds, this is actually pretty useful.

In your examples, you need to "progn" everything to achieve the same.


> But perhaps I'm misinterpreting what these directives actually do, or
> perhaps you can illustrate with some snippets of your own.


What use-package does is syntactic sugar for sure, but it also does add
some nice functionality. So, for example, this

(use-package foo
  :load-path "~/foo"
  :commands foo-a foo-b foo-c
  :defer 5
  )

actually does this...


(progn
  (eval-and-compile
    (push "~/foo" load-path))
  (run-with-idle-timer 5 nil #'require 'foo nil t)
  (unless
      (fboundp 'foo-a)
    (autoload #'foo-a "foo" nil t))
  (unless
      (fboundp 'foo-b)
    (autoload #'foo-b "foo" nil t))
  (unless
      (fboundp 'foo-c)
    (autoload #'foo-c "foo" nil t)))

while the apparently much simpler:

(use-package foo
  :load-path "~/foo"
  )

actually does this:

(progn
  (eval-and-compile
    (push "~/foo" load-path))
  (let
      ((now
        (current-time)))
    (message "%s..." "Loading package foo")
    (prog1
        (if
            (not
             (require 'foo nil 'noerror))
            (ignore
             (message
              (format "Could not load %s" 'foo))))
      (let
          ((elapsed
            (float-time
             (time-subtract
              (current-time)
              now))))
        (if
            (> elapsed 0.1)
            (message "%s...done (%.3fs)" "Loading package foo" elapsed)
          (message "%s...done" "Loading package foo"))))))

A useful system for working out why your .emacs is so slow to load.

*shrugs*. I really like it, and it's made my .emacs cleaner.

Phil



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 11:52       ` Juanma Barranquero
@ 2015-11-10 12:10         ` Oleh Krehel
  2015-11-10 12:23           ` Juanma Barranquero
                             ` (2 more replies)
  0 siblings, 3 replies; 95+ messages in thread
From: Oleh Krehel @ 2015-11-10 12:10 UTC (permalink / raw)
  To: Juanma Barranquero; +Cc: Dmitry Gutov, Emacs developers

Juanma Barranquero <lekktu@gmail.com> writes:

> On Tue, Nov 10, 2015 at 8:55 AM, Oleh Krehel <ohwoeowho@gmail.com> wrote:
>
>> I have some reservations for this. While I use use-package, I started
>> with it long after learning basic Elisp. Essentially, use-package is a
>> black box that abstracts and creates new syntax. Which is fine for
>> veteran users, since they have an idea of what it does. But I think it
>> might be detrimental to new Elisp users. Using the first method, they
>> learn what `add-hook' is, what `add-to-list' is, what keymaps are etc.
>> These things are useful in all kinds of places, not just in the context
>> of setting up packages.
>
> Wouldn't that be an argument against Customize, too?

Customize is for people that aren't yet ready to learn Elisp.  Once they
do, it indeed becomes redundant. I used Customize when I started out
around 5 years ago. I don't use it now, except for providing it to the
users of my packages.

Use-package is already an Elisp thing. We should encourage the core
Elisp to be simple to learn, because it is actually very simple.  Not
anymore so with macros like `cl-loop', `pcase' and `use-package'.  They
are powerful, but /they are their own language/ completely separate from
Elisp. They have their place, but in my opinion Elisp newbies should not
be encouraged to use them. And including `use-package' into the core
somehow promotes and recommends the use of it over the built-in
facilities, which are newbie-friendly, while `use-package' is not.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 12:10         ` Oleh Krehel
@ 2015-11-10 12:23           ` Juanma Barranquero
  2015-11-10 12:40             ` Oleh Krehel
  2015-11-10 12:42             ` Kaushal Modi
  2015-11-10 12:46           ` David Kastrup
  2015-11-10 14:58           ` Drew Adams
  2 siblings, 2 replies; 95+ messages in thread
From: Juanma Barranquero @ 2015-11-10 12:23 UTC (permalink / raw)
  To: Oleh Krehel; +Cc: Dmitry Gutov, Emacs developers

[-- Attachment #1: Type: text/plain, Size: 999 bytes --]

On Tue, Nov 10, 2015 at 1:10 PM, Oleh Krehel <ohwoeowho@gmail.com> wrote:

> Customize is for people that aren't yet ready to learn Elisp.  Once they
> do, it indeed becomes redundant.

Then, that's an argument *for* use-package. It's for users that aren't yet
ready to learn Elisp, but who want to load a package easily from their
init.el.

use-package is syntactic sugar, yes, and as such, it's easier to use that
the "real deal". It is its own language, but that's a feature: if you're a
user not interested in learning Elisp, to borrow from Phillip's example,
certainly

(use-package foo
  :load-path "~/foo"
  :commands foo-a foo-b foo-c
  :defer 5
  )

seems much easier than

(progn
  (eval-and-compile
    (push "~/foo" load-path))
  (run-with-idle-timer 5 nil #'require 'foo nil t)
  (unless
      (fboundp 'foo-a)
    (autoload #'foo-a "foo" nil t))
  (unless
      (fboundp 'foo-b)
    (autoload #'foo-b "foo" nil t))
  (unless
      (fboundp 'foo-c)
    (autoload #'foo-c "foo" nil t)))

[-- Attachment #2: Type: text/html, Size: 3050 bytes --]

^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 12:23           ` Juanma Barranquero
@ 2015-11-10 12:40             ` Oleh Krehel
  2015-11-10 12:47               ` Juanma Barranquero
  2015-11-10 14:03               ` David Kastrup
  2015-11-10 12:42             ` Kaushal Modi
  1 sibling, 2 replies; 95+ messages in thread
From: Oleh Krehel @ 2015-11-10 12:40 UTC (permalink / raw)
  To: Juanma Barranquero; +Cc: Emacs developers, Dmitry Gutov

Juanma Barranquero <lekktu@gmail.com> writes:

> On Tue, Nov 10, 2015 at 1:10 PM, Oleh Krehel <ohwoeowho@gmail.com> wrote:
>
>> Customize is for people that aren't yet ready to learn Elisp. Once they
>> do, it indeed becomes redundant.
>
> Then, that's an argument *for* use-package. It's for users that aren't yet ready to learn Elisp, but who want to load a package easily from their init.el.
>
> use-package is syntactic sugar, yes, and as such, it's easier to use that the "real deal". It is its own language, but that's a feature: if you're a user not interested in learning Elisp, to borrow from Phillip's example, certainly

I have a completely opposite opinion regarding syntactic sugar: it's
detrimental unless you know what it does. In fact, I generally dislike
it even if I know what it does (see my thread on `pcase').

A user who's copy-pasting syntactic sugar won't see the structure behind
it.  A user who's copy-pasting a bunch of `setq', `define-key' and
`add-hook' statements will eventually see the pattern and actually learn
the language.

> (use-package foo
> :load-path "~/foo"
> :commands foo-a foo-b foo-c
> :defer 5
> )
>
> seems much easier than
>
> (progn
> (eval-and-compile
> (push "~/foo" load-path))
> (run-with-idle-timer 5 nil #'require 'foo nil t)
> (unless
> (fboundp 'foo-a)
> (autoload #'foo-a "foo" nil t))
> (unless
> (fboundp 'foo-b)
> (autoload #'foo-b "foo" nil t))
> (unless
> (fboundp 'foo-c)
> (autoload #'foo-c "foo" nil t)))

The above `use-package' example essentially translates to 0 lines of
code if one uses package.el, since all commands are autoloaded
anyway. Regarding idle loading, I've found exactly one use for it - Org:
it simply doesn't pay off for the other packages.

Compare to this code, if the user decides against package.el for some reason:

(add-to-list 'load-path "~/foo")
(require 'foo)

The above 2 lines show how Emacs actually works, and are in fact very
simple. And they teach the new user `add-to-list' and `require' which
are relevant absolutely everywhere, not just in init config setups.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 12:23           ` Juanma Barranquero
  2015-11-10 12:40             ` Oleh Krehel
@ 2015-11-10 12:42             ` Kaushal Modi
  1 sibling, 0 replies; 95+ messages in thread
From: Kaushal Modi @ 2015-11-10 12:42 UTC (permalink / raw)
  To: Juanma Barranquero; +Cc: Dmitry Gutov, Oleh Krehel, Emacs developers

[-- Attachment #1: Type: text/plain, Size: 454 bytes --]

I'd also like to add that as use-package is a top-level form, we cannot use
edebug and other defun-specific functions on the functions defined in that
form: http://emacs.stackexchange.com/q/7643/115

I then came up with a custom solution that works for me to make edebugging
possible for such functions. If you notice, it's more like a hack. So
something need to be done to make such defun-related functions work in
use-package too, if we go that route.

[-- Attachment #2: Type: text/html, Size: 554 bytes --]

^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 12:10         ` Oleh Krehel
  2015-11-10 12:23           ` Juanma Barranquero
@ 2015-11-10 12:46           ` David Kastrup
  2015-11-10 13:06             ` Oleh Krehel
  2015-11-10 13:32             ` Wolfgang Jenkner
  2015-11-10 14:58           ` Drew Adams
  2 siblings, 2 replies; 95+ messages in thread
From: David Kastrup @ 2015-11-10 12:46 UTC (permalink / raw)
  To: Oleh Krehel; +Cc: Juanma Barranquero, Emacs developers, Dmitry Gutov

Oleh Krehel <ohwoeowho@gmail.com> writes:

> Juanma Barranquero <lekktu@gmail.com> writes:
>
>> On Tue, Nov 10, 2015 at 8:55 AM, Oleh Krehel <ohwoeowho@gmail.com> wrote:
>>
>>> I have some reservations for this. While I use use-package, I started
>>> with it long after learning basic Elisp. Essentially, use-package is a
>>> black box that abstracts and creates new syntax. Which is fine for
>>> veteran users, since they have an idea of what it does. But I think it
>>> might be detrimental to new Elisp users. Using the first method, they
>>> learn what `add-hook' is, what `add-to-list' is, what keymaps are etc.
>>> These things are useful in all kinds of places, not just in the context
>>> of setting up packages.
>>
>> Wouldn't that be an argument against Customize, too?
>
> Customize is for people that aren't yet ready to learn Elisp.  Once
> they do, it indeed becomes redundant.

Nonsense.  It provides type safety and makes sure that the variables are
set in the intended way.  It also makes sure that any followup actions
necessary after setting the variables are being performed.

It's like saying lamp sockets are for people that aren't yet ready to
learn soldering.  Once they do, they indeed become redundant.

> I used Customize when I started out around 5 years ago. I don't use it
> now, except for providing it to the users of my packages.

I don't see that this makes any sense since it means you have to learn
all about the various dependencies and intricacies of every single
package you are going to use.

> Use-package is already an Elisp thing.

It's for people that aren't yet read to manage load-file.  Or something.
And Elisp is for people that aren't yet ready to learn C.

> We should encourage the core Elisp to be simple to learn, because it
> is actually very simple.  Not anymore so with macros like `cl-loop',
> `pcase' and `use-package'.  They are powerful, but /they are their own
> language/ completely separate from Elisp. They have their place, but
> in my opinion Elisp newbies should not be encouraged to use them.

Sorry, but I cannot agree at all.  That's like saying C++ users should
not learn about the standard libraries since they should rather write
their own.

> And including `use-package' into the core somehow promotes and
> recommends the use of it over the built-in facilities, which are
> newbie-friendly, while `use-package' is not.

I think you got it backwards.

-- 
David Kastrup



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 12:40             ` Oleh Krehel
@ 2015-11-10 12:47               ` Juanma Barranquero
  2015-11-10 15:15                 ` John Wiegley
  2015-11-10 14:03               ` David Kastrup
  1 sibling, 1 reply; 95+ messages in thread
From: Juanma Barranquero @ 2015-11-10 12:47 UTC (permalink / raw)
  To: Oleh Krehel; +Cc: Emacs developers, Dmitry Gutov

[-- Attachment #1: Type: text/plain, Size: 457 bytes --]

On Tue, Nov 10, 2015 at 1:40 PM, Oleh Krehel <ohwoeowho@gmail.com> wrote:

> I have a completely opposite opinion regarding syntactic sugar: it's
> detrimental unless you know what it does.

I think you're assuming that someone who uses such syntactic sugar will
eventually want to learn what's underneath the sugar coating. Some do, some
don't. I've had colleagues who were happy using Emacs but wouldn't want to
learn even the simplest thing about elisp.

[-- Attachment #2: Type: text/html, Size: 631 bytes --]

^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 12:46           ` David Kastrup
@ 2015-11-10 13:06             ` Oleh Krehel
  2015-11-10 18:15               ` Evgeny Panasyuk
  2015-11-10 13:32             ` Wolfgang Jenkner
  1 sibling, 1 reply; 95+ messages in thread
From: Oleh Krehel @ 2015-11-10 13:06 UTC (permalink / raw)
  To: David Kastrup; +Cc: Juanma Barranquero, Dmitry Gutov, Emacs developers

David Kastrup <dak@gnu.org> writes:

>> Customize is for people that aren't yet ready to learn Elisp.  Once
>> they do, it indeed becomes redundant.
>
> Nonsense.  It provides type safety and makes sure that the variables are
> set in the intended way.  It also makes sure that any followup actions
> necessary after setting the variables are being performed.

I meant configuring your Emacs with the Customize interface is redundant
once you know Elisp. The type safety and :set handlers are separate from
that.

I only use this thing instead of `setq' for custom vars:

(defmacro csetq (variable value)
  `(funcall (or (get ',variable 'custom-set) 'set-default) ',variable ,value))

> It's like saying lamp sockets are for people that aren't yet ready to
> learn soldering.  Once they do, they indeed become redundant.

Lamp sockets are still relevant. Calling an electrician ("M-x"
`customize-group') isn't relevant.

>> I used Customize when I started out around 5 years ago. I don't use it
>> now, except for providing it to the users of my packages.
>
> I don't see that this makes any sense since it means you have to learn
> all about the various dependencies and intricacies of every single
> package you are going to use.

Having to learn the various dependencies and intricacies of every single
package I use make perfect sense to me.

>> Use-package is already an Elisp thing.
>
> It's for people that aren't yet read to manage load-file.  Or something.
> And Elisp is for people that aren't yet ready to learn C.

Bad analogy. Elisp is for people what want to get things done faster
than with C.

>> We should encourage the core Elisp to be simple to learn, because it
>> is actually very simple.  Not anymore so with macros like `cl-loop',
>> `pcase' and `use-package'.  They are powerful, but /they are their own
>> language/ completely separate from Elisp. They have their place, but
>> in my opinion Elisp newbies should not be encouraged to use them.
>
> Sorry, but I cannot agree at all.  That's like saying C++ users should
> not learn about the standard libraries since they should rather write
> their own.

No, it's like saying that it's OK for users to write Boost template
constructs and do QT stuff without learning the basic C++ and STL.

>> And including `use-package' into the core somehow promotes and
>> recommends the use of it over the built-in facilities, which are
>> newbie-friendly, while `use-package' is not.
>
> I think you got it backwards.

Let's agree to disagree then. John asked for opinions and I gave mine.
What it boils down to is: new users should learn how to use "while"
before they use "loop". And they should be aware that even some veteran
programmers are against the use of "loop" in favor of "while"; they
should not see "while" as training wheels and "loop" as the big boy's
bike.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 12:46           ` David Kastrup
  2015-11-10 13:06             ` Oleh Krehel
@ 2015-11-10 13:32             ` Wolfgang Jenkner
  2015-11-10 15:08               ` Customize is only for newbies? [was: use-package.el -> Emacs core] Drew Adams
  1 sibling, 1 reply; 95+ messages in thread
From: Wolfgang Jenkner @ 2015-11-10 13:32 UTC (permalink / raw)
  To: David Kastrup
  Cc: Juanma Barranquero, Dmitry Gutov, Oleh Krehel, Emacs developers

On Tue, Nov 10 2015, David Kastrup wrote:

> It also makes sure that any followup actions
> necessary after setting the variables are being performed.

Sure, :set is kind of a custom(er) lock-in.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 12:01           ` Phillip Lord
@ 2015-11-10 13:37             ` João Távora
  2015-11-10 14:07               ` Oleh Krehel
                                 ` (2 more replies)
  0 siblings, 3 replies; 95+ messages in thread
From: João Távora @ 2015-11-10 13:37 UTC (permalink / raw)
  To: Phillip Lord; +Cc: Pedro Silva, emacs-devel

phillip.lord@russet.org.uk (Phillip Lord) writes:

> use-package introduces a single (documented) form. So, it's easy to
> re-eval everything, and keeps all your code in one place. Trivial as
> this sounds, this is actually pretty useful.
>
> In your examples, you need to "progn" everything to achieve the same.

Or use `eval-region'. Or eval the whole .emacs while you're at it.
>
>> But perhaps I'm misinterpreting what these directives actually do, or
>> perhaps you can illustrate with some snippets of your own.
>
> (progn
>   (eval-and-compile
>     (push "~/foo" load-path))

How pushing foo to the load-path at compile-time needed/useful for this
example?

>   (run-with-idle-timer 5 nil #'require 'foo nil t)
>   (unless
>       (fboundp 'foo-a)
>     (autoload #'foo-a "foo" nil t))

According to the `autoload' docstring:

    If FUNCTION is already defined other than as an autoload,
    this does nothing and returns nil.

So, unless I'm missing something, your example is misrepresenting the
alternative: when I asked about a fair comparison, I didn't mean a mere
macroexpansion of the `use-package' form.

>           (message "%s...done" "Loading package foo"))))))

By the way, for the pretty logging functionality, why not add something
more atomic like a `timing' macro? It could be used as your `progn'
replacement

   (with-timing "Loading bla"
     ... configure bla ...)

As well as anything else not related to packages

   (with-timing "Frankinboging fretzels" ...)

I prefer reusable components to big obscure, hard-to-debug black magic
spells.

As another drawback, if a user messes up a line in use-package (still
totally possible right?) it's much easier to catch that error in a
backtrace, or a byte-compilation log, when *not* using the syntactic
sugar.

The problem could be slightly reduced if use-package came with an edebug
spec. I don't think it does.

If the user is already writing elisp, let him learn it while he's at it.

> A useful system for working out why your .emacs is so slow to load.
>
> *shrugs*. I really like it, and it's made my .emacs cleaner.

If *you* like it and in your opinion it's cleaner then *you* really
should use it :-)

My argument is that, by adding it to Emacs, especially to the core,
you're effectively supporting another official package configuration
method, thus burdening every package maintainer with a different opinion
with the need to learn a new DSL when reading user's bug
reports. Perhaps every other package maintainer has converted already,
but at least I haven't, not yet.

João



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 12:40             ` Oleh Krehel
  2015-11-10 12:47               ` Juanma Barranquero
@ 2015-11-10 14:03               ` David Kastrup
  2015-11-10 14:15                 ` Oleh Krehel
  2015-11-10 14:22                 ` João Távora
  1 sibling, 2 replies; 95+ messages in thread
From: David Kastrup @ 2015-11-10 14:03 UTC (permalink / raw)
  To: Oleh Krehel; +Cc: Juanma Barranquero, Dmitry Gutov, Emacs developers

Oleh Krehel <ohwoeowho@gmail.com> writes:

> Juanma Barranquero <lekktu@gmail.com> writes:
>
>> On Tue, Nov 10, 2015 at 1:10 PM, Oleh Krehel <ohwoeowho@gmail.com> wrote:
>>
>>> Customize is for people that aren't yet ready to learn Elisp. Once they
>>> do, it indeed becomes redundant.
>>
>> Then, that's an argument *for* use-package. It's for users that
>> aren't yet ready to learn Elisp, but who want to load a package
>> easily from their init.el.
>>
>> use-package is syntactic sugar, yes, and as such, it's easier to use
>> that the "real deal". It is its own language, but that's a feature:
>> if you're a user not interested in learning Elisp, to borrow from
>> Phillip's example, certainly
>
> I have a completely opposite opinion regarding syntactic sugar: it's
> detrimental unless you know what it does. In fact, I generally dislike
> it even if I know what it does (see my thread on `pcase').
>
> A user who's copy-pasting syntactic sugar won't see the structure behind
> it.  A user who's copy-pasting a bunch of `setq', `define-key' and
> `add-hook' statements will eventually see the pattern and actually learn
> the language.

`setq' is syntactic sugar for `set' and `quote'.  `define-key' and
`add-hook' are syntactic sugar for various forms of `set'.

The whole point of not using primitives is not having to provide every
part of some pattern by hand.

-- 
David Kastrup



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 13:37             ` João Távora
@ 2015-11-10 14:07               ` Oleh Krehel
  2015-11-10 14:39               ` Nicolas Richard
  2015-11-10 17:36               ` Phillip Lord
  2 siblings, 0 replies; 95+ messages in thread
From: Oleh Krehel @ 2015-11-10 14:07 UTC (permalink / raw)
  To: João Távora; +Cc: Pedro Silva, emacs-devel, Phillip Lord

joaotavora@gmail.com (João Távora) writes:

> By the way, for the pretty logging functionality, why not add something
> more atomic like a `timing' macro? It could be used as your `progn'
> replacement
>
>    (with-timing "Loading bla"
>      ... configure bla ...)
>
> As well as anything else not related to packages
>
>    (with-timing "Frankinboging fretzels" ...)
>
> I prefer reusable components to big obscure, hard-to-debug black magic
> spells.

I very much agree on this point. A large chunk of `use-package'
functionality is this new `with-timing' that could indeed be a reusable
component. That macro could also wrap a `condition-case' around, barfing
"errored while Frankinboging fretzels" on error.

> My argument is that, by adding it to Emacs, especially to the core,
> you're effectively supporting another official package configuration
> method, thus burdening every package maintainer with a different opinion
> with the need to learn a new DSL when reading user's bug
> reports. 

I agree on this point as well. One official way of doing things is
better than two (three even, if we include Customize). If `use-package'
is in GELPA, as the author of package "foo" I don't feed obliged to help
a user configure "foo" with `use-package': the user should know what
she's getting into.  But if `use-package' were in the core, I'd feel
that obligation, so that's more support tasks for all package authors.

> Perhaps every other package maintainer has converted already, but at
> least I haven't, not yet.

I switched to `use-package' only for the shorter autoload syntax and the
wrapped `condition-case'. If that's all it did, I see no problem with
it. However, it also includes >15 other keywords that have great
potential for misuse by inexperienced users, in my opinion.

The current status of `use-package' is perfect for me: if the user
installs it, she should take responsibility for it and not expect
support for `use-package' from third parties. However, if it becomes
official and encouraged, we might have a problem.

Additionally, `use-package' sort of cuts into the functionality of
package.el, which ideally should be a 0-config built-in utility, with
all useful commands autoloaded.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 14:03               ` David Kastrup
@ 2015-11-10 14:15                 ` Oleh Krehel
  2015-11-10 14:22                 ` João Távora
  1 sibling, 0 replies; 95+ messages in thread
From: Oleh Krehel @ 2015-11-10 14:15 UTC (permalink / raw)
  To: David Kastrup; +Cc: Juanma Barranquero, Emacs developers, Dmitry Gutov

David Kastrup <dak@gnu.org> writes:

> `setq' is syntactic sugar for `set' and `quote'.  `define-key' and
> `add-hook' are syntactic sugar for various forms of `set'.

`setq' is a simple and reusable abstraction (this one in particular has
survived the test of time, having been used and abused for decades), so
are `define-key' and `add-hook'.

> The whole point of not using primitives is not having to provide every
> part of some pattern by hand.

My point is that it's harmful to aggregate every single thing into one
construct, e.g:

    (use-package foo
        :setq (bar 1 baz 2 boo 3))

instead of

    (require 'foo)
    (setq bar 1)
    (setq baz 2)
    (setq boo 3)

It's like multiple inheritance vs. composition in C++: composition is
usually more clear.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 14:03               ` David Kastrup
  2015-11-10 14:15                 ` Oleh Krehel
@ 2015-11-10 14:22                 ` João Távora
  2015-11-10 15:17                   ` John Wiegley
  1 sibling, 1 reply; 95+ messages in thread
From: João Távora @ 2015-11-10 14:22 UTC (permalink / raw)
  To: David Kastrup
  Cc: Juanma Barranquero, Emacs developers, Oleh Krehel, Dmitry Gutov

David Kastrup <dak@gnu.org> writes:

> `setq' is syntactic sugar for `set' and `quote'.  `define-key' and
> `add-hook' are syntactic sugar for various forms of `set'.
>
> The whole point of not using primitives is not having to provide every
> part of some pattern by hand.

I don't think anyone is arguing against the usefulness of macros in
general, only skeptic macros that introduce a totally new mini-language
for a lot independent functionality, most of it already user-visible and
documented in the user manual. Such is the case of `use-package'

For fairness, such is also the case of the `define-minor-mode' macro,
which is invaluable, but that is for package developers, not users, and
that makes a difference in my opinion.

João



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 13:37             ` João Távora
  2015-11-10 14:07               ` Oleh Krehel
@ 2015-11-10 14:39               ` Nicolas Richard
  2015-11-10 14:48                 ` João Távora
  2015-11-10 17:36               ` Phillip Lord
  2 siblings, 1 reply; 95+ messages in thread
From: Nicolas Richard @ 2015-11-10 14:39 UTC (permalink / raw)
  To: João Távora; +Cc: Pedro Silva, emacs-devel, Phillip Lord

joaotavora@gmail.com (João Távora) writes:

>>   (unless
>>       (fboundp 'foo-a)
>>     (autoload #'foo-a "foo" nil t))
>
> According to the `autoload' docstring:
>
>     If FUNCTION is already defined other than as an autoload,
>     this does nothing and returns nil.


IIRC in the above snippet (from the expansion of a use-package
instance), `fboundp' is mostly used as `autoloadp' to avoid overwriting
existing autloads (I guess autloadp wasn't used because it takes an
OBJECT as argument instead of a symbol).

-- 
Nico.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 14:39               ` Nicolas Richard
@ 2015-11-10 14:48                 ` João Távora
  2015-11-10 15:40                   ` John Wiegley
  2015-11-12 12:43                   ` Nicolas Richard
  0 siblings, 2 replies; 95+ messages in thread
From: João Távora @ 2015-11-10 14:48 UTC (permalink / raw)
  To: Nicolas Richard; +Cc: Pedro Silva, emacs-devel, Phillip Lord

Nicolas Richard <youngfrog@members.fsf.org> writes:

> joaotavora@gmail.com (João Távora) writes:
>
>>>   (unless
>>>       (fboundp 'foo-a)
>>>     (autoload #'foo-a "foo" nil t))
>>
>> According to the `autoload' docstring:
>>
>>     If FUNCTION is already defined other than as an autoload,
>>     this does nothing and returns nil.
>
>
> IIRC in the above snippet (from the expansion of a use-package
> instance), `fboundp' is mostly used as `autoloadp' to avoid overwriting
> existing autloads (I guess autloadp wasn't used because it takes an
> OBJECT as argument instead of a symbol).

Is this useful or desirable? Doesn't this mean that making a correction
to a `use-package' instantiation and re-evaluating it will silently
produce a noop?

In the same vein, does `use-package' undo autoloads (or keybindings or
any other thing) when the directive's value changes?

João






^ permalink raw reply	[flat|nested] 95+ messages in thread

* Customize is only for newbies?   [was: use-package.el -> Emacs core]
  2015-11-10 12:10         ` Oleh Krehel
  2015-11-10 12:23           ` Juanma Barranquero
  2015-11-10 12:46           ` David Kastrup
@ 2015-11-10 14:58           ` Drew Adams
  2015-11-10 15:42             ` John Wiegley
  2 siblings, 1 reply; 95+ messages in thread
From: Drew Adams @ 2015-11-10 14:58 UTC (permalink / raw)
  To: Oleh Krehel, Juanma Barranquero; +Cc: Emacs developers, Dmitry Gutov

> Customize is for people that aren't yet ready to learn Elisp.

Wrong - if you meant "only" for such people.

Customize is for anyone who is wise enough to take advantage
of type-checking (:type), :set, :initialize, and other
Customize features.

And Customize (`defcustom') is not only the Customize UI.
It includes all of the `custom-*' and `customize-*' functions.

> Once they do, it indeed becomes redundant.

No, it ("indeed") does not.  Unless you do not consider using
any of the Lisp functions in cus-*.el as part of Customize.

Or unless you are prepared to write your own Lisp to do what
they do.  (At a certain level, all Lisp code except a very
few primitives can be called "redundant".)

It is a too common misconception (perhaps especially among
near-newbies) that Customize is only for newbies.  It's
too bad to see folks here propagate the same misconception.
That is the wrong message, not only for newbies but for
those who are no longer newbies.

Too many people think they are being Lispy by using only
`setq' to set option values in their init files (and later
they wonder why some things don't work, only to be told
about :type or about :set functions etc.).

> I used Customize when I started out around 5 years ago.
> I don't use it now, except for providing it to the
> users of my packages.

You don't use `custom-set-variables' or `custom-set-faces'
or any other `custom*' functions?

Or perhaps you use only simple options that have no :set
or :initialize triggers or other complications?

Or perhaps you don't need type-checking>  Or more likely,
perhaps the options you use do not have very complex :type
control?

Too many defcustoms are written with rudimentary :type
declarations, essentially trying to turn defcustom into
defvar.  (And this includes in the Emac core.)  Dommage.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Customize is only for newbies?   [was: use-package.el -> Emacs core]
  2015-11-10 13:32             ` Wolfgang Jenkner
@ 2015-11-10 15:08               ` Drew Adams
  2015-11-11  0:01                 ` Wolfgang Jenkner
  0 siblings, 1 reply; 95+ messages in thread
From: Drew Adams @ 2015-11-10 15:08 UTC (permalink / raw)
  To: Wolfgang Jenkner, David Kastrup
  Cc: Juanma Barranquero, Emacs developers, Oleh Krehel, Dmitry Gutov

> > It also makes sure that any followup actions
> > necessary after setting the variables are being performed.
> 
> Sure, :set is kind of a custom(er) lock-in.

Dunno whether that was supposed to be a joke.

:set is a hook for variables.  It runs code whenever
the variable is set.  That's a feature that you can
use in your programming.  It doesn't lock anyone into
anything.

We should have :set, :type etc. available for defvar
as well as defcustom, IMHO.

(Someone will no doubt chime in now about advising variables.)



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 12:47               ` Juanma Barranquero
@ 2015-11-10 15:15                 ` John Wiegley
  2015-11-10 15:42                   ` Juanma Barranquero
                                     ` (2 more replies)
  0 siblings, 3 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10 15:15 UTC (permalink / raw)
  To: Juanma Barranquero; +Cc: Dmitry Gutov, Oleh Krehel, Emacs developers

>>>>> Juanma Barranquero <lekktu@gmail.com> writes:

> On Tue, Nov 10, 2015 at 1:40 PM, Oleh Krehel <ohwoeowho@gmail.com> wrote:
>> I have a completely opposite opinion regarding syntactic sugar: it's
>> detrimental unless you know what it does.

> I think you're assuming that someone who uses such syntactic sugar will
> eventually want to learn what's underneath the sugar coating. Some do, some
> don't. I've had colleagues who were happy using Emacs but wouldn't want to
> learn even the simplest thing about elisp.

I agree, Juanma. I see what Oleh is saying pedagogically, but there are *many*
Emacs users who will never want to know anything about Emacs Lisp. Even if
they cut&paste an `add-to-list' form from some blog post -- and even given the
obvious nature of the name -- they won't know what Lisp lists are, or why they
need to be added to, or any of the things we take for granted. They just want
their Emacs to work.

use-package.el is a valuable DSL, in my opinion, because package configuration
is the one place in Emacs where non-Lisp programmers (and people who don't
want to become programmers) are forced to use Emacs Lisp to configure Emacs in
ways not allowed by the customization interface.

To suggest that we might lose an educational opportunity because we aren't
driving them towards define-key and with-eval-after-load, is to think of Emacs
as a Lisp environment rather than a text editor. Those who are motivated will
learn what these things do anyway; those who are not just want to get stuff
done with Emacs.

To me the primary reasons for having a DSL are: It makes it easier to do the
Right Thing; there are fewer things you need to learn; it offers more targeted
error handling and reporting; and for those who will cargo cult anyway, it
makes Emacs configuration (i.e., not Lisp, but configuration) more uniform
 and approachable.

Oleh's arguments against use-package.el seems to be that it will widen the gap
between users and Lisp; I want it to narrow the gap between users and Emacs.

John

Summary of responses so far:

For (7):

- Nicolas Petton
- Joakim Verona
- Phillip Lord
- Dimtry Gutov
- Artur Malabarb
- Kaushal Modi
- Ted Zlatanov

Cautious (1):

- Andreas Röhler

Against (2):

- Oleh Krehel - It encourages people away from learning Elisp
- João Távora - Adds too many bells & whistles
- [Stefan Monnier] - It detracts from authors taking package.el more seriously (?)



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 14:22                 ` João Távora
@ 2015-11-10 15:17                   ` John Wiegley
  2015-11-10 15:46                     ` João Távora
  2015-11-10 15:56                     ` Kaushal Modi
  0 siblings, 2 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10 15:17 UTC (permalink / raw)
  To: João Távora
  Cc: Juanma Barranquero, David Kastrup, Dmitry Gutov, Oleh Krehel,
	Emacs developers

>>>>> João Távora <joaotavora@gmail.com> writes:

> I don't think anyone is arguing against the usefulness of macros in general,
> only skeptic macros that introduce a totally new mini-language for a lot
> independent functionality, most of it already user-visible and documented in
> the user manual. Such is the case of `use-package'

use-package is not aimed at replacing the Lisp skills of the members of this
list; it is also for those whose only exposure to add-hook is an opaque thing
they copied from a web page. They will never read up on what it does, and
forcing them to see it does not encourage them to become programmers.

  (use-package python-mode :load-path "site-lisp/python-mode" :mode "\\.py$")

This is also something they'll just copy and paste, maybe not even knowing
what a mode is. Compare with:

  (add-to-list 'load-path (expand-file-name "site-lisp/python-mode"
                                            user-emacs-directory))
  (autoload 'python-mode "python-mode" nil t)
  (add-to-list 'auto-mode-alist '("\\.py$" . python-mode))

"Only a mother could love that". To an Emacs Lisp expert, the latter does have
some beauty, owing to its directness, and clarity with regard to fundamental
operations. Somehow, though, I prefer the former.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 14:48                 ` João Távora
@ 2015-11-10 15:40                   ` John Wiegley
  2015-11-12 12:43                   ` Nicolas Richard
  1 sibling, 0 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10 15:40 UTC (permalink / raw)
  To: João Távora
  Cc: Pedro Silva, Phillip Lord, Nicolas Richard, emacs-devel

>>>>> João Távora <joaotavora@gmail.com> writes:

> In the same vein, does `use-package' undo autoloads (or keybindings or any
> other thing) when the directive's value changes?

No, it was designed with the intention that it would be executed "once" at
Emacs load time in init.el. It doesn't have features for being changed and
then re-evaluated. Suggested use would be to make the change and restart
Emacs, just to be sure that everything happens as expected.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: Customize is only for newbies? [was: use-package.el -> Emacs core]
  2015-11-10 14:58           ` Drew Adams
@ 2015-11-10 15:42             ` John Wiegley
  0 siblings, 0 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10 15:42 UTC (permalink / raw)
  To: Drew Adams
  Cc: Juanma Barranquero, Dmitry Gutov, Oleh Krehel, Emacs developers

>>>>> Drew Adams <drew.adams@oracle.com> writes:

> It is a too common misconception (perhaps especially among near-newbies)
> that Customize is only for newbies. It's too bad to see folks here propagate
> the same misconception. That is the wrong message, not only for newbies but
> for those who are no longer newbies.

Just to chime in: I use customize, love customize in fact, and try to
configure as much as I can using the customize interface. It's clear,
declarative, and gives me a visual way to browse through my settings for
various packages. It stops me from making stupid errors. I love it.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 15:15                 ` John Wiegley
@ 2015-11-10 15:42                   ` Juanma Barranquero
  2015-11-10 15:56                     ` Dmitry Gutov
  2015-11-11  0:37                     ` Stephen Leake
  2015-11-10 15:55                   ` João Távora
  2015-11-10 16:23                   ` Drew Adams
  2 siblings, 2 replies; 95+ messages in thread
From: Juanma Barranquero @ 2015-11-10 15:42 UTC (permalink / raw)
  To: Juanma Barranquero, Oleh Krehel, Emacs developers, Dmitry Gutov

[-- Attachment #1: Type: text/plain, Size: 227 bytes --]

On Tue, Nov 10, 2015 at 4:15 PM, John Wiegley <jwiegley@gmail.com> wrote:

> For (7):
>
> - Nicolas Petton
> - Joakim Verona
> - Phillip Lord
> - Dimtry Gutov
> - Artur Malabarb
> - Kaushal Modi
> - Ted Zlatanov

I'm for

   J

[-- Attachment #2: Type: text/html, Size: 410 bytes --]

^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 15:17                   ` John Wiegley
@ 2015-11-10 15:46                     ` João Távora
  2015-11-10 18:15                       ` John Wiegley
  2015-11-10 15:56                     ` Kaushal Modi
  1 sibling, 1 reply; 95+ messages in thread
From: João Távora @ 2015-11-10 15:46 UTC (permalink / raw)
  To: David Kastrup
  Cc: Juanma Barranquero, Dmitry Gutov, Oleh Krehel, Emacs developers

John Wiegley <jwiegley@gmail.com> writes:

>>>>>> João Távora <joaotavora@gmail.com> writes:
>
>> I don't think anyone is arguing against the usefulness of macros in general,
>> only skeptic macros that introduce a totally new mini-language for a lot
>> independent functionality, most of it already user-visible and documented in
>> the user manual. Such is the case of `use-package'
>
> use-package is not aimed at replacing the Lisp skills of the members of this
> list; it is also for those whose only exposure to add-hook is an opaque thing
> they copied from a web page. They will never read up on what it does, and
> forcing them to see it does not encourage them to become programmers.
>
>   (use-package python-mode :load-path "site-lisp/python-mode" :mode "\\.py$")
>
> This is also something they'll just copy and paste, maybe not even knowing
> what a mode is. Compare with:
>
>   (add-to-list 'load-path (expand-file-name "site-lisp/python-mode"
>                                             user-emacs-directory))
>   (autoload 'python-mode "python-mode" nil t)
>   (add-to-list 'auto-mode-alist '("\\.py$" . python-mode))

But, if using package.el (or el-get), I don't need to write this, right? It's
already setup by python.el and by whatever method I used to install it.

For this simple example, doesn't `package-install' do exactly the same
thing? Why should we have a new way to solve the same problem? 

Can we have an example of real-world third-party emacs packages (perhaps
one in (m)ELPA and another one not on any package repository) and a fair
comparison of the different alternatives there are for setting it up? I
haven't seen any convincing examples, but I'm sure you can come up with
some.

I can help include other third-party alternatives like `el-get' for
instance in that comparison.

I think this is what we need before coming to a more objective
conclusion regarding usefulness.

Regarding functionality, correctness and the needs for documenting such
a high-profile feature in the user manual, that's a whole different
matter.

> "Only a mother could love that". To an Emacs Lisp expert, the latter does have
> some beauty, owing to its directness, and clarity with regard to fundamental
> operations. Somehow, though, I prefer the former.

Then by all means use it :). But should I have to learn it too?

Do you see my point about the impact that endorsing (another) package
installation/configuration method has for package maintainers?

Note that up until now I'm not talking, as others are, about "confusing"
new users. That is quite hard to measure or estimate. I can only
conjecture that some people are more attracted to the "single form"
aspect of it than to its particular mini-language. I know I am. And
someone mentioned bind-key's advantages and the logging also looks like
a nice feature.

In this sense, the particular merits of each particular feature could be
used to contribute to improving existing functionality, or to add new
functionality that helps everybody, not just fans of
use-package. Wouldn't that satisfy you? Wouldn't that be easier than
introducing and documenting a whole new way of configuring packages,
something that is a super-central pillar of Emacs?

João












^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 15:15                 ` John Wiegley
  2015-11-10 15:42                   ` Juanma Barranquero
@ 2015-11-10 15:55                   ` João Távora
  2015-11-10 16:08                     ` John Wiegley
  2015-11-10 16:23                   ` Drew Adams
  2 siblings, 1 reply; 95+ messages in thread
From: João Távora @ 2015-11-10 15:55 UTC (permalink / raw)
  To: Juanma Barranquero, Oleh Krehel, Emacs developers, Dmitry Gutov

On Tue, Nov 10, 2015 at 3:15 PM, John Wiegley <jwiegley@gmail.com> wrote:

> Against (2):
>
> - Oleh Krehel - It encourages people away from learning Elisp
> - João Távora - Adds too many bells & whistles
> - [Stefan Monnier] - It detracts from authors taking package.el more seriously (?)

I missed the recent changes in emacs-devel regarding maintainership. I
understand
you, John, are the head maintainer, but has emacs-devel moved to a
"vote" system?

Also "adds too many bells & whistles" is not a good summary of my
opinion. I'm not even
sure I am "against it". I haven't seen any fair comparisons. Basically
"wants to see
fair comparisons between different alternatives" would be a more
objective summary, if
such a thing is needed

-- 
João Távora



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 15:17                   ` John Wiegley
  2015-11-10 15:46                     ` João Távora
@ 2015-11-10 15:56                     ` Kaushal Modi
  2015-11-10 18:20                       ` John Wiegley
  1 sibling, 1 reply; 95+ messages in thread
From: Kaushal Modi @ 2015-11-10 15:56 UTC (permalink / raw)
  To: João Távora, David Kastrup, Juanma Barranquero,
	Emacs developers, Oleh Krehel, Dmitry Gutov

I would also fit in the cautious category, leaning towards against
(see below for what I mean).

My biggest concern is the duplication and confusion for end-user code.
define-key vs bind-key. As João mentioned in a different context, I
feel this kind of syntactic sugar is probably not OK for end-user
code; providing many options increases the complexity when debugging
code for the user and the maintainer.

My suggestion would be to first merge bind-key into define-key and
sister defuns/macros. If that is feasible, then we can think if
use-package can be merged.

Biggest concerns with bind-key

(1) Plain bind-key macro is not very much different for define-key or
global-set key. I believe its addition is not necessary in the core.
(2) bind-key*, bind-keys, bind-keys* would be good additions but
should they be refactored as define-key* (while retaining the original
define-key arg order) + global-set-key*, define-keys and define-keys*?
(3) How would describe-personal-bindings work? Because if bind-key is
made part of the core, we cannot control which internal package makes
use of it. Write now the only way we know that the user
added/redefined a key is if they made use of one of the bind-key
macros. That luxury will go away once it is part of the core.

About use-package: I also have a opinion that the user will understand
less of how requires, autoloads, eval-after-loads and idle timers work
if they start using use-package as the first thing.

Until we have a solid solution for the above, my vote is against for
both bind-key and use-package.

With that said, would adding bind-key and use-package to GNU Elpa be a
better option?

If we do that,
- There is no concern of duplication and confusion among users that I
mentioned above.
- Maintainers do not have to worry about the use/debug of
use-package+bind-key in the core packages.
- When helping out users debug something, the instructions for
defining keys are pretty consistent: either define-key or
global-set-key (usually the latter) vs the options of
define-key/global-set-key/bind-key/bind-key*/bind-keys/bind-keys*
- Also only the users who know what they are doing would install these packages.
- use-package + bind-key would still reach a wider user-base as not
all users add Melpa to package-archives



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 15:42                   ` Juanma Barranquero
@ 2015-11-10 15:56                     ` Dmitry Gutov
  2015-11-11  0:37                     ` Stephen Leake
  1 sibling, 0 replies; 95+ messages in thread
From: Dmitry Gutov @ 2015-11-10 15:56 UTC (permalink / raw)
  To: Juanma Barranquero, Oleh Krehel, Emacs developers

On 11/10/2015 05:42 PM, Juanma Barranquero wrote:

>  > For (7):
>  >
>  > - Nicolas Petton
>  > - Joakim Verona
>  > - Phillip Lord
>  > - Dimtry Gutov
>  > - Artur Malabarb
>  > - Kaushal Modi
>  > - Ted Zlatanov

I simply do not mind (too much). But it can go into GNU ELPA just as 
well, as far as I'm concerned.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 15:55                   ` João Távora
@ 2015-11-10 16:08                     ` John Wiegley
  0 siblings, 0 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10 16:08 UTC (permalink / raw)
  To: João Távora
  Cc: Juanma Barranquero, Dmitry Gutov, Oleh Krehel, Emacs developers

>>>>> João Távora <joaotavora@gmail.com> writes:

> I missed the recent changes in emacs-devel regarding maintainership. I
> understand you, John, are the head maintainer, but has emacs-devel moved to
> a "vote" system?

emacs-devel hasn't moved to a vote system, but I prefer to rule by consensus
when feasible. People have a lot of experience and expertise that I do not,
so I want to gather feedback before committing anything on this scale.

> Also "adds too many bells & whistles" is not a good summary of my opinion.
> I'm not even sure I am "against it". I haven't seen any fair comparisons.
> Basically "wants to see fair comparisons between different alternatives"
> would be a more objective summary, if such a thing is needed

Yes, we do need this summary. I'll craft a proposal for the Emacs Wiki, then,
as the way to move forward.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* RE: use-package.el -> Emacs core
  2015-11-10 15:15                 ` John Wiegley
  2015-11-10 15:42                   ` Juanma Barranquero
  2015-11-10 15:55                   ` João Távora
@ 2015-11-10 16:23                   ` Drew Adams
  2 siblings, 0 replies; 95+ messages in thread
From: Drew Adams @ 2015-11-10 16:23 UTC (permalink / raw)
  To: John Wiegley, Juanma Barranquero
  Cc: Emacs developers, Oleh Krehel, Dmitry Gutov

> package configuration is the one place in Emacs where non-Lisp
> programmers (and people who don't want to become programmers)
> are forced to use Emacs Lisp to configure Emacs in
> ways not allowed by the customization interface.

Wrong, in two ways:

1. No one is required to use packages, AFAIK.

2. Binding keys requires Lisp.  The Customize UI is not
   sufficient.   (This is unfortunate - there should be
   a reasonable Customize UI for key bindings.)

   (Of course, no one is required to bind keys either.)


---- OT ----

FWIW, I use this to let users use Customize to bind keys.
I don't claim it is ideal.  Just one attempt to provide
something.

(define-widget 'icicle-key-definition 'lazy
  "Key definition type for Icicle mode keys.
A list of three components: KEY, COMMAND, CONDITION, that represents
an `icicle-mode-map' binding of COMMAND according to KEY, if CONDITION
evaluates to non-nil.

KEY is either a key sequence (string or vector) or a command.
COMMAND is a command.
CONDITION is a sexp.

If KEY is a command, then the binding represented is its remapping to
COMMAND."
  :indent 1 :offset 0 :tag ""
  :type
  '(list
    (choice
     (key-sequence :tag "Key" :value [ignore])
     ;; Use `symbolp' instead of `commandp', in case the
     ;; library defining the command is not loaded.
     (restricted-sexp :tag "Command to remap"
      :match-alternatives (symbolp) :value ignore))
     ;; Use `symbolp' instead of `commandp'...
    (restricted-sexp :tag "Command"
     :match-alternatives (symbolp) :value ignore)
    (sexp :tag "Condition")))

Example:

(defcustom foo
  `((,(kbd "C-x m")       alpha    t)
    (,(kbd "C-x C-m -")   beta     t)
    (,(kbd "C-x C-m +")   gamma    (require 'toto nil t))
    (,(kbd "C-x v -")     delta    t))
  "*List of key bindings for blah..."
  :type '(repeat icicle-key-definition) :group 'some-group)



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 13:37             ` João Távora
  2015-11-10 14:07               ` Oleh Krehel
  2015-11-10 14:39               ` Nicolas Richard
@ 2015-11-10 17:36               ` Phillip Lord
  2 siblings, 0 replies; 95+ messages in thread
From: Phillip Lord @ 2015-11-10 17:36 UTC (permalink / raw)
  To: João Távora; +Cc: Pedro Silva, emacs-devel

João Távora <joaotavora@gmail.com> writes:

> phillip.lord@russet.org.uk (Phillip Lord) writes:
>
>> use-package introduces a single (documented) form. So, it's easy to
>> re-eval everything, and keeps all your code in one place. Trivial as
>> this sounds, this is actually pretty useful.
>>
>> In your examples, you need to "progn" everything to achieve the same.
>
> Or use `eval-region'. Or eval the whole .emacs while you're at it.

The first is error prone, the second assumes your entire .emacs is
idempotent.


> So, unless I'm missing something, your example is misrepresenting the
> alternative: when I asked about a fair comparison, I didn't mean a mere
> macroexpansion of the `use-package' form.

The point is that the two forms have quite different expansions, despite
containing quite overlapping arguments.


>>           (message "%s...done" "Loading package foo"))))))
>
> By the way, for the pretty logging functionality, why not add something
> more atomic like a `timing' macro? It could be used as your `progn'
> replacement
>
>    (with-timing "Loading bla"
>      ... configure bla ...)
>
> As well as anything else not related to packages
>
>    (with-timing "Frankinboging fretzels" ...)
>
> I prefer reusable components to big obscure, hard-to-debug black magic
> spells.

That would be nice, yes, and would be a valuable change, as the
with-timing could be turned on and off in a uniform way.

> As another drawback, if a user messes up a line in use-package (still
> totally possible right?) it's much easier to catch that error in a
> backtrace, or a byte-compilation log, when *not* using the syntactic
> sugar.

Yes. Although, the ability to turn lazy loading (with defer) on and off
is a big help in debugging .emacs files. Still use-package now has some
nice error handling. You can't use invalid keyword any more. I've also
found the clean mechanism for disabling all configuration for a package
at once to be helpful.


> The problem could be slightly reduced if use-package came with an edebug
> spec. I don't think it does.

That would be useful, but only so useful. In practice, edebug is not, in
my experience, enormously useful in debugging .emacs files.


>> A useful system for working out why your .emacs is so slow to load.
>>
>> *shrugs*. I really like it, and it's made my .emacs cleaner.
>
> If *you* like it and in your opinion it's cleaner then *you* really
> should use it :-)

I do.


> My argument is that, by adding it to Emacs, especially to the core,
> you're effectively supporting another official package configuration
> method, thus burdening every package maintainer with a different opinion
> with the need to learn a new DSL when reading user's bug
> reports. Perhaps every other package maintainer has converted already,
> but at least I haven't, not yet.

Yes, I agree. On the flip-side, you are removing the burden of bootstrap
problem that use-package has. I use it to ensure that all the packages I
use are installed, but I have to install it with a different technique
(I call package directly). I think that the bootstrap burden is a
sensible justification for keeping use-package in core.

Phil




^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 15:46                     ` João Távora
@ 2015-11-10 18:15                       ` John Wiegley
  2015-11-10 19:32                         ` João Távora
  0 siblings, 1 reply; 95+ messages in thread
From: John Wiegley @ 2015-11-10 18:15 UTC (permalink / raw)
  To: João Távora
  Cc: Juanma Barranquero, David Kastrup, Emacs developers, Oleh Krehel,
	Dmitry Gutov

>>>>> João Távora <joaotavora@gmail.com> writes:

>> (use-package python-mode :load-path "site-lisp/python-mode" :mode "\\.py$")

> But, if using package.el (or el-get), I don't need to write this, right?
> It's already setup by python.el and by whatever method I used to install it.

Correct. In fact, I'd _prefer_ it if the user didn't have to touch use-package
at all, and could get by with package.el and customize. use-package is the
"next step", after those two.

> Can we have an example of real-world third-party emacs packages (perhaps one
> in (m)ELPA and another one not on any package repository) and a fair
> comparison of the different alternatives there are for setting it up? I
> haven't seen any convincing examples, but I'm sure you can come up with
> some.
> 
> I can help include other third-party alternatives like `el-get' for instance
> in that comparison.

The only alternatives we need to consider right now is with and without
use-package.el -- for details not taken care of by package.el. el-get is
neither in core nor ELPA, so that knowledge doesn't help this discussion.

> Then by all means use it :). But should I have to learn it too?

Not necessarily. There are plenty of areas of Emacs that you don't have to
learn, but that doesn't prohibit them from being in Emacs. If you see a bug
dealing with use-package and don't want to handle it, don't.

> In this sense, the particular merits of each particular feature could be
> used to contribute to improving existing functionality, or to add new
> functionality that helps everybody, not just fans of use-package. Wouldn't
> that satisfy you? Wouldn't that be easier than introducing and documenting a
> whole new way of configuring packages, something that is a super-central
> pillar of Emacs?

It's not a "new way" of configuring packages. It's a WAY period. The
alternative, beyond package and customize, is to learn enough Emacs Lisp to
manually configure the package yourself. This is beyond many users' comfort
area, as I've learned from helping people with their Emacs setups.

I do want use-package in core, although it should probably be in ELPA for
25.1, until we flesh out what will happen to bind-key, a pillar feature. It
should also be documented as an official way of handling more complex
configuration scenarios. Such documentation would also, to answer Oleh's
concern, reference the various Emacs Lisp topics one would need to learn to
understand the logic beneath the sugar.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 13:06             ` Oleh Krehel
@ 2015-11-10 18:15               ` Evgeny Panasyuk
  2015-11-10 18:31                 ` Alan Mackenzie
  0 siblings, 1 reply; 95+ messages in thread
From: Evgeny Panasyuk @ 2015-11-10 18:15 UTC (permalink / raw)
  To: emacs-devel

10.11.2015 16:06, Oleh Krehel:

>>> We should encourage the core Elisp to be simple to learn, because it
>>> is actually very simple.  Not anymore so with macros like `cl-loop',
>>> `pcase' and `use-package'.  They are powerful, but /they are their own
>>> language/ completely separate from Elisp. They have their place, but
>>> in my opinion Elisp newbies should not be encouraged to use them.
>>
>> Sorry, but I cannot agree at all.  That's like saying C++ users should
>> not learn about the standard libraries since they should rather write
>> their own.
>
> No, it's like saying that it's OK for users to write Boost template
> constructs and do QT stuff without learning the basic C++ and STL.

It is OK to use Boost.Function or Boost.Spirit before learning every 
trick used inside. Yes, you have to read their documentation, but the 
same applies "normal/usual" libraries.
Another example is Boost.Preprocessor - it provides high level interface 
and uses a lot of tricks to make it portable across very different 
(buggy) preprocessor implementations - but you can successfully use it 
without knowing every internal trick and detail.




^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 15:56                     ` Kaushal Modi
@ 2015-11-10 18:20                       ` John Wiegley
  2015-11-10 18:32                         ` Drew Adams
  0 siblings, 1 reply; 95+ messages in thread
From: John Wiegley @ 2015-11-10 18:20 UTC (permalink / raw)
  To: Kaushal Modi
  Cc: David Kastrup, Juanma Barranquero, Emacs developers, Oleh Krehel,
	Dmitry Gutov, João Távora

>>>>> Kaushal Modi <kaushal.modi@gmail.com> writes:

> My biggest concern is the duplication and confusion for end-user code.
> define-key vs bind-key. As João mentioned in a different context, I feel
> this kind of syntactic sugar is probably not OK for end-user code; providing
> many options increases the complexity when debugging code for the user and
> the maintainer.

`define-key' is not really an end-user function, as I've met countless people
who have never even heard of it. `global-set-key' is much more user-facing,
and I could see merging `bind-key' into `global-set-key'.

> My suggestion would be to first merge bind-key into define-key and sister
> defuns/macros. If that is feasible, then we can think if use-package can be
> merged.

I don't see a need for that much caution. The two can proceed in parallel.
use-package.el should go into the ELPA-subset-that-comes-with-Emacs today, and
then receive official blessing and documentation as an announced feature in
25.2.

> About use-package: I also have a opinion that the user will understand less
> of how requires, autoloads, eval-after-loads and idle timers work if they
> start using use-package as the first thing.

Yes! That is the *point*. Emacs is not just for Lisp programmers.

> With that said, would adding bind-key and use-package to GNU Elpa be a
> better option?

Certainly a good starting place, as long as it's available in the tarball so
that it's immediately available, and users don't have to go through some other
configuration work to start using it.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  0:02 use-package.el -> Emacs core John Wiegley
                   ` (5 preceding siblings ...)
  2015-11-10  9:29 ` Nicolas Petton
@ 2015-11-10 18:21 ` Stephen Leake
  2015-11-10 18:34   ` John Wiegley
  6 siblings, 1 reply; 95+ messages in thread
From: Stephen Leake @ 2015-11-10 18:21 UTC (permalink / raw)
  To: emacs-devel

John Wiegley <jwiegley@gmail.com> writes:

> I'd like to integrate use-package.el into Emacs core, as an alternative for
> package management to those who do not rely on package.el. I know Stefan had
> some reservation, but I think enough people have enjoyed its utility to be
> worth including.
>
> Are there any objections to moving this into core before the 25.1 freeze?

What is the rationale for moving this to core instead of Gnu ELPA?

To me, this looks like a good ELPA package; no other core code will rely
on it, only some users want it.

-- 
-- Stephe



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 18:15               ` Evgeny Panasyuk
@ 2015-11-10 18:31                 ` Alan Mackenzie
  0 siblings, 0 replies; 95+ messages in thread
From: Alan Mackenzie @ 2015-11-10 18:31 UTC (permalink / raw)
  To: Evgeny Panasyuk; +Cc: emacs-tangents, emacs-devel

[ Mail-Followup-To: set ]

On Tue, Nov 10, 2015 at 09:15:51PM +0300, Evgeny Panasyuk wrote:
> 10.11.2015 16:06, Oleh Krehel:

> >>> We should encourage the core Elisp to be simple to learn, because it
> >>> is actually very simple.  Not anymore so with macros like `cl-loop',
> >>> `pcase' and `use-package'.  They are powerful, but /they are their own
> >>> language/ completely separate from Elisp. They have their place, but
> >>> in my opinion Elisp newbies should not be encouraged to use them.

> >> Sorry, but I cannot agree at all.  That's like saying C++ users should
> >> not learn about the standard libraries since they should rather write
> >> their own.

> > No, it's like saying that it's OK for users to write Boost template
> > constructs and do QT stuff without learning the basic C++ and STL.

> It is OK to use Boost.Function or Boost.Spirit before learning every 
> trick used inside. Yes, you have to read their documentation, but the 
> same applies "normal/usual" libraries.
> Another example is Boost.Preprocessor - it provides high level interface 
> and uses a lot of tricks to make it portable across very different 
> (buggy) preprocessor implementations - but you can successfully use it 
> without knowing every internal trick and detail.

I think this part of the thread, although interesting, no longer has
anything to do with Emacs.  Therefore it is a prime example of what
should move to emacs-tangents@gnu.org.

I have attempted to direct follow ups there.  This is something of an
experiment.

-- 
Alan Mackenzie (Nuremberg, Germany).



^ permalink raw reply	[flat|nested] 95+ messages in thread

* RE: use-package.el -> Emacs core
  2015-11-10 18:20                       ` John Wiegley
@ 2015-11-10 18:32                         ` Drew Adams
  2015-11-10 18:38                           ` John Wiegley
  0 siblings, 1 reply; 95+ messages in thread
From: Drew Adams @ 2015-11-10 18:32 UTC (permalink / raw)
  To: John Wiegley, Kaushal Modi
  Cc: David Kastrup, Juanma Barranquero, Emacs developers,
	João Távora, Dmitry Gutov, Oleh Krehel

> `define-key' is not really an end-user function, 

Until/unless we have an alternative that is more "end-user", it
definitely _is_ an end-user function, and the only one we offer,
for keys on maps other than `global-map'.

End users often want/need to add or change a key binding in
a particular keymap.  Questions of how to do that are FAQ.

But yes, `global-set-key' is also a command; `define-key' is not.

> as I've met countless people who have never even heard of it.

That means nothing in this regard.  There are countless people,
including countless Emacs users, who have never heard of plenty
of end-user features.  There are probably countless such who
have never heard of `M-x' or `C-h f' or even `C-h C-h'...

> `global-set-key' is much more user-facing,

Only because (1) users more commonly add/change global bindings
and (2) it is also a command.

But both are "end-user functions" and "user-facing".  (That
doesn't mean that something better cannot be found for end
users to use.)



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 18:21 ` Stephen Leake
@ 2015-11-10 18:34   ` John Wiegley
  2015-11-10 19:54     ` Dmitry Gutov
  2015-11-11  0:04     ` Stephen Leake
  0 siblings, 2 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10 18:34 UTC (permalink / raw)
  To: Stephen Leake; +Cc: emacs-devel

>>>>> Stephen Leake <stephen_leake@stephe-leake.org> writes:

> What is the rationale for moving this to core instead of Gnu ELPA?

Well, it will be maintained by a core developer. :) It would also be in the
Emacs manual, and blessed as an official method for declaring complex package
configuration.

Further, I wouldn't want it changing on users as ELPA updates. Once a user
downloads Emacs X.Y and reads the manual on how to write such configurations,
the information should remain true until Emacs X.Z.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 18:32                         ` Drew Adams
@ 2015-11-10 18:38                           ` John Wiegley
  2015-11-10 18:52                             ` Kaushal Modi
  2015-11-10 19:24                             ` Drew Adams
  0 siblings, 2 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10 18:38 UTC (permalink / raw)
  To: Drew Adams
  Cc: David Kastrup, Juanma Barranquero, Kaushal Modi, Emacs developers,
	Oleh Krehel, Dmitry Gutov, João Távora

>>>>> Drew Adams <drew.adams@oracle.com> writes:

> End users often want/need to add or change a key binding in
> a particular keymap.  Questions of how to do that are FAQ.

> But yes, `global-set-key' is also a command; `define-key' is not.

Yep, enriching global-set-key to take on the role of bind-key will mean
expanding it to handle keymaps, and this would make it the "Right Way" for end
users to modify their keybindings.

Core Emacs code should always use define-key, so that global-set-key bindings
can appear in the personal keybindings list.

>> as I've met countless people who have never even heard of it.

> That means nothing in this regard. There are countless people, including
> countless Emacs users, who have never heard of plenty of end-user features.
> There are probably countless such who have never heard of `M-x' or `C-h f'
> or even `C-h C-h'...

It means something to me, Drew, and I'm the one acting on behalf of those
users.

> But both are "end-user functions" and "user-facing".  (That
> doesn't mean that something better cannot be found for end
> users to use.)

I think that moving define-key to an internal/programmatic mechanism, and
enriching global-set-key toward an external/user mechanism, with all the
features of bind-key, is the solution we both want.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 18:38                           ` John Wiegley
@ 2015-11-10 18:52                             ` Kaushal Modi
  2015-11-10 18:55                               ` John Wiegley
  2015-11-10 19:24                             ` Drew Adams
  1 sibling, 1 reply; 95+ messages in thread
From: Kaushal Modi @ 2015-11-10 18:52 UTC (permalink / raw)
  To: Drew Adams, Kaushal Modi, David Kastrup, Juanma Barranquero,
	Emacs developers, Oleh Krehel, Dmitry Gutov,
	João Távora

> Yep, enriching global-set-key to take on the role of bind-key will mean
> expanding it to handle keymaps, and this would make it the "Right Way" for end
> users to modify their keybindings.

But then wouldn't global-set-key become a misnomer? global-set-key is
to set bindings only in the global-map.
Should `define-key` be enriched instead?



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 18:52                             ` Kaushal Modi
@ 2015-11-10 18:55                               ` John Wiegley
  0 siblings, 0 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10 18:55 UTC (permalink / raw)
  To: Kaushal Modi
  Cc: David Kastrup, Juanma Barranquero, Emacs developers, Oleh Krehel,
	Dmitry Gutov, Drew Adams, João Távora

>>>>> Kaushal Modi <kaushal.modi@gmail.com> writes:

> But then wouldn't global-set-key become a misnomer? global-set-key is to set
> bindings only in the global-map. Should `define-key` be enriched instead?

I'd like to rename it to "set-key", with global-set-key as an alias.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* RE: use-package.el -> Emacs core
  2015-11-10 18:38                           ` John Wiegley
  2015-11-10 18:52                             ` Kaushal Modi
@ 2015-11-10 19:24                             ` Drew Adams
  2015-11-10 19:35                               ` John Wiegley
  1 sibling, 1 reply; 95+ messages in thread
From: Drew Adams @ 2015-11-10 19:24 UTC (permalink / raw)
  To: John Wiegley
  Cc: David Kastrup, Juanma Barranquero, Kaushal Modi, Emacs developers,
	Oleh Krehel, Dmitry Gutov, João Távora

> >> `define-key' is not really an end-user function,
> >> ...
> >> as I've met countless people who have never even heard of it.
> 
> > That means nothing in this regard. There are countless people,
> > including countless Emacs users, who have never heard of plenty
> > of end-user features.  There are probably countless such who
> > have never heard of `M-x' or `C-h f' or even `C-h C-h'...
> 
> It means something to me, Drew, and I'm the one acting on behalf
> of those users.

Sure, but it's not an argument that just _because_ some end users
are unaware of something that is used by other end users (especially
if there is no alternative to using that something) it _follows_
that that thing is not "end-user".  That's a phony argument.

`define-key' is "end-user" because end users sometimes want/need
to use keymaps other than `global-map', and it is their only way
to do that.  It might not be "end-user" enough for you, but that
is something different.

It is only the argument that I find fault with, not the attempt
to come up with something better or more end-userish.

> > But both are "end-user functions" and "user-facing".  (That
> > doesn't mean that something better cannot be found for end
> > users to use.)
> 
> I think that moving define-key to an internal/programmatic mechanism, and
> enriching global-set-key toward an external/user mechanism, with all the
> features of bind-key, is the solution we both want.

That's not a solution that I proposed or necessarily want.
Just as I have no problem with end users using `setq', I have
no problem with them using `define-key'.

That doesn't mean that I oppose giving them something better
as well (for both `setq' and `define-key').  But that does
not imply "moving define-key to an internal/programmatic
mechanism" (whatever you might mean by that).

FWIW, I also object to some kind of definite line, dividing
non-Lisp Emacs users from "internal/programmatic mechanisms"
and Lisp.  There is naturally a spectrum of Emacs usage that
involves different degrees of using Lisp.  And that's a good
thing.  All kinds of Emacs user are welcome.

Attempts to provide non-Lisp ways to do things can be helpful.
(They are not always/necessarily helpful, however.)  But in
general my attitude is that Emacs _is_ Elisp - Emacs is a Lisp
environment.  That is what makes Emacs different and specially
useful.

It is a mistake to draw a hard line between Emacs "end use"
and Lisp.  Lisp vastly increases one's use of Emacs.  Without
some use of Lisp, you are not really taking advantage of Emacs.
You might even say that you are not _really_ using it.

We should, yes, cater to helping novice users who do not
know Lisp.  But we should also encourage the use of Lisp
with Emacs, not discourage it.  You don't need Lisp to
start using Emacs.  But if you really want to use Emacs
then you will want to learn some Lisp.  That should not
be because you _have to_ learn it, but because you can
do so much more with Emacs if you do.

Lack of Lisp knowledge should not be an unnecessary obstacle
to using basic Emacs features.  But we should not hide Lisp
from users, as something that isn't helpful to them or
something they really shouldn't bother with.

The other aspect of not having a dividing line between
internal/programmer and external/end-user is that this is
what free software is about: users can and do dive into
whatever level of the "internals" - the source code - they
feel like.  And they are not discouraged from doing so -
quite the contrary.

Users _are_ developers in this context, even just by
suggesting things that can affect them directly, but also
by, themselves, getting involved with Lisp and coming up
with other ways to do things.  GNU Emacs has a privileged
role to play in this regard.  It is the use-it, customize-it,
fiddle-with-it, extend-it end-user application par excellence.

(Just one opinion.)

> I'm the one acting on behalf of those users.
  ^^^^^^^^^^^

You are not the only one.  Lots of us here keep those
users in mind and try to act on their behalf.  I'm glad
you do too.  Welcome aboard. ;-)



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 18:15                       ` John Wiegley
@ 2015-11-10 19:32                         ` João Távora
  2015-11-10 19:47                           ` John Wiegley
  0 siblings, 1 reply; 95+ messages in thread
From: João Távora @ 2015-11-10 19:32 UTC (permalink / raw)
  To: David Kastrup
  Cc: Juanma Barranquero, Emacs developers, Oleh Krehel, Dmitry Gutov

John Wiegley <jwiegley@gmail.com> writes:
>>> (use-package python-mode :load-path "site-lisp/python-mode" :mode "\\.py$")
>
>> But, if using package.el (or el-get), I don't need to write this, right?
>> It's already setup by python.el and by whatever method I used to install it.
>
> Correct. In fact, I'd _prefer_ it if the user didn't have to touch use-package
> at all, and could get by with package.el and customize. use-package is the
> "next step", after those two.

Righto. So after having agreed that `python.el' is not an ideal
demonstration of the potential of use-package, in fact it's useless in
that one, can you give some better examples?

> The only alternatives we need to consider right now is with and without
> use-package.el -- for details not taken care of by package.el. el-get is
> neither in core nor ELPA, so that knowledge doesn't help this
> discussion.

But aren't we discussing the potential installation in Emacs of *a* new
tool to ease the installation and the configuration of package? If
el-get is such a tool, why shouldn't it be included in this discussion?

Here's a very simple example: here's a way to configure markdown-mode

   (package-install 'markdown-mode)
   (with-eval-after-load 'markdown-mode
     (modify-syntax-entry ?` "\"" markdown-mode-syntax-table))

Here's a completely different way using el-get (actually, untested and I
suspect there's a simpler way, but I think it does what I want)

   (add-to-list 'el-get-sources
                '(:name 'markdown-mode
                  :after (modify-syntax-entry ?` "\"" markdown-mode-syntax-table)))
   (el-get 'sync 'markdown-mode)

And, for completeness, here's the package.el-less way for people who
downloaded it separately?

   (add-to-list 'load-path "path/to/markdown-mode")
   (require 'markdown-mode-autoloads)
   (with-eval-after-load 'markdown-mode
     (modify-syntax-entry ?` "\"" markdown-mode-syntax-table))

How would use-package handle this simple example? 

>> Then by all means use it :). But should I have to learn it too?
> Not necessarily. There are plenty of areas of Emacs that you don't have to
> learn, but that doesn't prohibit them from being in Emacs. If you see a bug
> dealing with use-package and don't want to handle it, don't.

I don't think you understood. I don't mean bugs in `use-package', I mean
bug reports in my extensions that are reported in terms of
`use-package'. Should I not handle those bugs?

> It's not a "new way" of configuring packages. It's a WAY period. The

I don't understand. It's a "new way", at least for me.

João



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 19:24                             ` Drew Adams
@ 2015-11-10 19:35                               ` John Wiegley
  2015-11-10 20:42                                 ` Drew Adams
  0 siblings, 1 reply; 95+ messages in thread
From: John Wiegley @ 2015-11-10 19:35 UTC (permalink / raw)
  To: Drew Adams
  Cc: David Kastrup, Juanma Barranquero, Kaushal Modi, Emacs developers,
	Oleh Krehel, Dmitry Gutov, João Távora

>>>>> Drew Adams <drew.adams@oracle.com> writes:

> Sure, but it's not an argument that just _because_ some end users are
> unaware of something that is used by other end users (especially if there is
> no alternative to using that something) it _follows_ that that thing is not
> "end-user". That's a phony argument.
>
> `define-key' is "end-user" because end users sometimes want/need to use
> keymaps other than `global-map', and it is their only way to do that. It
> might not be "end-user" enough for you, but that is something different.
>
> It is only the argument that I find fault with, not the attempt to come up
> with something better or more end-userish.

Ah, OK, I concede your point. I have no grounds for saying define-key *isn't*
user facing, just that I'd like a clearer divide between what developers would
use for this functionality, and something that caters more to users.

> FWIW, I also object to some kind of definite line, dividing non-Lisp Emacs
> users from "internal/programmatic mechanisms" and Lisp. There is naturally a
> spectrum of Emacs usage that involves different degrees of using Lisp. And
> that's a good thing. All kinds of Emacs user are welcome.

Yes!

> It is a mistake to draw a hard line between Emacs "end use" and Lisp. Lisp
> vastly increases one's use of Emacs. Without some use of Lisp, you are not
> really taking advantage of Emacs. You might even say that you are not
> _really_ using it.
> 
> We should, yes, cater to helping novice users who do not know Lisp. But we
> should also encourage the use of Lisp with Emacs, not discourage it. You
> don't need Lisp to start using Emacs. But if you really want to use Emacs
> then you will want to learn some Lisp. That should not be because you _have
> to_ learn it, but because you can do so much more with Emacs if you do.

So we probably agree that Emacs is a spectrum from "application" to
"programming heaven", and that while we'd like to be a good tool at every
point along that spectrum, we shouldn't discourage a gradual migration
towards the bliss most of us have found.

>> I'm the one acting on behalf of those users.
>   ^^^^^^^^^^^
> You are not the only one. Lots of us here keep those users in mind and try
> to act on their behalf. I'm glad you do too. Welcome aboard. ;-)

I'm very glad to hear that. :)

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 19:32                         ` João Távora
@ 2015-11-10 19:47                           ` John Wiegley
  2015-11-10 21:00                             ` João Távora
  0 siblings, 1 reply; 95+ messages in thread
From: John Wiegley @ 2015-11-10 19:47 UTC (permalink / raw)
  To: João Távora
  Cc: Juanma Barranquero, David Kastrup, Dmitry Gutov, Oleh Krehel,
	Emacs developers

>>>>> João Távora <joaotavora@gmail.com> writes:

> Here's a very simple example: here's a way to configure markdown-mode

>    (package-install 'markdown-mode)
>    (with-eval-after-load 'markdown-mode
>      (modify-syntax-entry ?` "\"" markdown-mode-syntax-table))

> How would use-package handle this simple example? 

To match those semantics, you'd use:

    (use-package markdown-mode
      :ensure t
      :config (modify-syntax-entry ?` "\"" markdown-mode-syntax-table))

> I don't think you understood. I don't mean bugs in `use-package', I mean bug
> reports in my extensions that are reported in terms of `use-package'. Should
> I not handle those bugs?

Ah. Does it help that you can macro-expand use-package forms, so that you see
what the underlying Emacs Lisp calls? I try hard to make the expanded code
"look like what you'd write", as much as possible.

> I don't understand. It's a "new way", at least for me.

I meant that between customize and Emacs Lisp, there nothing in between for
users of core Emacs right now. Beyond Emacs, there do exist several other
ways.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 18:34   ` John Wiegley
@ 2015-11-10 19:54     ` Dmitry Gutov
  2015-11-10 20:09       ` Kaushal Modi
  2015-11-11  0:04     ` Stephen Leake
  1 sibling, 1 reply; 95+ messages in thread
From: Dmitry Gutov @ 2015-11-10 19:54 UTC (permalink / raw)
  To: emacs-devel

On 11/10/2015 08:34 PM, John Wiegley wrote:

> Well, it will be maintained by a core developer. :)

Quite a few packages in ELPA come from Emacs committers. Stefan has 
several (e.g. sml-mode). I maintain three (2 of which are comparable in 
popularity to use-package, judging by the number of stars on GitHub).

> It would also be in the
> Emacs manual, and blessed as an official method for declaring complex package
> configuration.

Packages can also include manuals (I don't know the details, but e.g. 
Flycheck does). Of course, you can't declare use-package to be "blessed" 
that way.

> Further, I wouldn't want it changing on users as ELPA updates. Once a user
> downloads Emacs X.Y and reads the manual on how to write such configurations,
> the information should remain true until Emacs X.Z.

Do you expect use-package to depend on new features in every Emacs 
version? Otherwise, you can have pretty much the same by only releasing 
a new version of use-package once a year. :)



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 19:54     ` Dmitry Gutov
@ 2015-11-10 20:09       ` Kaushal Modi
  2015-11-10 20:27         ` John Wiegley
  0 siblings, 1 reply; 95+ messages in thread
From: Kaushal Modi @ 2015-11-10 20:09 UTC (permalink / raw)
  To: Dmitry Gutov; +Cc: Emacs developers

> Packages can also include manuals (I don't know the details, but e.g. Flycheck does). Of course, you can't declare use-package to be "blessed" that way.

Also non-Elpa packages come with detailed manuals: magit

> Do you expect use-package to depend on new features in every Emacs version? Otherwise, you can have pretty much the same by only releasing a new version of use-package once a year. :)

+1

The development for use-package can continue as it is happening now
and versions can be git-tagged as something like "stable". When the
time for next emacs release comes, the GNU Elpa version can be synced
with the latest "stable" tagged version from the development git.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 20:09       ` Kaushal Modi
@ 2015-11-10 20:27         ` John Wiegley
  0 siblings, 0 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-10 20:27 UTC (permalink / raw)
  To: Kaushal Modi; +Cc: Emacs developers, Dmitry Gutov

>>>>> Kaushal Modi <kaushal.modi@gmail.com> writes:

> The development for use-package can continue as it is happening now and
> versions can be git-tagged as something like "stable". When the time for
> next emacs release comes, the GNU Elpa version can be synced with the latest
> "stable" tagged version from the development git.

Hmmm... you guys are both encouraging me to consider putting it in ELPA
instead. It really kind of is an "optional package if you want to do things
this way..."

I so want that ELPA policy document now. :) We're spending too much time
having this same debate about a fine line, like a hair in the dark.

I think for 25.1, at least, everything I've suggested recently should go into
ELPA. Then we'll let the policy document decide whether they belong in core
for 25.2.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* RE: use-package.el -> Emacs core
  2015-11-10 19:35                               ` John Wiegley
@ 2015-11-10 20:42                                 ` Drew Adams
  0 siblings, 0 replies; 95+ messages in thread
From: Drew Adams @ 2015-11-10 20:42 UTC (permalink / raw)
  To: John Wiegley
  Cc: David Kastrup, Juanma Barranquero, Kaushal Modi, Emacs developers,
	Oleh Krehel, Dmitry Gutov, João Távora

> So we probably agree that Emacs is a spectrum from "application" to
> "programming heaven", and that while we'd like to be a good tool at every
> point along that spectrum, we shouldn't discourage a gradual migration
> towards the bliss most of us have found.

Yes.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 19:47                           ` John Wiegley
@ 2015-11-10 21:00                             ` João Távora
  0 siblings, 0 replies; 95+ messages in thread
From: João Távora @ 2015-11-10 21:00 UTC (permalink / raw)
  To: John Wiegley
  Cc: Juanma Barranquero, Dmitry Gutov, Oleh Krehel, Emacs developers

John Wiegley <jwiegley@gmail.com> writes:

>>    (package-install 'markdown-mode)
>>    (with-eval-after-load 'markdown-mode
>>      (modify-syntax-entry ?` "\"" markdown-mode-syntax-table))
>
> To match those semantics, you'd use:
>
>     (use-package markdown-mode
>       :ensure t
>       :config (modify-syntax-entry ?` "\"" markdown-mode-syntax-table))

OK, so we would agree that in this particular example it doesn't bring a
great advantage, if any. Perhaps you could provide another example where
you definitely think it does.

>> I don't think you understood. I don't mean bugs in `use-package', I mean bug
>> reports in my extensions that are reported in terms of `use-package'. Should
>> I not handle those bugs?
>
> Ah. Does it help that you can macro-expand use-package forms, so that you see
> what the underlying Emacs Lisp calls? I try hard to make the expanded code
> "look like what you'd write", as much as possible.

That's what I would do yes. But then I have to have a running emacs with
`use-package' myself, right? I've seen some macroexpansions of it
somewhere in this thread and it's not particularly pretty (also not
particularly correct apparently: see my criticism of the use of fboundp
and autoload, for example).

But I can't resist pointing out a certain irony in your argument: if
use-package is not hiding any ugly implementation details, there's
really no use for it :-).

For contrast, and quite a scare, see the macroexpansions of
`define-minor-mode` or `define-globalized-minor-mode'. yucky.

On the other hand, I have to admit that by participanting in this
discussion I ended up probably learning more than enough of the
use-package minilanguage to handle such a bug report.

So I don't know. Count me in the "initially against, but now doesn't
care" category and let the masses decide :-)

João



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  5:37           ` Kaushal Modi
  2015-11-10  6:07             ` John Wiegley
@ 2015-11-10 23:27             ` Stephen Leake
  2015-11-10 23:32               ` John Wiegley
  1 sibling, 1 reply; 95+ messages in thread
From: Stephen Leake @ 2015-11-10 23:27 UTC (permalink / raw)
  To: Kaushal Modi; +Cc: johnw, Bruce Connor, Emacs developers

Kaushal Modi <kaushal.modi@gmail.com> writes:

> I use the use-package and bind-key packages in my config.
>
> The use-package would be nice to have in the core 

Would it be just as nice in ELPA?


-- 
-- Stephe



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 23:27             ` Stephen Leake
@ 2015-11-10 23:32               ` John Wiegley
  2015-11-11  9:29                 ` Oleh Krehel
  0 siblings, 1 reply; 95+ messages in thread
From: John Wiegley @ 2015-11-10 23:32 UTC (permalink / raw)
  To: Stephen Leake; +Cc: Emacs developers, Bruce Connor, Kaushal Modi

>>>>> Stephen Leake <stephen_leake@stephe-leake.org> writes:

> Kaushal Modi <kaushal.modi@gmail.com> writes:
>> I use the use-package and bind-key packages in my config.
>> 
>> The use-package would be nice to have in the core 

> Would it be just as nice in ELPA?

I think now that it would be!

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: Customize is only for newbies? [was: use-package.el -> Emacs core]
  2015-11-10 15:08               ` Customize is only for newbies? [was: use-package.el -> Emacs core] Drew Adams
@ 2015-11-11  0:01                 ` Wolfgang Jenkner
  0 siblings, 0 replies; 95+ messages in thread
From: Wolfgang Jenkner @ 2015-11-11  0:01 UTC (permalink / raw)
  To: Drew Adams
  Cc: Juanma Barranquero, David Kastrup, Dmitry Gutov, Oleh Krehel,
	Emacs developers

On Tue, Nov 10 2015, Drew Adams wrote:

>> > It also makes sure that any followup actions
>> > necessary after setting the variables are being performed.
>> 
>> Sure, :set is kind of a custom(er) lock-in.
>
> Dunno whether that was supposed to be a joke.

Quite serious, if a bit laconic.

> :set is a hook for variables.  It runs code whenever
> the variable is set.  That's a feature that you can
> use in your programming.  It doesn't lock anyone into
> anything.

Please see

http://permalink.gmane.org/gmane.emacs.bugs/107690

The bug report's author makes my point in an admirably eloquent way.

Wolfgang :-)



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 18:34   ` John Wiegley
  2015-11-10 19:54     ` Dmitry Gutov
@ 2015-11-11  0:04     ` Stephen Leake
  1 sibling, 0 replies; 95+ messages in thread
From: Stephen Leake @ 2015-11-11  0:04 UTC (permalink / raw)
  To: emacs-devel

John Wiegley <jwiegley@gmail.com> writes:

>>>>>> Stephen Leake <stephen_leake@stephe-leake.org> writes:
>
>> What is the rationale for moving this to core instead of Gnu ELPA?

(My search of list-packages did not find `use-package' the first time,
so I did not realize it is already in Gnu ELPA).

> Well, it will be maintained by a core developer. :) 

Not a good reason; I maintain ada-mode in ELPA, because I want an
independent release cycle. But I still consider myself a minor Emacs
core developer.

> It would also be in the Emacs manual,

It can provide a .info file, which will be in the user's top level info
list. Is that not sufficient?

Hmm. It might be that other sections of the Emacs manual want to 
reference use-package. They can do so, as long as they clearly label it
as an ELPA package, so users will know how to find it. For example:

    If you use the (really cool) ELPA package @elparef{use-package},
    then you can do ...

I'm not clear exactly what "@elparef" should do, but it seems like a
good idea. Perhaps it should add the "ELPA package" text, so it is done
consistently. Can it add a clickable link to the package.el description
of the package?

> and blessed as an official method for declaring complex package
> configuration.

Ah. So you are asking us to agree that _this_ package is better than
other similar packages.

That's a reasonable request in general. But given the controversy around
CEDET, I think it needs to wait for emacs 25+, so we can establish a
process for such requests.

> Further, I wouldn't want it changing on users as ELPA updates. 
> Once a user downloads Emacs X.Y and reads the manual on how to write
> such configurations, the information should remain true until Emacs
> X.Z.

As the package maintainer, that's under your control; if you don't want
it to change, don't change it.

You are completely free to determine the release schedule for your ELPA
package. If you want it synced with Emacs releases, do that. There is a
small race condition window at the actual release, but I don't think
that's a significant problem. Proper use of Emacs version in the
dependency header should handle that.

If you want to work on it between releases, use a branch in ELPA git, or
a separate repository.


On the other hand, that means you can't release bug fixes, either. Nor
really cool but backward-compatible enhancements. I'd rather have a
package in ELPA, so I don't have to wait for the next Emacs release.

-- 
-- Stephe



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  8:24 ` joakim
@ 2015-11-11  0:29   ` Stephen Leake
  2015-11-11  0:45     ` Dmitry Gutov
  0 siblings, 1 reply; 95+ messages in thread
From: Stephen Leake @ 2015-11-11  0:29 UTC (permalink / raw)
  To: joakim; +Cc: emacs-devel

joakim@verona.se writes:

> I use req-package, https://github.com/edvorg/req-package, which is
> use-package with some additional features, like logging and load order
> reordering. I think use-package would be a great addition to emacs core,
> for people like me that like a clear and readable emacs
> configuration.

It's currently in Gnu ELPA; is that sufficient?

-- 
-- Stephe



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10  9:29 ` Nicolas Petton
@ 2015-11-11  0:32   ` Stephen Leake
  2015-11-11  0:37     ` John Wiegley
  0 siblings, 1 reply; 95+ messages in thread
From: Stephen Leake @ 2015-11-11  0:32 UTC (permalink / raw)
  To: Nicolas Petton; +Cc: John Wiegley, emacs-devel

Nicolas Petton <nicolas@petton.fr> writes:

> John Wiegley <jwiegley@gmail.com> writes:
>
>> I'd like to integrate use-package.el into Emacs core, as an alternative for
>> package management to those who do not rely on package.el. I know Stefan had
>> some reservation, but I think enough people have enjoyed its utility to be
>> worth including.
>>
>> Are there any objections to moving this into core before the 25.1
>> freeze?
>
> That's fine with me. use-package.el is already used by many people.

Which is an argument for it being in Gnu ELPA; would that be enough?

I'm bugging people about this to help clarify the ELPA vs core policy.

-- 
-- Stephe



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 15:42                   ` Juanma Barranquero
  2015-11-10 15:56                     ` Dmitry Gutov
@ 2015-11-11  0:37                     ` Stephen Leake
  2015-11-11  0:56                       ` Juanma Barranquero
  1 sibling, 1 reply; 95+ messages in thread
From: Stephen Leake @ 2015-11-11  0:37 UTC (permalink / raw)
  To: Juanma Barranquero; +Cc: Dmitry Gutov, Oleh Krehel, Emacs developers

Juanma Barranquero <lekktu@gmail.com> writes:

> On Tue, Nov 10, 2015 at 4:15 PM, John Wiegley <jwiegley@gmail.com> wrote:
>
>> For (7):
>>
>> - Nicolas Petton
>> - Joakim Verona
>> - Phillip Lord
>> - Dimtry Gutov
>> - Artur Malabarb
>> - Kaushal Modi
>> - Ted Zlatanov
>
> I'm for

Would you support putting it in Gnu ELPA instead?

It seems it's already there.

I'm trying to clarify ELPA vs core policy.

-- 
-- Stephe



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-11  0:32   ` Stephen Leake
@ 2015-11-11  0:37     ` John Wiegley
  0 siblings, 0 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-11  0:37 UTC (permalink / raw)
  To: Stephen Leake; +Cc: Nicolas Petton, emacs-devel

>>>>> Stephen Leake <stephen_leake@stephe-leake.org> writes:

>> That's fine with me. use-package.el is already used by many people.

> Which is an argument for it being in Gnu ELPA; would that be enough?

I think so.

> I'm bugging people about this to help clarify the ELPA vs core policy.

Thank you, it is helping. I can feel the mists converging toward a less
inchoate adumbration. :)

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-11  0:29   ` Stephen Leake
@ 2015-11-11  0:45     ` Dmitry Gutov
  2015-11-11  9:30       ` Stephen Leake
  0 siblings, 1 reply; 95+ messages in thread
From: Dmitry Gutov @ 2015-11-11  0:45 UTC (permalink / raw)
  To: Stephen Leake, joakim; +Cc: emacs-devel

On 11/11/2015 02:29 AM, Stephen Leake wrote:

>> I use req-package, https://github.com/edvorg/req-package, which is
>> use-package with some additional features, like logging and load order
>> reordering. I think use-package would be a great addition to emacs core,
>> for people like me that like a clear and readable emacs
>> configuration.
>
> It's currently in Gnu ELPA

What makes you think so?



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-11  0:37                     ` Stephen Leake
@ 2015-11-11  0:56                       ` Juanma Barranquero
  0 siblings, 0 replies; 95+ messages in thread
From: Juanma Barranquero @ 2015-11-11  0:56 UTC (permalink / raw)
  To: Stephen Leake; +Cc: Dmitry Gutov, Oleh Krehel, Emacs developers

[-- Attachment #1: Type: text/plain, Size: 146 bytes --]

On Wed, Nov 11, 2015 at 1:37 AM, Stephen Leake <
stephen_leake@stephe-leake.org> wrote:
> Would you support putting it in Gnu ELPA instead?

Yes.

[-- Attachment #2: Type: text/html, Size: 352 bytes --]

^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 23:32               ` John Wiegley
@ 2015-11-11  9:29                 ` Oleh Krehel
  2015-11-11 16:48                   ` John Wiegley
  0 siblings, 1 reply; 95+ messages in thread
From: Oleh Krehel @ 2015-11-11  9:29 UTC (permalink / raw)
  To: Stephen Leake; +Cc: Emacs developers, Bruce Connor, Kaushal Modi

John Wiegley <jwiegley@gmail.com> writes:

>> Would it be just as nice in ELPA?
>
> I think now that it would be!

I use (a narrow subset of) use-package; I like it, and I'm all for
having it in GNU ELPA.  That should cover my reservations for added
Elisp complexity: if it's not in the core, my previously listed concerns
are much less severe.

    Oleh



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-11  0:45     ` Dmitry Gutov
@ 2015-11-11  9:30       ` Stephen Leake
  2015-11-11 10:04         ` Xue Fuqiao
  2015-11-11 10:20         ` Artur Malabarba
  0 siblings, 2 replies; 95+ messages in thread
From: Stephen Leake @ 2015-11-11  9:30 UTC (permalink / raw)
  To: Dmitry Gutov; +Cc: joakim, emacs-devel

Dmitry Gutov <dgutov@yandex.ru> writes:

> On 11/11/2015 02:29 AM, Stephen Leake wrote:
>
>>> I use req-package, https://github.com/edvorg/req-package, which is
>>> use-package with some additional features, like logging and load order
>>> reordering. I think use-package would be a great addition to emacs core,
>>> for people like me that like a clear and readable emacs
>>> configuration.
>>
>> It's currently in Gnu ELPA
>
> What makes you think so?

Sorry, I misread the output of list-packages; it's currently in MELPA.

Which raises the question; what is the rationale for moving from MELPA
to Gnu ELPA?

-- 
-- Stephe



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-11  9:30       ` Stephen Leake
@ 2015-11-11 10:04         ` Xue Fuqiao
  2015-11-11 10:20         ` Artur Malabarba
  1 sibling, 0 replies; 95+ messages in thread
From: Xue Fuqiao @ 2015-11-11 10:04 UTC (permalink / raw)
  To: Stephen Leake; +Cc: Emacs-devel, joakim, Dmitry Gutov

On Wed, Nov 11, 2015 at 5:30 PM, Stephen Leake
<stephen_leake@stephe-leake.org> wrote:

> what is the rationale for moving from MELPA to Gnu ELPA?

Some advantage of GNU ELPA (in comparison with MELPA):

* The GNU ELPA archive is the only archive that's configured by default,
  so we can tell people to M-x package-install without worrying about
  whether or not they've added MELPA to their config.

* The code uses the same copyright rules as Emacs code, so that we can
  easily move code between the two.  IOW it'd be ready for inclusion in
  Emacs proper.  (I'm aware of the controversy, but what if we want to
  move it to the core in the future?)

* All Emacs developers have write access to the code, so it can benefit
  from random cleanups or adjustments to new features.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-11  9:30       ` Stephen Leake
  2015-11-11 10:04         ` Xue Fuqiao
@ 2015-11-11 10:20         ` Artur Malabarba
  1 sibling, 0 replies; 95+ messages in thread
From: Artur Malabarba @ 2015-11-11 10:20 UTC (permalink / raw)
  To: Stephen Leake; +Cc: emacs-devel, joakim, Dmitry Gutov

> Sorry, I misread the output of list-packages; it's currently in MELPA.
>
> Which raises the question; what is the rationale for moving from MELPA
> to Gnu ELPA?

Being the default package archive, adding a package to Gelpa increases
its visibility to users who don't have Melpa configured (either for
not knowing it or not wanting it).
And if the author/maintainer doesn't mind managing a package on Gelpa,
then there's no downside either.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-11  9:29                 ` Oleh Krehel
@ 2015-11-11 16:48                   ` John Wiegley
  2015-11-11 20:04                     ` Kaushal Modi
  0 siblings, 1 reply; 95+ messages in thread
From: John Wiegley @ 2015-11-11 16:48 UTC (permalink / raw)
  To: Oleh Krehel; +Cc: Kaushal Modi, Stephen Leake, Bruce Connor, Emacs developers

>>>>> Oleh Krehel <ohwoeowho@gmail.com> writes:

> I use (a narrow subset of) use-package; I like it, and I'm all for having it
> in GNU ELPA. That should cover my reservations for added Elisp complexity:
> if it's not in the core, my previously listed concerns are much less severe.

Thanks, Oleh, I do think it belongs in ELPA, so long as it's on the user's
load-path by default after they install Emacs. Since we're converging toward a
notion of "tarball ELPA" in other threads, this should satisfy both our
concerns.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-11 16:48                   ` John Wiegley
@ 2015-11-11 20:04                     ` Kaushal Modi
  2015-11-11 20:10                       ` John Wiegley
  2015-11-12  2:11                       ` Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core) Michael Heerdegen
  0 siblings, 2 replies; 95+ messages in thread
From: Kaushal Modi @ 2015-11-11 20:04 UTC (permalink / raw)
  To: Oleh Krehel, Stephen Leake, Emacs developers, Bruce Connor,
	Kaushal Modi

Do all the contributors here:
https://github.com/jwiegley/use-package/graphs/contributors

need to have signed the FSF copyright assignment?



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-11 20:04                     ` Kaushal Modi
@ 2015-11-11 20:10                       ` John Wiegley
  2015-11-12  2:11                       ` Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core) Michael Heerdegen
  1 sibling, 0 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-11 20:10 UTC (permalink / raw)
  To: Kaushal Modi; +Cc: Stephen Leake, Oleh Krehel, Bruce Connor, Emacs developers

>>>>> Kaushal Modi <kaushal.modi@gmail.com> writes:

> Do all the contributors here:
> https://github.com/jwiegley/use-package/graphs/contributors
> need to have signed the FSF copyright assignment?

Good call, Kaushal. They in fact do. I'll have to process that before
use-package.el can be considered for ELPA.

The same goes for the various backends people have contributed to alert.el. No
one has changed the core infrastructure but myself, I believe, but many of the
backends were written by other people.

pl.el has no contributors but myself.

Thanks for bringing this up, I don't fully have my GNU maintainer hat on tight
yet, clearly!

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core)
  2015-11-11 20:04                     ` Kaushal Modi
  2015-11-11 20:10                       ` John Wiegley
@ 2015-11-12  2:11                       ` Michael Heerdegen
  2015-11-12  2:19                         ` Copyright assignments in Gnu Elpa John Wiegley
                                           ` (2 more replies)
  1 sibling, 3 replies; 95+ messages in thread
From: Michael Heerdegen @ 2015-11-12  2:11 UTC (permalink / raw)
  To: emacs-devel

Kaushal Modi <kaushal.modi@gmail.com> writes:

> Do all the contributors here:
> https://github.com/jwiegley/use-package/graphs/contributors
>
> need to have signed the FSF copyright assignment?

This is a good question.

I've never thought about it, but AFAIU all contributors for all external
packages in Gnu Elpa need copyright assignments - right?

Are we sure that this is currently the case at all with all those
packages developed on Github (pull requests!) ?

And should there not be something said about that in elpa/README?


Michael.




^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: Copyright assignments in Gnu Elpa
  2015-11-12  2:11                       ` Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core) Michael Heerdegen
@ 2015-11-12  2:19                         ` John Wiegley
  2015-11-12  3:50                         ` Artur Malabarba
  2015-11-12 22:31                         ` Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core) Richard Stallman
  2 siblings, 0 replies; 95+ messages in thread
From: John Wiegley @ 2015-11-12  2:19 UTC (permalink / raw)
  To: Michael Heerdegen; +Cc: emacs-devel

>>>>> Michael Heerdegen <michael_heerdegen@web.de> writes:

> I've never thought about it, but AFAIU all contributors for all external
> packages in Gnu Elpa need copyright assignments - right?

I put out a call for papers today for use-package and alert, and so far the
results have been quite positive. At least six people are mailing in signed
assignments. Many others already had an assignment. No one has said they'd
rather have their change pulled.

John



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: Copyright assignments in Gnu Elpa
  2015-11-12  2:11                       ` Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core) Michael Heerdegen
  2015-11-12  2:19                         ` Copyright assignments in Gnu Elpa John Wiegley
@ 2015-11-12  3:50                         ` Artur Malabarba
  2015-11-12 22:31                         ` Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core) Richard Stallman
  2 siblings, 0 replies; 95+ messages in thread
From: Artur Malabarba @ 2015-11-12  3:50 UTC (permalink / raw)
  To: Michael Heerdegen; +Cc: emacs-devel

Michael Heerdegen <michael_heerdegen@web.de> writes:

> This is a good question.
>
> I've never thought about it, but AFAIU all contributors for all external
> packages in Gnu Elpa need copyright assignments - right?

Non-trivial contributors, yes.

> Are we sure that this is currently the case at all with all those
> packages developed on Github (pull requests!) ?

Currently, for code to get into Gelpa it needs to be manually commited
by someone with push access. Gelpa (and Emacs) thus work on the
assumption that those with push access will only push code that they
have authored, or code that they were told was authored by someone with
an assignment on file.

> And should there not be something said about that in elpa/README?

Yes.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2015-11-10 14:48                 ` João Távora
  2015-11-10 15:40                   ` John Wiegley
@ 2015-11-12 12:43                   ` Nicolas Richard
  1 sibling, 0 replies; 95+ messages in thread
From: Nicolas Richard @ 2015-11-12 12:43 UTC (permalink / raw)
  To: João Távora; +Cc: Pedro Silva, Phillip Lord, emacs-devel

Hello,

joaotavora@gmail.com (João Távora) writes:
> Nicolas Richard <youngfrog@members.fsf.org> writes:
>> IIRC in the above snippet (from the expansion of a use-package
>> instance), `fboundp' is mostly used as `autoloadp' to avoid overwriting
>> existing autloads (I guess autloadp wasn't used because it takes an
>> OBJECT as argument instead of a symbol).
>
> Is this useful or desirable?

I guess it was useful to some people. This triggered its addition :
https://github.com/jwiegley/use-package/issues/135
(then later : https://github.com/jwiegley/use-package/issues/177)

I think however that this is a detail which is pretty much independent
from the question of adding use-package to core.

>                              Doesn't this mean that making a correction
> to a `use-package' instantiation and re-evaluating it will silently
> produce a noop?

In case of autoloads it seems so. For other configuration keywords, not
necessarily.

> In the same vein, does `use-package' undo autoloads (or keybindings or
> any other thing) when the directive's value changes?

No.

-- 
Nico.



^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core)
  2015-11-12  2:11                       ` Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core) Michael Heerdegen
  2015-11-12  2:19                         ` Copyright assignments in Gnu Elpa John Wiegley
  2015-11-12  3:50                         ` Artur Malabarba
@ 2015-11-12 22:31                         ` Richard Stallman
  2015-11-15 14:51                           ` Copyright assignments in Gnu Elpa Andreas Röhler
  2 siblings, 1 reply; 95+ messages in thread
From: Richard Stallman @ 2015-11-12 22:31 UTC (permalink / raw)
  To: Michael Heerdegen; +Cc: emacs-devel

[[[ To any NSA and FBI agents reading my email: please consider    ]]]
[[[ whether defending the US Constitution against all enemies,     ]]]
[[[ foreign or domestic, requires you to follow Snowden's example. ]]]

  > I've never thought about it, but AFAIU all contributors for all external
  > packages in Gnu Elpa need copyright assignments - right?

All those who make nontrivial contributions of code need to have their
work assigned to the FSF, or else disclaimed.

They can do these by signing individual papers, or they may be
covered by employer's papers.

-- 
Dr Richard Stallman
President, Free Software Foundation (gnu.org, fsf.org)
Internet Hall-of-Famer (internethalloffame.org)
Skype: No way! See stallman.org/skype.html.




^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: Copyright assignments in Gnu Elpa
  2015-11-12 22:31                         ` Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core) Richard Stallman
@ 2015-11-15 14:51                           ` Andreas Röhler
  2015-11-16 19:30                             ` Richard Stallman
  0 siblings, 1 reply; 95+ messages in thread
From: Andreas Röhler @ 2015-11-15 14:51 UTC (permalink / raw)
  To: emacs-devel; +Cc: Richard Stallman

  On 12.11.2015 23:31, Richard Stallman wrote:
> [[[ To any NSA and FBI agents reading my email: please consider    ]]]
> [[[ whether defending the US Constitution against all enemies,     ]]]
> [[[ foreign or domestic, requires you to follow Snowden's example. ]]]
>
>    >  I've never thought about it, but AFAIU all contributors for all external
>    >  packages in Gnu Elpa need copyright assignments - right?
>
> All those who make nontrivial contributions of code need to have their
> work assigned to the FSF, or else disclaimed.

Is "else disclaimed" to be understood as signing the disclaimer handed 
out by FSF?
Saying: I'm the author and coyright-owner etc.?

That would be great.




> They can do these by signing individual papers, or they may be
> covered by employer's papers.
>




^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: Copyright assignments in Gnu Elpa
  2015-11-15 14:51                           ` Copyright assignments in Gnu Elpa Andreas Röhler
@ 2015-11-16 19:30                             ` Richard Stallman
  0 siblings, 0 replies; 95+ messages in thread
From: Richard Stallman @ 2015-11-16 19:30 UTC (permalink / raw)
  To: Andreas Röhler; +Cc: emacs-devel

[[[ To any NSA and FBI agents reading my email: please consider    ]]]
[[[ whether defending the US Constitution against all enemies,     ]]]
[[[ foreign or domestic, requires you to follow Snowden's example. ]]]

  > > All those who make nontrivial contributions of code need to have their
  > > work assigned to the FSF, or else disclaimed.

  > Is "else disclaimed" to be understood as signing the disclaimer handed 
  > out by FSF?
  > Saying: I'm the author and coyright-owner etc.?

The contributor can sign either a copyright assignment (which transfers
the copyright to the FSF) or a copyright disclaimer (which says only
"I don't claim any copyright").

This is explained in what we give to contributors to show them
the options for contributing.

-- 
Dr Richard Stallman
President, Free Software Foundation (gnu.org, fsf.org)
Internet Hall-of-Famer (internethalloffame.org)
Skype: No way! See stallman.org/skype.html.




^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
@ 2017-02-15 19:49 Toon Claes
  2017-02-15 19:51 ` John Wiegley
  0 siblings, 1 reply; 95+ messages in thread
From: Toon Claes @ 2017-02-15 19:49 UTC (permalink / raw)
  To: John Wiegley, Emacs Devel

On Mon, 09 Nov 2015 16:02:33 -0800 John Wiegley wrote:
> I'd like to integrate use-package.el into Emacs core, as an alternative for
> package management to those who do not rely on package.el. I know Stefan had
> some reservation, but I think enough people have enjoyed its utility to be
> worth including.
> 
> Are there any objections to moving this into core before the 25.1 freeze?
> 
> John

I was reading through this thread from 2015 and I was wondering what happened
with the plans to integrate use-package.el into the Emacs core?

-- Toon


^ permalink raw reply	[flat|nested] 95+ messages in thread

* Re: use-package.el -> Emacs core
  2017-02-15 19:49 Toon Claes
@ 2017-02-15 19:51 ` John Wiegley
  0 siblings, 0 replies; 95+ messages in thread
From: John Wiegley @ 2017-02-15 19:51 UTC (permalink / raw)
  To: Toon Claes; +Cc: Emacs Devel

>>>>> Toon Claes <toon@iotcl.com> writes:

> I was reading through this thread from 2015 and I was wondering what
> happened with the plans to integrate use-package.el into the Emacs core?

I should have all the copyright assignments from everyone now, I just need to
reserve a weekend to go through them, one by one, and ensure that it's OK to
move the code in. Then I'll need to adapt the documentation to fit within the
Emacs manual.

-- 
John Wiegley                  GPG fingerprint = 4710 CF98 AF9B 327B B80F
http://newartisans.com                          60E1 46C4 BD1A 7AC1 4BA2



^ permalink raw reply	[flat|nested] 95+ messages in thread

end of thread, other threads:[~2017-02-15 19:51 UTC | newest]

Thread overview: 95+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-11-10  0:02 use-package.el -> Emacs core John Wiegley
2015-11-10  0:14 ` Dmitry Gutov
2015-11-10  0:31   ` John Wiegley
2015-11-10  0:40     ` Dmitry Gutov
2015-11-10  7:55     ` Oleh Krehel
2015-11-10 11:52       ` Juanma Barranquero
2015-11-10 12:10         ` Oleh Krehel
2015-11-10 12:23           ` Juanma Barranquero
2015-11-10 12:40             ` Oleh Krehel
2015-11-10 12:47               ` Juanma Barranquero
2015-11-10 15:15                 ` John Wiegley
2015-11-10 15:42                   ` Juanma Barranquero
2015-11-10 15:56                     ` Dmitry Gutov
2015-11-11  0:37                     ` Stephen Leake
2015-11-11  0:56                       ` Juanma Barranquero
2015-11-10 15:55                   ` João Távora
2015-11-10 16:08                     ` John Wiegley
2015-11-10 16:23                   ` Drew Adams
2015-11-10 14:03               ` David Kastrup
2015-11-10 14:15                 ` Oleh Krehel
2015-11-10 14:22                 ` João Távora
2015-11-10 15:17                   ` John Wiegley
2015-11-10 15:46                     ` João Távora
2015-11-10 18:15                       ` John Wiegley
2015-11-10 19:32                         ` João Távora
2015-11-10 19:47                           ` John Wiegley
2015-11-10 21:00                             ` João Távora
2015-11-10 15:56                     ` Kaushal Modi
2015-11-10 18:20                       ` John Wiegley
2015-11-10 18:32                         ` Drew Adams
2015-11-10 18:38                           ` John Wiegley
2015-11-10 18:52                             ` Kaushal Modi
2015-11-10 18:55                               ` John Wiegley
2015-11-10 19:24                             ` Drew Adams
2015-11-10 19:35                               ` John Wiegley
2015-11-10 20:42                                 ` Drew Adams
2015-11-10 12:42             ` Kaushal Modi
2015-11-10 12:46           ` David Kastrup
2015-11-10 13:06             ` Oleh Krehel
2015-11-10 18:15               ` Evgeny Panasyuk
2015-11-10 18:31                 ` Alan Mackenzie
2015-11-10 13:32             ` Wolfgang Jenkner
2015-11-10 15:08               ` Customize is only for newbies? [was: use-package.el -> Emacs core] Drew Adams
2015-11-11  0:01                 ` Wolfgang Jenkner
2015-11-10 14:58           ` Drew Adams
2015-11-10 15:42             ` John Wiegley
2015-11-10  8:49     ` use-package.el -> Emacs core João Távora
2015-11-10  8:57       ` Pedro Silva
2015-11-10  9:45         ` João Távora
2015-11-10 12:01           ` Phillip Lord
2015-11-10 13:37             ` João Távora
2015-11-10 14:07               ` Oleh Krehel
2015-11-10 14:39               ` Nicolas Richard
2015-11-10 14:48                 ` João Távora
2015-11-10 15:40                   ` John Wiegley
2015-11-12 12:43                   ` Nicolas Richard
2015-11-10 17:36               ` Phillip Lord
2015-11-10  0:44 ` Artur Malabarba
2015-11-10  1:05   ` John Wiegley
2015-11-10  1:24     ` Artur Malabarba
2015-11-10  1:37       ` John Wiegley
2015-11-10  3:20         ` Artur Malabarba
2015-11-10  5:37           ` Kaushal Modi
2015-11-10  6:07             ` John Wiegley
2015-11-10 23:27             ` Stephen Leake
2015-11-10 23:32               ` John Wiegley
2015-11-11  9:29                 ` Oleh Krehel
2015-11-11 16:48                   ` John Wiegley
2015-11-11 20:04                     ` Kaushal Modi
2015-11-11 20:10                       ` John Wiegley
2015-11-12  2:11                       ` Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core) Michael Heerdegen
2015-11-12  2:19                         ` Copyright assignments in Gnu Elpa John Wiegley
2015-11-12  3:50                         ` Artur Malabarba
2015-11-12 22:31                         ` Copyright assignments in Gnu Elpa (was: use-package.el -> Emacs core) Richard Stallman
2015-11-15 14:51                           ` Copyright assignments in Gnu Elpa Andreas Röhler
2015-11-16 19:30                             ` Richard Stallman
2015-11-10  1:37 ` use-package.el -> Emacs core Ted Zlatanov
2015-11-10  8:24 ` joakim
2015-11-11  0:29   ` Stephen Leake
2015-11-11  0:45     ` Dmitry Gutov
2015-11-11  9:30       ` Stephen Leake
2015-11-11 10:04         ` Xue Fuqiao
2015-11-11 10:20         ` Artur Malabarba
2015-11-10  8:44 ` Andreas Röhler
2015-11-10  9:29 ` Nicolas Petton
2015-11-11  0:32   ` Stephen Leake
2015-11-11  0:37     ` John Wiegley
2015-11-10 18:21 ` Stephen Leake
2015-11-10 18:34   ` John Wiegley
2015-11-10 19:54     ` Dmitry Gutov
2015-11-10 20:09       ` Kaushal Modi
2015-11-10 20:27         ` John Wiegley
2015-11-11  0:04     ` Stephen Leake
  -- strict thread matches above, loose matches on Subject: below --
2017-02-15 19:49 Toon Claes
2017-02-15 19:51 ` John Wiegley

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).