all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Alan Mackenzie <acm@muc.de>
To: Stefan Monnier <monnier@iro.umontreal.ca>
Cc: Juanma Barranquero <lekktu@gmail.com>, emacs-devel@gnu.org
Subject: Re: Interactive hat.
Date: Thu, 26 Mar 2009 15:27:38 +0000	[thread overview]
Message-ID: <20090326152738.GF3358@muc.de> (raw)
In-Reply-To: <jwvtz5g9yyj.fsf-monnier+emacsbugreports@gnu.org>

Hi, Stefan!

On Thu, Mar 26, 2009 at 09:50:27AM -0400, Stefan Monnier wrote:
> > If we're going to be keeping interactive-hat, I think we definitely need
> > some sort of warning to package maintainers to be careful with it, and we
> > should offer them a recipe for maintaining compatibility.

> I think you're blinded by your hatred of this (mis)feature.

Yes, I hate this feature.  But rather than blinding me, this has opened
my eyes to its problems, and I am thus motivated to root them out.  By
contrast, those who like the feature will be blind to these problems.

> It has nothing particularly more special than any other new feature
> we introduced.

Sorry, I disagree.

> Yes, if people use it, they get backward compatibility problems.
> So what?

OK, I'm speaking here as a representative of external package
maintainers, even if not elected.

I don't feel it's appropriate to be so cavalier with external hackers'
time and effort.  More than once, in the past 8 or 9 years, I've asked
myself "what were these idiots thinking about when they implemented
this?".  It's not good to encourage package maintainers to think of the
Emacs core team as idiots, especially since I've become one myself ;-).

It is not a good use of hackers' time and energy to keep reinventing the
wheel.  It isn't fun working round incompatibilities between various
(X)Emacs versions.  Really it isn't.  It's boring, it's drudgery, isn't
at all creative, saps enthusiasm and it diverts effort from adding new
snazzy features.

This particular feature is an order of magnitude nastier to field than
most.  A typical conscientious package maintainer is going to go through
all the thoughts that we've posting on emacs-devel, and most of the time
will come up with some sub-optimal half-solution.  Probably, they'll
just decide not to use "^".  At the end of it all, a weekend's hacking
time per hacker has been lost.

#########################################################################

Anyhow, I've discovered that this problem is not new, and it's already
been solved.  XEmacs put a "_" into their interactive string long ago,
and there's a macro `defunx' in antlr-mode.el which, when used in place
of `defun', strips out the "_" from an interactive string; OK, it does a
few other things, too.

How about adapting this macro and putting it into a special source file
in .../lisp/, and making a discreet mention of it in "Using Interactive"
in the elisp manual?  For example: "Note that using \"^\" will prevent
your function running in older Emacs versions.  If you need this
compatibility, consider using the macro `defunh' in the file
lisp/compatibility.el.".

I would far rather put the work in here and now than have to field
complaints on bug-cc-mode in a year's time, asking why the CC Mode
commands don't work with shift-select-mode.

So, how about it?  This solution will leave interactive-hat, as it is
currently implemented, untouched, and it will stop me moaning about it
for ever.

>         Stefan

-- 
Alan Mackenzie (Nuremberg, Germany).




  reply	other threads:[~2009-03-26 15:27 UTC|newest]

Thread overview: 64+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <20090324154937.GB4657@muc.de>
2009-03-23 22:37 ` bug#2760: CUA-like stuff spuriously enables transient-mark-mode Alan Mackenzie
2009-03-24  0:46   ` Stefan Monnier
2009-03-24 13:52     ` Alan Mackenzie
2009-03-25  1:38       ` Stefan Monnier
2009-03-25 10:16         ` Interactive hat. [Was: CUA-like stuff spuriously enables transient-mark-mode] Alan Mackenzie
2009-03-25 10:30           ` Interactive hat Miles Bader
2009-03-25 10:53             ` Alan Mackenzie
2009-03-25 11:03               ` Lennart Borgman
2009-03-25 14:24                 ` Alan Mackenzie
2009-03-26 11:29                 ` Alan Mackenzie
2009-03-25 14:59               ` Miles Bader
2009-03-26 11:51                 ` Alan Mackenzie
2009-03-26 12:14                   ` David Kastrup
2009-03-26 12:51                     ` Alan Mackenzie
2009-03-26 13:48                   ` Stefan Monnier
2009-03-26 14:33                     ` Alan Mackenzie
2009-03-26 16:30                       ` Stefan Monnier
2009-03-26 16:45                         ` Alan Mackenzie
2009-03-26 18:57                           ` Stefan Monnier
2009-03-29  0:44                             ` Kim F. Storm
2009-03-29  1:40                               ` Miles Bader
2009-03-29  2:02                                 ` Lennart Borgman
2009-03-26 14:47                     ` Stephen J. Turnbull
2009-03-26 15:23                       ` Miles Bader
2009-03-26 17:43                         ` Stephen J. Turnbull
2009-03-25 16:18             ` Stefan Monnier
2009-03-25 11:26           ` Interactive hat. [Was: CUA-like stuff spuriously enables transient-mark-mode] Juanma Barranquero
2009-03-25 13:20             ` Interactive hat Chong Yidong
2009-03-25 14:19             ` Interactive hat. [Was: CUA-like stuff spuriously enables transient-mark-mode] Alan Mackenzie
2009-03-25 16:41               ` Juanma Barranquero
2009-03-26 12:44                 ` Alan Mackenzie
2009-03-26 13:50                   ` Interactive hat Stefan Monnier
2009-03-26 15:27                     ` Alan Mackenzie [this message]
2009-03-26 17:09                       ` Stefan Monnier
2009-03-26 19:06                         ` Alan Mackenzie
2009-03-26 21:18                           ` Stefan Monnier
2009-03-26 22:32                             ` Johan Bockgård
2009-03-26 23:34                               ` Alan Mackenzie
2009-03-26 23:32                             ` Alan Mackenzie
2009-03-27  2:50                               ` Stefan Monnier
2009-03-27 11:15                                 ` Alan Mackenzie
2009-04-13 19:32                                 ` Interactive hat. (Patch) Alan Mackenzie
2009-04-13 20:47                                   ` Eli Zaretskii
2009-04-14 20:15                                     ` Alan Mackenzie
2009-04-14 20:47                                       ` Eli Zaretskii
     [not found]                                     ` <20090423205030.GA2723@muc.de>
2009-04-24 13:38                                       ` Interactive hat. (Patch V2) Eli Zaretskii
2009-04-27 11:46                                         ` Alan Mackenzie
2009-04-27 18:39                                           ` Eli Zaretskii
2009-04-28 22:33                                             ` Alan Mackenzie
2009-04-29  7:22                                               ` Eli Zaretskii
2009-04-29 11:36                                                 ` Alan Mackenzie
2009-04-29 13:13                                                   ` Eli Zaretskii
2009-05-07 19:14                                                     ` Stefan Monnier
2009-04-28  0:14                                           ` Karl Berry
2009-04-28  1:12                                             ` Miles Bader
2009-04-28  7:55                                               ` Eli Zaretskii
2009-04-28 21:44                                               ` Alan Mackenzie
2009-04-28 21:39                                             ` Alan Mackenzie
2009-04-13 22:50                                   ` Interactive hat. (Patch) Miles Bader
2009-04-14 20:22                                     ` Alan Mackenzie
2009-04-14 20:49                                       ` Eli Zaretskii
2009-04-15  8:29                                         ` Stephen J. Turnbull
2009-03-24 15:55   ` bug#2760: marked as done (CUA-like stuff spuriously enables transient-mark-mode.) Emacs bug Tracking System
2009-03-27  0:20 Interactive hat naesten

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20090326152738.GF3358@muc.de \
    --to=acm@muc.de \
    --cc=emacs-devel@gnu.org \
    --cc=lekktu@gmail.com \
    --cc=monnier@iro.umontreal.ca \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this external index

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

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.