Gnus development mailing list
 help / color / mirror / Atom feed
* 23.1.90; Selective display in Gnus summary broken
@ 2009-12-21 16:59 Andreas Schwab
  2010-01-05 20:41 ` Andreas Schwab
  0 siblings, 1 reply; 3+ messages in thread
From: Andreas Schwab @ 2009-12-21 16:59 UTC (permalink / raw)
  To: emacs-pretest-bug; +Cc: ding

Selective display in the Gnus summary buffer does not work correctly any
more since it is using overlays (2009-10-14 change of Stefan Monnier).
If you hide all threads (T H) in a threaded display while on a thread
where the previous thread consists of more than one message the previous
thread is displayed as "..."  instead of the summary line.

Andreas.

-- 
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 58CA 54C7 6D53 942B 1756  01D3 44D5 214B 8276 4ED5
"And now for something completely different."



^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: 23.1.90; Selective display in Gnus summary broken
  2009-12-21 16:59 23.1.90; Selective display in Gnus summary broken Andreas Schwab
@ 2010-01-05 20:41 ` Andreas Schwab
  2010-01-06  0:10   ` Katsumi Yamaoka
  0 siblings, 1 reply; 3+ messages in thread
From: Andreas Schwab @ 2010-01-05 20:41 UTC (permalink / raw)
  To: emacs-pretest-bug; +Cc: ding

I have now checked this patch into the emacs repo to fix the bug.

Andreas.

2010-01-05  Andreas Schwab  <schwab@linux-m68k.org>

	* gnus-sum.el (gnus-forward-line-ignore-invisible): New function.
	(gnus-summary-recenter): Use it instead of forward-line.  (Bug#5257)

=== modified file 'lisp/gnus/gnus-sum.el'
--- lisp/gnus/gnus-sum.el	2010-01-04 05:35:18 +0000
+++ lisp/gnus/gnus-sum.el	2010-01-05 20:29:46 +0000
@@ -6727,6 +6727,26 @@ Also do horizontal recentering."
 
 (put 'gnus-recenter 'isearch-scroll t)
 
+(defun gnus-forward-line-ignore-invisible (n)
+  "Move N lines forward (backward if N is negative).
+Like forward-line, but skip over (and don't count) invisible lines."
+  (let (done)
+    (while (and (> n 0) (not done))
+      ;; If the following character is currently invisible,
+      ;; skip all characters with that same `invisible' property value.
+      (while (invisible-p (point))
+	(goto-char (next-char-property-change (point))))
+      (forward-line 1)
+      (if (eobp)
+	  (setq done t)
+	(setq n (1- n))))
+    (while (and (< n 0) (not done))
+      (forward-line -1)
+      (if (bobp) (setq done t)
+	(setq n (1+ n))
+	(while (and (not (bobp)) (invisible-p (1- (point))))
+	  (goto-char (previous-char-property-change (point))))))))
+    
 (defun gnus-summary-recenter ()
   "Center point in the summary window.
 If `gnus-auto-center-summary' is nil, or the article buffer isn't
@@ -6742,16 +6762,19 @@ displayed, no centering will be performe
 			     gnus-auto-center-summary
                            (/ (1- (window-height)) 2)))))
 	   (height (1- (window-height)))
-	   (bottom (save-excursion (goto-char (point-max))
-				   (forward-line (- height))
-				   (point)))
+	   (bottom (save-excursion
+		     (goto-char (point-max))
+		     (gnus-forward-line-ignore-invisible (- height))
+		     (point)))
 	   (window (get-buffer-window (current-buffer))))
       (when (get-buffer-window gnus-article-buffer)
 	;; Only do recentering when the article buffer is displayed,
 	;; Set the window start to either `bottom', which is the biggest
 	;; possible valid number, or the second line from the top,
 	;; whichever is the least.
-	(let ((top-pos (save-excursion (forward-line (- top)) (point))))
+	(let ((top-pos (save-excursion
+			 (gnus-forward-line-ignore-invisible (- top))
+			 (point))))
 	  (if (> bottom top-pos)
 	      ;; Keep the second line from the top visible
 	      (set-window-start window top-pos)
@@ -6760,12 +6783,12 @@ displayed, no centering will be performe
 	    ;; visible, or revert to using TOP-POS.
 	    (save-excursion
 	      (goto-char (point-max))
-	      (forward-line -1)
+	      (gnus-forward-line-ignore-invisible -1)
 	      (let ((last-line-start (point)))
 		(goto-char bottom)
 		(set-window-start window (point) t)
 		(when (not (pos-visible-in-window-p last-line-start window))
-		  (forward-line 1)
+		  (gnus-forward-line-ignore-invisible 1)
 		  (set-window-start window (min (point) top-pos) t)))))))
       ;; Do horizontal recentering while we're at it.
       (when (and (get-buffer-window (current-buffer) t)


-- 
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 58CA 54C7 6D53 942B 1756  01D3 44D5 214B 8276 4ED5
"And now for something completely different."



^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: 23.1.90; Selective display in Gnus summary broken
  2010-01-05 20:41 ` Andreas Schwab
@ 2010-01-06  0:10   ` Katsumi Yamaoka
  0 siblings, 0 replies; 3+ messages in thread
From: Katsumi Yamaoka @ 2010-01-06  0:10 UTC (permalink / raw)
  To: Andreas Schwab; +Cc: emacs-pretest-bug, ding

>>>>> Andreas Schwab wrote:
> I have now checked this patch into the emacs repo to fix the bug.

> Andreas.

> 2010-01-05  Andreas Schwab  <schwab@linux-m68k.org>

> 	* gnus-sum.el (gnus-forward-line-ignore-invisible): New function.
> 	(gnus-summary-recenter): Use it instead of forward-line.  (Bug#5257)

I've replaced `invisible-p', `next-char-property-change' and
`previous-char-property-change' with the `gnus-' prefixed ones
installed in gnus-util.el for the compatibility with various
Emacs versions that Gnus supports.  Thanks.



^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2010-01-06  0:10 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2009-12-21 16:59 23.1.90; Selective display in Gnus summary broken Andreas Schwab
2010-01-05 20:41 ` Andreas Schwab
2010-01-06  0:10   ` Katsumi Yamaoka

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).