mirror of
https://github.com/beefytech/Beef.git
synced 2025-06-08 11:38:21 +02:00
Support for null chars in rawString view
This commit is contained in:
parent
49a470e154
commit
1097619f48
5 changed files with 24 additions and 24 deletions
|
@ -153,7 +153,7 @@ void StringView::ToString(StringImpl& str) const
|
|||
|
||||
StringSplitEnumerator StringView::Split(char c)
|
||||
{
|
||||
return StringSplitEnumerator(mPtr, mLength, c, 0x7FFFFFFF, false);
|
||||
return StringSplitEnumerator(mPtr, (int)mLength, c, 0x7FFFFFFF, false);
|
||||
}
|
||||
|
||||
//////////////////////////////////////////////////////////////////////////
|
||||
|
@ -314,11 +314,11 @@ bool StringImpl::EqualsHelper(const char * a, const char * b, intptr length)
|
|||
return strncmp(a, b, length) == 0;
|
||||
}
|
||||
|
||||
bool StringImpl::EqualsIgnoreCaseHelper(const char * a, const char * b, int length)
|
||||
bool StringImpl::EqualsIgnoreCaseHelper(const char * a, const char * b, intptr length)
|
||||
{
|
||||
const char* curA = a;
|
||||
const char* curB = b;
|
||||
int curLength = length;
|
||||
intptr curLength = length;
|
||||
|
||||
/*Contract.Requires(strA != null);
|
||||
Contract.Requires(strB != null);
|
||||
|
@ -627,11 +627,11 @@ intptr StringImpl::Compare(const StringImpl & strA, intptr indexA, const StringI
|
|||
|
||||
void StringImpl::ReplaceLargerHelper(const StringView& find, const StringView& replace)
|
||||
{
|
||||
Array<int> replaceEntries;
|
||||
Array<intptr> replaceEntries;
|
||||
|
||||
int_strsize moveOffset = replace.mLength - find.mLength;
|
||||
intptr moveOffset = replace.mLength - find.mLength;
|
||||
|
||||
for (int startIdx = 0; startIdx < mLength - find.mLength; startIdx++)
|
||||
for (intptr startIdx = 0; startIdx < mLength - find.mLength; startIdx++)
|
||||
{
|
||||
if (EqualsHelper(GetPtr() + startIdx, find.mPtr, find.mLength))
|
||||
{
|
||||
|
@ -684,8 +684,8 @@ void StringImpl::Replace(const StringView& find, const StringView & replace)
|
|||
auto findPtr = find.mPtr;
|
||||
auto replacePtr = replace.mPtr;
|
||||
|
||||
int_strsize inIdx = 0;
|
||||
int_strsize outIdx = 0;
|
||||
intptr inIdx = 0;
|
||||
intptr outIdx = 0;
|
||||
|
||||
while (inIdx < mLength - find.mLength)
|
||||
{
|
||||
|
@ -721,7 +721,7 @@ void StringImpl::Replace(const StringView& find, const StringView & replace)
|
|||
}
|
||||
|
||||
ptr[outIdx] = 0;
|
||||
mLength = outIdx;
|
||||
mLength = (int_strsize)outIdx;
|
||||
}
|
||||
|
||||
void StringImpl::TrimEnd()
|
||||
|
|
|
@ -18,7 +18,7 @@ class StringView
|
|||
{
|
||||
public:
|
||||
const char* mPtr;
|
||||
int mLength;
|
||||
intptr mLength;
|
||||
|
||||
public:
|
||||
struct iterator
|
||||
|
@ -270,12 +270,12 @@ public:
|
|||
mLength -= (int)length;
|
||||
}
|
||||
|
||||
void RemoveToEnd(int startIdx)
|
||||
void RemoveToEnd(intptr startIdx)
|
||||
{
|
||||
RemoveFromEnd(mLength - startIdx);
|
||||
}
|
||||
|
||||
void RemoveFromEnd(int length)
|
||||
void RemoveFromEnd(intptr length)
|
||||
{
|
||||
mLength -= length;
|
||||
}
|
||||
|
@ -530,17 +530,17 @@ protected:
|
|||
void Realloc(intptr newSize, bool copyStr = true);
|
||||
void Realloc(char* newPtr, intptr newSize);
|
||||
static bool EqualsHelper(const char* a, const char* b, intptr length);
|
||||
static bool EqualsIgnoreCaseHelper(const char* a, const char* b, int length);
|
||||
static bool EqualsIgnoreCaseHelper(const char* a, const char* b, intptr length);
|
||||
static int CompareOrdinalIgnoreCaseHelper(const StringImpl& strA, const StringImpl& strB);
|
||||
static intptr CompareOrdinalIgnoreCaseHelper(const char* strA, intptr lengthA, const char* strB, intptr lengthB);
|
||||
static intptr CompareOrdinalIgnoreCaseHelper(const StringImpl& strA, intptr indexA, intptr lengthA, const StringImpl& strB, intptr indexB, intptr lengthB);
|
||||
static intptr CompareOrdinalHelper(const char* strA, intptr lengthA, const char* strB, intptr lengthB);
|
||||
static intptr CompareOrdinalHelper(const StringImpl& strA, intptr indexA, intptr lengthA, const StringImpl& strB, intptr indexB, intptr lengthB);
|
||||
|
||||
void Init(const char* charPtr, int_strsize count)
|
||||
void Init(const char* charPtr, intptr count)
|
||||
{
|
||||
int_strsize internalSize = (int_strsize)(sizeof(StringImpl) - offsetof(StringImpl, mPtr));
|
||||
int_strsize allocSize = count + 1;
|
||||
int_strsize allocSize = (int_strsize)count + 1;
|
||||
|
||||
if (allocSize <= internalSize)
|
||||
{
|
||||
|
@ -549,7 +549,7 @@ protected:
|
|||
memcpy(ptr, charPtr, count);
|
||||
ptr[count] = 0;
|
||||
mAllocSizeAndFlags = internalSize;
|
||||
this->mLength = count;
|
||||
this->mLength = (int_strsize)count;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -559,7 +559,7 @@ protected:
|
|||
ptr[count] = 0;
|
||||
this->mPtr = ptr;
|
||||
mAllocSizeAndFlags = allocSize | DynAllocFlag | StrPtrFlag;
|
||||
this->mLength = count;
|
||||
this->mLength = (int_strsize)count;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue