Mercurial > hg > xemacs-beta
diff lisp/lisp.el @ 4724:7eef89a3d41f
Improve docstrings of defun movement functions.
author | Stephen J. Turnbull <stephen@xemacs.org> |
---|---|
date | Fri, 09 Oct 2009 05:10:03 +0900 |
parents | a46d7513a364 |
children | 4bbda1c11a7b |
line wrap: on
line diff
--- a/lisp/lisp.el Wed Oct 07 19:42:42 2009 +0200 +++ b/lisp/lisp.el Fri Oct 09 05:10:03 2009 +0900 @@ -158,30 +158,38 @@ ;; derived stuff from GNU Emacs (defvar beginning-of-defun-function nil - "If non-nil, function for `beginning-of-defun-raw' to call. -This is used to find the beginning of the defun instead of using the -normal recipe (see `beginning-of-defun'). Modes can define this -if defining `defun-prompt-regexp' is not sufficient to handle the mode's -needs.") + "If non-nil, this function will be called by `beginning-of-defun-raw'. +It will be called with one argument, which is a repetition count. +It provides an alternative algorithm to find the beginning of the current +defun instead of using the standard one implemented by `beginning-of-defun'. +See also `defun-prompt-regexp' for minor tweaks.") (make-variable-buffer-local 'beginning-of-defun-function) (defvar end-of-defun-function nil - "If non-nil, function for `end-of-defun' to call. -This is used to find the end of the defun instead of using the normal -recipe (see `end-of-defun'). Modes can define this if the -normal method is not appropriate.") + "If non-nil, this function will be called by `end-of-defun'. +It will be called with no arguments. \(Repetition is implemented in +`end-of-defun' by calling this function that many times.) +This function provides an alternative algorithm to find the end +of the current defun instead of using the standard one implemented by +`end-of-defun'. +") (make-variable-buffer-local 'end-of-defun-function) (defun beginning-of-defun (&optional arg) - "Move backward to the beginning of a defun. + "Move backward to the beginning of the current defun. With argument, do it that many times. Negative arg -N means move forward to Nth following beginning of defun. Returns t unless search stops due to beginning or end of buffer. -Normally a defun starts when there is an char with open-parenthesis -syntax at the beginning of a line. If `defun-prompt-regexp' is -non-nil, then a string which matches that regexp may precede the -open-parenthesis, and point ends up at the beginning of the line." +In the default implementation provided by `beginning-of-defun-raw', +a defun starts at a char with open-parenthesis syntax at the beginning +of a line. If `defun-prompt-regexp' is non-nil, then a string which +matches that regexp may precede the open-parenthesis. Alternatively, +if `beginning-of-defun-function' is non-nil, that function is called, +and none of the default processing is done. + +If the beginning of defun function returns t, point moves to the +beginning of the line containing the beginning of defun." ;; XEmacs change (for zmacs regions) (interactive "_p") (and (beginning-of-defun-raw arg) @@ -214,8 +222,13 @@ "Move forward to next end of defun. With argument, do it that many times. Negative argument -N means move back to Nth preceding end of defun. -An end of a defun occurs right after the close-parenthesis that matches -the open-parenthesis that starts a defun; see `beginning-of-defun'." +In the default implementation, the end of a defun is the end of the +s-expression started at the character identified by `beginning-of-defun'. + +If `end-of-defun-function' is non-nil, none of the default processing is +done. For a repetition count greater than 1, `end-of-defun-function' is +called that many times. If the repetition count is less than 1, nothing +is done. \(This is a bug.)" ;; XEmacs change (for zmacs regions) (interactive "_p") (if (or (null arg) (= arg 0)) (setq arg 1))