diff options
| author | Neil <nyamatongwe@gmail.com> | 2014-05-01 10:51:55 +1000 | 
|---|---|---|
| committer | Neil <nyamatongwe@gmail.com> | 2014-05-01 10:51:55 +1000 | 
| commit | d4240cac256a9fc8e49e127a602a8ec6e47ba067 (patch) | |
| tree | b95f529ed4a663877831868f4cbce56e65ad1cbe /src/Editor.cxx | |
| parent | 87c435a58c291770bedbc1302a86dacff14cac4f (diff) | |
| download | scintilla-mirror-d4240cac256a9fc8e49e127a602a8ec6e47ba067.tar.gz | |
Consolidate insertion for paste into Editor class and perform line end
conversion in Editor.
Diffstat (limited to 'src/Editor.cxx')
| -rw-r--r-- | src/Editor.cxx | 39 | 
1 files changed, 36 insertions, 3 deletions
| diff --git a/src/Editor.cxx b/src/Editor.cxx index 2ad5f5863..b690d8011 100644 --- a/src/Editor.cxx +++ b/src/Editor.cxx @@ -4152,8 +4152,9 @@ void Editor::AddCharUTF(char *s, unsigned int len, bool treatAsDBCS) {  	}  } -void Editor::InsertPaste(SelectionPosition selStart, const char *text, int len) { +void Editor::InsertPaste(const char *text, int len) {  	if (multiPasteMode == SC_MULTIPASTE_ONCE) { +		SelectionPosition selStart = sel.Start();  		selStart = SelectionPosition(InsertSpace(selStart.Position(), selStart.VirtualSpace()));  		const int lengthInserted = pdoc->InsertString(selStart.Position(), text, len);  		if (lengthInserted > 0) { @@ -4186,6 +4187,35 @@ void Editor::InsertPaste(SelectionPosition selStart, const char *text, int len)  	}  } +void Editor::InsertPasteShape(const char *text, int len, PasteShape shape) { +	std::string convertedText; +	if (convertPastes) { +		// Convert line endings of the paste into our local line-endings mode +		convertedText = Document::TransformLineEnds(text, len, pdoc->eolMode); +		len = static_cast<int>(convertedText.length()); +		text = convertedText.c_str(); +	} +	if (shape == pasteRectangular) { +		PasteRectangular(sel.Start(), text, len); +	} else { +		if (shape == pasteLine) { +			int insertPos = pdoc->LineStart(pdoc->LineFromPosition(sel.MainCaret())); +			int lengthInserted = pdoc->InsertString(insertPos, text, len); +			// add the newline if necessary +			if ((len > 0) && (text[len - 1] != '\n' && text[len - 1] != '\r')) { +				const char *endline = StringFromEOLMode(pdoc->eolMode); +				int length = static_cast<int>(strlen(endline)); +				lengthInserted += pdoc->InsertString(insertPos + lengthInserted, endline, length); +			} +			if (sel.MainCaret() == insertPos) { +				SetEmptySelection(sel.MainCaret() + lengthInserted); +			} +		} else { +			InsertPaste(text, len); +		} +	} +} +  void Editor::ClearSelection(bool retainMultipleSelections) {  	if (!sel.IsRectangular() && !retainMultipleSelections)  		FilterSelections(); @@ -6150,14 +6180,17 @@ void Editor::DropAt(SelectionPosition position, const char *value, size_t length  		}  		position = positionAfterDeletion; +		std::string convertedText = Document::TransformLineEnds(value, lengthValue, pdoc->eolMode); +  		if (rectangular) { -			PasteRectangular(position, value, static_cast<int>(lengthValue)); +			PasteRectangular(position, convertedText.c_str(), static_cast<int>(convertedText.length()));  			// Should try to select new rectangle but it may not be a rectangle now so just select the drop position  			SetEmptySelection(position);  		} else {  			position = MovePositionOutsideChar(position, sel.MainCaret() - position.Position());  			position = SelectionPosition(InsertSpace(position.Position(), position.VirtualSpace())); -			const int lengthInserted = pdoc->InsertString(position.Position(), value, static_cast<int>(lengthValue)); +			const int lengthInserted = pdoc->InsertString( +				position.Position(), convertedText.c_str(), static_cast<int>(convertedText.length()));  			if (lengthInserted > 0) {  				SelectionPosition posAfterInsertion = position;  				posAfterInsertion.Add(lengthInserted); | 
