changeset 44756:56b4ca0725c1

(line-move-finish): Find beg and end of line before calling line-move-to-column. Do consider intangible when finding the end. Take more care in analyzing the results of intangibility after line-move-to-column.
author Richard M. Stallman <rms@gnu.org>
date Mon, 22 Apr 2002 22:35:46 +0000 (2002-04-22)
parents 52388a234829
children 133c512f02bb
files lisp/simple.el
diffstat 1 files changed, 20 insertions(+), 7 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/simple.el	Mon Apr 22 22:35:45 2002 +0000
+++ b/lisp/simple.el	Mon Apr 22 22:35:46 2002 +0000
@@ -2638,12 +2638,17 @@
       ;; Set REPEAT to t to repeat the whole thing.
       (setq repeat nil)
 
-      ;; Move to the desired column.
-      (line-move-to-column column)
-
-      (let ((new (point))
+      (let (new
 	    (line-beg (save-excursion (beginning-of-line) (point)))
-	    (line-end (save-excursion (end-of-line) (point))))
+	    (line-end
+	     ;; Compute the end of the line
+	     ;; ignoring effectively intangible newlines.
+	     (let ((inhibit-point-motion-hooks nil))
+	       (save-excursion (end-of-line) (point)))))
+
+	;; Move to the desired column.
+	(line-move-to-column column)
+	(setq new (point))
 
 	;; Process intangibility within a line.
 	;; Move to the chosen destination position from above,
@@ -2656,7 +2661,15 @@
 	  ;; If intangibility moves us to a different (later) place
 	  ;; in the same line, use that as the destination.
 	  (if (<= (point) line-end)
-	      (setq new (point))))
+	      (setq new (point))
+	    ;; If that position is "too late",
+	    ;; try the previous allowable position.
+	    ;; See if it is ok.
+	    (backward-char)
+	    (if (<= (point) line-end)
+		(setq new (point))
+	      ;; As a last resort, use the end of the line.
+	      (setq new line-end))))
 
 	;; Now move to the updated destination, processing fields
 	;; as well as intangibility.
@@ -2666,7 +2679,7 @@
 	   (constrain-to-field new opoint nil t
 			       'inhibit-line-move-field-capture)))
 
-	;; If intangibility processing moved us to a different line,
+	;; If all this moved us to a different line,
 	;; retry everything within that new line.
 	(when (or (< (point) line-beg) (> (point) line-end))
 	  ;; Repeat the intangibility and field processing.