mirror of
https://github.com/raysan5/raylib.git
synced 2026-01-31 11:19:18 -05:00
[rtext] Fix and enhance TextReplace() function (#5511)
* add check for replacement,replace strcpy,strncpy with memcpy * add 4 spaces in if statement * add spaces
This commit is contained in:
24
src/rtext.c
24
src/rtext.c
@ -1727,14 +1727,15 @@ char *GetTextBetween(const char *text, const char *begin, const char *end)
|
|||||||
|
|
||||||
// Replace text string
|
// Replace text string
|
||||||
// REQUIRES: strstr(), strncpy()
|
// REQUIRES: strstr(), strncpy()
|
||||||
// TODO: If (replacement == "") remove "search" text
|
|
||||||
// WARNING: Allocated memory must be manually freed
|
// WARNING: Allocated memory must be manually freed
|
||||||
char *TextReplace(const char *text, const char *search, const char *replacement)
|
char *TextReplace(const char *text, const char *search, const char *replacement)
|
||||||
{
|
{
|
||||||
char *result = NULL;
|
char *result = NULL;
|
||||||
|
|
||||||
if ((text != NULL) && (search != NULL))
|
if ((text != NULL) && (search != NULL))
|
||||||
{
|
{
|
||||||
|
if (replacement == NULL) replacement = "";
|
||||||
|
|
||||||
char *insertPoint = NULL; // Next insert point
|
char *insertPoint = NULL; // Next insert point
|
||||||
char *temp = NULL; // Temp pointer
|
char *temp = NULL; // Temp pointer
|
||||||
int textLen = 0; // Text string length
|
int textLen = 0; // Text string length
|
||||||
@ -1767,16 +1768,15 @@ char *TextReplace(const char *text, const char *search, const char *replacement)
|
|||||||
{
|
{
|
||||||
insertPoint = (char *)strstr(text, search);
|
insertPoint = (char *)strstr(text, search);
|
||||||
lastReplacePos = (int)(insertPoint - text);
|
lastReplacePos = (int)(insertPoint - text);
|
||||||
|
|
||||||
// TODO: Review logic to avoid strcpy()
|
memcpy(temp, text, lastReplacePos);
|
||||||
// OK - Those lines work
|
temp += lastReplacePos;
|
||||||
temp = strncpy(temp, text, lastReplacePos) + lastReplacePos;
|
|
||||||
temp = strcpy(temp, replacement) + replaceLen;
|
if (replaceLen > 0)
|
||||||
// WRONG - But not those ones
|
{
|
||||||
//temp = strncpy(temp, text, tempLen - 1) + lastReplacePos;
|
memcpy(temp, replacement, replaceLen);
|
||||||
//tempLen -= lastReplacePos;
|
temp += replaceLen;
|
||||||
//temp = strncpy(temp, replacement, tempLen - 1) + replaceLen;
|
}
|
||||||
//tempLen -= replaceLen;
|
|
||||||
|
|
||||||
text += lastReplacePos + searchLen; // Move to next "end of replace"
|
text += lastReplacePos + searchLen; // Move to next "end of replace"
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user