2005-02-04 15:39:11 +00:00
|
|
|
/*
|
2005-05-28 13:34:26 +00:00
|
|
|
* $Id: primitive.h,v 1.3 2005-05-28 13:34:26 bacon Exp $
|
2005-02-04 15:39:11 +00:00
|
|
|
*/
|
|
|
|
|
2005-05-28 13:34:26 +00:00
|
|
|
#ifndef _XP_LSP_PRIM_H_
|
|
|
|
#define _XP_LSP_PRIM_H_
|
2005-02-04 15:39:11 +00:00
|
|
|
|
2005-05-28 13:34:26 +00:00
|
|
|
#include <xp/lsp/types.h>
|
|
|
|
#include <xp/lsp/lisp.h>
|
2005-02-04 15:39:11 +00:00
|
|
|
|
|
|
|
typedef xp_lisp_obj_t* (*xp_lisp_pimpl_t) (xp_lisp_t*, xp_lisp_obj_t*);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_abort (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_eval (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_prog1 (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_progn (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_gc (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_cond (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_if (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_while (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_car (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_cdr (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_cons (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_set (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_setq (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_quote (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_defun (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_demac (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_let (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_letx (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_plus (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_gt (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
xp_lisp_obj_t* xp_lisp_prim_lt (xp_lisp_t*, xp_lisp_obj_t* args);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2005-02-04 16:00:37 +00:00
|
|
|
#define XP_LISP_PRIM_CHECK_ARG_COUNT(lsp,args,min,max) \
|
2005-02-04 15:39:11 +00:00
|
|
|
{ \
|
|
|
|
xp_size_t count; \
|
|
|
|
if (xp_lisp_probe_args(lsp->mem, args, &count) == -1) { \
|
2005-02-04 16:00:37 +00:00
|
|
|
lsp->error = XP_LISP_ERR_BAD_ARG; \
|
2005-02-04 15:39:11 +00:00
|
|
|
return XP_NULL; \
|
|
|
|
} \
|
|
|
|
if (count < min) { \
|
2005-02-04 16:00:37 +00:00
|
|
|
lsp->error = XP_LISP_ERR_TOO_FEW_ARGS; \
|
2005-02-04 15:39:11 +00:00
|
|
|
return XP_NULL; \
|
|
|
|
} \
|
|
|
|
if (count > max) { \
|
2005-02-04 16:00:37 +00:00
|
|
|
lsp->error = XP_LISP_ERR_TOO_MANY_ARGS; \
|
2005-02-04 15:39:11 +00:00
|
|
|
return XP_NULL; \
|
|
|
|
} \
|
|
|
|
}
|
|
|
|
|
2005-02-04 16:00:37 +00:00
|
|
|
#define XP_LISP_PRIM_MAX_ARG_COUNT ((xp_size_t)~(xp_size_t)0)
|
2005-02-04 15:39:11 +00:00
|
|
|
|
|
|
|
#endif
|