Prevent redundant memory reallocation in Str.c
This commit is contained in:
23
Str.c
23
Str.c
@@ -156,8 +156,7 @@ Strcopy(Str x, Str y)
|
|||||||
STR_LENGTH_CHECK(x);
|
STR_LENGTH_CHECK(x);
|
||||||
STR_LENGTH_CHECK(y);
|
STR_LENGTH_CHECK(y);
|
||||||
if (x->area_size < y->length + 1) {
|
if (x->area_size < y->length + 1) {
|
||||||
GC_free(x->ptr);
|
x->ptr = GC_REALLOC(x->ptr, y->length + 1);
|
||||||
x->ptr = GC_MALLOC_ATOMIC(y->length + 1);
|
|
||||||
if (x->ptr == NULL)
|
if (x->ptr == NULL)
|
||||||
exit(1);
|
exit(1);
|
||||||
x->area_size = y->length + 1;
|
x->area_size = y->length + 1;
|
||||||
@@ -181,8 +180,7 @@ Strcopy_charp(Str x, const char *y)
|
|||||||
if (len < 0 || len >= STR_SIZE_MAX)
|
if (len < 0 || len >= STR_SIZE_MAX)
|
||||||
len = STR_SIZE_MAX - 1;
|
len = STR_SIZE_MAX - 1;
|
||||||
if (x->area_size < len + 1) {
|
if (x->area_size < len + 1) {
|
||||||
GC_free(x->ptr);
|
x->ptr = GC_REALLOC(x->ptr, len + 1);
|
||||||
x->ptr = GC_MALLOC_ATOMIC(len + 1);
|
|
||||||
if (x->ptr == NULL)
|
if (x->ptr == NULL)
|
||||||
exit(1);
|
exit(1);
|
||||||
x->area_size = len + 1;
|
x->area_size = len + 1;
|
||||||
@@ -206,8 +204,7 @@ Strcopy_charp_n(Str x, const char *y, int n)
|
|||||||
if (len < 0 || len >= STR_SIZE_MAX)
|
if (len < 0 || len >= STR_SIZE_MAX)
|
||||||
len = STR_SIZE_MAX - 1;
|
len = STR_SIZE_MAX - 1;
|
||||||
if (x->area_size < len + 1) {
|
if (x->area_size < len + 1) {
|
||||||
GC_free(x->ptr);
|
x->ptr = GC_REALLOC(x->ptr, len + 1);
|
||||||
x->ptr = GC_MALLOC_ATOMIC(len + 1);
|
|
||||||
if (x->ptr == NULL)
|
if (x->ptr == NULL)
|
||||||
exit(1);
|
exit(1);
|
||||||
x->area_size = len + 1;
|
x->area_size = len + 1;
|
||||||
@@ -223,7 +220,7 @@ Strcat_charp_n(Str x, const char *y, int n)
|
|||||||
int newlen;
|
int newlen;
|
||||||
|
|
||||||
STR_LENGTH_CHECK(x);
|
STR_LENGTH_CHECK(x);
|
||||||
if (y == NULL)
|
if (y == NULL || n == 0)
|
||||||
return;
|
return;
|
||||||
if (n < 0)
|
if (n < 0)
|
||||||
n = STR_SIZE_MAX - 1;
|
n = STR_SIZE_MAX - 1;
|
||||||
@@ -231,18 +228,17 @@ Strcat_charp_n(Str x, const char *y, int n)
|
|||||||
if (newlen <= 0 || newlen > STR_SIZE_MAX) {
|
if (newlen <= 0 || newlen > STR_SIZE_MAX) {
|
||||||
newlen = STR_SIZE_MAX;
|
newlen = STR_SIZE_MAX;
|
||||||
n = newlen - x->length - 1;
|
n = newlen - x->length - 1;
|
||||||
|
if (n <= 0)
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
if (x->area_size < newlen) {
|
if (x->area_size < newlen) {
|
||||||
char *old = x->ptr;
|
|
||||||
newlen += newlen / 2;
|
newlen += newlen / 2;
|
||||||
if (newlen <= 0 || newlen > STR_SIZE_MAX)
|
if (newlen <= 0 || newlen > STR_SIZE_MAX)
|
||||||
newlen = STR_SIZE_MAX;
|
newlen = STR_SIZE_MAX;
|
||||||
x->ptr = GC_MALLOC_ATOMIC(newlen);
|
x->ptr = GC_REALLOC(x->ptr, newlen);
|
||||||
if (x->ptr == NULL)
|
if (x->ptr == NULL)
|
||||||
exit(1);
|
exit(1);
|
||||||
x->area_size = newlen;
|
x->area_size = newlen;
|
||||||
bcopy((void *)old, (void *)x->ptr, x->length);
|
|
||||||
GC_free(old);
|
|
||||||
}
|
}
|
||||||
bcopy((void *)y, (void *)&x->ptr[x->length], n);
|
bcopy((void *)y, (void *)&x->ptr[x->length], n);
|
||||||
x->length += n;
|
x->length += n;
|
||||||
@@ -278,7 +274,6 @@ Strcat_m_charp(Str x, ...)
|
|||||||
void
|
void
|
||||||
Strgrow(Str x)
|
Strgrow(Str x)
|
||||||
{
|
{
|
||||||
char *old = x->ptr;
|
|
||||||
int newlen;
|
int newlen;
|
||||||
newlen = x->area_size + x->area_size / 5;
|
newlen = x->area_size + x->area_size / 5;
|
||||||
if (newlen == x->area_size)
|
if (newlen == x->area_size)
|
||||||
@@ -289,12 +284,10 @@ Strgrow(Str x)
|
|||||||
x->length = newlen - 2;
|
x->length = newlen - 2;
|
||||||
}
|
}
|
||||||
if (x->area_size < newlen) {
|
if (x->area_size < newlen) {
|
||||||
x->ptr = GC_MALLOC_ATOMIC(newlen);
|
x->ptr = GC_REALLOC(x->ptr, newlen);
|
||||||
if (x->ptr == NULL)
|
if (x->ptr == NULL)
|
||||||
exit(1);
|
exit(1);
|
||||||
x->area_size = newlen;
|
x->area_size = newlen;
|
||||||
bcopy((void *)old, (void *)x->ptr, x->length);
|
|
||||||
GC_free(old);
|
|
||||||
}
|
}
|
||||||
x->ptr[x->length] = '\0';
|
x->ptr[x->length] = '\0';
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user