aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/Editor.cxx
diff options
context:
space:
mode:
authornyamatongwe <unknown>2009-07-08 00:14:41 +0000
committernyamatongwe <unknown>2009-07-08 00:14:41 +0000
commitec28516b5908c2aabd5c7381af65e79ef2dc7fff (patch)
tree40fb06f7739fb74955b5185bc9b7f4e58021b4c2 /src/Editor.cxx
parenta8253c4498fe0ca70458d03b86315b728988d08e (diff)
downloadscintilla-mirror-ec28516b5908c2aabd5c7381af65e79ef2dc7fff.tar.gz
Moved calculation of rectangular range from occurring after every style
change to after the styles have been valided. Previously was very slow when setting monospaced font mode. Made more code sensitive to virtual spaces to draw caret and selection more accurately.
Diffstat (limited to 'src/Editor.cxx')
-rw-r--r--src/Editor.cxx4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/Editor.cxx b/src/Editor.cxx
index eeee752a8..f1210e8c9 100644
--- a/src/Editor.cxx
+++ b/src/Editor.cxx
@@ -225,7 +225,6 @@ void Editor::InvalidateStyleData() {
palette.Release();
llc.Invalidate(LineLayout::llInvalid);
posCache.Clear();
- SetRectangularRange();
}
void Editor::InvalidateStyleRedraw() {
@@ -258,6 +257,7 @@ void Editor::RefreshStyleData() {
wrapAddIndent = vs.aveCharWidth; // must indent to show start visual
}
SetScrollBars();
+ SetRectangularRange();
}
}
@@ -3077,7 +3077,7 @@ void Editor::DrawCarets(Surface *surface, ViewStyle &vsDraw, int lineDoc, int xS
if (widthOverstrikeCaret < 3) // Make sure its visible
widthOverstrikeCaret = 3;
- if (offset > ll->LineStart(subLine))
+ if (posCaret > SelectionPosition(ll->LineStart(subLine) + rangeLine.start))
caretWidthOffset = 1; // Move back so overlaps both character cells.
if (posDrag.IsValid()) {
/* Dragging text, use a line caret */