This section describes some routines that understand basic English language forms.
This moves mark count words forward (if positive) or backwards (if
negative). If mark is in the middle of a word, that counts as one. If
there were count (-count if negative) words in the appropriate
direction, this returns mark, otherwise nil. This always moves mark.
A word lies between two characters whose Word Delimiter attribute value
is 1
(see section sys-def-chars).
This moves mark count sentences forward (if positive) or backwards (if negative). If mark is in the middle of a sentence, that counts as one. If there were count (-count if negative) sentences in the appropriate direction, this returns mark, otherwise nil. This always moves mark.
A sentence ends with a character whose Sentence Terminator attribute is
1
followed by two spaces, a newline, or the end of the buffer. The
terminating character is optionally followed by any number of characters whose
Sentence Closing Char attribute is 1
. A sentence begins after a
previous sentence ends, at the beginning of a paragraph, or at the beginning of
the buffer.
&optional
prefix ¶This moves mark count paragraphs forward (if positive) or backwards (if negative). If mark is in the middle of a paragraph, that counts as one. If there were count (-count if negative) paragraphs in the appropriate direction, this returns mark, otherwise nil. This only moves mark if there were enough paragraphs.
Paragraph Delimiter Function holds a function that takes a mark,
typically at the beginning of a line, and returns whether or not the current
line should break the paragraph. default-para-delim-function
returns t
if the next character, the first on the line, has a Paragraph Delimiter
attribute value of 1
. This is typically a space, for an indented
paragraph, or a newline, for a block style. Some modes require a more
complicated determinant; for example, Scribe modes adds some characters
to the set and special cases certain formatting commands.
Prefix defaults to Fill Prefix (see section filling), and the right prefix is necessary to correctly skip paragraphs. If prefix is non-nil, and a line begins with prefix, then the scanning process skips the prefix before invoking the Paragraph Delimiter Function. Note, when scanning for paragraph bounds, and prefix is non-nil, lines are potentially part of the paragraph regardless of whether they contain the prefix; only the result of invoking the delimiter function matters.
The programmer should be aware of an idiom for finding the end of the current
paragraph. Assume paragraphp
is the result of moving mark
one
paragraph, then the following correctly determines whether there actually is a
current paragraph:
(or paragraphp (and (last-line-p mark) (end-line-p mark) (not (blank-line-p (mark-line mark)))))
In this example mark
is at the end of the last paragraph in the buffer, and
there is no last newline character in the buffer. paragraph-offset
would
have returned nil since it could not skip any paragraphs since mark
was at
the end of the current and last paragraph. However, you still have found a
current paragraph on which to operate. mark-paragraph
understands this
problem.
This marks the next or current paragraph, setting mark1 to the beginning and mark2 to the end. This uses Fill Prefix (see section filling). Mark1 is always on the first line of the paragraph, regardless of whether the previous line is blank. Mark2 is typically at the beginning of the line after the line the paragraph ends on, this returns mark2 on success. If this cannot find a paragraph, then the marks are left unmoved, and nil is returned.