extern "C" closure builtin_function_reapply(OperationArgs& Args) { int index1 = Args.reference(0).as_index_var(); int R1 = Args.current_closure().lookup_in_env( index1 ); int index2 = Args.reference(1).as_index_var(); int R2 = Args.current_closure().lookup_in_env( index2 ); expression_ref apply_E; { expression_ref fE = index_var(1); expression_ref argE = index_var(0); apply_E = (fE, argE); } // %1 %0 {R1,R2} int apply_reg = Args.allocate({apply_E,{R1, R2}}); // FIXME - aren't we trying to eliminate general evaluation of regs that aren't children? See below: // Evaluate the newly create application reg - and depend upon it! if (Args.evaluate_changeables()) Args.evaluate_reg_to_object(apply_reg); return {index_var(0),{apply_reg}}; }
extern "C" closure builtin_function_get_modifiable_for_index(OperationArgs& Args) { assert(not Args.evaluate_changeables()); int R1 = Args.evaluate(0).as_int(); return {index_var(0),{R1}}; }
extern "C" closure builtin_function_get_modifiable_index(OperationArgs& Args) { assert(not Args.evaluate_changeables()); int R1 = Args.evaluate_slot_to_reg(0); const reg_heap& M = Args.memory(); assert(is_modifiable(M.access(R1).C.exp)); return {R1}; }
extern "C" closure builtin_function_is_changeable(OperationArgs& Args) { assert(not Args.evaluate_changeables()); int R1 = Args.evaluate_slot_to_reg(0); const reg_heap& M = Args.memory(); if (M.reg_is_changeable(R1)) return constructor("Prelude.True",0); else return constructor("Prelude.False",0); }
extern "C" closure builtin_function_is_modifiable(OperationArgs& Args) { assert(not Args.evaluate_changeables()); int R1 = Args.evaluate_slot_to_reg(0); const reg_heap& M = Args.memory(); if (M.access(R1).C.exp.head().type() == modifiable_type) return constructor("Prelude.True",0); else return constructor("Prelude.False",0); }
extern "C" closure builtin_function_register_probability(OperationArgs& Args) { assert(not Args.evaluate_changeables()); int R = Args.reg_for_slot(0); auto& M = Args.memory(); M.register_probability(R); return constructor("()",0); }
extern "C" closure builtin_function_set_modifiable_value(OperationArgs& Args) { assert(not Args.evaluate_changeables()); int c = Args.evaluate(0).as_int(); int R1 = Args.evaluate_slot_to_reg(1); int R2 = Args.evaluate_slot_to_reg(2); Args.memory().set_reg_value_in_context(R1, {index_var(0),{R2}}, c); return constructor("()",0); }
extern "C" closure builtin_function_add_parameter(OperationArgs& Args) { assert(not Args.evaluate_changeables()); const std::string name = Args.evaluate(0).as_<String>(); int R = Args.evaluate_slot_to_reg(1); auto& M = Args.memory(); M.parameters.push_back({name,R}); return constructor("()",0); }
extern "C" closure builtin_function_get_modifiable_value(OperationArgs& Args) { assert(not Args.evaluate_changeables()); int c = Args.evaluate(0).as_int(); int R1 = Args.evaluate_slot_to_reg(1); int R2 = Args.memory().get_modifiable_value_in_context(R1, c); assert( R2 ); return {index_var(0),{R2}}; }
extern "C" closure builtin_function_new_modifiable(OperationArgs& Args) { assert(not Args.evaluate_changeables()); reg_heap& M = Args.memory(); int D = Args.reg_for_slot(0); // Allocate a reg, and fill it with a modifiable of the correct index expression_ref E(new expression(modifiable(),{index_var(0)})); closure C{E,{D}}; int R1 = Args.allocate(std::move(C)); M.make_reg_changeable(R1); // Return a reference to the new modifiable. return {index_var(0),{R1}}; }
extern "C" closure builtin_function_evaluate(OperationArgs& Args) { auto& M = Args.memory(); int c = Args.evaluate(0).as_int(); #ifndef NDEBUG if (Args.evaluate_changeables() and c >= 0) throw myexception()<<"Calling builtin_function_evaluate( ) when evaluate_changeables=true and c >= 0"; #endif int R1 = Args.reg_for_slot(1); int R2 = 0; if (c < 0) R2 = M.incremental_evaluate_unchangeable(R1); else R2 = M.incremental_evaluate_in_context(R1, c).first; assert( R2 ); return {index_var(0),{R2}}; }