diff options
| author | nyamatongwe <devnull@localhost> | 2001-04-03 12:45:38 +0000 | 
|---|---|---|
| committer | nyamatongwe <devnull@localhost> | 2001-04-03 12:45:38 +0000 | 
| commit | a1e68d0148853c74ec7f8cb0b10a5f810a0262b5 (patch) | |
| tree | 9af75d238ed93765984a8d5c3663c6b88ffac1f5 /src/Editor.cxx | |
| parent | 8a44372b918d6bf8fcfa238633a38d7dac4c0dd6 (diff) | |
| download | scintilla-mirror-a1e68d0148853c74ec7f8cb0b10a5f810a0262b5.tar.gz | |
Regular expression find support.
Diffstat (limited to 'src/Editor.cxx')
| -rw-r--r-- | src/Editor.cxx | 30 | 
1 files changed, 19 insertions, 11 deletions
| diff --git a/src/Editor.cxx b/src/Editor.cxx index afc127c07..479157e39 100644 --- a/src/Editor.cxx +++ b/src/Editor.cxx @@ -2458,13 +2458,17 @@ void Editor::Indent(bool forwards) {  long Editor::FindText(unsigned int iMessage, unsigned long wParam, long lParam) {  	TextToFind *ft = reinterpret_cast<TextToFind *>(lParam); +	int lengthFound = strlen(ft->lpstrText);  	int pos = pdoc->FindText(ft->chrg.cpMin, ft->chrg.cpMax, ft->lpstrText, -	                         wParam & SCFIND_MATCHCASE, wParam & SCFIND_WHOLEWORD, -	                         wParam & SCFIND_WORDSTART); +		wParam & SCFIND_MATCHCASE,  +		wParam & SCFIND_WHOLEWORD, +		wParam & SCFIND_WORDSTART, +		wParam & SCFIND_REGEXP, +		&lengthFound);  	if (pos != -1) {  		if (iMessage != EM_FINDTEXT) {  			ft->chrgText.cpMin = pos; -			ft->chrgText.cpMax = pos + strlen(ft->lpstrText); +			ft->chrgText.cpMax = pos + lengthFound;  		}  	}  	return pos; @@ -2489,21 +2493,25 @@ void Editor::SearchAnchor() {  long Editor::SearchText(unsigned int iMessage, unsigned long wParam, long lParam) {  	const char *txt = reinterpret_cast<char *>(lParam);  	int pos; - +	int lengthFound = strlen(txt);  	if (iMessage == SCI_SEARCHNEXT) {  		pos = pdoc->FindText(searchAnchor, pdoc->Length(), txt, -		                     wParam & SCFIND_MATCHCASE, -		                     wParam & SCFIND_WHOLEWORD, -		                     wParam & SCFIND_WORDSTART); +					wParam & SCFIND_MATCHCASE, +					wParam & SCFIND_WHOLEWORD, +					wParam & SCFIND_WORDSTART, +					wParam & SCFIND_REGEXP, +					&lengthFound);  	} else {  		pos = pdoc->FindText(searchAnchor, 0, txt, -		                     wParam & SCFIND_MATCHCASE, -		                     wParam & SCFIND_WHOLEWORD, -		                     wParam & SCFIND_WORDSTART); +					wParam & SCFIND_MATCHCASE, +					wParam & SCFIND_WHOLEWORD, +					wParam & SCFIND_WORDSTART, +					wParam & SCFIND_REGEXP, +					&lengthFound);  	}  	if (pos != -1) { -		SetSelection(pos, pos + strlen(txt)); +		SetSelection(pos, pos + lengthFound);  	}  	return pos; | 
