123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352 |
- typedef enum
- {
- SCM_EXPANDED_VOID,
- SCM_EXPANDED_CONST,
- SCM_EXPANDED_PRIMITIVE_REF,
- SCM_EXPANDED_LEXICAL_REF,
- SCM_EXPANDED_LEXICAL_SET,
- SCM_EXPANDED_MODULE_REF,
- SCM_EXPANDED_MODULE_SET,
- SCM_EXPANDED_TOPLEVEL_REF,
- SCM_EXPANDED_TOPLEVEL_SET,
- SCM_EXPANDED_TOPLEVEL_DEFINE,
- SCM_EXPANDED_CONDITIONAL,
- SCM_EXPANDED_CALL,
- SCM_EXPANDED_PRIMCALL,
- SCM_EXPANDED_SEQ,
- SCM_EXPANDED_LAMBDA,
- SCM_EXPANDED_LAMBDA_CASE,
- SCM_EXPANDED_LET,
- SCM_EXPANDED_LETREC,
- SCM_NUM_EXPANDED_TYPES,
- } scm_t_expanded_type;
- SCM_INTERNAL SCM scm_exp_vtable_vtable;
- enum
- {
- SCM_EXPANDED_TYPE_NAME = scm_vtable_offset_user,
- SCM_EXPANDED_TYPE_CODE,
- SCM_EXPANDED_TYPE_FIELDS,
- }
- (SCM_STRUCTP (x) \
- && (scm_is_eq (SCM_STRUCT_VTABLE (SCM_STRUCT_VTABLE (x)), scm_exp_vtable_vtable)))
- (scm_struct_ref (x, SCM_I_MAKINUM (SCM_EXPANDED_##type##_##field)))
- SCM_STRUCT_DATA_REF (SCM_STRUCT_VTABLE (x), SCM_EXPANDED_TYPE_CODE)
- { "src" }
- enum
- {
- SCM_EXPANDED_VOID_SRC,
- SCM_NUM_EXPANDED_VOID_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_VOID], 0, SCM_NUM_EXPANDED_VOID_FIELDS, SCM_UNPACK (src))
- { "src", "exp", }
- enum
- {
- SCM_EXPANDED_CONST_SRC,
- SCM_EXPANDED_CONST_EXP,
- SCM_NUM_EXPANDED_CONST_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_CONST], 0, SCM_NUM_EXPANDED_CONST_FIELDS, SCM_UNPACK (src), SCM_UNPACK (exp))
- { "src", "name", }
- enum
- {
- SCM_EXPANDED_PRIMITIVE_REF_SRC,
- SCM_EXPANDED_PRIMITIVE_REF_NAME,
- SCM_NUM_EXPANDED_PRIMITIVE_REF_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_PRIMITIVE_REF], 0, SCM_NUM_EXPANDED_PRIMITIVE_REF_FIELDS, SCM_UNPACK (src), SCM_UNPACK (name))
- { "src", "name", "gensym", }
- enum
- {
- SCM_EXPANDED_LEXICAL_REF_SRC,
- SCM_EXPANDED_LEXICAL_REF_NAME,
- SCM_EXPANDED_LEXICAL_REF_GENSYM,
- SCM_NUM_EXPANDED_LEXICAL_REF_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_LEXICAL_REF], 0, SCM_NUM_EXPANDED_LEXICAL_REF_FIELDS, SCM_UNPACK (src), SCM_UNPACK (name), SCM_UNPACK (gensym))
- { "src", "name", "gensym", "exp", }
- enum
- {
- SCM_EXPANDED_LEXICAL_SET_SRC,
- SCM_EXPANDED_LEXICAL_SET_NAME,
- SCM_EXPANDED_LEXICAL_SET_GENSYM,
- SCM_EXPANDED_LEXICAL_SET_EXP,
- SCM_NUM_EXPANDED_LEXICAL_SET_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_LEXICAL_SET], 0, SCM_NUM_EXPANDED_LEXICAL_SET_FIELDS, SCM_UNPACK (src), SCM_UNPACK (name), SCM_UNPACK (gensym), SCM_UNPACK (exp))
- { "src", "mod", "name", "public?", }
- enum
- {
- SCM_EXPANDED_MODULE_REF_SRC,
- SCM_EXPANDED_MODULE_REF_MOD,
- SCM_EXPANDED_MODULE_REF_NAME,
- SCM_EXPANDED_MODULE_REF_PUBLIC,
- SCM_NUM_EXPANDED_MODULE_REF_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_MODULE_REF], 0, SCM_NUM_EXPANDED_MODULE_REF_FIELDS, SCM_UNPACK (src), SCM_UNPACK (mod), SCM_UNPACK (name), SCM_UNPACK (public))
- { "src", "mod", "name", "public?", "exp", }
- enum
- {
- SCM_EXPANDED_MODULE_SET_SRC,
- SCM_EXPANDED_MODULE_SET_MOD,
- SCM_EXPANDED_MODULE_SET_NAME,
- SCM_EXPANDED_MODULE_SET_PUBLIC,
- SCM_EXPANDED_MODULE_SET_EXP,
- SCM_NUM_EXPANDED_MODULE_SET_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_MODULE_SET], 0, SCM_NUM_EXPANDED_MODULE_SET_FIELDS, SCM_UNPACK (src), SCM_UNPACK (mod), SCM_UNPACK (name), SCM_UNPACK (public), SCM_UNPACK (exp))
- { "src", "name", }
- enum
- {
- SCM_EXPANDED_TOPLEVEL_REF_SRC,
- SCM_EXPANDED_TOPLEVEL_REF_NAME,
- SCM_NUM_EXPANDED_TOPLEVEL_REF_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_TOPLEVEL_REF], 0, SCM_NUM_EXPANDED_TOPLEVEL_REF_FIELDS, SCM_UNPACK (src), SCM_UNPACK (name))
- { "src", "name", "exp", }
- enum
- {
- SCM_EXPANDED_TOPLEVEL_SET_SRC,
- SCM_EXPANDED_TOPLEVEL_SET_NAME,
- SCM_EXPANDED_TOPLEVEL_SET_EXP,
- SCM_NUM_EXPANDED_TOPLEVEL_SET_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_TOPLEVEL_SET], 0, SCM_NUM_EXPANDED_TOPLEVEL_SET_FIELDS, SCM_UNPACK (src), SCM_UNPACK (name), SCM_UNPACK (exp))
- { "src", "name", "exp", }
- enum
- {
- SCM_EXPANDED_TOPLEVEL_DEFINE_SRC,
- SCM_EXPANDED_TOPLEVEL_DEFINE_NAME,
- SCM_EXPANDED_TOPLEVEL_DEFINE_EXP,
- SCM_NUM_EXPANDED_TOPLEVEL_DEFINE_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_TOPLEVEL_DEFINE], 0, SCM_NUM_EXPANDED_TOPLEVEL_DEFINE_FIELDS, SCM_UNPACK (src), SCM_UNPACK (name), SCM_UNPACK (exp))
- { "src", "test", "consequent", "alternate", }
- enum
- {
- SCM_EXPANDED_CONDITIONAL_SRC,
- SCM_EXPANDED_CONDITIONAL_TEST,
- SCM_EXPANDED_CONDITIONAL_CONSEQUENT,
- SCM_EXPANDED_CONDITIONAL_ALTERNATE,
- SCM_NUM_EXPANDED_CONDITIONAL_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_CONDITIONAL], 0, SCM_NUM_EXPANDED_CONDITIONAL_FIELDS, SCM_UNPACK (src), SCM_UNPACK (test), SCM_UNPACK (consequent), SCM_UNPACK (alternate))
- { "src", "proc", "args", }
- enum
- {
- SCM_EXPANDED_CALL_SRC,
- SCM_EXPANDED_CALL_PROC,
- SCM_EXPANDED_CALL_ARGS,
- SCM_NUM_EXPANDED_CALL_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_CALL], 0, SCM_NUM_EXPANDED_CALL_FIELDS, SCM_UNPACK (src), SCM_UNPACK (proc), SCM_UNPACK (args))
- { "src", "name", "args", }
- enum
- {
- SCM_EXPANDED_PRIMCALL_SRC,
- SCM_EXPANDED_PRIMCALL_NAME,
- SCM_EXPANDED_PRIMCALL_ARGS,
- SCM_NUM_EXPANDED_PRIMCALL_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_PRIMCALL], 0, SCM_NUM_EXPANDED_PRIMCALL_FIELDS, SCM_UNPACK (src), SCM_UNPACK (name), SCM_UNPACK (args))
- { "src", "head", "tail", }
- enum
- {
- SCM_EXPANDED_SEQ_SRC,
- SCM_EXPANDED_SEQ_HEAD,
- SCM_EXPANDED_SEQ_TAIL,
- SCM_NUM_EXPANDED_SEQ_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_SEQ], 0, SCM_NUM_EXPANDED_SEQ_FIELDS, SCM_UNPACK (src), SCM_UNPACK (head), SCM_UNPACK (tail))
- { "src", "meta", "body", }
- enum
- {
- SCM_EXPANDED_LAMBDA_SRC,
- SCM_EXPANDED_LAMBDA_META,
- SCM_EXPANDED_LAMBDA_BODY,
- SCM_NUM_EXPANDED_LAMBDA_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_LAMBDA], 0, SCM_NUM_EXPANDED_LAMBDA_FIELDS, SCM_UNPACK (src), SCM_UNPACK (meta), SCM_UNPACK (body))
- { "src", "req", "opt", "rest", "kw", "inits", "gensyms", "body", "alternate", }
- enum
- {
- SCM_EXPANDED_LAMBDA_CASE_SRC,
- SCM_EXPANDED_LAMBDA_CASE_REQ,
- SCM_EXPANDED_LAMBDA_CASE_OPT,
- SCM_EXPANDED_LAMBDA_CASE_REST,
- SCM_EXPANDED_LAMBDA_CASE_KW,
- SCM_EXPANDED_LAMBDA_CASE_INITS,
- SCM_EXPANDED_LAMBDA_CASE_GENSYMS,
- SCM_EXPANDED_LAMBDA_CASE_BODY,
- SCM_EXPANDED_LAMBDA_CASE_ALTERNATE,
- SCM_NUM_EXPANDED_LAMBDA_CASE_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_LAMBDA_CASE], 0, SCM_NUM_EXPANDED_LAMBDA_CASE_FIELDS, SCM_UNPACK (src), SCM_UNPACK (req), SCM_UNPACK (opt), SCM_UNPACK (rest), SCM_UNPACK (kw), SCM_UNPACK (inits), SCM_UNPACK (gensyms), SCM_UNPACK (body), SCM_UNPACK (alternate))
- { "src", "names", "gensyms", "vals", "body", }
- enum
- {
- SCM_EXPANDED_LET_SRC,
- SCM_EXPANDED_LET_NAMES,
- SCM_EXPANDED_LET_GENSYMS,
- SCM_EXPANDED_LET_VALS,
- SCM_EXPANDED_LET_BODY,
- SCM_NUM_EXPANDED_LET_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_LET], 0, SCM_NUM_EXPANDED_LET_FIELDS, SCM_UNPACK (src), SCM_UNPACK (names), SCM_UNPACK (gensyms), SCM_UNPACK (vals), SCM_UNPACK (body))
- { "src", "in-order?", "names", "gensyms", "vals", "body", }
- enum
- {
- SCM_EXPANDED_LETREC_SRC,
- SCM_EXPANDED_LETREC_IN_ORDER_P,
- SCM_EXPANDED_LETREC_NAMES,
- SCM_EXPANDED_LETREC_GENSYMS,
- SCM_EXPANDED_LETREC_VALS,
- SCM_EXPANDED_LETREC_BODY,
- SCM_NUM_EXPANDED_LETREC_FIELDS,
- }
- scm_c_make_struct (exp_vtables[SCM_EXPANDED_LETREC], 0, SCM_NUM_EXPANDED_LETREC_FIELDS, SCM_UNPACK (src), SCM_UNPACK (in_order_p), SCM_UNPACK (names), SCM_UNPACK (gensyms), SCM_UNPACK (vals), SCM_UNPACK (body))
- SCM_INTERNAL SCM scm_macroexpand (SCM exp)
- SCM_INTERNAL SCM scm_macroexpanded_p (SCM exp)
- SCM_INTERNAL SCM scm_convert_assignment (SCM exp)
- SCM_INTERNAL void scm_init_expand (void)
|