Fun 0.41.5
The programming language that makes you have fun!
Loading...
Searching...
No Matches
zip.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 zip.c
12 * @brief Implements the OP_ZIP opcode for array zipping in the VM.
13 *
14 * This file handles the OP_ZIP instruction, which combines two arrays into
15 * an array of pairs (subarrays with two elements).
16 *
17 * Behavior:
18 * - Pops two arrays from the stack
19 * - Creates new array of [a[i],b[i]] pairs
20 * - Length is minimum of input array lengths
21 * - Pushes resulting array onto stack
22 *
23 * Error Handling:
24 * - Exits with error if arguments aren't arrays
25 *
26 * Example:
27 * - Bytecode: OP_ZIP
28 * - Stack before: [[1,2], ['a','b']]
29 * - Stack after: [[[1,'a'], [2,'b']]]
30 */
31
32case OP_ZIP: {
33 Value b = pop_value(vm);
35 if (a.type != VAL_ARRAY || b.type != VAL_ARRAY) {
36 fprintf(stderr, "Runtime type error: ZIP expects (array, array)\n");
37 exit(1);
38 }
43 break;
44}
Value a
Definition add.c:37
Value out
Definition apop.c:38
uint32_t b
Definition band.c:32
@ OP_ZIP
Definition bytecode.h:118
Value bi_zip(const Value *a, const Value *b)
Zip two arrays into an array of pairs up to the shorter length.
Definition iter.c:66
Tagged union representing a Fun value.
Definition value.h:68
@ VAL_ARRAY
Definition value.h:55
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
free_value(a)
push_value(vm, out)