diff options
| author | nyamatongwe <devnull@localhost> | 2001-04-08 13:16:15 +0000 | 
|---|---|---|
| committer | nyamatongwe <devnull@localhost> | 2001-04-08 13:16:15 +0000 | 
| commit | 2c7b080289c003a3efde4d8fed68eb1be0117baf (patch) | |
| tree | 1509ff9648651261328f5b4a5ead8ec57029dc3d /src | |
| parent | 031fdca93e03464d541a3255a92a7b5603b14a50 (diff) | |
| download | scintilla-mirror-2c7b080289c003a3efde4d8fed68eb1be0117baf.tar.gz | |
Removed old unused code from SString.
Added method to change resize behaviour.
Added detach() method to take over ownership of buffer.
Cleaned up naming.
Removed WordAccumulator class from PropSet as SString can do it all now.
Diffstat (limited to 'src')
| -rw-r--r-- | src/PropSet.cxx | 58 | 
1 files changed, 8 insertions, 50 deletions
| diff --git a/src/PropSet.cxx b/src/PropSet.cxx index 5f4e20a1c..d0722f632 100644 --- a/src/PropSet.cxx +++ b/src/PropSet.cxx @@ -560,48 +560,6 @@ static unsigned int LengthWord(const char *word, char otherSeparator) {  }  /** - * Accumulate words in a space separated string - */ -class WordAccumulator { -	/// How many characters will be pre-allocated (to avoid buffer reallocation on each new word) -	enum {wordChunk = 1000}; -	/// Length of the returned buffer of words (string) -	unsigned int length;  -	/// Allocated size of the buffer -	unsigned int size; -public: -	/// Buffer for the words returned - this must be freed by client using delete[]. -	char *buffer;  -	WordAccumulator() : length(0), size(wordChunk), buffer(0) { -		buffer = new char[size]; -		if (buffer) -			buffer[0] = '\0'; -	} -	void Append(const char *word, unsigned int wordLen) { -		if (!buffer) -			return; -		unsigned int newLength = length + wordLen; // stretch the buffer -		if (length) -			newLength++; -		if (newLength >= size) { -			unsigned int newSize = (((newLength+1) / wordChunk) + 1) * wordChunk; -			char *newBuffer = new char[newSize]; -			if (!newBuffer) -				return; -			memcpy(newBuffer, buffer, length); -			delete []buffer; -			buffer = newBuffer; -			size = newSize; -		} -		if (length) // append a new entry -			buffer[length++] = ' '; -		memcpy(buffer + length, word, wordLen); -		length = newLength; -		buffer[length] = '\0'; -	} -}; - -/**   * Returns elements (first words of them) of the wordlist array which have   * the same beginning as the passed string.   * The length of the word to compare is passed too. @@ -617,7 +575,8 @@ char *WordList::GetNearestWords(  	bool ignoreCase /*= false*/,   	char otherSeparator /*= '\0'*/) {  	int wordlen; // length of the word part (before the '(' brace) of the api array element -	WordAccumulator wordsNear; +	SString wordsNear; +	wordsNear.setsizegrowth(1000);  	int start = 0; // lower bound of the api array block to search  	int end = len - 1; // upper bound of the api array block to search  	int pivot; // index of api array element just being compared @@ -640,7 +599,7 @@ char *WordList::GetNearestWords(  				oldpivot = pivot;  				do { // browse sequentially the rest after the hit  					wordlen = LengthWord(word, otherSeparator) + 1; -					wordsNear.Append(word, wordlen); +					wordsNear.append(word, wordlen, ' ');  					if (++pivot > end)  						break;  					word = wordsNoCase[pivot]; @@ -654,9 +613,9 @@ char *WordList::GetNearestWords(  					if (CompareNCaseInsensitive(wordStart, word, searchLen))  						break;  					wordlen = LengthWord(word, otherSeparator) + 1; -					wordsNear.Append(word, wordlen); +					wordsNear.append(word, wordlen, ' ');  				} -				return wordsNear.buffer; +				return wordsNear.detach();  			}  			else if (cond < 0)  				end = pivot - 1; @@ -672,7 +631,7 @@ char *WordList::GetNearestWords(  				oldpivot = pivot;  				do { // browse sequentially the rest after the hit  					wordlen = LengthWord(word, otherSeparator) + 1; -					wordsNear.Append(word, wordlen); +					wordsNear.append(word, wordlen, ' ');  					if (++pivot > end)  						break;  					word = words[pivot]; @@ -686,9 +645,9 @@ char *WordList::GetNearestWords(  					if (strncmp(wordStart, word, searchLen))  						break;  					wordlen = LengthWord(word, otherSeparator) + 1; -					wordsNear.Append(word, wordlen); +					wordsNear.append(word, wordlen, ' ');  				} -				return wordsNear.buffer; +				return wordsNear.detach();  			}  			else if (cond < 0)  				end = pivot - 1; @@ -696,6 +655,5 @@ char *WordList::GetNearestWords(  				start = pivot + 1;  		}  	} -	delete []wordsNear.buffer;  	return NULL;  } | 
