-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvalue_helpers.h
73 lines (58 loc) · 2.25 KB
/
value_helpers.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#ifndef __VALUE_HELPERS_H_
#define __VALUE_HELPERS_H_
#include "vm.h"
#include "env.h"
#include <stdlib.h>
#define make_fixnum(n) ((value_t *)(((n) << 1)|1))
#define is_fixnum(p) (((size_t)(p)) & 1)
#define to_fixnum(p) (((long)(p)) >> 1)
bool is_environment(vm_t *p_vm, value_t *);
bool is_binding(vm_t *p_vm, value_t *);
bool is_closure(vm_t *p_vm, value_t *);
bool is_ifunc(vm_t *p_vm, value_t *);
bool is_string(vm_t *p_vm, value_t *);
bool is_cons(vm_t *p_vm, value_t *);
bool is_macro(vm_t *p_vm, value_t *);
bool is_number(vm_t *p_vm, value_t *);
bool is_bytecode(vm_t *p_vm, value_t *);
bool is_pool(vm_t *p_vm, value_t *);
bool is_lambda(vm_t *p_vm, value_t *);
bool is_null(vm_t *p_vm, value_t *);
bool is_pid(vm_t *p_vm, value_t *);
bool is_process(vm_t *p_vm, value_t *);
inline bool is_symbol_function_dynamic(vm_t *p_vm, value_t *p_val)
{
if (p_val->m_cons[2] != p_vm->voidobj) {
return true;
}
return false;
}
inline bool is_symbol_dynamic(vm_t *p_vm, value_t *p_val)
{
if (p_val->m_cons[1] != p_vm->voidobj) {
return true;
}
return false;
}
inline bool is_symbol(vm_t *p_vm, value_t *p_val)
{
if(p_val == p_vm->nil || is_fixnum(p_val)) {
return false;
}
return p_val->m_type == VT_SYMBOL;
}
value_t * value_create_number(vm_t *p_vm, int p_number);
value_t * value_create_string(vm_t *p_vm, char const * const p_symbol);
value_t * value_create_symbol(vm_t *p_vm, char const * const p_symbol);
value_t * value_create_internal_func(vm_t *p_vm, vm_func_t p_func, int p_nargs, bool p_is_macro);
value_t * value_create_cons(vm_t *p_vm, value_t *p_car, value_t *p_cdr);
value_t * value_create_bytecode(vm_t *p_vm, bytecode_t *p_code, int p_code_count);
value_t * value_create_pool(vm_t *p_vm, value_t *p_literals[], int p_literal_count);
value_t * value_create_lambda(vm_t *p_vm, value_t *p_parameters, value_t *p_bytecode, value_t *p_pool);
value_t * value_create_closure(vm_t *p_vm, value_t *p_env, value_t *p_lambda);
value_t * value_create_environment(vm_t *p_vm, value_t *p_env);
value_t * value_create_binding(vm_t *p_vm, value_t *p_key, value_t *p_binding);
value_t * value_create_process(vm_t *p_vm, value_t *p_parent_vm);
value_t * list(vm_t *p_vm, value_t *p_value);
char const *valuetype_print(int p_val);
#endif /* __VALUE_HELPERS_H_ */