|
|
@ -501,11 +501,11 @@ double plString::ToDouble() const |
|
|
|
|
|
|
|
|
|
|
|
plString plString::IFormat(const char *fmt, va_list vptr) |
|
|
|
plString plString::IFormat(const char *fmt, va_list vptr) |
|
|
|
{ |
|
|
|
{ |
|
|
|
char buffer[256]; |
|
|
|
char buffer[STRING_STACK_SIZE]; |
|
|
|
va_list vptr_save; |
|
|
|
va_list vptr_save; |
|
|
|
va_copy(vptr_save, vptr); |
|
|
|
va_copy(vptr_save, vptr); |
|
|
|
|
|
|
|
|
|
|
|
int chars = vsnprintf(buffer, 256, fmt, vptr); |
|
|
|
int chars = vsnprintf(buffer, STRING_STACK_SIZE, fmt, vptr); |
|
|
|
if (chars < 0) { |
|
|
|
if (chars < 0) { |
|
|
|
// We will need to try this multiple times until we get a
|
|
|
|
// We will need to try this multiple times until we get a
|
|
|
|
// large enough buffer :(
|
|
|
|
// large enough buffer :(
|
|
|
@ -522,9 +522,8 @@ plString plString::IFormat(const char *fmt, va_list vptr) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
size *= 2; |
|
|
|
size *= 2; |
|
|
|
hsAssert(size > 0, "Formatted string output is waaaaay too long"); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} else if (chars >= 256) { |
|
|
|
} else if (chars >= STRING_STACK_SIZE) { |
|
|
|
va_copy(vptr, vptr_save); |
|
|
|
va_copy(vptr, vptr_save); |
|
|
|
plStringBuffer<char> bigbuffer; |
|
|
|
plStringBuffer<char> bigbuffer; |
|
|
|
char *data = bigbuffer.CreateWritableBuffer(chars); |
|
|
|
char *data = bigbuffer.CreateWritableBuffer(chars); |
|
|
@ -823,14 +822,24 @@ plString operator+(const char *left, const plString &right) |
|
|
|
|
|
|
|
|
|
|
|
plStringStream &plStringStream::append(const char *data, size_t length) |
|
|
|
plStringStream &plStringStream::append(const char *data, size_t length) |
|
|
|
{ |
|
|
|
{ |
|
|
|
if (fLength + length > fBufSize) { |
|
|
|
size_t bufSize = ICanHasHeap() ? fBufSize : STRING_STACK_SIZE; |
|
|
|
char *bigger = new char[fBufSize * 2]; |
|
|
|
char *bufp = ICanHasHeap() ? fBuffer : fShort; |
|
|
|
memcpy(bigger, fBuffer, fBufSize); |
|
|
|
|
|
|
|
|
|
|
|
if (fLength + length > bufSize) { |
|
|
|
|
|
|
|
size_t bigSize = bufSize; |
|
|
|
|
|
|
|
do { |
|
|
|
|
|
|
|
bigSize *= 2; |
|
|
|
|
|
|
|
} while (fLength + length > bigSize); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
char *bigger = new char[bigSize]; |
|
|
|
|
|
|
|
memcpy(bigger, GetRawBuffer(), bufSize); |
|
|
|
|
|
|
|
if (ICanHasHeap()) |
|
|
|
delete [] fBuffer; |
|
|
|
delete [] fBuffer; |
|
|
|
fBuffer = bigger; |
|
|
|
fBuffer = bufp = bigger; |
|
|
|
fBufSize *= 2; |
|
|
|
fBufSize = bigSize; |
|
|
|
} |
|
|
|
} |
|
|
|
memcpy(fBuffer + fLength, data, length); |
|
|
|
|
|
|
|
|
|
|
|
memcpy(bufp + fLength, data, length); |
|
|
|
fLength += length; |
|
|
|
fLength += length; |
|
|
|
return *this; |
|
|
|
return *this; |
|
|
|
} |
|
|
|
} |
|
|
@ -855,6 +864,13 @@ plStringStream &plStringStream::operator<<(unsigned int num) |
|
|
|
return operator<<(buffer); |
|
|
|
return operator<<(buffer); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
plStringStream &plStringStream::operator<<(double num) |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
char buffer[64]; |
|
|
|
|
|
|
|
snprintf(buffer, 64, "%f", num); |
|
|
|
|
|
|
|
return operator<<(buffer); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
size_t ustrlen(const UniChar *ustr, size_t max) |
|
|
|
size_t ustrlen(const UniChar *ustr, size_t max) |
|
|
|
{ |
|
|
|
{ |
|
|
|
size_t length = 0; |
|
|
|
size_t length = 0; |
|
|
|