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:
parent
d56eb9cf5d
commit
c57ff65839
@ -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);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user