Fun 0.41.5
The programming language that makes you have fun!
Loading...
Searching...
No Matches
set.c
Go to the documentation of this file.
1/*
2 * This file is part of the Fun programming language.
3 * https://fun-lang.xyz/
4 *
5 * Copyright 2025 Johannes Findeisen <you@hanez.org>
6 * Licensed under the terms of the Apache-2.0 license.
7 * https://opensource.org/license/apache-2-0
8 */
9
10/**
11 * @file set.c
12 * @brief Implements the OP_SET opcode for setting elements in arrays in the VM.
13 *
14 * Handles the OP_SET instruction, which sets a value at a specified index in an array.
15 * The value, index, and array are popped from the stack; the value is returned back
16 * on the stack (as a copy) to mirror expression semantics.
17 *
18 * Behavior:
19 * - Pops the value, index, and array from the stack.
20 * - Sets the value at the specified index in the array.
21 * - Pushes a copy of the value back onto the stack.
22 *
23 * Error Handling:
24 * - Exits with a runtime error if the array or index is of the wrong type.
25 * - Exits with a runtime error if the index is out of bounds.
26 *
27 * Example:
28 * - Bytecode: OP_SET
29 * - Stack before: [42, 1, [10, 20, 30]]
30 * - Stack after: [42]
31 */
32
33case OP_SET: {
34 Value v = pop_value(vm);
37 if (arr.type != VAL_ARRAY || idx.type != VAL_INT) {
38 fprintf(stderr, "Runtime type error: ARR_SET expects (array, int, value)\n");
39 exit(1);
40 }
41 if (!array_set(&arr, (int)idx.i, v)) {
42 fprintf(stderr, "Runtime error: set index out of range\n");
43 exit(1);
44 }
47 /* v already owned by array; push copy for return value */
50 break;
51}
free_value(arr)
push_value(vm, copy_value(&v))
@ OP_SET
Definition bytecode.h:87
Value v
Definition cast.c:22
array_clear & arr
Definition clear.c:38
int idx
Definition index_of.c:38
Tagged union representing a Fun value.
Definition value.h:68
int array_set(Value *v, int index, Value newElem)
Replace an element of an array with a new Value.
Definition value.c:210
Value copy_value(const Value *v)
Shallow copy a Value.
Definition value.c:415
@ VAL_ARRAY
Definition value.h:55
@ VAL_INT
Definition value.h:51
static Value pop_value(VM *vm)
Pop a Value from the VM operand stack.
Definition vm.c:580
#define fprintf
Definition vm.c:200
#define exit(code)
Definition vm.c:230