all repos — hex @ a94604c63a794cf83139f86bbc91b2b1ae4b7286

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

Fixed ==.
h3rald h3rald@h3rald.com
Tue, 26 Nov 2024 14:46:02 +0100
commit

a94604c63a794cf83139f86bbc91b2b1ae4b7286

parent

16a08d74be8162d83080c21dd44f1b80fc2c8b1f

1 files changed, 22 insertions(+), 12 deletions(-)

jump to
M hex.chex.c

@@ -1535,35 +1535,45 @@ // Comparison symbols

int hex_equal(hex_item_t a, hex_item_t b) { - int result = 0; - if (a.type == HEX_TYPE_INTEGER && b.type == HEX_TYPE_INTEGER) + if (a.type == HEX_TYPE_INVALID || b.type == HEX_TYPE_INVALID) + { + return 0; + } + if (a.type == HEX_TYPE_NATIVE_SYMBOL || a.type == HEX_TYPE_USER_SYMBOL) { - result = a.data.intValue == b.data.intValue; + return (strcmp(a.token->value, b.token->value) == 0); } - else if (a.type == HEX_TYPE_STRING && b.type == HEX_TYPE_STRING) + if (a.type != b.type) { - result = (strcmp(a.data.strValue, b.data.strValue) == 0); + return 0; } - else if (a.type == HEX_TYPE_QUOTATION && b.type == HEX_TYPE_QUOTATION) + if (a.type == HEX_TYPE_INTEGER) + { + return a.data.intValue == b.data.intValue; + } + if (a.type == HEX_TYPE_STRING) + { + return (strcmp(a.data.strValue, b.data.strValue) == 0); + } + if (a.type == HEX_TYPE_QUOTATION) { if (a.quotationSize != b.quotationSize) { - result = 0; + return 0; } else { - result = 1; for (int i = 0; i < a.quotationSize; i++) { - if (a.data.quotationValue[i] != b.data.quotationValue[i]) + if (!hex_equal(*a.data.quotationValue[i], *b.data.quotationValue[i])) { - result = 0; - break; + return 0; } } + return 1; } } - return result; + return 0; } int hex_symbol_equal()