* lisp/emacs-lisp/lisp.el (forward-sexp-function): Set back to nil.
authorJuri Linkov <juri@linkov.net>
Wed, 17 Apr 2024 06:53:02 +0000 (09:53 +0300)
committerJuri Linkov <juri@linkov.net>
Wed, 17 Apr 2024 06:53:02 +0000 (09:53 +0300)
(forward-sexp): Revert back to checking 'forward-sexp-function'
for nil (bug#70426).

etc/NEWS
lisp/emacs-lisp/lisp.el
lisp/treesit.el

index 99f33a7b8dd4ce0f093d0c6f00c9104b4381c831..bc8be5577113df7e8aeb1e17f43bf0ee62ac4af3 100644 (file)
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -2103,10 +2103,6 @@ All tree-sitter enabled modes that define 'sentence' in
 
 ** Functions and variables to move by program sexps
 
-*** New function 'forward-sexp-default-function'.
-The previous implementation of 'forward-sexp' is moved into its
-own function, to be bound by 'forward-sexp-function'.
-
 *** New function 'treesit-forward-sexp'.
 Tree-sitter conditionally sets 'forward-sexp-function' for major modes
 that have defined 'sexp' in 'treesit-thing-settings' to enable
index bd0b38db7eafb3b8e8413300d45418fe44129fea..7e6db51b1d5cfb482c30249594d395632a9ea9b9 100644 (file)
@@ -50,7 +50,7 @@ This affects `insert-parentheses' and `insert-pair'."
   (goto-char (or (scan-sexps (point) arg) (buffer-end arg)))
   (if (< arg 0) (backward-prefix-chars)))
 
-(defvar forward-sexp-function #'forward-sexp-default-function
+(defvar forward-sexp-function nil
   ;; FIXME:
   ;; - for some uses, we may want a "sexp-only" version, which only
   ;;   jumps over a well-formed sexp, rather than some dwimish thing
@@ -79,9 +79,9 @@ report errors as appropriate for this kind of usage."
                                     "No next sexp"
                                   "No previous sexp"))))
     (or arg (setq arg 1))
-    (funcall (or forward-sexp-function
-                 #'forward-sexp-default-function)
-             arg)))
+    (if forward-sexp-function
+        (funcall forward-sexp-function arg)
+      (forward-sexp-default-function arg))))
 
 (defun backward-sexp (&optional arg interactive)
   "Move backward across one balanced expression (sexp).
index 2973aba771cd2514359e6a6c3714193548bafc26..2b899a841832394df2d4865a47afca8828ba578d 100644 (file)
@@ -2153,7 +2153,7 @@ by `text' and `sexp' in `treesit-thing-settings'."
   (let ((arg (or arg 1))
         (pred (or treesit-sexp-type-regexp 'sexp)))
     (or (when (treesit-node-match-p (treesit-node-at (point)) 'text t)
-          (funcall #'forward-sexp-default-function arg)
+          (forward-sexp-default-function arg)
           t)
         (if (> arg 0)
             (treesit-end-of-thing pred (abs arg) 'restricted)