From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.io!.POSTED.blaine.gmane.org!not-for-mail From: Alan Mackenzie Newsgroups: gmane.emacs.devel Subject: Re: cond* with bug fixed. Date: Mon, 29 Jan 2024 20:04:51 +0000 Message-ID: References: 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="18439"; mail-complaints-to="usenet@ciao.gmane.io" Cc: emacs-devel@gnu.org To: Richard Stallman Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Mon Jan 29 21:05:58 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 1rUXtG-0004T5-73 for ged-emacs-devel@m.gmane-mx.org; Mon, 29 Jan 2024 21:05:58 +0100 Original-Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1rUXsk-0001gy-7f; Mon, 29 Jan 2024 15:05:28 -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 1rUXsV-0001YC-DV for emacs-devel@gnu.org; Mon, 29 Jan 2024 15:05:14 -0500 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 ) id 1rUXsS-00031J-Ic for emacs-devel@gnu.org; Mon, 29 Jan 2024 15:05:11 -0500 Original-Received: (qmail 85562 invoked by uid 3782); 29 Jan 2024 21:04:52 +0100 Original-Received: from acm.muc.de (pd953a87a.dip0.t-ipconnect.de [217.83.168.122]) (using STARTTLS) by colin.muc.de (tmda-ofmipd) with ESMTP; Mon, 29 Jan 2024 21:04:52 +0100 Original-Received: (qmail 10633 invoked by uid 1000); 29 Jan 2024 20:04:51 -0000 Content-Disposition: inline In-Reply-To: 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: -18 X-Spam_score: -1.9 X-Spam_bar: - X-Spam_report: (-1.9 / 5.0 requ) BAYES_00=-1.9, SPF_HELO_PASS=-0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01 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." 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:315607 Archived-At: Hello, Richard. On Mon, Jan 29, 2024 at 09:17:39 -0500, 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. ]]] > I found the spurious comma in no time after adding a feature to > the byte compiler to warn about spurious calls to comma. > Here's the fixed version of cond-star.el. [ .... ] I proof read it, and there were typos in the doc strings and comments. Also, in the doc string for match*, there's a reference to COND*-EXPENDER with no text explaining it. Should this perhaps be cond*-expAnder? Or is it for a syntactic element which is no longer in cond*? I've put a FIXME!!! into the text at this place. I've included a patch for all the above corrections. Also the "\\>" concatenated onto regular expressions in two places, meaning "end of the text to be matched" which we discussed before, should really be "\\'", as pointed out by Andreas Schwab this morning. I've included corrections for these in the patch, (which I hope are correct). Also I'm very impressed by the clarity of the comments and doc strings. Thanks for putting the effort into these. They should make using cond* and future maintenance much easier than it would otherwise have been. I believe the question of how to commit the new file to the git repository is still open. As Eli noted this morning, I'm willing (and indeed eager) to lend my services for the creation and maintenance of a git branch, should the decision fall that way (and even if it doesn't). I think it would be good to commit cond-star.el soon. Here's the patch: --- stallman.20240129.el 2024-01-29 18:51:38.182384122 +0000 +++ stallman.20240129b.el 2024-01-29 19:48:00.309197752 +0000 @@ -24,8 +24,8 @@ (defmacro cond* (&rest clauses) "Extended form of traditional Lisp `cond' construct. -A `ond*' construct is a series of clauses, and a clause -normally has the form (CONDITION BDOY...). +A `cond*' construct is a series of clauses, and a clause +normally has the form (CONDITION BODY...). CONDITION can be a Lisp expression, as in `cond'. Or it can be `(bind* BINDINGS...)' or `(match* PATTERN DATUM)'. @@ -36,18 +36,18 @@ unconditionally for whatever scope they cover. `(match* PATTERN DATUM)' means to match DATUM against the pattern PATTERN -The condition counts as teue if PATTERN matches DATUM. +The condition counts as true if PATTERN matches DATUM. -Mon=exit clause: +Non-exit clause: If a clause has only one element, or if its first element is -t, or if it starts or ends with the keyword :nn-exit, then +t, or if it starts or ends with the keyword :non-exit, then this clause never exits the `cond*' construct. Instead, control falls through to the next clause (if any). The bindings made for the BODY of the clause are made again for the rest of the clauses in this `cond*' construct. -\\[match*\\] for documention of the patterns for use in `match*'." +\\[match*\\] for documentation of the patterns for use in `match*'." (cond*-convert clauses)) (defmacro match* (pattern datum) @@ -55,13 +55,13 @@ It is not really a LIsp function, and it is meaningful only in the CONDITION of a `cond*' clause. -`_' matvhes any value. +`_' matches any value. KEYWORD matches that keyword. nil matches nil. t matches t. SYMBOL matches any value and binds SYMBOL to that value. If SYMBOL has been matched and bound earlier in this pattern, - it matches here the same value that it mached before. + it matches here the same value that it matched before. REGEXP matches a string if REGEXP matches it. The match must cover the entire string from its first char to its last. ATOM (meaning any other kind of non-list not described above) @@ -70,7 +70,7 @@ as in the function `rx', and matches the data that way. (rx REGEXP SYM0 SYM1...) uses a regexp specified in s-expression form, and binds the symbols SYM0, SYM1, and so on - to (match-string 0 DATUN), (match-string 1 DATUM), and so on. + to (match-string 0 DATUM), (match-string 1 DATUM), and so on. You can use as many SYMs as regexp matching supports. `OBJECT matches any value `equal' to OBJECT. @@ -89,14 +89,16 @@ Strict checking is the default. (cdr-safe PATTERN) matches PATTERN with lax checking of cdrs. That means that `list' patterns do not examine the final cdr. -(and CONJUNCTS...) matches each of te CONJUNCTS against the same data. +(and CONJUNCTS...) matches each of the CONJUNCTS against the same data. If all of them match, this pattern succeeds. If one CONJUNCT fails, this pattern fails and does not try more CONJUNCTS. -(or DISJUNCTS...) matches each of te DISJUNCTS against the same data. - If all of them match, this pattern matches. +(or DISJUNCTS...) matches each of the DISJUNCTS against the same data. + If any of them match, this pattern matches. If one DISJUNCT succeeds, this pattern succeeds - and does not try more DISJUNCT. + and does not try more DISJUNCTS. (COND*-EXPENDER ...) + FIXME!!! Text appears to be missing here, ACM, 2024-01-27. Should that be + cond*-expAnder, perhaps? (PREDICATE SYMBOL) matches datum if (PREDICATE DATUM) is true, then binds SYMBOL to DATUM. @@ -186,7 +188,7 @@ this one could have exited but does not exit. This is used for conditional exit clauses." (if (and uncondit-clauses rest) - (error "Clase is both exiting and non-exit")) + (error "Clause is both exiting and non-exit")) (let ((pat-type (car-safe condition))) (cond ((eq pat-type 'bind*) (let* ((bindings (cdr condition)) @@ -345,15 +347,15 @@ ;;; ??? Probably should optimize the `nth' calls in handling `list'. (defun cond*-subpat (subpat cdr-ignore bindings inside-or backtrack-aliases data) - "Generate code to match ibe subpattern within `match*'. + "Generate code to match the subpattern within `match*'. SUBPAT is the subpattern to handle. CDR-IGNORE if true means don't verify there are no extra elts in a list. BINDINGS is the list of bindings made by the containing and previous subpatterns of this pattern. -Each element of BINDINGS must have the frm (VAR VALUE). +Each element of BINDINGS must have the form (VAR VALUE). BACKTRACK-ALIASES is used to pass data upward. Initial call should pass (list). The cdr of this collects backtracking aliases made for -variables boung within (or...) patterns so that the caller +variables bound within (or...) patterns so that the caller can bind them etc. Each of them has the form (USER-SYMBOL . GENSYM). DATA is the expression for the data that this subpattern is supposed to match against. @@ -409,7 +411,7 @@ (cons bindings `(eql ,subpat ,data))) ;; Regular expressions as strings. ((stringp subpat) - (cons bindings `(string-match ,(concat subpat "\\>") ,data))) + (cons bindings `(string-match ,(concat subpat "\\'") ,data))) ;; All other atoms match with `equal'. ((not (consp subpat)) (cons bindings `(equal ,subpat ,data))) @@ -418,7 +420,7 @@ ;; Regular expressions specified as list structure. ;; (rx REGEXP VARS...) ((eq (car subpat) 'rx) - (let* ((rxpat (concat (rx-to-string (cadr subpat) t) "\\>")) + (let* ((rxpat (concat (rx-to-string (cadr subpat) t) "\\'")) (vars (cddr subpat)) setqs (varnum 0) (match-exp `(string-match ,rxpat ,data))) (if (null vars) @@ -469,7 +471,7 @@ expressions) (setq i (1+ i)) (push (cdr result) expressions))) - ;; Verify that list ends here, if we are suppose to check that. + ;; Verify that list ends here, if we are supposed to check that. (unless cdr-ignore (push `(null (nthcdr ,i ,data)) expressions)) (cons bindings (cond*-and (nreverse expressions))))) @@ -516,7 +518,7 @@ ;; Handle disjunction subpatterns. ((eq (car subpat) 'or) ;; The main complexity is unsetting the pattern variables - ;; that tentatively matches in an or-branch that later failed. + ;; that tentatively match in an or-branch that later failed. (let (expressions (bindings-before-or bindings) (aliases-before-or (cdr backtrack-aliases))) @@ -592,7 +594,7 @@ ;; Process VAR to get a binding for it. (let ((result (cond*-subpat (cadr subpat) cdr-ignore bindings inside-or backtrack-aliases data))) (cons (car result) - ;; This is the test condition + ;; This is the test condition. (cond*-bind-around (car result) (nth 2 subpat))))) (t (byte-compile-warn-x subpat "Undefined pattern type `%s' in `cond*'" (car subpat))))) @@ -642,7 +644,7 @@ (car conjuncts) `(and . ,conjuncts)))) -;; Convert the arguments in a form that calls `backuotelist*' +;; Convert the arguments in a form that calls `backquote-list*' ;; into equivalent args to pass to `list'. ;; We assume the last argument has the form 'LIST. ;; That means quotify each of that list's elements, > -- > 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).