mirror of
https://github.com/beefytech/Beef.git
synced 2025-06-16 23:34:10 +02:00
Added String.Replace() methods for replacing a range within the string
This commit is contained in:
parent
2da891f7ec
commit
10b64ff09e
1 changed files with 86 additions and 31 deletions
|
@ -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);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue