Hash :
ed2cf4e6
Author :
Thomas de Grivel
Date :
2024-08-21T18:57:05
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 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120
/* kc3
* Copyright 2022,2023,2024 kmx.io <contact@kmx.io>
*
* Permission is hereby granted to use this software granted the above
* copyright notice and this permission paragraph are included in all
* copies and substantial portions of this software.
*
* THIS SOFTWARE IS PROVIDED "AS-IS" WITHOUT ANY GUARANTEE OF
* PURPOSE AND PERFORMANCE. IN NO EVENT WHATSOEVER SHALL THE
* AUTHOR BE CONSIDERED LIABLE FOR THE USE AND PERFORMANCE OF
* THIS SOFTWARE.
*/
#include "assert.h"
#include "data.h"
#include "sym.h"
#include "tag.h"
#include "var.h"
s_tag * var_assign (s_var *var, const s_tag *value, s_tag *dest)
{
assert(var);
assert(value);
assert(dest);
if (! var_set(var, value))
return NULL;
return tag_init_copy(dest, value);
}
s_var * var_init (s_var *var, s_tag *ptr, const s_sym *type)
{
s_var tmp = {0};
assert(var);
assert(ptr);
assert(type);
if (! sym_is_module(type)) {
err_write_1("var_init: invalid type: ");
err_inspect_sym(&type);
err_write_1("\n");
assert(! "var_init: invalid type");
return NULL;
}
tmp.ptr = ptr;
tmp.type = type;
*var = tmp;
return var;
}
s_tag * var_init_cast (s_tag *tag, const s_sym * const *type,
const s_tag *src)
{
void *data;
s_tag tmp = {0};
assert(tag);
assert(type);
assert(src);
if (*type == &g_sym_Var) {
err_puts("var_init_cast: cannot cast to Var");
assert(! "var_init_cast: cannot cast to Var");
return NULL;
}
if (! sym_to_tag_type(*type, &tmp.type))
return NULL;
if (! tag_to_pointer(&tmp, *type, &data))
return NULL;
if (! data_init_cast(data, type, src))
return NULL;
*tag = tmp;
return tag;
}
s_var * var_init_copy (s_var *var, const s_var *src)
{
assert(var);
assert(src);
*var = *src;
return var;
}
bool * var_is_unbound (s_var *var, bool *dest)
{
assert(var);
assert(dest);
*dest = var->ptr->type == TAG_VAR;
return dest;
}
s_var * var_reset (s_var *var)
{
s_tag tmp = {0};
assert(var);
assert(var->ptr);
tmp.type = TAG_VAR;
var_init(&tmp.data.var, var->ptr, var->type);
tag_clean(var->ptr);
*var->ptr = tmp;
return var;
}
s_var * var_set (s_var *var, const s_tag *value)
{
const s_sym *value_type;
assert(var);
assert(value);
if (var->type != &g_sym_Tag) {
if (! tag_type(value, &value_type))
return NULL;
if (var->type != value_type) {
err_write_1("var_set: type mismatch: ");
err_inspect_sym(&var->type);
err_write_1(" != ");
err_inspect_sym(&value_type);
err_write_1("\n");
assert(! "var_set: type mismatch");
return NULL;
}
}
if (! tag_init_copy(var->ptr, value))
return NULL;
return var;
}