diff options
| author | nyamatongwe <unknown> | 2001-12-20 07:28:44 +0000 | 
|---|---|---|
| committer | nyamatongwe <unknown> | 2001-12-20 07:28:44 +0000 | 
| commit | 7ba0c2b34a959f5980fe25e3bdfbafcdca17062d (patch) | |
| tree | f4a96a8934abc4e9c97a570befe1cfa6c9273332 /src/Editor.cxx | |
| parent | 4eefbc39519d93c5c2857ccd61299909d021c640 (diff) | |
| download | scintilla-mirror-7ba0c2b34a959f5980fe25e3bdfbafcdca17062d.tar.gz | |
Increased allocations for laying out and wrapping lines to allow 16000
characters and 400 lines.
Optimised display by reusing a LineLayout for all the visible lines of a
document line.
Fixed some processing of multi-byte and UTF-8 characters so that, for
example, performing a rectangular selection does not select partial
characters.
Diffstat (limited to 'src/Editor.cxx')
| -rw-r--r-- | src/Editor.cxx | 16 | 
1 files changed, 11 insertions, 5 deletions
| diff --git a/src/Editor.cxx b/src/Editor.cxx index 439e1388d..dbf517c50 100644 --- a/src/Editor.cxx +++ b/src/Editor.cxx @@ -305,7 +305,7 @@ int Editor::PositionFromLocation(Point pt) {  			for (int i = lineStart; i < lineEnd; i++) {  				if (pt.x < (((ll.positions[i] + ll.positions[i + 1]) / 2) - subLineStart) ||  					ll.chars[i] == '\r' || ll.chars[i] == '\n') { -					return i + posLineStart; +					return pdoc->MovePositionOutsideChar(i + posLineStart, 1);  				}  			}  			return lineEnd + posLineStart; @@ -350,7 +350,7 @@ int Editor::PositionFromLocationClose(Point pt) {  			for (int i = lineStart; i < lineEnd; i++) {  				if (pt.x < (((ll.positions[i] + ll.positions[i + 1]) / 2) - subLineStart) ||  					ll.chars[i] == '\r' || ll.chars[i] == '\n') { -					return i + posLineStart; +					return pdoc->MovePositionOutsideChar(i + posLineStart, 1);  				}  			}  		} @@ -359,6 +359,8 @@ int Editor::PositionFromLocationClose(Point pt) {  	return INVALID_POSITION;  } +// Find the document position corresponding to an x coordinate on a particular document line. +// Ensure is between whole characters when document is in multi-byte or UTF-8 mode.  int Editor::PositionFromLineX(int lineDoc, int x) {  	RefreshStyleData();  	if (lineDoc >= pdoc->LinesTotal()) @@ -377,7 +379,7 @@ int Editor::PositionFromLineX(int lineDoc, int x) {  		for (int i = lineStart; i < lineEnd; i++) {  			if (x < (((ll.positions[i] + ll.positions[i + 1]) / 2) - subLineStart) ||  				ll.chars[i] == '\r' || ll.chars[i] == '\n') { -				return i + posLineStart; +				return pdoc->MovePositionOutsideChar(i + posLineStart, 1);  			}  		} @@ -1540,6 +1542,8 @@ void Editor::Paint(Surface *surfaceWindow, PRectangle rcArea) {  		double durLayout = 0.0;  		double durPaint = 0.0;  		double durCopy = 0.0; +		int lineDocPrevious = -1;	// Used to avoid laying out one document line multiple times +		LineLayout ll;  		while (visibleLine < cs.LinesDisplayed() && yposScreen < rcArea.bottom) {  			int lineDoc = cs.DocFromDisplay(visibleLine); @@ -1551,9 +1555,11 @@ void Editor::Paint(Surface *surfaceWindow, PRectangle rcArea) {  			// Copy this line and its styles from the document into local arrays  			// and determine the x position at which each character starts. -			LineLayout ll;  			ElapsedTime et; -			LayoutLine(lineDoc, surface, vs, ll, wrapWidth); +			if (lineDoc != lineDocPrevious) { +				LayoutLine(lineDoc, surface, vs, ll, wrapWidth); +				lineDocPrevious = lineDoc; +			}  			durLayout += et.Duration(true);  			ll.selStart = SelectionStart(lineDoc); | 
