diff options
| author | Neil <nyamatongwe@gmail.com> | 2015-12-31 14:38:45 +1100 | 
|---|---|---|
| committer | Neil <nyamatongwe@gmail.com> | 2015-12-31 14:38:45 +1100 | 
| commit | 50d26808c5fd0421ad0aa7803d39ce3efa2d324c (patch) | |
| tree | 8bde314ca3a90a2c3e392d9e05a308581c116e36 /src | |
| parent | 6e8f80c1ac63d0d25cf9e6a0daca1302b1824722 (diff) | |
| download | scintilla-mirror-50d26808c5fd0421ad0aa7803d39ce3efa2d324c.tar.gz | |
Bug [#1796]. Expand folded areas before deleting fold header line.
Diffstat (limited to 'src')
| -rw-r--r-- | src/Editor.cxx | 23 | 
1 files changed, 15 insertions, 8 deletions
| diff --git a/src/Editor.cxx b/src/Editor.cxx index 58abc37fd..29799534e 100644 --- a/src/Editor.cxx +++ b/src/Editor.cxx @@ -2579,17 +2579,24 @@ void Editor::NotifyModified(Document *, DocModification mh, void *) {  		}  		if ((mh.modificationType & (SC_MOD_BEFOREINSERT | SC_MOD_BEFOREDELETE)) && cs.HiddenLines()) {  			// Some lines are hidden so may need shown. -			// TODO: check if the modified area is hidden. +			const int lineOfPos = pdoc->LineFromPosition(mh.position); +			int endNeedShown = mh.position;  			if (mh.modificationType & SC_MOD_BEFOREINSERT) { -				int lineOfPos = pdoc->LineFromPosition(mh.position); -				const bool insertingNewLine = pdoc->ContainsLineEnd(mh.text, mh.length); -				if (insertingNewLine && (mh.position != pdoc->LineStart(lineOfPos))) -					NeedShown(mh.position, pdoc->LineStart(lineOfPos+1) - mh.position); -				else -					NeedShown(mh.position, 0); +				if (pdoc->ContainsLineEnd(mh.text, mh.length) && (mh.position != pdoc->LineStart(lineOfPos))) +					endNeedShown = pdoc->LineStart(lineOfPos+1);  			} else if (mh.modificationType & SC_MOD_BEFOREDELETE) { -				NeedShown(mh.position, mh.length); +				// Extend the need shown area over any folded lines +				endNeedShown = mh.position + mh.length; +				int lineLast = pdoc->LineFromPosition(mh.position+mh.length); +				for (int line = lineOfPos; line <= lineLast; line++) { +					const int lineMaxSubord = pdoc->GetLastChild(line, -1, -1); +					if (lineLast < lineMaxSubord) { +						lineLast = lineMaxSubord; +						endNeedShown = pdoc->LineEnd(lineLast); +					} +				}  			} +			NeedShown(mh.position, endNeedShown - mh.position);  		}  		if (mh.linesAdded != 0) {  			// Update contraction state for inserted and removed lines | 
