From mboxrd@z Thu Jan  1 00:00:00 1970
Path: news.gmane.io!.POSTED.blaine.gmane.org!not-for-mail
From: Alan Mackenzie <acm@muc.de>
Newsgroups: gmane.emacs.devel
Subject: Re: Why shouldn't we have a #if .... #else .... #endif construct in
 Emacs Lisp?
Date: Thu, 31 Aug 2023 07:50:23 +0000
Message-ID: <ZPBGP5tFOTgFtiD6@ACM>
References: <ZOz3lR_4Al88SEJ_@ACM> <ua5ubq782@gentoo.org>
 <ZOz-Q9RllUkK8ojC@ACM> <u5y4yrida@gentoo.org>
 <ZO0VxowBjg33g8pX@ACM> <E1qbX5M-0003CP-EL@fencepost.gnu.org>
Mime-Version: 1.0
Content-Type: text/plain; charset=us-ascii
Injection-Info: ciao.gmane.io; posting-host="blaine.gmane.org:116.202.254.214";
	logging-data="6997"; mail-complaints-to="usenet@ciao.gmane.io"
Cc: ulm@gentoo.org, emacs-devel@gnu.org
To: Richard Stallman <rms@gnu.org>
Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Thu Aug 31 09:51:48 2023
Return-path: <emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org>
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 <emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org>)
	id 1qbcSy-0001e4-HH
	for ged-emacs-devel@m.gmane-mx.org; Thu, 31 Aug 2023 09:51:48 +0200
Original-Received: from localhost ([::1] helo=lists1p.gnu.org)
	by lists.gnu.org with esmtp (Exim 4.90_1)
	(envelope-from <emacs-devel-bounces@gnu.org>)
	id 1qbcRm-00014R-2k; Thu, 31 Aug 2023 03:50:34 -0400
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 <acm@muc.de>) id 1qbcRk-00014I-Sx
 for emacs-devel@gnu.org; Thu, 31 Aug 2023 03:50:32 -0400
Original-Received: from mail.muc.de ([193.149.48.3])
 by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)
 (Exim 4.90_1) (envelope-from <acm@muc.de>) id 1qbcRf-00012s-U7
 for emacs-devel@gnu.org; Thu, 31 Aug 2023 03:50:32 -0400
Original-Received: (qmail 24126 invoked by uid 3782); 31 Aug 2023 09:50:25 +0200
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=muc.de; i=@muc.de;
 q=dns/txt; s=default; t=1693468225; h=date : to : cc : subject :
 message-id : references : mime-version : content-type : in-reply-to :
 from : from; bh=EhU8+VIkWcAXxgOd3tsqmEbVqpyZ6t3Qh6GX80wOG/8=;
 b=hH7d36L6yXoJBbXQO9PpD2Nz8t4Q1QJIQhRqJI/ey0Zv6mvyzjmm/KCV01brFBJlXYsU7
 ndd47iQFQhuofcrUXvf9ItyyRowxMPX7bSfU/WhwxBJxzUNEG8Ch+HE9KxzA7WtS3U6/2sm
 cpUoTpQHcCnkZZXeT7svczGFsrjnZjkwzqu69phFqlzfgzpXbKILKaaSgw3sjqK/rkpOLia
 PipO3Pp9CtkTpQEtwJNIz+ZbwpjHTtobzG5t4IvRoQZo0ghLz7hDvdEgNQme1rhL0rSer8c
 59aRvYkcfi9UG5W1s8PeVQ3QunTvpKa+XuKuFS4M9IdBy4TGzr64mENhOtcA==
Original-Received: from acm.muc.de (p4fe15975.dip0.t-ipconnect.de [79.225.89.117])
 (using STARTTLS) by colin.muc.de (tmda-ofmipd) with ESMTP;
 Thu, 31 Aug 2023 09:50:23 +0200
Original-Received: (qmail 15473 invoked by uid 1000); 31 Aug 2023 07:50:23 -0000
Content-Disposition: inline
In-Reply-To: <E1qbX5M-0003CP-EL@fencepost.gnu.org>
X-Submission-Agent: TMDA/1.3.x (Ph3nix)
X-Primary-Address: acm@muc.de
Received-SPF: pass client-ip=193.149.48.3; envelope-from=acm@muc.de;
 helo=mail.muc.de
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, SPF_HELO_PASS=-0.001,
 SPF_PASS=-0.001 autolearn=unavailable autolearn_force=no
X-Spam_action: no action
X-BeenThere: emacs-devel@gnu.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: "Emacs development discussions." <emacs-devel.gnu.org>
List-Unsubscribe: <https://lists.gnu.org/mailman/options/emacs-devel>,
 <mailto:emacs-devel-request@gnu.org?subject=unsubscribe>
List-Archive: <https://lists.gnu.org/archive/html/emacs-devel>
List-Post: <mailto:emacs-devel@gnu.org>
List-Help: <mailto:emacs-devel-request@gnu.org?subject=help>
List-Subscribe: <https://lists.gnu.org/mailman/listinfo/emacs-devel>,
 <mailto:emacs-devel-request@gnu.org?subject=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:309604
Archived-At: <http://permalink.gmane.org/gmane.emacs.devel/309604>

Hello, Richard.

On Wed, Aug 30, 2023 at 22:07:04 -0400, 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. ]]]

>   > >     (when (eval-when-compile (< emacs-major-version 24))
>   > >       (defadvice .....))

>   > However, when evaluating the containing defun/defmacro rather than byte
>   > compiling it, the irritating warning message will appear with the e-w-c
>   > strategem, but not with hash-if.  ;-)

> How about making the byte compiler recognize the construct
 
>  (if (< emacs-major-version NUMBER) ...)

> and do this optimization on it?

> I think that will DTRT when compiled and when interpreted,
> and it won't require changes in the code of the programs that use it.

The conditions we want to test are sometimes/frequently expressed in
terms of the (non-)existence of variables, etc.  It would be
inconvenient for package maintainers to have to determine "critical"
Emacs version numbers to use.  Also, it is possible for the condition to
be dependent upon a minor version number, maybe.

Why do you think a more restricted test of the version number would be
better than a more general test?

The changes to the code to convert from `if' to `hash-if' (or
`static-if' as has been proposed) are minor - they just need amending
the if/when/unless forms to hash-if.  Also, there will not be all that
many of them.  That way, we have more flexibility than testing just the
major version number.

> That will handle `when' and `unless', since they expand into `if'.

> It may be necessary to implement this in two places, one for inside of
> function bodies and one for top level (outside of function
> definitions).  But the code for this should be so short that having
> two is hardly much loss.

The macro hash-if itself is very short, the current version taking 13
lines (including doc string), including a condition-case checking for
`eval' having only one parameter.  The idea is that a package maintainer
can copy this directly into her source code (inside an (if (not (fboundp
'hash-if)) ....)) so the mechanism will work also in older Emacsen.

> -- 
> Dr Richard Stallman (https://stallman.org)
> Chief GNUisance of the GNU Project (https://gnu.org)
> Founder, Free Software Foundation (https://fsf.org)
> Internet Hall-of-Famer (https://internethalloffame.org)

-- 
Alan Mackenzie (Nuremberg, Germany).