diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/CellBuffer.cxx | 5 | ||||
| -rw-r--r-- | src/SplitVector.h | 17 | 
2 files changed, 18 insertions, 4 deletions
| diff --git a/src/CellBuffer.cxx b/src/CellBuffer.cxx index 064ef1a2a..de1605837 100644 --- a/src/CellBuffer.cxx +++ b/src/CellBuffer.cxx @@ -351,10 +351,7 @@ void CellBuffer::GetCharRange(char *buffer, int position, int lengthRetrieve) co  		                      lengthRetrieve, substance.Length());  		return;  	} - -	for (int i=0; i<lengthRetrieve; i++) { -		*buffer++ = substance.ValueAt(position + i); -	} +	substance.GetRange(buffer, position, lengthRetrieve);  }  char CellBuffer::StyleAt(int position) const { diff --git a/src/SplitVector.h b/src/SplitVector.h index 2c5c7a1d0..2e17ba3dc 100644 --- a/src/SplitVector.h +++ b/src/SplitVector.h @@ -238,6 +238,23 @@ public:  		DeleteRange(0, lengthBody);  	} +	// Retrieve a range of elemetns into an array +	void GetRange(T *buffer, int position, int retrieveLength) const { +		// Split into up to 2 ranges, before and after the split then use memcpy on each. +		int range1Length = 0; +		if (position < part1Length) { +			int part1AfterPosition = part1Length - position; +			range1Length = retrieveLength; +			if (range1Length > part1AfterPosition) +				range1Length = part1AfterPosition; +		} +		memcpy(buffer, body + position, range1Length * sizeof(T)); +		buffer += range1Length; +		position = position + range1Length + gapLength; +		int range2Length = retrieveLength - range1Length; +		memcpy(buffer, body + position, range2Length * sizeof(T)); +	} +  	T *BufferPointer() {  		RoomFor(1);  		GapTo(lengthBody); | 
