all repos — hex @ 180d70124e155be8d9dcc8e8eb99c184a8672b51

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

Added bit operations.
h3rald h3rald@h3rald.com
Sat, 16 Nov 2024 22:03:03 +0000
commit

180d70124e155be8d9dcc8e8eb99c184a8672b51

parent

91fcbc68b6e3be6ebd2ea28069bffa2572dfa81b

1 files changed, 97 insertions(+), 0 deletions(-)

jump to
M hex.chex.c

@@ -559,6 +559,79 @@ free_element(a);

free_element(b); } +// Bit operators + +void operator_bitand() +{ + StackElement right = pop(); // Pop the second operand + StackElement left = pop(); // Pop the first operand + if (left.type == TYPE_INTEGER && right.type == TYPE_INTEGER) { + int result = left.data.intValue & right.data.intValue; // Bitwise AND + push_int(result); // Push the result back onto the stack + } else { + fail("Bitwise AND requires two integers"); + } +} + +void operator_bitor() +{ + StackElement right = pop(); + StackElement left = pop(); + if (left.type == TYPE_INTEGER && right.type == TYPE_INTEGER) { + int result = left.data.intValue | right.data.intValue; // Bitwise OR + push_int(result); + } else { + fail("Bitwise OR requires two integers"); + } +} + +void operator_bitxor() +{ + StackElement right = pop(); + StackElement left = pop(); + if (left.type == TYPE_INTEGER && right.type == TYPE_INTEGER) { + int result = left.data.intValue ^ right.data.intValue; // Bitwise XOR + push_int(result); + } else { + fail("Bitwise XOR requires two integers"); + } +} + +void operator_shiftleft() +{ + StackElement right = pop(); // The number of positions to shift + StackElement left = pop(); // The value to shift + if (left.type == TYPE_INTEGER && right.type == TYPE_INTEGER) { + int result = left.data.intValue << right.data.intValue; // Left shift + push_int(result); + } else { + fail("Left shift requires two integers"); + } +} + +void operator_shiftright() +{ + StackElement right = pop(); // The number of positions to shift + StackElement left = pop(); // The value to shift + if (left.type == TYPE_INTEGER && right.type == TYPE_INTEGER) { + int result = left.data.intValue >> right.data.intValue; // Right shift + push_int(result); + } else { + fail("Right shift requires two integers"); + } +} + +void operator_bitnot() +{ + StackElement element = pop(); // Only one operand for bitwise NOT + if (element.type == TYPE_INTEGER) { + int result = ~element.data.intValue; // Bitwise NOT (complement) + push_int(result); + } else { + fail("Bitwise NOT requires one integer"); + } +} + // Converter operators void operator_int() {

@@ -635,6 +708,30 @@ }

else if (is_operator(token, "gets")) { operator_gets(); + } + else if (is_operator(token, "&")) + { + operator_bitand(); + } + else if (is_operator(token, "|")) + { + operator_bitor(); + } + else if (is_operator(token, "^")) + { + operator_bitxor(); + } + else if (is_operator(token, "~")) + { + operator_bitnot(); + } + else if (is_operator(token, "<<")) + { + operator_shiftleft(); + } + else if (is_operator(token, ">>")) + { + operator_shiftright(); } else if (is_operator(token, "-")) {