From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.io!.POSTED.blaine.gmane.org!not-for-mail From: =?UTF-8?B?Sm/Do28gVMOhdm9yYQ==?= Newsgroups: gmane.emacs.devel Subject: Re: Distinguishing `consp` and `functionp` Date: Tue, 30 Jan 2024 23:43:38 +0000 Message-ID: References: <86msssble8.fsf@gnu.org> <86bk9448ai.fsf@gnu.org> <864jew40m3.fsf@gnu.org> Mime-Version: 1.0 Content-Type: multipart/alternative; boundary="0000000000002b9954061032553f" Injection-Info: ciao.gmane.io; posting-host="blaine.gmane.org:116.202.254.214"; logging-data="36710"; mail-complaints-to="usenet@ciao.gmane.io" Cc: emacs-devel@gnu.org To: Stefan Monnier Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Wed Jan 31 04:22:43 2024 Return-path: Envelope-to: ged-emacs-devel@m.gmane-mx.org Original-Received: from lists.gnu.org ([209.51.188.17]) by ciao.gmane.io with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1rV1BR-0009FE-Ru for ged-emacs-devel@m.gmane-mx.org; Wed, 31 Jan 2024 04:22:41 +0100 Original-Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1rV1Ak-00040v-0u; Tue, 30 Jan 2024 22:21:58 -0500 Original-Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1rUxlb-0007zA-UA for emacs-devel@gnu.org; Tue, 30 Jan 2024 18:43:47 -0500 Original-Received: from mail-lj1-x232.google.com ([2a00:1450:4864:20::232]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1rUxlZ-0002KY-SD for emacs-devel@gnu.org; Tue, 30 Jan 2024 18:43:47 -0500 Original-Received: by mail-lj1-x232.google.com with SMTP id 38308e7fff4ca-2cf595d5b4aso37928431fa.0 for ; Tue, 30 Jan 2024 15:43:45 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1706658224; x=1707263024; darn=gnu.org; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:from:to:cc:subject:date:message-id:reply-to; bh=C5RsJ7Tb8ZbI4x9/vyyc5JA7Xk0IWPapMYgvoT9zPjg=; b=YldnmQuiRzLLY7vMgx72ZhmnapIjzXSxj/pL30GeViEMDCWmnskglPBfDPP9EQTzzH yFWACVhqAAXb+Di3vbgBrXnCLdkA2dL8dpMnKD8MzgPLRFQX1YuUfRnZ6wM7/3nErGNA z6I90Wi9p4Jdl4bUCyuHaKTLir+y1PQ0Cleu534bXVdnEHhGrHr0W1nnsbnCH/vSS90F 7MsM5g0w9IVhcjqPvKOskYZEh93byyfACvT1jxeuJowUPEKyuTizCtjyIM6IHnWJ7VP1 lFZbSQIax/IB9QOeT7x3Yl3q9Zt3Tv5RHAUzEEd5DJdqMwxfYsTKURnabRkNmFhABM4o ridg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1706658224; x=1707263024; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=C5RsJ7Tb8ZbI4x9/vyyc5JA7Xk0IWPapMYgvoT9zPjg=; b=uvEWx0cFGakBuAqrS1zziSpQiigWYpb1RTfr+6wM7Lho8woj15nSwwLIknBZJnVX7M PHBqtfBJhF1tJDusAzssjZLKO4MXL/m2esJV6yCCZ0HC/pBkpw8kQlD2tnZhyFmJM0ES LafV+v4ngOCFObzenCToEf2bEf6ccrywR4/CFWSweE6+nlqoyl1ltin7WRnE7mrvaeNO Quiniw1QVHluZOiyTd30SNC2XjNJCI4b4XunGzp9MYrMOSHAbTJGA1oG54ZVPtyUB0EB s0h68ieHMOtwrG3CH8hT9haabAP7xOm+wvkcwy2igVIHfGbnVcxRMmdrNRSY7iJ9ZOBT /pzA== X-Gm-Message-State: AOJu0YzZL+vpC6ELfG7b2W0vM1HhiruEhZlA6NnNQs0bxWhwXQgbYLr5 tkqFMdXmPB4kYibiaxI2ztHMWH6bTgmY3MKtbzI94JrDBUrTf5lL+gLMRfd6KPC7fB+fg+RQp6H JVqOne7WIjzNQistqyUfyT1ciP3zfQO3vd54= X-Google-Smtp-Source: AGHT+IFr3LoGcu/w4Ym7EdIKXNOB6gytDCHkWUqC3WqRPp0ff4HOYvWn44YGawYfuc+RmynC49cYh74+3W4iBs6x3+Q= X-Received: by 2002:a2e:9907:0:b0:2cd:a70d:fecb with SMTP id v7-20020a2e9907000000b002cda70dfecbmr1531lji.50.1706658223592; Tue, 30 Jan 2024 15:43:43 -0800 (PST) In-Reply-To: Received-SPF: pass client-ip=2a00:1450:4864:20::232; envelope-from=joaotavora@gmail.com; helo=mail-lj1-x232.google.com X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, FREEMAIL_FROM=0.001, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01 autolearn=ham autolearn_force=no X-Spam_action: no action X-Mailman-Approved-At: Tue, 30 Jan 2024 22:21:54 -0500 X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: "Emacs development discussions." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Original-Sender: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Xref: news.gmane.io gmane.emacs.devel:315650 Archived-At: --0000000000002b9954061032553f Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable On Tue, Jan 30, 2024 at 11:13=E2=80=AFPM Stefan Monnier wrote: E.g. for `eglot-server-programs` it seems that we > will/would suffer because we start by testing `functionp` instead of > first handling the non-function-like lists. Yeah but, I could fix that if I had a time machine :-) Anyway I tend to think it makes the code simpler to get that functionp case out of the way first and it doesn't seem I'm alone. Have you grepped for the words "can also be a function" ? It sure seems to suggest many many others do the same: start by calling functionp. Won't they _all_ be broken if users have been putting lists in those user vars by mistake? > >> We could also consider an intermediate step where `functionp` returns > >> t but emits a warning. > > Indeed, though in that case I'd make the funcall warn. I think it's there > > that this proposed runtime warning ultimately matters and is useful > > to help users correct their elisp. Runtime warnings are a bit icky though > > :-| but better than nothing. > > We already have compile time warnings at those places where the compiler > easily knows that the list should be a function, but for all those other > cases (like `eglot-server-programs`), we don't have any tool currently > other than run-time warnings. Of course. What I'm saying is basically. * Do this patch, it's probably a good step. * keep functionp returning t for those lists for a while (say one major version) to avoid too much fallout. * warn at runtime in the funcall. Then users using these problematic customizations will start fixing their code. We'll probably catch some library doing this too. One thing it'd be nice to have for runtime warnings is some kind of file location hint. Maybe check the calling frame? > >> - it can give a wrong impression to a beginner, encouraging confusion. > >> - it can occasionally hide an error, making debugging a bit more difficult. > > Wouldn't you add "complicates type propagation, static analysis and > > optimization" to that list? > > No. All these can be blissfully unaware of what `funcall` does when > presented with a list starting with `lambda`. In theory, it's true that > analysis&optimization could assume that *after* the `funcall` the > argument was a valid function obeying `functionp`, but I suspect our > analysis/optimization technology is pretty far from that level, and even > if we were able to make that work, the potential for gains from such > information seems vanishingly small. Dunno. SBCL's compiler is pretty good, it propagates types and warns say, when using generic+ instead of must faster fixum+. You can really extract some good perf from it. Our byte-compiler is not advanced enough? Maybe. But what about the native compiler? And shouldn't we be making way for these advances. All in all, I can't see how these fishy funcalls don't amount to anything other than 'eval' in disguise. And though I'm admittedly not as expert in this field as you are, I've always learned 'eval' is known to be nono because of these and other pitfalls. See e.g. this very good Rainer Joswig answer https://stackoverflow.com/a/2571549 (I'm aware you're probably aware of those arguments, just mentioned for others who may be interested). Jo=C3=A3o --0000000000002b9954061032553f Content-Type: text/html; charset="UTF-8" Content-Transfer-Encoding: quoted-printable
On Tue, Jan 30, 2024 at 11:13=E2=80=AFPM Stefan Monnier &l= t;monnier@iro.umontreal.ca&= gt; wrote:

=C2=A0 E.g. for `eglot-server-programs` i= t seems that we
> will/would suffer because we start by testing `fu= nctionp` instead of
> first handling the non-function-like lists.
= =C2=A0
Yeah but, I could fix that if I had a time machine :-)
=
Anyway I tend to think it makes the code simpler to get that functionp= case
out of the way first and it doesn't seem I'm alone.= =C2=A0 Have you grepped for the=C2=A0
words "can also be a f= unction" ? It sure seems to suggest many many others
do the = same: start by calling functionp.=C2=A0 Won't they _all_ be broken if u= sers
have been putting lists in those user vars by mistake?

> >> We could also consider an intermediate step where `fu= nctionp` returns
> >> t but emits a warning.
> > Indee= d, though in that case I'd make the funcall warn. I think it's ther= e
> > that this proposed runtime warning =C2=A0ultimately matters = and is useful
> > to help users correct their elisp. Runtime warni= ngs are a bit icky though
> > :-| but better than nothing.
>=
> We already have compile time warnings at those places where the co= mpiler
> easily knows that the list should be a function, but for all= those other
> cases (like `eglot-server-programs`), we don't hav= e any tool currently
> other than run-time warnings.

Of course= .=C2=A0 What I'm saying is basically. =C2=A0

* Do this patch, it= 's probably a good step.
* keep functionp returning t for those list= s for a while (say one major version)
=C2=A0 to avoid too much fallout. = =C2=A0
* warn at runtime in the funcall.=C2=A0 Then users using the= se problematic=C2=A0
customizations will start fixing=C2=A0 their= code. We'll probably catch some=C2=A0
library doing this too= .

One thing it'd be nice to have for runtime w= arnings is some kind of
file location hint.=C2=A0 Maybe check the= calling frame?

> >> - it can give a wrong impression= to a beginner, encouraging confusion.
> >> - it can occasional= ly hide an error, making debugging a bit more difficult.
> > Would= n't you add "complicates type propagation, static analysis and
= > > optimization" to that list?
>
> No.=C2=A0 All th= ese can be blissfully unaware of what `funcall` does when
> presented= with a list starting with `lambda`.=C2=A0 In theory, it's true that> analysis&optimization could assume that *after* the `funcall` the=
> argument was a valid function obeying `functionp`, but I suspect o= ur
> analysis/optimization technology is pretty far from that level, = and even
> if we were able to make that work, the potential for gains= from such
> information seems vanishingly small.

Dunno.=C2=A0= SBCL's compiler is pretty good, it propagates types =C2=A0and warnssay, when using generic+ instead of must faster fixum+.=C2=A0 You can real= ly
extract =C2=A0some good perf from it.=C2=A0 Our byte-compiler is not= advanced enough?
Maybe.=C2=A0 But what about the native compiler?=C2= =A0 And shouldn't we be making
way for these advances. =C2=A0
All in all, I can't see how these fishy funcalls don't amount to = anything
other than 'eval' in disguise. And though I'm admi= ttedly not as expert in
this field as you are, I've always lea= rned=C2=A0 'eval' is known to be nono=C2=A0
because of th= ese and other pitfalls.=C2=A0 See e.g. this very good Rainer Joswig=C2=A0
answer https://sta= ckoverflow.com/a/2571549 (I'm aware you're probably
aware = of those arguments, just mentioned for others who may be interested).
Jo=C3=A3o
--0000000000002b9954061032553f--