qse/ase/lsp/primitive.h

65 lines
2.2 KiB
C
Raw Normal View History

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