Implemented format-appending operators, more optimizations and bugfixes

git-svn-id: file:///srv/svn/repos/haiku/trunk/current@1191 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Stefano Ceccherini 2002-09-26 06:53:49 +00:00
parent f4b41f88a2
commit 7c64b6d7d5

View File

@ -110,6 +110,9 @@ BString::operator=(const char *str)
{ {
if (str) if (str)
_DoAssign(str, strlen(str)); _DoAssign(str, strlen(str));
else
_GrowBy(-Length()); // Empties the string
return *this; return *this;
} }
@ -128,7 +131,9 @@ BString::SetTo(const char *str, int32 length)
if (str) { if (str) {
int32 len = (int32)strlen(str); int32 len = (int32)strlen(str);
_DoAssign(str, min(length, len)); _DoAssign(str, min(length, len));
} } else
_GrowBy(-Length()); // Empties the string
return *this; return *this;
} }
@ -249,10 +254,9 @@ BString::Append(const char *str, int32 length)
BString& BString&
BString::Append(char c, int32 count) BString::Append(char c, int32 count)
{ {
char *tmp = (char*)malloc(count); _GrowBy(count);
memset(tmp, c, count); memset(_privateData + Length() - count, c, count);
_DoAppend(tmp, count);
free(tmp);
return *this; return *this;
} }
@ -299,10 +303,9 @@ BString::Prepend(const BString &string, int32 len)
BString& BString&
BString::Prepend(char c, int32 count) BString::Prepend(char c, int32 count)
{ {
char *tmp = (char*)malloc(count); _GrowBy(count);
memset(tmp, c, count); memset(_privateData, c, count);
_DoPrepend(tmp, count);
free(tmp);
return *this; return *this;
} }
@ -375,11 +378,9 @@ BString::Insert(const BString &string, int32 fromOffset, int32 length, int32 pos
BString& BString&
BString::Insert(char c, int32 count, int32 pos) BString::Insert(char c, int32 count, int32 pos)
{ {
char *tmp = (char*)malloc(count); _OpenAtBy(pos, count);
memset(tmp, c, count); memset(_privateData + pos, c, count);
_privateData = _OpenAtBy(pos, count);
memcpy(_privateData + pos, tmp, count);
free(tmp);
return *this; return *this;
} }
@ -442,6 +443,7 @@ BString::RemoveAll(const BString &string)
int32 pos = B_ERROR; int32 pos = B_ERROR;
while ((pos = _FindAfter(string.String(), 0, -1)) >= 0) while ((pos = _FindAfter(string.String(), 0, -1)) >= 0)
_privateData = _ShrinkAtBy(pos, string.Length()); _privateData = _ShrinkAtBy(pos, string.Length());
return *this; return *this;
} }
@ -518,6 +520,7 @@ BString::MoveInto(char *into, int32 from, int32 length)
} }
} }
/*---- Compare functions ---------------------------------------------------*/ /*---- Compare functions ---------------------------------------------------*/
// Implemented inline in the header file // Implemented inline in the header file
/*---- strcmp-style compare functions --------------------------------------*/ /*---- strcmp-style compare functions --------------------------------------*/
@ -610,9 +613,8 @@ int32
BString::FindFirst(char c) const BString::FindFirst(char c) const
{ {
char tmp[2] = { c, '\0' }; char tmp[2] = { c, '\0' };
int32 result = _FindAfter(tmp, 0, -1);
return result; return _FindAfter(tmp, 0, -1);
} }
@ -620,9 +622,8 @@ int32
BString::FindFirst(char c, int32 fromOffset) const BString::FindFirst(char c, int32 fromOffset) const
{ {
char tmp[2] = { c, '\0' }; char tmp[2] = { c, '\0' };
int32 result = _FindAfter(tmp, fromOffset, -1);
return result; return _FindAfter(tmp, fromOffset, -1);
} }
@ -649,8 +650,10 @@ BString&
BString::ReplaceAll(char replaceThis, char withThis, int32 fromOffset) BString::ReplaceAll(char replaceThis, char withThis, int32 fromOffset)
{ {
int32 pos = B_ERROR; int32 pos = B_ERROR;
while ((pos = FindFirst(replaceThis, fromOffset)) >= 0) while ((pos = FindFirst(replaceThis, fromOffset)) >= 0) {
_privateData[pos] = withThis; _privateData[pos] = withThis;
fromOffset += pos;
}
return *this; return *this;
} }
@ -807,7 +810,7 @@ BString::UnlockBuffer(int32 length)
BString& BString&
BString::ToLower() BString::ToLower()
{ {
for (int count = 0; count < Length(); count++) for (int32 count = 0; count < Length(); count++)
_privateData[count] = tolower(_privateData[count]); _privateData[count] = tolower(_privateData[count]);
return *this; return *this;
@ -817,7 +820,7 @@ BString::ToLower()
BString& BString&
BString::ToUpper() BString::ToUpper()
{ {
for (int count = 0; count < Length(); count++) for (int32 count = 0; count < Length(); count++)
_privateData[count] = toupper(_privateData[count]); _privateData[count] = toupper(_privateData[count]);
return *this; return *this;
@ -827,12 +830,11 @@ BString::ToUpper()
BString& BString&
BString::Capitalize() BString::Capitalize()
{ {
_privateData[0] = toupper(_privateData[0]);
for (int32 count = 0; count < Length(); count++)
_privateData[count] = tolower(_privateData[count]);
for (int count = 0; count < Length(); count++)
if (isalpha(_privateData[count])) {
_privateData[count] = toupper(_privateData[count]);
break;
}
return *this; return *this;
} }
@ -908,55 +910,70 @@ BString::operator<<(char c)
BString& BString&
BString::operator<<(int i) BString::operator<<(int i)
{ {
//TODO: implement char num[64];
return *this; sprintf(num, "%d", i);
return *this << num;
} }
BString& BString&
BString::operator<<(unsigned int i) BString::operator<<(unsigned int i)
{ {
//TODO: implement char num[64];
return *this; sprintf(num, "%u", i);
return *this << num;
} }
BString& BString&
BString::operator<<(uint32 i) BString::operator<<(uint32 i)
{ {
//TODO: implement char num[64];
return *this; sprintf(num, "%lu", i);
return *this << num;
} }
BString& BString&
BString::operator<<(int32 i) BString::operator<<(int32 i)
{ {
//TODO: implement char num[64];
return *this; sprintf(num, "%ld", i);
return *this << num;
} }
BString& BString&
BString::operator<<(uint64 i) BString::operator<<(uint64 i)
{ {
//TODO: implement char num[64];
return *this; sprintf(num, "%llu", i);
return *this << num;
} }
BString& BString&
BString::operator<<(int64 i) BString::operator<<(int64 i)
{ {
//TODO: implement char num[64];
return *this; sprintf(num, "%lld", i);
return *this << num;
} }
BString& BString&
BString::operator<<(float f) BString::operator<<(float f)
{ {
//TODO: implement char num[64];
return *this; sprintf(num, "%.00f", f);
return *this << num;
} }
@ -1086,12 +1103,12 @@ BString::_IFindAfter(const char *str, int32 offset, int32 ) const
assert(str != NULL); assert(str != NULL);
if (offset > Length()) if (offset > Length())
return B_ERROR; return B_ERROR;
#if 0
char *ptr = strcasestr(String() + offset, str); char *ptr = strcasestr(String() + offset, str);
if (ptr != NULL) if (ptr != NULL)
return ptr - (String() + offset); return ptr - (String() + offset);
#endif
return B_ERROR; return B_ERROR;
} }