all repos — hex @ 9d4174e79962563ef59ae5faf07777c8501d8155

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

Removed slice and insert, added ord and chr.
h3rald h3rald@h3rald.com
Thu, 12 Dec 2024 07:57:43 +0100
commit

9d4174e79962563ef59ae5faf07777c8501d8155

parent

2c89d9fda662c97d5e377a5eaf3f59f1ea78f11b

3 files changed, 84 insertions(+), 281 deletions(-)

jump to
M scripts/test.hexscripts/test.hex

@@ -89,8 +89,8 @@ ;32

("hello" " world" cat "hello world" ==) ((0x1 "a") ("b") cat (0x1 "a" "b") ==) - ((0x1 0x2 0x3) 0x1 0x2 slice (0x2 0x3) ==) - ("hello" 0x0 0x3 slice "hell" ==) + ((() not) (error) try "Symbol 'not' requires an integer" ==) + ((() 0x1 xor) (error) try "Symbol 'xor' requires two integers" ==) ;36 ("aaaaa" len 0x5 ==)

@@ -99,10 +99,10 @@ ((0x2 0x3 0x4) 0x2 get 0x4 ==)

("abcde" 0x1 get "b" ==) ;40 - ("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) ==) + ("a/b/c" "t-path" : (t-path "/" index 0x0 >=) (t-path "/" "\\" replace "t-path" :) while t-path "a\\b\\c" == "t-path" #) + ("assets\"" "\"" "/" replace "assets/" ==) + (("" () cat) (error) try "Symbol 'cat' requires two quotations or two strings" ==) + ((0x4 len) (error) try "Symbol 'len' requires a quotation or a string" ==) ;44 ("this is a test" "is" index 0x2 ==)

@@ -195,32 +195,30 @@ (("a" "b" and) (error) try "Symbol 'and' requires two integers" ==)

((0x1 "a" or) (error) try "Symbol 'or' requires two integers" ==) ;104 - ((() not) (error) try "Symbol 'not' requires an integer" ==) - ((() 0x1 xor) (error) try "Symbol 'xor' requires two integers" ==) - (("" () cat) (error) try "Symbol 'cat' requires two quotations or two strings" ==) - (("abcde" 0x1 "2" slice ) (error) try "Slice indices must be integers" ==) + (("abc" 0x3 get) (error) try "Index out of range" ==) + (((0x2) 0x2 get) (error) try "Index out of range" ==) + ((() 0x0 get) (error) try "Index out of range" ==) + ((0x4 0x4 get) (error) try "Symbol 'get' requires a quotation or a string" ==) ;108 - (("abcde" 0xffffffff 0x2 slice ) (error) try "Slice indices out of range" ==) - (("abcde" 0x2 0xf slice ) (error) try "Slice indices out of range" ==) - (((0x4 0x5) 0xffffffff 0x2 slice ) (error) try "Slice indices out of range" ==) - (((0x3 0x4 0x5 0x6) 0x2 0xf slice ) (error) try "Slice indices out of range" ==) - ;112 - - ((0x4 0x5 0x6 slice) (error) try "Symbol 'slice' requires a quotation or a string" ==) - ((0x4 len) (error) try "Symbol 'len' requires a quotation or a string" ==) (("abc" "b" get) (error) try "Index must be an integer" ==) (((0x4 "aa" test) "b" get) (error) try "Index must be an integer" ==) + ("a" ord 0x61 ==) + (0x61 chr "a" ==) + ;112 + + ("=" ord 0x3d ==) + (0x3d chr "=" ==) + ("é" ord 0xffffffff ==) + (0x80 chr "" ==) ;116 - (("abc" 0x3 get) (error) try "Index out of range" ==) - (((0x2) 0x2 get) (error) try "Index out of range" ==) - ((() 0x0 get) (error) try "Index out of range" ==) - ((0x4 0x4 get) (error) try "Symbol 'get' requires a quotation or a string" ==) + ("abc" ord 0xffffffff ==) + ((0x56 ord) (error) try "Symbol 'ord' requires a string" ==) + (("t" chr) (error) try "Symbol 'chr' requires an integer" ==) + ((() chr) (error) try "Symbol 'chr' requires an integer" ==) ;120 - ("a/b/c" "t-path" : (t-path "/" index 0x0 >=) (t-path "/" "\\" replace "t-path" :) while t-path "a\\b\\c" == "t-path" #) - ("assets\"" "\"" "/" replace "assets/" ==) ) "tests" :
M src/hex.csrc/hex.c

@@ -491,14 +491,14 @@ hex_doc(docs, "int", "s", "i", "Converts a string to a hex integer.");

hex_doc(docs, "str", "i", "s", "Converts a hex integer to a string."); hex_doc(docs, "dec", "i", "s", "Converts a hex integer to a decimal string."); hex_doc(docs, "hex", "s", "i", "Converter a decimal string to a hex integer."); + hex_doc(docs, "chr", "i", "s", "Converts an integer to a single-character string."); + hex_doc(docs, "ord", "s", "i", "Converts a single-character string to an integer."); hex_doc(docs, "type", "a", "s", "Pushes the data type of 'a' on the stack."); // List hex_doc(docs, "cat", "(s s|q q) ", "(s|q)", "Concatenates two quotations or two strings."); - hex_doc(docs, "slice", "(s i1 i2|q i1 i2)", "(s|q)", "Removes 'i2' items 's' or 'q' at index 'i1'."); hex_doc(docs, "len", "(s|q)", "i ", "Returns the length of 's' or 'q'."); hex_doc(docs, "get", "(s|q)", "a", "Gets the item at position 'i' in 's' or 'q'."); - hex_doc(docs, "insert", "(s a i|q a i)", "(s|q)", "Inserts 'a' at position 'i'."); hex_doc(docs, "index", "(s a|q a)", "i", "Returns the index of 'a' within 's' or 'q'."); hex_doc(docs, "join", "q s", "s", "Joins the strings in 'q' using separator 's'.");

@@ -1703,6 +1703,60 @@ FREE(ctx, item);

return 1; } +int hex_symbol_ord(hex_context_t *ctx) +{ + POP(ctx, item); + if (item.type == HEX_TYPE_INVALID) + { + FREE(ctx, item); + return 1; + } + if (item.type == HEX_TYPE_STRING) + { + if (strlen(item.data.str_value) > 1) + { + return hex_push_integer(ctx, -1); + } + unsigned char *str = (unsigned char *)item.data.str_value; + if (str[0] < 128) + { + return hex_push_integer(ctx, str[0]); + } + else + { + return hex_push_integer(ctx, -1); + } + } + hex_error(ctx, "Symbol 'ord' requires a string"); + FREE(ctx, item); + return 1; +} + +int hex_symbol_chr(hex_context_t *ctx) +{ + POP(ctx, item); + if (item.type == HEX_TYPE_INVALID) + { + FREE(ctx, item); + return 1; + } + if (item.type == HEX_TYPE_INTEGER) + { + if (item.data.int_value >= 0 && item.data.int_value < 128) + { + char str[2] = {(char)item.data.int_value, '\0'}; + return hex_push_string(ctx, str); + } + else + { + return hex_push_string(ctx, ""); + } + } + hex_error(ctx, "Symbol 'chr' requires an integer"); + FREE(ctx, item); + return 1; +} + // Comparison symbols static int hex_equal(hex_item_t a, hex_item_t b)

@@ -2145,106 +2199,6 @@

return result; } -int hex_symbol_slice(hex_context_t *ctx) -{ - - POP(ctx, end); - if (end.type == HEX_TYPE_INVALID) - { - FREE(ctx, end); - return 1; - } - POP(ctx, start); - if (start.type == HEX_TYPE_INVALID) - { - FREE(ctx, start); - FREE(ctx, end); - return 1; - } - POP(ctx, list); - if (list.type == HEX_TYPE_INVALID) - { - FREE(ctx, list); - FREE(ctx, start); - FREE(ctx, end); - return 1; - } - int result = 0; - if (list.type == HEX_TYPE_QUOTATION) - { - if (start.type != HEX_TYPE_INTEGER || end.type != HEX_TYPE_INTEGER) - { - hex_error(ctx, "Slice indices must be integers"); - result = 1; - } - else if (start.data.int_value < 0 || start.data.int_value >= list.quotation_size || end.data.int_value < 0 || end.data.int_value >= list.quotation_size) - { - hex_error(ctx, "Slice indices out of range"); - result = 1; - } - else - { - int newSize = end.data.int_value - start.data.int_value + 1; - hex_item_t **newQuotation = (hex_item_t **)malloc(newSize * sizeof(hex_item_t *)); - if (!newQuotation) - { - hex_error(ctx, "Memory allocation failed"); - result = 1; - } - else - { - for (int i = 0; i < newSize; i++) - { - newQuotation[i] = (hex_item_t *)malloc(sizeof(hex_item_t)); - *newQuotation[i] = *list.data.quotation_value[start.data.int_value + i]; - } - result = hex_push_quotation(ctx, newQuotation, newSize); - } - } - } - else if (list.type == HEX_TYPE_STRING) - { - if (start.type != HEX_TYPE_INTEGER || end.type != HEX_TYPE_INTEGER) - { - hex_error(ctx, "Slice indices must be integers"); - result = 1; - } - else if (start.data.int_value < 0 || start.data.int_value >= (int)strlen(list.data.str_value) || end.data.int_value < 0 || end.data.int_value >= (int)strlen(list.data.str_value)) - { - hex_error(ctx, "Slice indices out of range"); - result = 1; - } - else - { - int newSize = end.data.int_value - start.data.int_value + 1; - char *newStr = (char *)malloc(newSize + 1); - if (!newStr) - { - hex_error(ctx, "Memory allocation failed"); - result = 1; - } - else - { - strncpy(newStr, list.data.str_value + start.data.int_value, newSize); - newStr[newSize] = '\0'; - result = hex_push_string(ctx, newStr); - } - } - } - else - { - hex_error(ctx, "Symbol 'slice' requires a quotation or a string"); - result = 1; - } - if (result != 0) - { - FREE(ctx, list); - FREE(ctx, start); - FREE(ctx, end); - } - return result; -} - int hex_symbol_len(hex_context_t *ctx) {

@@ -2339,155 +2293,6 @@ FREE(ctx, list);

FREE(ctx, index); } return result; -} - -int hex_symbol_insert(hex_context_t *ctx) -{ - - POP(ctx, index); - if (index.type == HEX_TYPE_INVALID) - { - FREE(ctx, index); - return 1; - } - POP(ctx, value); - if (value.type == HEX_TYPE_INVALID) - { - FREE(ctx, index); - FREE(ctx, value); - return 1; - } - - POP(ctx, target); - if (target.type == HEX_TYPE_INVALID) - { - FREE(ctx, target); - FREE(ctx, index); - FREE(ctx, value); - return 1; - } - - if (index.type != HEX_TYPE_INTEGER) - { - hex_error(ctx, "Index must be an integer"); - FREE(ctx, target); - FREE(ctx, index); - FREE(ctx, value); - return 1; - } - - if (target.type == HEX_TYPE_STRING) - { - if (value.type != HEX_TYPE_STRING) - { - hex_error(ctx, "Value must be a string when inserting into a string"); - FREE(ctx, target); - FREE(ctx, index); - FREE(ctx, value); - return 1; - } - - size_t target_len = strlen(target.data.str_value); - size_t value_len = strlen(value.data.str_value); - size_t pos = index.data.int_value; - - if (index.data.int_value < 0 || pos > target_len) - { - 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); - if (!new_str) - { - hex_error(ctx, "Memory allocation failed"); - FREE(ctx, target); - FREE(ctx, index); - FREE(ctx, value); - return 1; - } - - strncpy(new_str, target.data.str_value, pos); - strcpy(new_str + pos, value.data.str_value); - strcpy(new_str + pos + value_len, target.data.str_value + pos); - - free(target.data.str_value); - target.data.str_value = new_str; - - if (PUSH(ctx, target) != 0) - { - free(new_str); - FREE(ctx, target); - FREE(ctx, index); - FREE(ctx, value); - return 1; // Failed to push the result onto the stack - } - - return 0; - } - else if (target.type == HEX_TYPE_QUOTATION) - { - if (index.data.int_value < 0 || index.data.int_value > target.quotation_size) - { - hex_error(ctx, "Index out of range"); - FREE(ctx, target); - FREE(ctx, index); - FREE(ctx, value); - return 1; - } - - hex_item_t **new_quotation = (hex_item_t **)realloc( - target.data.quotation_value, - (target.quotation_size + 1) * sizeof(hex_item_t *)); - if (!new_quotation) - { - hex_error(ctx, "Memory allocation failed"); - FREE(ctx, target); - FREE(ctx, index); - FREE(ctx, value); - return 1; - } - - for (size_t i = target.quotation_size; i > (size_t)index.data.int_value; --i) - { - new_quotation[i] = new_quotation[i - 1]; - } - new_quotation[index.data.int_value] = (hex_item_t *)malloc(sizeof(hex_item_t)); - if (!new_quotation[index.data.int_value]) - { - hex_error(ctx, "Memory allocation failed"); - FREE(ctx, target); - FREE(ctx, index); - FREE(ctx, value); - return 1; - } - - *new_quotation[index.data.int_value] = value; - target.data.quotation_value = new_quotation; - target.quotation_size++; - - if (PUSH(ctx, target) != 0) - { - free(new_quotation[index.data.int_value]); - FREE(ctx, target); - FREE(ctx, index); - FREE(ctx, value); - return 1; // Failed to push the result onto the stack - } - - return 0; - } - else - { - hex_error(ctx, "Target must be a string or quotation"); - FREE(ctx, target); - FREE(ctx, index); - FREE(ctx, value); - return 1; - } } int hex_symbol_index(hex_context_t *ctx)

@@ -3806,6 +3611,8 @@ hex_set_native_symbol(ctx, "int", hex_symbol_int);

hex_set_native_symbol(ctx, "str", hex_symbol_str); hex_set_native_symbol(ctx, "dec", hex_symbol_dec); hex_set_native_symbol(ctx, "hex", hex_symbol_hex); + hex_set_native_symbol(ctx, "chr", hex_symbol_chr); + hex_set_native_symbol(ctx, "ord", hex_symbol_ord); hex_set_native_symbol(ctx, "==", hex_symbol_equal); hex_set_native_symbol(ctx, "!=", hex_symbol_notequal); hex_set_native_symbol(ctx, ">", hex_symbol_greater);

@@ -3817,10 +3624,8 @@ hex_set_native_symbol(ctx, "or", hex_symbol_or);

hex_set_native_symbol(ctx, "not", hex_symbol_not); hex_set_native_symbol(ctx, "xor", hex_symbol_xor); hex_set_native_symbol(ctx, "cat", hex_symbol_cat); - hex_set_native_symbol(ctx, "slice", hex_symbol_slice); hex_set_native_symbol(ctx, "len", hex_symbol_len); hex_set_native_symbol(ctx, "get", hex_symbol_get); - hex_set_native_symbol(ctx, "insert", hex_symbol_insert); hex_set_native_symbol(ctx, "index", hex_symbol_index); hex_set_native_symbol(ctx, "join", hex_symbol_join); hex_set_native_symbol(ctx, "split", hex_symbol_split);
M web/contents/spec.htmlweb/contents/spec.html

@@ -111,19 +111,19 @@ <h5 id="dec-symbol"><code>dec</code> Symbol</h5>

<p><mark> i &rarr; s</mark></p> <h5 id="hex-symbol"><code>hex</code> Symbol</h5> <p><mark> s &rarr; i</mark></p> + <h5 id="ord-symbol"><code>ord</code> Symbol</h5> + <p><mark> s &rarr; i</mark></p> + <h5 id="chr-symbol"><code>chr</code> Symbol</h5> + <p><mark> i &rarr; s</mark></p> <h5 id="type-symbol"><code>type</code> Symbol</h5> <p><mark> a &rarr; s</mark></p> <h4 id="list-symbols">List (Strings and Quotations) Symbols</h4> <h5 id="cat-symbol"><code>cat</code> Symbol</h5> <p><mark> (s s|q q) &rarr; (s|q)</mark></p> - <h5 id="slice-symbol"><code>slice</code> Symbol</h5> - <p><mark> (s i1 i2|q i1 i2) &rarr; (s|q)</mark></p> <h5 id="len-symbol"><code>len</code> Symbol</h5> <p><mark> (s|q) &rarr; i</mark></p> <h5 id="get-symbol"><code>get</code> Symbol</h5> <p><mark> (s|q) &rarr; a</mark></p> - <h5 id="insert-symbol"><code>insert</code> Symbol</h5> - <p><mark> (s a i|q a i) &rarr; (s|q)</mark></p> <h5 id="index-symbol"><code>index</code> Symbol</h5> <p><mark> (s a|q a) &rarr; i</mark></p> <h5 id="join-symbol"><code>join</code> Symbol</h5>