1
0
Fork 0
mirror of https://github.com/beefytech/Beef.git synced 2025-06-12 05:14:10 +02:00

Merge pull request #1800 from MineGame159/string_changes

String changes
This commit is contained in:
Brian Fiete 2023-02-21 06:33:12 -05:00 committed by GitHub
commit 7abecdbdb5
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -2125,18 +2125,18 @@ namespace System
return UTF8.Decode(ptr + idx, mLength - idx).c == c; return UTF8.Decode(ptr + idx, mLength - idx).c == c;
} }
private void ReplaceLargerHelper(String find, String replace) private void ReplaceLargerHelper(StringView find, StringView replace)
{ {
List<int> replaceEntries = scope List<int>(8192); List<int> replaceEntries = scope List<int>(8192);
int_strsize moveOffset = replace.mLength - find.mLength; int_strsize moveOffset = (.) (replace.Length - find.Length);
for (int startIdx = 0; startIdx <= mLength - find.mLength; startIdx++) for (int startIdx = 0; startIdx <= mLength - find.Length; startIdx++)
{ {
if (EqualsHelper(Ptr + startIdx, find.Ptr, find.mLength)) if (EqualsHelper(Ptr + startIdx, find.Ptr, find.Length))
{ {
replaceEntries.Add(startIdx); replaceEntries.Add(startIdx);
startIdx += find.mLength - 1; startIdx += find.Length - 1;
} }
} }
@ -2154,14 +2154,14 @@ namespace System
for (int moveIdx = replaceEntries.Count - 1; moveIdx >= 0; moveIdx--) for (int moveIdx = replaceEntries.Count - 1; moveIdx >= 0; moveIdx--)
{ {
int srcStartIdx = replaceEntries[moveIdx]; int srcStartIdx = replaceEntries[moveIdx];
int srcEndIdx = srcStartIdx + find.mLength; int srcEndIdx = srcStartIdx + find.Length;
int destStartIdx = srcStartIdx + moveIdx * moveOffset; int destStartIdx = srcStartIdx + moveIdx * moveOffset;
int destEndIdx = destStartIdx + replace.mLength; int destEndIdx = destStartIdx + replace.Length;
for (int i = lastDestStartIdx - destEndIdx - 1; i >= 0; i--) for (int i = lastDestStartIdx - destEndIdx - 1; i >= 0; i--)
ptr[destEndIdx + i] = ptr[srcEndIdx + i]; ptr[destEndIdx + i] = ptr[srcEndIdx + i];
for (int i < replace.mLength) for (int i < replace.Length)
ptr[destStartIdx + i] = replacePtr[i]; ptr[destStartIdx + i] = replacePtr[i];
lastDestStartIdx = destStartIdx; lastDestStartIdx = destStartIdx;
@ -2170,9 +2170,9 @@ namespace System
mLength = (int_strsize)destLength; mLength = (int_strsize)destLength;
} }
public void Replace(String find, String replace) public void Replace(StringView find, StringView replace)
{ {
if (replace.mLength > find.mLength) if (replace.Length > find.Length)
{ {
ReplaceLargerHelper(find, replace); ReplaceLargerHelper(find, replace);
return; return;
@ -2193,10 +2193,10 @@ namespace System
{ {
if (ptr[inIdx] == findC) if (ptr[inIdx] == findC)
{ {
for (int i = 0; i < replace.mLength; i++) for (int i = 0; i < replace.Length; i++)
ptr[outIdx++] = replacePtr[i]; ptr[outIdx++] = replacePtr[i];
inIdx += find.mLength; inIdx += (.) find.Length;
} }
else if (inIdx == outIdx) else if (inIdx == outIdx)
{ {
@ -2211,14 +2211,14 @@ namespace System
} }
else else
{ {
while (inIdx <= mLength - find.mLength) while (inIdx <= mLength - find.Length)
{ {
if (EqualsHelper(ptr + inIdx, findPtr, find.mLength)) if (EqualsHelper(ptr + inIdx, findPtr, find.Length))
{ {
for (int i = 0; i < replace.mLength; i++) for (int i = 0; i < replace.Length; i++)
ptr[outIdx++] = replacePtr[i]; ptr[outIdx++] = replacePtr[i];
inIdx += find.mLength; inIdx += (.) find.Length;
} }
else if (inIdx == outIdx) else if (inIdx == outIdx)
{ {
@ -2248,6 +2248,53 @@ namespace System
mLength = outIdx; mLength = outIdx;
} }
public void Replace(int start, int length, StringView replaceWith)
{
Debug.Assert(start >= 0 && start <= Length);
Debug.Assert(length >= 0 && length <= Length - start);
if (replaceWith.IsEmpty)
return;
if (replaceWith.Length == length)
{
Internal.MemCpy(&Ptr[start], replaceWith.Ptr, length);
}
else if (replaceWith.Length > length)
{
int additional = replaceWith.Length - length;
CalculatedReserve(Length + additional);
if (start + length < Length)
Internal.MemMove(&Ptr[start + replaceWith.Length], &Ptr[start + length], Length - (start + length));
mLength += (.) additional;
Internal.MemCpy(&Ptr[start], replaceWith.Ptr, replaceWith.Length);
}
else
{
int difference = length - replaceWith.Length;
Internal.MemCpy(&Ptr[start], replaceWith.Ptr, replaceWith.Length);
if (start + length < Length)
Internal.MemMove(&Ptr[start + replaceWith.Length], &Ptr[start + length], Length - (start + length));
mLength -= (.) difference;
}
}
public void Replace(IndexRange range, StringView replaceWith)
{
StringView view = this;
int start = view.[Friend]GetRangeStart(range);
int end = view.[Friend]GetRangeEnd(range);
Replace(start, end - start, replaceWith);
}
public void TrimEnd() public void TrimEnd()
{ {
let ptr = Ptr; let ptr = Ptr;
@ -3461,43 +3508,51 @@ namespace System
#endif #endif
get get
{ {
char8* start; int start = GetRangeStart(range);
switch (range.[Friend]mStart) int end = GetRangeEnd(range);
return .(mPtr + start, end - start);
}
}
private int GetRangeStart(IndexRange range)
{
switch (range.Start)
{
case .FromFront(let offset):
Debug.Assert((uint)offset <= (uint)mLength);
return offset;
case .FromEnd(let offset):
Debug.Assert((uint)offset <= (uint)mLength);
return mLength - offset;
}
}
private int GetRangeEnd(IndexRange range)
{
if (range.IsClosed)
{
switch (range.End)
{
case .FromFront(let offset):
Debug.Assert((uint)offset < (uint)mLength);
return offset + 1;
case .FromEnd(let offset):
Debug.Assert((uint)(offset - 1) <= (uint)mLength);
return mLength - offset + 1;
}
}
else
{
switch (range.End)
{ {
case .FromFront(let offset): case .FromFront(let offset):
Debug.Assert((uint)offset <= (uint)mLength); Debug.Assert((uint)offset <= (uint)mLength);
start = mPtr + offset; return offset;
case .FromEnd(let offset): case .FromEnd(let offset):
Debug.Assert((uint)offset <= (uint)mLength); Debug.Assert((uint)offset <= (uint)mLength);
start = mPtr + mLength - offset; return mLength - offset;
} }
char8* end;
if (range.[Friend]mIsClosed)
{
switch (range.[Friend]mEnd)
{
case .FromFront(let offset):
Debug.Assert((uint)offset < (uint)mLength);
end = mPtr + offset + 1;
case .FromEnd(let offset):
Debug.Assert((uint)(offset - 1) <= (uint)mLength);
end = mPtr + mLength - offset + 1;
}
}
else
{
switch (range.[Friend]mEnd)
{
case .FromFront(let offset):
Debug.Assert((uint)offset <= (uint)mLength);
end = mPtr + offset;
case .FromEnd(let offset):
Debug.Assert((uint)offset <= (uint)mLength);
end = mPtr + mLength - offset;
}
}
return .(start, end - start);
} }
} }