Prevent very small allocation in Str.c
This commit is contained in:
		
							
								
								
									
										30
									
								
								Str.c
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								Str.c
									
									
									
									
									
								
							| @@ -58,6 +58,8 @@ Strnew_size(int n) | |||||||
| 	exit(1); | 	exit(1); | ||||||
|     if (n < 0 || n >= STR_SIZE_MAX) |     if (n < 0 || n >= STR_SIZE_MAX) | ||||||
| 	n = STR_SIZE_MAX - 1; | 	n = STR_SIZE_MAX - 1; | ||||||
|  |     else if (n + 1 < INITIAL_STR_SIZE) | ||||||
|  | 	n = INITIAL_STR_SIZE - 1; | ||||||
|     x->ptr = GC_MALLOC_ATOMIC(n + 1); |     x->ptr = GC_MALLOC_ATOMIC(n + 1); | ||||||
|     if (x->ptr == NULL) |     if (x->ptr == NULL) | ||||||
| 	exit(1); | 	exit(1); | ||||||
| @@ -71,7 +73,7 @@ Str | |||||||
| Strnew_charp(const char *p) | Strnew_charp(const char *p) | ||||||
| { | { | ||||||
|     Str x; |     Str x; | ||||||
|     int n; |     int n, len; | ||||||
|  |  | ||||||
|     if (p == NULL) |     if (p == NULL) | ||||||
| 	return Strnew(); | 	return Strnew(); | ||||||
| @@ -81,12 +83,15 @@ Strnew_charp(const char *p) | |||||||
|     n = strlen(p) + 1; |     n = strlen(p) + 1; | ||||||
|     if (n <= 0 || n > STR_SIZE_MAX) |     if (n <= 0 || n > STR_SIZE_MAX) | ||||||
| 	n = STR_SIZE_MAX; | 	n = STR_SIZE_MAX; | ||||||
|  |     len = n - 1; | ||||||
|  |     if (n < INITIAL_STR_SIZE) | ||||||
|  | 	n = INITIAL_STR_SIZE; | ||||||
|     x->ptr = GC_MALLOC_ATOMIC(n); |     x->ptr = GC_MALLOC_ATOMIC(n); | ||||||
|     if (x->ptr == NULL) |     if (x->ptr == NULL) | ||||||
| 	exit(1); | 	exit(1); | ||||||
|     x->area_size = n; |     x->area_size = n; | ||||||
|     x->length = n - 1; |     x->length = len; | ||||||
|     bcopy((void *)p, (void *)x->ptr, n - 1); |     bcopy((void *)p, (void *)x->ptr, len); | ||||||
|     x->ptr[x->length] = '\0'; |     x->ptr[x->length] = '\0'; | ||||||
|     return x; |     return x; | ||||||
| } | } | ||||||
| @@ -109,6 +114,7 @@ Str | |||||||
| Strnew_charp_n(const char *p, int n) | Strnew_charp_n(const char *p, int n) | ||||||
| { | { | ||||||
|     Str x; |     Str x; | ||||||
|  |     int len; | ||||||
|  |  | ||||||
|     if (p == NULL) |     if (p == NULL) | ||||||
| 	return Strnew_size(n); | 	return Strnew_size(n); | ||||||
| @@ -117,13 +123,16 @@ Strnew_charp_n(const char *p, int n) | |||||||
| 	exit(1); | 	exit(1); | ||||||
|     if (n < 0 || n >= STR_SIZE_MAX) |     if (n < 0 || n >= STR_SIZE_MAX) | ||||||
| 	n = STR_SIZE_MAX - 1; | 	n = STR_SIZE_MAX - 1; | ||||||
|  |     len = n; | ||||||
|  |     if (n + 1 < INITIAL_STR_SIZE) | ||||||
|  | 	n = INITIAL_STR_SIZE - 1; | ||||||
|     x->ptr = GC_MALLOC_ATOMIC(n + 1); |     x->ptr = GC_MALLOC_ATOMIC(n + 1); | ||||||
|     if (x->ptr == NULL) |     if (x->ptr == NULL) | ||||||
| 	exit(1); | 	exit(1); | ||||||
|     x->area_size = n + 1; |     x->area_size = n + 1; | ||||||
|     x->length = n; |     x->length = len; | ||||||
|     bcopy((void *)p, (void *)x->ptr, n); |     bcopy((void *)p, (void *)x->ptr, len); | ||||||
|     x->ptr[n] = '\0'; |     x->ptr[x->length] = '\0'; | ||||||
|     return x; |     return x; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -274,10 +283,11 @@ Strcat_m_charp(Str x, ...) | |||||||
| void | void | ||||||
| Strgrow(Str x) | Strgrow(Str x) | ||||||
| { | { | ||||||
|     int newlen; |     int newlen, addlen; | ||||||
|     newlen = x->area_size + x->area_size / 5; |     addlen = x->area_size / 5; | ||||||
|     if (newlen == x->area_size) |     if (addlen < INITIAL_STR_SIZE) | ||||||
| 	newlen += 2; | 	addlen = INITIAL_STR_SIZE; | ||||||
|  |     newlen = x->area_size + addlen; | ||||||
|     if (newlen <= 0 || newlen > STR_SIZE_MAX) { |     if (newlen <= 0 || newlen > STR_SIZE_MAX) { | ||||||
| 	newlen = STR_SIZE_MAX; | 	newlen = STR_SIZE_MAX; | ||||||
| 	if (x->length + 1 >= newlen) | 	if (x->length + 1 >= newlen) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user