Function: smie-down-list
smie-down-list is an interactive and byte-compiled function defined in
smie.el.gz.
Signature
(smie-down-list &optional ARG)
Documentation
Move forward down one level paren-like blocks. Like down-list.
With argument ARG, do this that many times. A negative argument means move backward but still go down a level. This command assumes point is not in a string or comment.
Key Bindings
Source Code
;; Defined in /usr/src/emacs/lisp/emacs-lisp/smie.el.gz
(defun smie-down-list (&optional arg)
"Move forward down one level paren-like blocks. Like `down-list'.
With argument ARG, do this that many times.
A negative argument means move backward but still go down a level.
This command assumes point is not in a string or comment."
(interactive "p")
(let ((start (point))
(inc (if (< arg 0) -1 1))
(offset (if (< arg 0) 1 0))
(next-token (if (< arg 0)
smie-backward-token-function
smie-forward-token-function)))
(while (/= arg 0)
(setq arg (- arg inc))
(while
(let* ((pos (point))
(token (funcall next-token))
(levels (assoc token smie-grammar)))
(cond
((zerop (length token))
(if (if (< inc 0) (looking-back "\\s(\\|\\s)" (1- (point)))
(looking-at "\\s(\\|\\s)"))
;; Go back to `start' in case of an error. This presumes
;; none of the token we've found until now include a ( or ).
(progn (goto-char start) (down-list inc) nil)
(forward-sexp inc)
(/= (point) pos)))
((and levels (not (numberp (nth (+ 1 offset) levels)))) nil)
((and levels (not (numberp (nth (- 2 offset) levels))))
(let ((end (point)))
(goto-char start)
(signal 'scan-error
(list "Containing expression ends prematurely"
pos end))))
(t)))))))