From: Drew Adams <drew.adams@oracle.com>
To: rms@gnu.org
Cc: emacs-devel@gnu.org
Subject: RE: Should mode commands be idempotent?
Date: Sun, 24 Sep 2017 10:26:57 -0700 (PDT) [thread overview]
Message-ID: <76b52493-ec33-4a95-8378-03500def37de@default> (raw)
In-Reply-To: <<E1dvYUB-0007na-Mx@fencepost.gnu.org>>
> > > Users expect major modes to be idempotent. Any time one is not, it
> > > will cause them surprises. We should treat that as a bug and fix it
> > > to be idempotent.
> >
> > Yes. You're talking about code distributed with Emacs, no doubt.
> >
> > And any 3rd-party library (if there were any) that might have
> > such a mode function would be well advised to make clear to its
> > users that the function is not idempotent, and explain why:
> > what to expect and why.
>
> I think that approach isn't strong enough to give users predictable
> behavior. We should say that all major modes and minor modes are
> idempotent; then, if any fails to be, it will clearly be a bug.
1. Are you talking about a convention only for code
distributed with Emacs? If so, see above. It's fine for
Emacs Dev to consider that a bug. An author/maintainer has
every right to define what "bug" means for their software.
But I think at least some here are talking about a
convention for Emacs _users_ to follow, e.g., for
3rd-party code, not just for code distributed with Emacs.
In that case, I don't see it as appropriate for an Emacs
convention to call out what constitutes a bug.
Certainly, some 3rd-party code might not _intend_ to have
a non-idempotent mode. And in that case, the maintainer
might well prefer to fix that unintentional behavior, as
a bug.
(Some code that tests a mode and lets an author know that it
is in some way not idempotent could be useful in that case.)
But the rule being discussed seems to go beyond saying
only that if your mode doesn't _intend_ to be
non-idempotent then you might want to consider making it
idempotent. We seem to be on the verge of prescribing
non-idempotence as a no-no.
2. Beyond that, just what kind of "idempotence" is in
view? What program state do we expect must be identical
if a mode is turned on more than once? And what do we
mean by "identical" here?
Are we proposing a rule that a mode should not
establish any state that can be preserved and updated
each time the mode is turned on? Or are we proposing
something much less than that?
"Idempotence" is a big word. Just what do folks have
in mind for it, for the proposed rule?
In general it means that an operation "can be applied
multiple times without changing the result beyond the
initial application" (Wikipedia).
Just what do you have in mind wrt what is meant by the
"result" in this context? Program state has lots of
aspects that can be affected by Lisp code, including
code that turns on a mode.
Which parts of the state of an Emacs session - and its
persistent context (e.g, disk files, websites,...) -
would you allow to be changed, i.e., to _not_ be
considered as part of the "result" of turning on a
mode, without violating your idempotence rule?
next prev parent reply other threads:[~2017-09-24 17:26 UTC|newest]
Thread overview: 41+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-09-19 19:58 Should mode commands be idempotent? Philipp Stephani
2017-09-19 22:10 ` Clément Pit-Claudel
2017-09-19 22:29 ` Stefan Monnier
2017-09-20 7:24 ` Clément Pit-Claudel
2017-09-20 14:52 ` John Wiegley
2017-09-20 22:30 ` Stefan Monnier
2017-09-20 23:05 ` Drew Adams
2017-10-08 15:09 ` Philipp Stephani
2017-09-20 22:25 ` Stefan Monnier
2017-09-23 8:16 ` Clément Pit-Claudel
2017-09-23 14:17 ` Stefan Monnier
2017-09-23 20:37 ` Stefan Monnier
2017-09-19 22:58 ` Drew Adams
2017-09-20 3:10 ` Stefan Monnier
2017-09-20 17:52 ` Drew Adams
2017-09-21 1:11 ` Stefan Monnier
2017-09-21 5:22 ` Drew Adams
2017-09-21 18:28 ` Richard Stallman
[not found] ` <<9f11a3c6-b113-4bf6-9dab-f894b2ad77b5@default>
[not found] ` <<E1dv6D1-0006Jr-Fl@fencepost.gnu.org>
2017-09-22 15:54 ` Drew Adams
2017-09-23 0:39 ` Richard Stallman
2017-09-23 8:05 ` Clément Pit-Claudel
2017-09-24 17:26 ` Drew Adams
2017-09-25 7:03 ` Clément Pit-Claudel
2017-09-25 13:57 ` Drew Adams
2017-09-26 0:36 ` Stefan Monnier
2017-09-26 3:30 ` John Wiegley
2017-09-26 17:55 ` Drew Adams
2017-09-26 18:01 ` John Wiegley
2017-09-26 18:50 ` Drew Adams
2017-09-26 18:54 ` John Wiegley
2017-10-08 15:28 ` Philipp Stephani
2017-10-08 19:04 ` Stefan Monnier
2017-10-10 2:10 ` John Wiegley
2017-12-21 20:49 ` Philipp Stephani
2017-12-22 2:20 ` Stefan Monnier
2017-10-10 23:15 ` Herring, Davis
[not found] ` <<E1dvYUB-0007na-Mx@fencepost.gnu.org>
2017-09-24 17:26 ` Drew Adams [this message]
2017-09-25 22:06 ` Richard Stallman
2017-09-19 23:50 ` John Wiegley
2017-09-20 3:09 ` Stefan Monnier
2017-09-20 13:01 ` Richard Stallman
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=76b52493-ec33-4a95-8378-03500def37de@default \
--to=drew.adams@oracle.com \
--cc=emacs-devel@gnu.org \
--cc=rms@gnu.org \
/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.