diff options
| author | bozo.kopic <bozo@kopic.xyz> | 2022-08-02 01:20:12 +0200 |
|---|---|---|
| committer | bozo.kopic <bozo@kopic.xyz> | 2022-09-25 02:40:23 +0200 |
| commit | 288727f09a1b3458c268497d111349e608c3f9fa (patch) | |
| tree | d62565249fa3c7127856c65405752572fc41aca9 /src_c/builtin.c | |
Diffstat (limited to 'src_c/builtin.c')
| -rw-r--r-- | src_c/builtin.c | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/src_c/builtin.c b/src_c/builtin.c new file mode 100644 index 0000000..92e1fa8 --- /dev/null +++ b/src_c/builtin.c @@ -0,0 +1,65 @@ +#include "builtin.h" + + +lsp_status_t lsp_builtin_get_args_1(lsp_mem_t *m, lsp_addr_t args, + lsp_addr_t *arg1) { + if (args == m->nil) + return LSP_ERR_ARG_COUNT; + + *arg1 = lsp_mem_get_pair_first(m, args); + + args = lsp_mem_get_pair_second(m, args); + if (args != m->nil) + return LSP_ERR_ARG_COUNT; + + return LSP_SUCCESS; +} + + +lsp_status_t lsp_builtin_get_args_2(lsp_mem_t *m, lsp_addr_t args, + lsp_addr_t *arg1, lsp_addr_t *arg2) { + if (args == m->nil) + return LSP_ERR_ARG_COUNT; + + *arg1 = lsp_mem_get_pair_first(m, args); + + args = lsp_mem_get_pair_second(m, args); + if (args == m->nil) + return LSP_ERR_ARG_COUNT; + + *arg2 = lsp_mem_get_pair_first(m, args); + + args = lsp_mem_get_pair_second(m, args); + if (args != m->nil) + return LSP_ERR_ARG_COUNT; + + return LSP_SUCCESS; +} + + +lsp_status_t lsp_builtin_get_args_3(lsp_mem_t *m, lsp_addr_t args, + lsp_addr_t *arg1, lsp_addr_t *arg2, + lsp_addr_t *arg3) { + if (args == m->nil) + return LSP_ERR_ARG_COUNT; + + *arg1 = lsp_mem_get_pair_first(m, args); + + args = lsp_mem_get_pair_second(m, args); + if (args == m->nil) + return LSP_ERR_ARG_COUNT; + + *arg2 = lsp_mem_get_pair_first(m, args); + + args = lsp_mem_get_pair_second(m, args); + if (args == m->nil) + return LSP_ERR_ARG_COUNT; + + *arg3 = lsp_mem_get_pair_first(m, args); + + args = lsp_mem_get_pair_second(m, args); + if (args != m->nil) + return LSP_ERR_ARG_COUNT; + + return LSP_SUCCESS; +} |
