Avoid scrolling vertically if scrolling area is outside the text rect. Pin parameters in Select() before doing other checks on them (reported by Marc Flerackers)

git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@21511 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Stefano Ceccherini 2007-06-27 10:43:48 +00:00
parent d56eb9cf5d
commit c57ff65839

View File

@ -1369,17 +1369,20 @@ BTextView::Select(int32 startOffset, int32 endOffset)
if (startOffset > endOffset) if (startOffset > endOffset)
return; return;
// pin offsets at reasonable values
if (startOffset < 0)
startOffset = 0;
if (endOffset < 0)
endOffset = 0;
else if (endOffset > fText->Length())
endOffset = fText->Length();
// is the new selection any different from the current selection? // is the new selection any different from the current selection?
if (startOffset == fSelStart && endOffset == fSelEnd) if (startOffset == fSelStart && endOffset == fSelEnd)
return; return;
fStyles->InvalidateNullStyle(); fStyles->InvalidateNullStyle();
// pin offsets at reasonable values
startOffset = (startOffset < 0) ? 0 : startOffset;
endOffset = (endOffset < 0) ? 0 : endOffset;
endOffset = (endOffset > fText->Length()) ? fText->Length() : endOffset;
// hide the caret // hide the caret
if (fCaretVisible) if (fCaretVisible)
InvertCaret(); InvertCaret();
@ -4030,6 +4033,11 @@ BTextView::PerformAutoScrolling()
// TODO: Refine this, I can't even remember how beos works here // TODO: Refine this, I can't even remember how beos works here
scrollBy.y = lineHeight > 0 ? lineHeight * (int32)(floorf(vertDiff) / lineHeight) : 0; scrollBy.y = lineHeight > 0 ? lineHeight * (int32)(floorf(vertDiff) / lineHeight) : 0;
if (bounds.bottom + scrollBy.y > fTextRect.Height())
scrollBy.y = fTextRect.Height() - bounds.bottom;
else if (bounds.top + scrollBy.y < 0)
scrollBy.y = -bounds.top;
if (scrollBy != B_ORIGIN) if (scrollBy != B_ORIGIN)
ScrollBy(scrollBy.x, scrollBy.y); ScrollBy(scrollBy.x, scrollBy.y);
} }