From: Alan Mackenzie <acm@muc.de>
To: Dmitry Gutov <dmitry@gutov.dev>
Cc: Eli Zaretskii <eliz@gnu.org>,
stefankangas@gmail.com, emacs-devel@gnu.org
Subject: Re: Installing cond* in core
Date: Sun, 28 Jan 2024 14:32:48 +0000 [thread overview]
Message-ID: <ZbZlkOnQVKPraPKt@ACM> (raw)
In-Reply-To: <6415235c-b06c-41b2-9909-39ecc74a6873@gutov.dev>
Hello, Dmitry.
On Sun, Jan 28, 2024 at 15:48:04 +0200, Dmitry Gutov wrote:
> On 28/01/2024 15:38, Alan Mackenzie wrote:
> > On Sun, Jan 28, 2024 at 15:02:29 +0200, Dmitry Gutov wrote:
> >> On 28/01/2024 14:38, Alan Mackenzie wrote:
> >>> Pretending it didn't happen and failing to discuss it is not healthy for
> >>> the project. Routine bug fixes, and uncontroversial stuff is committed
> >>> without discussion, yes. Otherwise we'd be doing nothing else but silly
> >>> discussions on emacs-devel.
> >> The addition of pcase was a boon for the project.
> > You're missing the point. pcase has flaws, and even now, 14 years
> > later, isn't satisfactorally documented. All you seem to be saying is
> > that pcase is better than no pcase. I'd agree with that.
> > But if pcase were so good, why is Richard writing a better replacement?
> It all started with some people not understanding what pcase does and
> how it works.
I don't think that's true. People understand how it works. Enough
people have difficulty reading and debugging pcase and its numerous
variants to matter.
> We're yet to see whether cond* is any better in those areas.
This is true, but it's highly likely cond* will be better. It's being
designed by an expert designer, and has been through a phase of open
comment and revision. Also, it takes advantage of the experience of
pcase.
[ .... ]
> > That's not the way things happened. pcase was simply installed in
> > Emacs, with all its faults, and then proliferated round Emacs. Where
> > was the room for discussion? Discussion is difficult after something
> > has already been done.
> We're doing it all the time by commenting on commits in an email to
> emacs-devel.
To have been effective, such comment would have resulted in the removal
or fundamental alteration of pcase long after it had been ground into the
core of Emacs. That just wasn't going to happen.
You weren't there at the time. I was. I was completely unaware of pcase
happening, and it was a shock being confronted by it for the first time.
> > If you're trying to say that pcase is better than nothing, so people use
> > it, then I'd agree. But if you're trying to insist it's as good as it
> > could be,
> One does not need to insist on that to disagree with your original
> statements.
You cannot disagree with my original statement made last night. As I
said, you weren't there at the time.
> > I'd ask you why Richard is spending a lot of time crafting a
> > better replacement.
> Rewriting other people's code that one doesn't understand has a long and
> varied history in software development. We even have a term for it.
You're suggesting in that paragraph that the fault lies in Richard's lack
of ability. That's uncalled for. He has trouble reading and
understanding code written with pcase, as do I, and as do others here.
The fault is in pcase; it is flawed. At the same time, it is not doubted
that there are people here fully conversant with pcase. Having such a
split in the project is a bad thing.
--
Alan Mackenzie (Nuremberg, Germany).
next prev parent reply other threads:[~2024-01-28 14:32 UTC|newest]
Thread overview: 52+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-01-27 21:36 Installing cond* in core Stefan Kangas
2024-01-27 23:33 ` Alan Mackenzie
2024-01-28 0:26 ` Stefan Kangas
2024-01-28 2:43 ` Po Lu
2024-01-28 6:46 ` Eli Zaretskii
2024-01-28 7:21 ` Po Lu
2024-01-28 7:32 ` Eli Zaretskii
2024-01-28 6:14 ` Eli Zaretskii
2024-01-28 15:58 ` Alan Mackenzie
2024-01-28 6:09 ` Eli Zaretskii
2024-01-28 12:38 ` Alan Mackenzie
2024-01-28 13:02 ` Dmitry Gutov
2024-01-28 13:38 ` Alan Mackenzie
2024-01-28 13:48 ` Dmitry Gutov
2024-01-28 14:32 ` Alan Mackenzie [this message]
2024-01-28 16:54 ` Dmitry Gutov
2024-01-28 19:14 ` Alan Mackenzie
2024-01-28 19:26 ` Eli Zaretskii
2024-01-28 20:43 ` Dmitry Gutov
2024-01-30 3:56 ` Richard Stallman
2024-01-28 13:19 ` Emanuel Berg
2024-01-28 14:18 ` Eli Zaretskii
2024-01-28 15:26 ` Alan Mackenzie
2024-01-28 15:40 ` Eli Zaretskii
2024-01-30 3:57 ` Richard Stallman
2024-01-28 4:28 ` Stefan Monnier via Emacs development discussions.
2024-01-30 3:58 ` Richard Stallman
2024-01-30 14:33 ` Stefan Monnier
2024-02-02 3:39 ` Richard Stallman
2024-02-02 13:17 ` Stefan Monnier
2024-02-02 15:24 ` Alan Mackenzie
2024-02-02 18:50 ` Stefan Monnier
2024-02-04 4:47 ` Richard Stallman
2024-02-04 14:12 ` Stefan Monnier
2024-02-06 3:49 ` Richard Stallman
2024-02-05 3:33 ` Richard Stallman
2024-02-05 12:39 ` Stefan Monnier
2024-03-13 2:27 ` Richard Stallman
2024-03-13 3:05 ` Stefan Monnier
2024-03-16 1:45 ` Richard Stallman
2024-03-16 16:15 ` Stefan Monnier
2024-03-18 2:42 ` Richard Stallman
2024-03-18 3:06 ` Stefan Monnier
2024-03-19 9:19 ` Peter Hull
2024-03-20 22:40 ` Richard Stallman
2024-03-20 22:54 ` Stefan Monnier
2024-01-28 14:28 ` Emanuel Berg
2024-01-30 3:58 ` Richard Stallman
2024-01-30 13:04 ` Eli Zaretskii
2024-03-16 20:53 ` Lynn Winebarger
2024-03-18 2:41 ` Richard Stallman
2024-03-19 19:48 ` Lynn Winebarger
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=ZbZlkOnQVKPraPKt@ACM \
--to=acm@muc.de \
--cc=dmitry@gutov.dev \
--cc=eliz@gnu.org \
--cc=emacs-devel@gnu.org \
--cc=stefankangas@gmail.com \
/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.