3 #include "../src/err.h"
5 #include "../api/bool.h"
7 static inline bool get_bool_arg(UwUVMArgs *args, size_t i)
9 return uwubool_get(uwuvm_get_arg(args, i));
12 #include "../api/str.h"
13 UwUVMValue uwu_if(UwUVMArgs *args)
16 error("error: :bool:if requires exactly 3 arguments\n");
18 return uwuvm_copy_value(get_bool_arg(args, 0)
19 ? uwuvm_get_arg(args, 1)
20 : uwuvm_get_arg(args, 2)
24 UwUVMValue uwu_and(UwUVMArgs *args)
27 error("error: :bool:and requires at least one argument\n");
29 for (size_t i = 0; i < args->num; i++)
30 if (! get_bool_arg(args, i))
31 return uwubool_create(false);
33 return uwubool_create(true);
36 UwUVMValue uwu_or(UwUVMArgs *args)
39 error("error: :bool:or requires at least one argument\n");
41 for (size_t i = 0; i < args->num; i++)
42 if (get_bool_arg(args, i))
43 return uwubool_create(true);
45 return uwubool_create(false);
48 UwUVMValue uwu_equal(UwUVMArgs *args)
51 error("error: :bool:equal requires at least 2 arguments\n");
53 bool value = get_bool_arg(args, 0);
55 for (size_t i = 1; i < args->num; i++)
56 if (get_bool_arg(args, i) != value)
57 return uwubool_create(false);
59 return uwubool_create(true);
62 UwUVMValue uwu_not(UwUVMArgs *args)
65 error("error: :bool:not requires exactly 1 argument\n");
67 return uwubool_create(! get_bool_arg(args, 0));
70 UwUVMValue uwu_true(UwUVMArgs *args)
73 error("error: :bool:true does not take any arguments\n");
75 return uwubool_create(true);
78 UwUVMValue uwu_false(UwUVMArgs *args)
81 error("error: :bool:false does not take any arguments\n");
83 return uwubool_create(false);
86 UwUVMValue uwu_is(UwUVMArgs *args)
89 error("error: :bool:is requires at least 1 argument\n");
91 for (size_t i = 0; i < args->num; i++) {
92 UwUVMValue value = uwuvm_get_arg(args, i);
93 return uwubool_create(value.type != VT_NAT || value.value.nat_value.type != &uwubool_type);
96 return uwubool_create(true);