Excerpts from William Morgan's message of Sun Aug 23 10:55:59 -0700 2009:
> Reformatted excerpts from Carl Worth's message of 2009-08-19:
> > Specifically, scroll as little as possible to get the current message
> > to just fit on the right side.
> 
> Is this the same as setting loose_alignment to true, and the
> IDEAL_*_CONTENTs to 0?

I don't think so.

Doing that, (at least as in the below patch, for example), always puts
the current message flush left. And that can result in later messages
in the threads, (not descendants of the current thread though), being
cut off on the left. (And all this with dozens of empty columns on the
right of my terminal.) That's precisely the behavior I was getting
before my patch and which I'm trying to change.

What I want instead is for the message to appear in its "natural"
position (according to the threading), unless that would cause the
message to be cut off on the right. In which case, we jump to the
minimum column such that:

        1. We don't cut any of the current message off on the left

        2. We display all of the message on the right, (if possible
           without violating point 1).

I believe that what I've coded achieves that. The two open questions I
still have are:

        A. Is there some simpler way to achieve the result I want with
           some of the existing code?

        B. If not, is some of the existing code rendered obsolete with
           my code in place?

As for (B), for example, with my code in place I don't think there's
any need for a notion of "ideal context". The ideal context is the
natural position of the thread.

And I still haven't figured out what loose_alignment means and which
actions will cause loose vs. non-loose layout.

-Carl

diff --git a/lib/sup/modes/thread-view-mode.rb 
b/lib/sup/modes/thread-view-mode.rb
index dfe30ff..b7bbc7c 100644
--- a/lib/sup/modes/thread-view-mode.rb
+++ b/lib/sup/modes/thread-view-mode.rb
@@ -401,9 +401,9 @@ EOS
     end
   end
 
-  IDEAL_TOP_CONTEXT = 3 # try and give 3 rows of top context
-  IDEAL_LEFT_CONTEXT = 4 # try and give 4 columns of left context
-  def jump_to_message m, loose_alignment=false
+  IDEAL_TOP_CONTEXT = 0 # don't bother trying to give any rows of top context
+  IDEAL_LEFT_CONTEXT = 0 # don't bother trying to give any columns of left 
context
+  def jump_to_message m, loose_alignment=true
     l = @layout[m]
     left = l.depth * INDENT_SPACES
     right = left + l.width

Attachment: signature.asc
Description: PGP signature

_______________________________________________
sup-talk mailing list
sup-talk@rubyforge.org
http://rubyforge.org/mailman/listinfo/sup-talk

Reply via email to