aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/EditView.cxx
diff options
context:
space:
mode:
authorNeil <nyamatongwe@gmail.com>2022-08-15 17:06:21 +1000
committerNeil <nyamatongwe@gmail.com>2022-08-15 17:06:21 +1000
commitf8236d657fd29f392c3474e96d43a2c73ea216e8 (patch)
treeac214aaad6346a7af948eb43dde77c734fa4e705 /src/EditView.cxx
parentd93312d7c9a65b5a41bc4dbf53e81f98d5f2be1f (diff)
downloadscintilla-mirror-f8236d657fd29f392c3474e96d43a2c73ea216e8.tar.gz
Fix bug where deletion at line end indicated with point disappeared when text
inserted on line. Ensure not using old data by clearing all positions - this was hiding problems because deleted positions were still set.
Diffstat (limited to 'src/EditView.cxx')
-rw-r--r--src/EditView.cxx13
1 files changed, 6 insertions, 7 deletions
diff --git a/src/EditView.cxx b/src/EditView.cxx
index a40c6c3b8..a7b98e233 100644
--- a/src/EditView.cxx
+++ b/src/EditView.cxx
@@ -536,7 +536,7 @@ void EditView::LayoutLine(const EditModel &model, Surface *surface, const ViewSt
segments.push_back(bfLayout.Next());
}
- std::fill(&ll->positions[0], &ll->positions[numCharsInLine], 0.0f);
+ ll->ClearPositions();
if (!segments.empty()) {
@@ -1238,14 +1238,13 @@ static void DrawIndicator(int indicNum, Sci::Position startPos, Sci::Position en
int value, bool bidiEnabled, int tabWidthMinimumPixels) {
const XYPOSITION subLineStart = ll->positions[ll->LineStart(subLine)];
+ const XYPOSITION horizontalOffset = xStart - subLineStart;
std::vector<PRectangle> rectangles;
- const PRectangle rcIndic(
- ll->positions[startPos] + xStart - subLineStart,
- rcLine.top + vsDraw.maxAscent,
- ll->positions[endPos] + xStart - subLineStart,
- rcLine.top + vsDraw.maxAscent + 3);
+ const XYPOSITION left = ll->XInLine(startPos) + horizontalOffset;
+ const XYPOSITION right = ll->XInLine(endPos) + horizontalOffset;
+ const PRectangle rcIndic(left, rcLine.top + vsDraw.maxAscent, right, rcLine.top + vsDraw.maxAscent + 3);
if (bidiEnabled) {
ScreenLine screenLine(ll, subLine, vsDraw, rcLine.right - xStart, tabWidthMinimumPixels);
@@ -1269,7 +1268,7 @@ static void DrawIndicator(int indicNum, Sci::Position startPos, Sci::Position en
// Allow full descent space for character indicators
rcFirstCharacter.bottom = rcLine.top + vsDraw.maxAscent + vsDraw.maxDescent;
if (secondCharacter >= 0) {
- rcFirstCharacter.right = ll->positions[secondCharacter] + xStart - subLineStart;
+ rcFirstCharacter.right = ll->XInLine(secondCharacter) + horizontalOffset;
} else {
// Indicator continued from earlier line so make an empty box and don't draw
rcFirstCharacter.right = rcFirstCharacter.left;