# HG changeset patch # User Stefan Monnier # Date 973856620 0 # Node ID 2c0585b6e6d616c279b67da83a2005100c048b2c # Parent 246e375abefb525907a75e16a08667a277424e36 (fill-indent-according-to-mode): New var. (fill-region-as-paragraph): Use it. diff -r 246e375abefb -r 2c0585b6e6d6 lisp/textmodes/fill.el --- a/lisp/textmodes/fill.el Fri Nov 10 11:37:09 2000 +0000 +++ b/lisp/textmodes/fill.el Fri Nov 10 11:43:40 2000 +0000 @@ -120,6 +120,9 @@ :type 'function :group 'fill) +(defvar fill-indent-according-to-mode nil + "Whether or not filling should try to use the major mode's indentation.") + (defun current-fill-column () "Return the fill-column to use for this line. The fill-column to use for a buffer is stored in the variable `fill-column', @@ -193,7 +196,7 @@ (defun fill-common-string-prefix (s1 s2) "Return the longest common prefix of strings S1 and S2, or nil if none." (let ((cmp (compare-strings s1 nil nil s2 nil nil))) - (if (eq cmp t) + (if (eq cmp t) s1 (setq cmp (1- (abs cmp))) (unless (zerop cmp) @@ -380,10 +383,10 @@ (backward-char 1) (setq oneleft t))) (setq to (point)) -;;; ;; If there was no newline, and there is text in the paragraph, then -;;; ;; create a newline. -;;; (if (and (not oneleft) (> to from-plus-indent)) -;;; (newline)) + ;; ;; If there was no newline, and there is text in the paragraph, then + ;; ;; create a newline. + ;; (if (and (not oneleft) (> to from-plus-indent)) + ;; (newline)) (goto-char from-plus-indent)) (if (not (> to (point))) @@ -642,7 +645,13 @@ ;; Give newline the properties of the space(s) it replaces (set-text-properties (1- (point)) (point) (text-properties-at (point))) - (indent-to-left-margin) + (if (or fill-prefix + (not fill-indent-according-to-mode) + (memq indent-line-function + ;; Brain dead "indenting" functions. + '(indent-relative-maybe indent-relative))) + (indent-to-left-margin) + (indent-according-to-mode)) ;; Insert the fill prefix after indentation. ;; Set prefixcol so whitespace in the prefix won't get lost. (and fill-prefix (not (equal fill-prefix ""))