X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=phpstr%2Fphpstr.c;h=7c9bad0970f42a54e259b915278d6d11823a7224;hp=999230005bdf15c94d40e84cb8f511ae40678bcf;hb=1877c25f3174e7ec12dfcfe2797e2454bd9d94eb;hpb=7038c951485d1b2afa79c9a84b8dcdcb57c9bc54 diff --git a/phpstr/phpstr.c b/phpstr/phpstr.c index 9992300..7c9bad0 100644 --- a/phpstr/phpstr.c +++ b/phpstr/phpstr.c @@ -5,7 +5,7 @@ #include "phpstr.h" #ifndef PHPSTR_DEFAULT_SIZE -#define PHPSTR_DEFAULT_SIZE 4096 +#define PHPSTR_DEFAULT_SIZE 256 #endif PHPSTR_API phpstr *phpstr_init_ex(phpstr *buf, size_t chunk_size, zend_bool pre_alloc) @@ -14,17 +14,17 @@ PHPSTR_API phpstr *phpstr_init_ex(phpstr *buf, size_t chunk_size, zend_bool pre_ buf = ecalloc(1, sizeof(phpstr)); } - buf->used = 0; buf->size = chunk_size > 0 ? chunk_size : PHPSTR_DEFAULT_SIZE; - buf->free = pre_alloc ? buf->size : 0; buf->data = pre_alloc ? emalloc(buf->size) : NULL; + buf->free = pre_alloc ? buf->size : 0; + buf->used = 0; return buf; } PHPSTR_API phpstr *phpstr_from_string_ex(phpstr *buf, char *string, size_t length) { - buf = phpstr_init(buf); + buf = phpstr_init(buf); phpstr_append(buf, string, length); return buf; } @@ -139,10 +139,10 @@ PHPSTR_API phpstr *phpstr_dup(const phpstr *buf) return dup; } -PHPSTR_API ssize_t phpstr_cut(phpstr *buf, size_t offset, size_t length) +PHPSTR_API size_t phpstr_cut(phpstr *buf, size_t offset, size_t length) { if (offset >= buf->used) { - return -1; + return 0; } if (offset + length > buf->used) { length = buf->used - offset; @@ -230,7 +230,7 @@ PHPSTR_API int phpstr_cmp(phpstr *left, phpstr *right) } } -PHPSTR_API void phpstr_free(phpstr *buf) +PHPSTR_API void phpstr_dtor(phpstr *buf) { if (buf->data) { efree(buf->data); @@ -240,10 +240,10 @@ PHPSTR_API void phpstr_free(phpstr *buf) buf->free = 0; } -PHPSTR_API void phpstr_dtor(phpstr *buf) +PHPSTR_API void phpstr_free(phpstr *buf) { if (buf) { - phpstr_free(buf); + phpstr_dtor(buf); efree(buf); } }