about summary refs log tree commit diff stats
path: root/js/scripting-lang/baba-yaga-c/src
diff options
context:
space:
mode:
Diffstat (limited to 'js/scripting-lang/baba-yaga-c/src')
-rw-r--r--js/scripting-lang/baba-yaga-c/src/function.c22
-rw-r--r--js/scripting-lang/baba-yaga-c/src/interpreter.c82
-rw-r--r--js/scripting-lang/baba-yaga-c/src/parser.c23
-rw-r--r--js/scripting-lang/baba-yaga-c/src/stdlib.c264
4 files changed, 310 insertions, 81 deletions
diff --git a/js/scripting-lang/baba-yaga-c/src/function.c b/js/scripting-lang/baba-yaga-c/src/function.c
index 57910cc..2eca14d 100644
--- a/js/scripting-lang/baba-yaga-c/src/function.c
+++ b/js/scripting-lang/baba-yaga-c/src/function.c
@@ -46,6 +46,8 @@ typedef struct {
     char* source;       /**< Source code for debugging */
 } FunctionBody;
 
+
+
 /**
  * @brief Function value structure
  */
@@ -56,7 +58,7 @@ typedef struct {
     int param_count;            /**< Number of parameters */
     int required_params;        /**< Number of required parameters */
     union {
-        Value (*native_func)(Value*, int);  /**< Native function pointer */
+        Value (*native_func)(Value*, int, Scope*);  /**< Native function pointer */
         FunctionBody user_body;             /**< User function body */
     } body;
     void* closure_scope;        /**< Closure scope (placeholder) */
@@ -86,7 +88,9 @@ static void function_body_destroy(FunctionBody* body) {
  * Public Function API
  * ============================================================================ */
 
-Value baba_yaga_value_function(const char* name, Value (*body)(Value*, int), 
+
+
+Value baba_yaga_value_function(const char* name, Value (*body)(Value*, int, Scope*), 
                               int param_count, int required_param_count) {
     Value value;
     value.type = VAL_FUNCTION;
@@ -140,7 +144,9 @@ Value baba_yaga_function_call(const Value* func, const Value* args,
     
     FunctionValue* func_value = (FunctionValue*)func->data.function;
     
-    /* Check if we have enough arguments */
+
+    
+    /* Check if we have enough arguments for partial application */
     if (arg_count < func_value->required_params) {
         /* TODO: Implement partial application */
         /* For now, return a new function with fewer required parameters */
@@ -151,7 +157,7 @@ Value baba_yaga_function_call(const Value* func, const Value* args,
     switch (func_value->type) {
     case FUNC_NATIVE:
         if (func_value->body.native_func != NULL) {
-            return func_value->body.native_func((Value*)args, arg_count);
+            return func_value->body.native_func((Value*)args, arg_count, scope);
         }
         break;
         
@@ -187,6 +193,8 @@ Value baba_yaga_function_call(const Value* func, const Value* args,
             return result;
         }
         break;
+        
+
     }
     
     return baba_yaga_value_nil();
@@ -231,9 +239,9 @@ void function_decrement_ref(Value* func) {
             }
             
                     /* Clean up function body */
-        if (func_value->type == FUNC_USER) {
-            function_body_destroy(&func_value->body.user_body);
-        }
+            if (func_value->type == FUNC_USER) {
+                function_body_destroy(&func_value->body.user_body);
+            }
             
             /* TODO: Clean up closure scope */
             
diff --git a/js/scripting-lang/baba-yaga-c/src/interpreter.c b/js/scripting-lang/baba-yaga-c/src/interpreter.c
index 4b53e7d..f865adb 100644
--- a/js/scripting-lang/baba-yaga-c/src/interpreter.c
+++ b/js/scripting-lang/baba-yaga-c/src/interpreter.c
@@ -74,7 +74,7 @@ static void register_stdlib(Scope* scope) {
     DEBUG_INFO("Registering standard library functions");
     
     /* Core combinator */
-    Value apply_func = baba_yaga_value_function("apply", stdlib_apply, 10, 1);
+    Value apply_func = baba_yaga_value_function("apply", stdlib_apply_wrapper, 10, 1);
     scope_define(scope, "apply", apply_func, true);
     
     /* Predefined variables for testing */
@@ -82,90 +82,90 @@ static void register_stdlib(Scope* scope) {
     scope_define(scope, "hello", hello_var, true);
     
     /* Arithmetic functions */
-    Value add_func = baba_yaga_value_function("add", stdlib_add, 2, 2);
+    Value add_func = baba_yaga_value_function("add", stdlib_add_wrapper, 2, 2);
     scope_define(scope, "add", add_func, true);
     
-    Value subtract_func = baba_yaga_value_function("subtract", stdlib_subtract, 2, 2);
+    Value subtract_func = baba_yaga_value_function("subtract", stdlib_subtract_wrapper, 2, 2);
     scope_define(scope, "subtract", subtract_func, true);
     
-    Value multiply_func = baba_yaga_value_function("multiply", stdlib_multiply, 2, 2);
+    Value multiply_func = baba_yaga_value_function("multiply", stdlib_multiply_wrapper, 2, 2);
     scope_define(scope, "multiply", multiply_func, true);
     
-    Value divide_func = baba_yaga_value_function("divide", stdlib_divide, 2, 2);
+    Value divide_func = baba_yaga_value_function("divide", stdlib_divide_wrapper, 2, 2);
     scope_define(scope, "divide", divide_func, true);
     
-    Value modulo_func = baba_yaga_value_function("modulo", stdlib_modulo, 2, 2);
+    Value modulo_func = baba_yaga_value_function("modulo", stdlib_modulo_wrapper, 2, 2);
     scope_define(scope, "modulo", modulo_func, true);
     
-    Value pow_func = baba_yaga_value_function("pow", stdlib_pow, 2, 2);
+    Value pow_func = baba_yaga_value_function("pow", stdlib_pow_wrapper, 2, 2);
     scope_define(scope, "pow", pow_func, true);
     
-    Value negate_func = baba_yaga_value_function("negate", stdlib_negate, 1, 1);
+    Value negate_func = baba_yaga_value_function("negate", stdlib_negate_wrapper, 1, 1);
     scope_define(scope, "negate", negate_func, true);
     
     /* Comparison functions */
-    Value equals_func = baba_yaga_value_function("equals", stdlib_equals, 2, 2);
+    Value equals_func = baba_yaga_value_function("equals", stdlib_equals_wrapper, 2, 2);
     scope_define(scope, "equals", equals_func, true);
     
-    Value not_equals_func = baba_yaga_value_function("not_equals", stdlib_not_equals, 2, 2);
+    Value not_equals_func = baba_yaga_value_function("not_equals", stdlib_not_equals_wrapper, 2, 2);
     scope_define(scope, "not_equals", not_equals_func, true);
     
-    Value less_func = baba_yaga_value_function("less", stdlib_less, 2, 2);
+    Value less_func = baba_yaga_value_function("less", stdlib_less_wrapper, 2, 2);
     scope_define(scope, "less", less_func, true);
     
-    Value less_equal_func = baba_yaga_value_function("less_equal", stdlib_less_equal, 2, 2);
+    Value less_equal_func = baba_yaga_value_function("less_equal", stdlib_less_equal_wrapper, 2, 2);
     scope_define(scope, "less_equal", less_equal_func, true);
     
-    Value greater_func = baba_yaga_value_function("greater", stdlib_greater, 2, 2);
+    Value greater_func = baba_yaga_value_function("greater", stdlib_greater_wrapper, 2, 2);
     scope_define(scope, "greater", greater_func, true);
     
-    Value greater_equal_func = baba_yaga_value_function("greater_equal", stdlib_greater_equal, 2, 2);
+    Value greater_equal_func = baba_yaga_value_function("greater_equal", stdlib_greater_equal_wrapper, 2, 2);
     scope_define(scope, "greater_equal", greater_equal_func, true);
     
     /* Add canonical names for JavaScript compatibility */
-    Value greater_than_func = baba_yaga_value_function("greaterThan", stdlib_greater, 2, 2);
+    Value greater_than_func = baba_yaga_value_function("greaterThan", stdlib_greater_wrapper, 2, 2);
     scope_define(scope, "greaterThan", greater_than_func, true);
     
-    Value less_than_func = baba_yaga_value_function("lessThan", stdlib_less, 2, 2);
+    Value less_than_func = baba_yaga_value_function("lessThan", stdlib_less_wrapper, 2, 2);
     scope_define(scope, "lessThan", less_than_func, true);
     
-    Value greater_equal_than_func = baba_yaga_value_function("greaterEqual", stdlib_greater_equal, 2, 2);
+    Value greater_equal_than_func = baba_yaga_value_function("greaterEqual", stdlib_greater_equal_wrapper, 2, 2);
     scope_define(scope, "greaterEqual", greater_equal_than_func, true);
     
-    Value less_equal_than_func = baba_yaga_value_function("lessEqual", stdlib_less_equal, 2, 2);
+    Value less_equal_than_func = baba_yaga_value_function("lessEqual", stdlib_less_equal_wrapper, 2, 2);
     scope_define(scope, "lessEqual", less_equal_than_func, true);
     
     /* Logical functions */
-    Value and_func = baba_yaga_value_function("and", stdlib_and, 2, 2);
+    Value and_func = baba_yaga_value_function("and", stdlib_and_wrapper, 2, 2);
     scope_define(scope, "and", and_func, true);
     
-    Value or_func = baba_yaga_value_function("or", stdlib_or, 2, 2);
+    Value or_func = baba_yaga_value_function("or", stdlib_or_wrapper, 2, 2);
     scope_define(scope, "or", or_func, true);
     
-    Value xor_func = baba_yaga_value_function("xor", stdlib_xor, 2, 2);
+    Value xor_func = baba_yaga_value_function("xor", stdlib_xor_wrapper, 2, 2);
     scope_define(scope, "xor", xor_func, true);
     
-    Value not_func = baba_yaga_value_function("not", stdlib_not, 1, 1);
+    Value not_func = baba_yaga_value_function("not", stdlib_not_wrapper, 1, 1);
     scope_define(scope, "not", not_func, true);
     
     /* Function composition */
-    Value compose_func = baba_yaga_value_function("compose", stdlib_compose, 4, 2);
+    Value compose_func = baba_yaga_value_function("compose", stdlib_compose_wrapper, 4, 2);
     scope_define(scope, "compose", compose_func, true);
     
     /* IO functions */
-    Value out_func = baba_yaga_value_function("out", stdlib_out, 1, 1);
+    Value out_func = baba_yaga_value_function("out", stdlib_out_wrapper, 1, 1);
     scope_define(scope, "out", out_func, true);
     
-    Value in_func = baba_yaga_value_function("in", stdlib_in, 0, 0);
+    Value in_func = baba_yaga_value_function("in", stdlib_in_wrapper, 0, 0);
     scope_define(scope, "in", in_func, true);
     
-    Value assert_func = baba_yaga_value_function("assert", stdlib_assert, 1, 1);
+    Value assert_func = baba_yaga_value_function("assert", stdlib_assert_wrapper, 1, 1);
     scope_define(scope, "assert", assert_func, true);
     
-    Value emit_func = baba_yaga_value_function("emit", stdlib_emit, 1, 1);
+    Value emit_func = baba_yaga_value_function("emit", stdlib_emit_wrapper, 1, 1);
     scope_define(scope, "emit", emit_func, true);
     
-    Value listen_func = baba_yaga_value_function("listen", stdlib_listen, 0, 0);
+    Value listen_func = baba_yaga_value_function("listen", stdlib_listen_wrapper, 0, 0);
     scope_define(scope, "listen", listen_func, true);
     
     /* Higher-order functions */
@@ -179,45 +179,45 @@ static void register_stdlib(Scope* scope) {
     scope_define(scope, "reduce", reduce_func, true);
     
     /* Advanced combinators */
-    Value each_func = baba_yaga_value_function("each", stdlib_each, 3, 2);
+    Value each_func = baba_yaga_value_function("each", stdlib_each, 3, 3);
     scope_define(scope, "each", each_func, true);
     
-    Value flip_func = baba_yaga_value_function("flip", stdlib_flip, 3, 1);
+    Value flip_func = baba_yaga_value_function("flip", stdlib_flip_wrapper, 3, 1);
     scope_define(scope, "flip", flip_func, true);
     
-    Value constant_func = baba_yaga_value_function("constant", stdlib_constant, 2, 1);
+    Value constant_func = baba_yaga_value_function("constant", stdlib_constant_wrapper, 2, 1);
     scope_define(scope, "constant", constant_func, true);
     
     /* Table operations namespace */
-    Value t_map_func = baba_yaga_value_function("t.map", stdlib_t_map, 2, 2);
+    Value t_map_func = baba_yaga_value_function("t.map", stdlib_t_map_wrapper, 2, 2);
     scope_define(scope, "t.map", t_map_func, true);
     
-    Value t_filter_func = baba_yaga_value_function("t.filter", stdlib_t_filter, 2, 2);
+    Value t_filter_func = baba_yaga_value_function("t.filter", stdlib_t_filter_wrapper, 2, 2);
     scope_define(scope, "t.filter", t_filter_func, true);
     
-    Value t_reduce_func = baba_yaga_value_function("t.reduce", stdlib_t_reduce, 3, 3);
+    Value t_reduce_func = baba_yaga_value_function("t.reduce", stdlib_t_reduce_wrapper, 3, 3);
     scope_define(scope, "t.reduce", t_reduce_func, true);
     
-    Value t_set_func = baba_yaga_value_function("t.set", stdlib_t_set, 3, 3);
+    Value t_set_func = baba_yaga_value_function("t.set", stdlib_t_set_wrapper, 3, 3);
     scope_define(scope, "t.set", t_set_func, true);
     
-    Value t_delete_func = baba_yaga_value_function("t.delete", stdlib_t_delete, 2, 2);
+    Value t_delete_func = baba_yaga_value_function("t.delete", stdlib_t_delete_wrapper, 2, 2);
     scope_define(scope, "t.delete", t_delete_func, true);
     
-    Value t_merge_func = baba_yaga_value_function("t.merge", stdlib_t_merge, 2, 2);
+    Value t_merge_func = baba_yaga_value_function("t.merge", stdlib_t_merge_wrapper, 2, 2);
     scope_define(scope, "t.merge", t_merge_func, true);
     
-    Value t_length_func = baba_yaga_value_function("t.length", stdlib_t_length, 1, 1);
+    Value t_length_func = baba_yaga_value_function("t.length", stdlib_t_length_wrapper, 1, 1);
     scope_define(scope, "t.length", t_length_func, true);
     
-    Value t_has_func = baba_yaga_value_function("t.has", stdlib_t_has, 2, 2);
+    Value t_has_func = baba_yaga_value_function("t.has", stdlib_t_has_wrapper, 2, 2);
     scope_define(scope, "t.has", t_has_func, true);
     
-    Value t_get_func = baba_yaga_value_function("t.get", stdlib_t_get, 3, 3);
+    Value t_get_func = baba_yaga_value_function("t.get", stdlib_t_get_wrapper, 3, 3);
     scope_define(scope, "t.get", t_get_func, true);
     
     /* Internal table entry function for key-value pairs */
-    Value table_entry_func = baba_yaga_value_function("table_entry", stdlib_table_entry, 2, 2);
+    Value table_entry_func = baba_yaga_value_function("table_entry", stdlib_table_entry_wrapper, 2, 2);
     scope_define(scope, "table_entry", table_entry_func, true);
     
     /* Create t namespace table */
diff --git a/js/scripting-lang/baba-yaga-c/src/parser.c b/js/scripting-lang/baba-yaga-c/src/parser.c
index 896c24f..6c94913 100644
--- a/js/scripting-lang/baba-yaga-c/src/parser.c
+++ b/js/scripting-lang/baba-yaga-c/src/parser.c
@@ -2618,7 +2618,6 @@ static ASTNode* parser_parse_when_expression(Parser* parser) {
             Token* current_token = parser_peek(parser);
             if (current_token->type == TOKEN_LPAREN) {
                 /* Expression in parentheses - parse the expression */
-                /* Parse expression but stop at 'is' token */
                 identifiers[i] = parser_parse_expression(parser);
                 if (identifiers[i] == NULL) {
                     /* Cleanup on error */
@@ -2628,13 +2627,6 @@ static ASTNode* parser_parse_when_expression(Parser* parser) {
                     free(identifiers);
                     return NULL;
                 }
-                
-                /* Check if we consumed the 'is' token and back up if needed */
-                if (parser->current < parser->token_count && 
-                    parser->tokens[parser->current]->type == TOKEN_KEYWORD_IS) {
-                    /* We consumed the 'is' token, need to back up */
-                    parser->current--;
-                }
             } else {
                 /* Identifier - parse as identifier */
                 Token* id_token = parser_advance(parser);
@@ -2644,6 +2636,18 @@ static ASTNode* parser_parse_when_expression(Parser* parser) {
         
         /* Create a sequence node for the identifiers */
         test = ast_sequence_node(identifiers, identifier_count, when_token->line, when_token->column);
+        
+        /* Ensure we're positioned at the 'is' token */
+        if (parser->current < parser->token_count && 
+            parser->tokens[parser->current]->type != TOKEN_KEYWORD_IS) {
+            /* We're not at the 'is' token - find it */
+            for (int j = parser->current; j < parser->token_count; j++) {
+                if (parser->tokens[j]->type == TOKEN_KEYWORD_IS) {
+                    parser->current = j;
+                    break;
+                }
+            }
+        }
     } else {
         /* Parse as single expression */
         test = parser_parse_expression(parser);
@@ -2796,6 +2800,9 @@ static ASTNode* parser_parse_when_pattern(Parser* parser) {
             /* If we hit a comparison operator, it's not multi-parameter */
             literal_count = 0;
             break;
+        } else if (token->type == TOKEN_SEMICOLON) {
+            /* If we hit a semicolon, stop looking */
+            break;
         } else {
             /* If we hit anything other than a literal or expression, it's not multi-parameter */
             literal_count = 0;
diff --git a/js/scripting-lang/baba-yaga-c/src/stdlib.c b/js/scripting-lang/baba-yaga-c/src/stdlib.c
index ed34541..3ecce0b 100644
--- a/js/scripting-lang/baba-yaga-c/src/stdlib.c
+++ b/js/scripting-lang/baba-yaga-c/src/stdlib.c
@@ -16,6 +16,191 @@
 #include "baba_yaga.h"
 
 /* ============================================================================
+ * Wrapper Functions for Basic Operations (to match function signature)
+ * ============================================================================ */
+
+Value stdlib_add_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_add(args, argc);
+}
+
+Value stdlib_subtract_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_subtract(args, argc);
+}
+
+Value stdlib_multiply_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_multiply(args, argc);
+}
+
+Value stdlib_divide_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_divide(args, argc);
+}
+
+Value stdlib_modulo_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_modulo(args, argc);
+}
+
+Value stdlib_pow_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_pow(args, argc);
+}
+
+Value stdlib_negate_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_negate(args, argc);
+}
+
+Value stdlib_equals_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_equals(args, argc);
+}
+
+Value stdlib_not_equals_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_not_equals(args, argc);
+}
+
+Value stdlib_less_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_less(args, argc);
+}
+
+Value stdlib_less_equal_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_less_equal(args, argc);
+}
+
+Value stdlib_greater_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_greater(args, argc);
+}
+
+Value stdlib_greater_equal_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_greater_equal(args, argc);
+}
+
+Value stdlib_and_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_and(args, argc);
+}
+
+Value stdlib_or_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_or(args, argc);
+}
+
+Value stdlib_xor_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_xor(args, argc);
+}
+
+Value stdlib_not_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_not(args, argc);
+}
+
+Value stdlib_compose_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_compose(args, argc);
+}
+
+Value stdlib_out_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_out(args, argc);
+}
+
+Value stdlib_in_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_in(args, argc);
+}
+
+Value stdlib_assert_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_assert(args, argc);
+}
+
+Value stdlib_emit_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_emit(args, argc);
+}
+
+Value stdlib_listen_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_listen(args, argc);
+}
+
+Value stdlib_flip_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_flip(args, argc);
+}
+
+Value stdlib_constant_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_constant(args, argc);
+}
+
+Value stdlib_apply_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_apply(args, argc);
+}
+
+/* Table operation wrappers */
+Value stdlib_t_map_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_t_map(args, argc);
+}
+
+Value stdlib_t_filter_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_t_filter(args, argc);
+}
+
+Value stdlib_t_reduce_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_t_reduce(args, argc);
+}
+
+Value stdlib_t_set_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_t_set(args, argc);
+}
+
+Value stdlib_t_delete_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_t_delete(args, argc);
+}
+
+Value stdlib_t_merge_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_t_merge(args, argc);
+}
+
+Value stdlib_t_length_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_t_length(args, argc);
+}
+
+Value stdlib_t_has_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_t_has(args, argc);
+}
+
+Value stdlib_t_get_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_t_get(args, argc);
+}
+
+Value stdlib_table_entry_wrapper(Value* args, int argc, Scope* scope) {
+    (void)scope; /* Unused */
+    return stdlib_table_entry(args, argc);
+}
+
+/* ============================================================================
  * Standard Library Functions
  * ============================================================================ */
 
@@ -556,7 +741,7 @@ Value stdlib_listen(Value* args, int argc) {
 }
 
 /* Higher-order functions */
-Value stdlib_map(Value* args, int argc) {
+Value stdlib_map(Value* args, int argc, Scope* scope) {
     if (argc != 2) {
         DEBUG_ERROR("map: expected 2 arguments, got %d", argc);
         return baba_yaga_value_nil();
@@ -575,61 +760,90 @@ Value stdlib_map(Value* args, int argc) {
         return baba_yaga_value_nil();
     }
     
-    /* For now, return the original table */
-    /* TODO: Implement actual mapping */
-    DEBUG_DEBUG("map: mapping function over table");
-    return baba_yaga_value_copy(&table);
+    DEBUG_DEBUG("map: applying function to each value in table");
+    
+    char* keys[1000];
+    size_t key_count = baba_yaga_table_get_keys(&table, keys, 1000);
+    Value result = baba_yaga_value_table();
+    for (size_t i = 0; i < key_count; i++) {
+        Value value = baba_yaga_table_get_by_key(&table, keys[i]);
+        if (value.type != VAL_NIL) {
+            Value func_args[1] = {value};
+            Value mapped_value = baba_yaga_function_call(&func, func_args, 1, scope);
+            result = baba_yaga_table_set(&result, keys[i], &mapped_value);
+        }
+        free(keys[i]);
+    }
+    return result;
 }
 
-Value stdlib_filter(Value* args, int argc) {
+Value stdlib_filter(Value* args, int argc, Scope* scope) {
     if (argc != 2) {
         DEBUG_ERROR("filter: expected 2 arguments, got %d", argc);
         return baba_yaga_value_nil();
     }
-    
     Value func = args[0];
     Value table = args[1];
-    
     if (func.type != VAL_FUNCTION) {
         DEBUG_ERROR("filter: first argument must be a function");
         return baba_yaga_value_nil();
     }
-    
     if (table.type != VAL_TABLE) {
         DEBUG_ERROR("filter: second argument must be a table");
         return baba_yaga_value_nil();
     }
-    
-    /* For now, return the original table */
-    /* TODO: Implement actual filtering */
-    DEBUG_DEBUG("filter: filtering table with function");
-    return baba_yaga_value_copy(&table);
+    DEBUG_DEBUG("filter: filtering table with predicate");
+    char* keys[1000];
+    size_t key_count = baba_yaga_table_get_keys(&table, keys, 1000);
+    Value result = baba_yaga_value_table();
+    int result_index = 1;
+    for (size_t i = 0; i < key_count; i++) {
+        Value value = baba_yaga_table_get_by_key(&table, keys[i]);
+        if (value.type != VAL_NIL) {
+            Value func_args[1] = {value};
+            Value predicate_result = baba_yaga_function_call(&func, func_args, 1, scope);
+            if (baba_yaga_value_is_truthy(&predicate_result)) {
+                char key_str[32];
+                snprintf(key_str, sizeof(key_str), "%d", result_index++);
+                result = baba_yaga_table_set(&result, key_str, &value);
+            }
+        }
+        free(keys[i]);
+    }
+    return result;
 }
 
-Value stdlib_reduce(Value* args, int argc) {
+Value stdlib_reduce(Value* args, int argc, Scope* scope) {
     if (argc != 3) {
         DEBUG_ERROR("reduce: expected 3 arguments, got %d", argc);
         return baba_yaga_value_nil();
     }
-    
     Value func = args[0];
     Value initial = args[1];
     Value table = args[2];
-    
     if (func.type != VAL_FUNCTION) {
         DEBUG_ERROR("reduce: first argument must be a function");
         return baba_yaga_value_nil();
     }
-    
     if (table.type != VAL_TABLE) {
         DEBUG_ERROR("reduce: third argument must be a table");
         return baba_yaga_value_nil();
     }
-    
-    /* For now, return the initial value */
-    /* TODO: Implement actual reduction */
     DEBUG_DEBUG("reduce: reducing table with function");
-    return baba_yaga_value_copy(&initial);
+    char* keys[1000];
+    size_t key_count = baba_yaga_table_get_keys(&table, keys, 1000);
+    Value result = baba_yaga_value_copy(&initial);
+    for (size_t i = 0; i < key_count; i++) {
+        Value value = baba_yaga_table_get_by_key(&table, keys[i]);
+        if (value.type != VAL_NIL) {
+            Value func_args[2] = {result, value};
+            Value new_result = baba_yaga_function_call(&func, func_args, 2, scope);
+            baba_yaga_value_destroy(&result);
+            result = new_result;
+        }
+        free(keys[i]);
+    }
+    return result;
 }
 
 /**
@@ -639,7 +853,7 @@ Value stdlib_reduce(Value* args, int argc) {
  * @param argc Number of arguments (should be 3)
  * @return New table with function applied to each element
  */
-Value stdlib_each(Value* args, int argc) {
+Value stdlib_each(Value* args, int argc, Scope* scope) {
     if (argc != 3) {
         DEBUG_ERROR("each: expected 3 arguments, got %d", argc);
         return baba_yaga_value_nil();
@@ -694,7 +908,7 @@ Value stdlib_each(Value* args, int argc) {
                 Value func_args[2];
                 func_args[0] = element1;
                 func_args[1] = element2;
-                Value element_result = baba_yaga_function_call(&func, func_args, 2, NULL);
+                Value element_result = baba_yaga_function_call(&func, func_args, 2, scope);
                 
                 /* Add result to new table */
                 result = baba_yaga_table_set(&result, keys[i], &element_result);
@@ -719,7 +933,7 @@ Value stdlib_each(Value* args, int argc) {
                 Value func_args[2];
                 func_args[0] = element;
                 func_args[1] = arg3;
-                Value element_result = baba_yaga_function_call(&func, func_args, 2, NULL);
+                Value element_result = baba_yaga_function_call(&func, func_args, 2, scope);
                 
                 /* Add result to new table */
                 result = baba_yaga_table_set(&result, keys[i], &element_result);