Improved split to support empty string as separator.
h3rald h3rald@h3rald.com
Sun, 08 Dec 2024 17:18:02 +0100
2 files changed,
58 insertions(+),
23 deletions(-)
M
scripts/test.hex
→
scripts/test.hex
@@ -155,6 +155,8 @@ ((0x2 0x3) (0x2 0x1) > 0x1 ==)
((test abc) (test cde) < 0x1 ==) (("test" "abc") ("test" "abc") <= 0x1 ==) ;80 + + ("hello" "" split ("h" "e" "l" "l" "o") ==) ) "tests" :
M
src/hex.c
→
src/hex.c
@@ -2616,7 +2616,6 @@ }
int hex_symbol_split(hex_context_t *ctx) { - POP(ctx, separator); if (separator.type == HEX_TYPE_INVALID) {@@ -2633,39 +2632,73 @@ }
int result = 0; if (str.type == HEX_TYPE_STRING && separator.type == HEX_TYPE_STRING) { - char *token = strtok(str.data.str_value, separator.data.str_value); - int capacity = 2; - int size = 0; - hex_item_t **quotation = (hex_item_t **)malloc(capacity * sizeof(hex_item_t *)); - if (!quotation) + if (strlen(separator.data.str_value) == 0) { - hex_error(ctx, "Memory allocation failed"); - result = 1; - } - else - { - while (token) + // Separator is an empty string: split into individual characters + int size = strlen(str.data.str_value); + hex_item_t **quotation = (hex_item_t **)malloc(size * sizeof(hex_item_t *)); + if (!quotation) { - if (size >= capacity) + hex_error(ctx, "Memory allocation failed"); + result = 1; + } + else + { + for (int i = 0; i < size; i++) { - capacity *= 2; - quotation = (hex_item_t **)realloc(quotation, capacity * sizeof(hex_item_t *)); - if (!quotation) + quotation[i] = (hex_item_t *)malloc(sizeof(hex_item_t)); + if (!quotation[i]) { hex_error(ctx, "Memory allocation failed"); result = 1; break; } + quotation[i]->type = HEX_TYPE_STRING; + quotation[i]->data.str_value = strndup(&str.data.str_value[i], 1); } - quotation[size] = (hex_item_t *)malloc(sizeof(hex_item_t)); - quotation[size]->type = HEX_TYPE_STRING; - quotation[size]->data.str_value = strdup(token); - size++; - token = strtok(NULL, separator.data.str_value); + if (result == 0) + { + result = hex_push_quotation(ctx, quotation, size); + } + } + } + else + { + // Separator is not empty: split as usual + char *token = strtok(str.data.str_value, separator.data.str_value); + int capacity = 2; + int size = 0; + hex_item_t **quotation = (hex_item_t **)malloc(capacity * sizeof(hex_item_t *)); + if (!quotation) + { + hex_error(ctx, "Memory allocation failed"); + result = 1; } - if (result == 0) + else { - result = hex_push_quotation(ctx, quotation, size); + while (token) + { + if (size >= capacity) + { + capacity *= 2; + quotation = (hex_item_t **)realloc(quotation, capacity * sizeof(hex_item_t *)); + if (!quotation) + { + hex_error(ctx, "Memory allocation failed"); + result = 1; + break; + } + } + quotation[size] = (hex_item_t *)malloc(sizeof(hex_item_t)); + quotation[size]->type = HEX_TYPE_STRING; + quotation[size]->data.str_value = strdup(token); + size++; + token = strtok(NULL, separator.data.str_value); + } + if (result == 0) + { + result = hex_push_quotation(ctx, quotation, size); + } } } }