unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
From: Alan Mackenzie <acm@muc.de>
To: Richard Stallman <rms@gnu.org>
Cc: emacs-devel@gnu.org
Subject: Re: cond* with bug fixed.
Date: Mon, 29 Jan 2024 20:04:51 +0000	[thread overview]
Message-ID: <ZbgE46fMZKvun9mA@ACM> (raw)
In-Reply-To: <E1rUSSB-00030X-4B@fencepost.gnu.org>

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).



  reply	other threads:[~2024-01-29 20:04 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-01-29 14:17 cond* with bug fixed Richard Stallman
2024-01-29 20:04 ` Alan Mackenzie [this message]
2024-02-01  3:49   ` Richard Stallman
2024-02-01  7:45     ` Eli Zaretskii
2024-02-04  4:44       ` 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

  List information: https://www.gnu.org/software/emacs/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=ZbgE46fMZKvun9mA@ACM \
    --to=acm@muc.de \
    --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 public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).