all repos — hex @ f17d97656227812b0b5d664f209f971dfc9ec1c1

A tiny, minimalist, slightly-esoteric concatenative programming lannguage.

Fixes.
h3rald h3rald@h3rald.com
Fri, 29 Nov 2024 07:41:13 +0100
commit

f17d97656227812b0b5d664f209f971dfc9ec1c1

parent

abbec03572e7f253dc90c2152610c6230d9b7ba5

3 files changed, 37 insertions(+), 42 deletions(-)

jump to
M hex.chex.c

@@ -2,7 +2,7 @@ #include "hex.h"

// Common operations #define POP(ctx, x) hex_item_t x = hex_pop(ctx) -#define FREE(ctx, x) hex_free_element(ctx, x) +#define FREE(ctx, x) hex_free_item(ctx, x) #define PUSH(ctx, x) hex_push(ctx, x) ////////////////////////////////////////

@@ -112,7 +112,7 @@ {

hex_error(ctx, "Stack overflow"); return 1; } - hex_debug_element(ctx, "PUSH", element); + hex_debug_item(ctx, "PUSH", element); int result = 0; if (element.type == HEX_TYPE_USER_SYMBOL) {

@@ -130,7 +130,7 @@ }

} else if (element.type == HEX_TYPE_NATIVE_SYMBOL) { - hex_debug_element(ctx, "CALL", element); + hex_debug_item(ctx, "CALL", element); add_to_stack_trace(ctx, element.token); result = element.data.fnValue(ctx); }

@@ -140,11 +140,11 @@ ctx->stack.entries[++ctx->stack.top] = element;

} if (result == 0) { - hex_debug_element(ctx, "DONE", element); + hex_debug_item(ctx, "DONE", element); } else { - hex_debug_element(ctx, "FAIL", element); + hex_debug_item(ctx, "FAIL", element); } return result; }

@@ -251,31 +251,24 @@ {

hex_error(ctx, "Insufficient elements on the stack"); return (hex_item_t){.type = HEX_TYPE_INVALID}; } - hex_debug_element(ctx, " POP", ctx->stack.entries[ctx->stack.top]); + hex_debug_item(ctx, " POP", ctx->stack.entries[ctx->stack.top]); return ctx->stack.entries[ctx->stack.top--]; } // Free a stack element -void hex_free_element(hex_context_t *ctx, hex_item_t element) +void hex_free_item(hex_context_t *ctx, hex_item_t element) { - hex_debug_element(ctx, "FREE", element); + hex_debug_item(ctx, "FREE", element); if (element.type == HEX_TYPE_STRING && element.data.strValue != NULL) { - free(element.data.strValue); + /// FC Evaluate if strings actually need to be freed (segfaults in quotations) + // free(element.data.strValue); element.data.strValue = NULL; } + else if (element.type == HEX_TYPE_QUOTATION && element.data.quotationValue != NULL) { - for (int i = 0; i < element.quotationSize; i++) - { - if (element.data.quotationValue[i] != NULL) - { - FREE(ctx, *element.data.quotationValue[i]); - // free(element.data.quotationValue[i]); - // element.data.quotationValue[i] = NULL; - } - } - free(element.data.quotationValue); + hex_free_list(ctx, element.data.quotationValue, element.quotationSize); element.data.quotationValue = NULL; } else if (element.type == HEX_TYPE_NATIVE_SYMBOL && element.token->value != NULL)

@@ -290,7 +283,6 @@ }

void hex_free_list(hex_context_t *ctx, hex_item_t **quotation, int size) { - hex_error(ctx, "An error occurred while filtering the list"); for (int i = 0; i < size; i++) { FREE(ctx, *quotation[i]);

@@ -306,7 +298,7 @@ {

va_list args; va_start(args, format); vsnprintf(ctx->error, sizeof(ctx->error), format, args); - if (ctx->settings.errors_enabled) + if (ctx->settings.errors_enabled) /// FC { fprintf(stderr, "[error] "); fprintf(stderr, "%s\n", ctx->error);

@@ -348,12 +340,12 @@ return "unknown";

} } -void hex_debug_element(hex_context_t *ctx, const char *message, hex_item_t element) +void hex_debug_item(hex_context_t *ctx, const char *message, hex_item_t element) { if (ctx->settings.debugging_enabled) { fprintf(stdout, "*** %s: ", message); - hex_print_element(stdout, element); + hex_print_item(stdout, element); fprintf(stdout, "\n"); } }

@@ -869,7 +861,7 @@ {

return hex_itoa(num, 16); } -void hex_raw_print_element(FILE *stream, hex_item_t element) +void hex_raw_print_item(FILE *stream, hex_item_t element) { switch (element.type) {

@@ -891,7 +883,7 @@ if (i > 0)

{ fprintf(stream, " "); } - hex_print_element(stream, *element.data.quotationValue[i]); + hex_print_item(stream, *element.data.quotationValue[i]); } fprintf(stream, ")"); break;

@@ -905,7 +897,7 @@ break;

} } -void hex_print_element(FILE *stream, hex_item_t element) +void hex_print_item(FILE *stream, hex_item_t element) { switch (element.type) {

@@ -972,7 +964,7 @@ if (i > 0)

{ fprintf(stream, " "); } - hex_print_element(stream, *element.data.quotationValue[i]); + hex_print_item(stream, *element.data.quotationValue[i]); } fprintf(stream, ")"); break;

@@ -1139,7 +1131,7 @@ {

FREE(ctx, element); return 1; } - hex_raw_print_element(stdout, element); + hex_raw_print_item(stdout, element); printf("\n"); return 0; }

@@ -1154,7 +1146,7 @@ {

FREE(ctx, element); return 1; } - hex_raw_print_element(stderr, element); + hex_raw_print_item(stderr, element); printf("\n"); return 0; }

@@ -1169,7 +1161,7 @@ {

FREE(ctx, element); return 1; } - hex_raw_print_element(stdout, element); + hex_raw_print_item(stdout, element); return 0; }

@@ -2245,9 +2237,13 @@ size_t target_len = strlen(target.data.strValue);

size_t value_len = strlen(value.data.strValue); size_t pos = index.data.intValue; - if (pos > target_len) + if (index.data.intValue < 0 || pos > target_len) { - pos = target_len; // Append at the end if position exceeds target length + hex_error(ctx, "Index out of range"); + FREE(ctx, target); + FREE(ctx, index); + FREE(ctx, value); + return 1; } char *new_str = (char *)malloc(target_len + value_len + 1);

@@ -2282,7 +2278,7 @@ else if (target.type == HEX_TYPE_QUOTATION)

{ if (index.data.intValue < 0 || index.data.intValue > target.quotationSize) { - hex_error(ctx, "Invalid index for quotation"); + hex_error(ctx, "Index out of range"); FREE(ctx, target); FREE(ctx, index); FREE(ctx, value);

@@ -3280,10 +3276,7 @@ for (int i = 0; i < tryBlock.quotationSize; i++)

{ if (hex_push(ctx, *tryBlock.data.quotationValue[i]) != 0) { - FREE(ctx, catchBlock); - FREE(ctx, tryBlock); ctx->settings.errors_enabled = 1; - return 1; } } ctx->settings.errors_enabled = 1;

@@ -3866,8 +3859,8 @@ hex_interpret(ctx, line, "<repl>", 1, 1);

// Print the top element of the stack if (ctx->stack.top >= 0) { - hex_print_element(stdout, ctx->stack.entries[ctx->stack.top]); - // hex_print_element(stdout, HEX_STACK[HEX_TOP]); + hex_print_item(stdout, ctx->stack.entries[ctx->stack.top]); + // hex_print_item(stdout, HEX_STACK[HEX_TOP]); printf("\n"); } }
M hex.hhex.h

@@ -145,7 +145,7 @@ void hex_print_help(hex_doc_dictionary_t *docs);

void hex_print_doc(hex_doc_entry_t *doc); // Free data -void hex_free_element(hex_context_t *ctx, hex_item_t element); +void hex_free_item(hex_context_t *ctx, hex_item_t element); void hex_free_token(hex_token_t *token); void hex_free_list(hex_context_t *ctx, hex_item_t **quotation, int size);

@@ -159,8 +159,8 @@

// Errors and debugging void hex_error(hex_context_t *ctx, const char *format, ...); void hex_debug(hex_context_t *ctx, const char *format, ...); -void hex_debug_element(hex_context_t *ctx, const char *message, hex_item_t element); -void hex_print_element(FILE *stream, hex_item_t element); +void hex_debug_item(hex_context_t *ctx, const char *message, hex_item_t element); +void hex_print_item(FILE *stream, hex_item_t element); void add_to_stack_trace(hex_context_t *ctx, hex_token_t *token); void print_stack_trace(hex_context_t *ctx);

@@ -183,7 +183,7 @@ // Helpers

char *hex_itoa(int num, int base); char *hex_itoa_dec(int num); char *hex_itoa_hex(int num); -void hex_raw_print_element(FILE *stream, hex_item_t element); +void hex_raw_print_item(FILE *stream, hex_item_t element); int hex_is_symbol(hex_token_t *token, char *value); char *hex_type(hex_item_type_t type);
M tests.hextests.hex

@@ -95,6 +95,8 @@ ("abdef" "c" 0x2 insert "abcdef" ==)

("bcdef" "a" 0x0 insert "abcdef" ==) ("abcde" "f" 0x5 insert "abcdef" ==) ((0x1 0x2 0x3) 0x4 0x3 insert (0x1 0x2 0x3 0x4) ==) + ;44 + ) "tests" store