expand.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365
  1. /* classes: h_files */
  2. #ifndef SCM_EXPAND_H
  3. #define SCM_EXPAND_H
  4. /* Copyright (C) 2010, 2011
  5. * Free Software Foundation, Inc.
  6. *
  7. * This library is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU Lesser General Public License
  9. * as published by the Free Software Foundation; either version 3 of
  10. * the License, or (at your option) any later version.
  11. *
  12. * This library is distributed in the hope that it will be useful, but
  13. * WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * Lesser General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Lesser General Public
  18. * License along with this library; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
  20. * 02110-1301 USA
  21. */
  22. #include "libguile/__scm.h"
  23. #ifdef BUILDING_LIBGUILE
  24. /* All private for now. Ask if you want to use this. Surely this should be
  25. auto-generated by something; for now I wrangle it with keyboard macros. */
  26. typedef enum
  27. {
  28. SCM_EXPANDED_VOID,
  29. SCM_EXPANDED_CONST,
  30. SCM_EXPANDED_PRIMITIVE_REF,
  31. SCM_EXPANDED_LEXICAL_REF,
  32. SCM_EXPANDED_LEXICAL_SET,
  33. SCM_EXPANDED_MODULE_REF,
  34. SCM_EXPANDED_MODULE_SET,
  35. SCM_EXPANDED_TOPLEVEL_REF,
  36. SCM_EXPANDED_TOPLEVEL_SET,
  37. SCM_EXPANDED_TOPLEVEL_DEFINE,
  38. SCM_EXPANDED_CONDITIONAL,
  39. SCM_EXPANDED_CALL,
  40. SCM_EXPANDED_PRIMCALL,
  41. SCM_EXPANDED_SEQ,
  42. SCM_EXPANDED_LAMBDA,
  43. SCM_EXPANDED_LAMBDA_CASE,
  44. SCM_EXPANDED_LET,
  45. SCM_EXPANDED_LETREC,
  46. SCM_EXPANDED_DYNLET,
  47. SCM_NUM_EXPANDED_TYPES,
  48. } scm_t_expanded_type;
  49. /* {Expanded Source}
  50. */
  51. SCM_INTERNAL SCM scm_exp_vtable_vtable;
  52. enum
  53. {
  54. SCM_EXPANDED_TYPE_NAME = scm_vtable_offset_user,
  55. SCM_EXPANDED_TYPE_CODE,
  56. SCM_EXPANDED_TYPE_FIELDS,
  57. };
  58. #define SCM_EXPANDED_P(x) \
  59. (SCM_STRUCTP (x) \
  60. && (scm_is_eq (SCM_STRUCT_VTABLE (SCM_STRUCT_VTABLE (x)), scm_exp_vtable_vtable)))
  61. #define SCM_EXPANDED_REF(x,type,field) \
  62. (scm_struct_ref (x, SCM_I_MAKINUM (SCM_EXPANDED_##type##_##field)))
  63. #define SCM_EXPANDED_TYPE(x) \
  64. SCM_STRUCT_DATA_REF (SCM_STRUCT_VTABLE (x), SCM_EXPANDED_TYPE_CODE)
  65. #define SCM_EXPANDED_VOID_TYPE_NAME "void"
  66. #define SCM_EXPANDED_VOID_FIELD_NAMES \
  67. { "src" }
  68. enum
  69. {
  70. SCM_EXPANDED_VOID_SRC,
  71. SCM_NUM_EXPANDED_VOID_FIELDS,
  72. };
  73. #define SCM_MAKE_EXPANDED_VOID(src) \
  74. scm_c_make_struct (exp_vtables[SCM_EXPANDED_VOID], 0, SCM_NUM_EXPANDED_VOID_FIELDS, SCM_UNPACK (src))
  75. #define SCM_EXPANDED_CONST_TYPE_NAME "const"
  76. #define SCM_EXPANDED_CONST_FIELD_NAMES \
  77. { "src", "exp", }
  78. enum
  79. {
  80. SCM_EXPANDED_CONST_SRC,
  81. SCM_EXPANDED_CONST_EXP,
  82. SCM_NUM_EXPANDED_CONST_FIELDS,
  83. };
  84. #define SCM_MAKE_EXPANDED_CONST(src, exp) \
  85. scm_c_make_struct (exp_vtables[SCM_EXPANDED_CONST], 0, SCM_NUM_EXPANDED_CONST_FIELDS, SCM_UNPACK (src), SCM_UNPACK (exp))
  86. #define SCM_EXPANDED_PRIMITIVE_REF_TYPE_NAME "primitive-ref"
  87. #define SCM_EXPANDED_PRIMITIVE_REF_FIELD_NAMES \
  88. { "src", "name", }
  89. enum
  90. {
  91. SCM_EXPANDED_PRIMITIVE_REF_SRC,
  92. SCM_EXPANDED_PRIMITIVE_REF_NAME,
  93. SCM_NUM_EXPANDED_PRIMITIVE_REF_FIELDS,
  94. };
  95. #define SCM_MAKE_EXPANDED_PRIMITIVE_REF(src, name) \
  96. scm_c_make_struct (exp_vtables[SCM_EXPANDED_PRIMITIVE_REF], 0, SCM_NUM_EXPANDED_PRIMITIVE_REF_FIELDS, SCM_UNPACK (src), SCM_UNPACK (name))
  97. #define SCM_EXPANDED_LEXICAL_REF_TYPE_NAME "lexical-ref"
  98. #define SCM_EXPANDED_LEXICAL_REF_FIELD_NAMES \
  99. { "src", "name", "gensym", }
  100. enum
  101. {
  102. SCM_EXPANDED_LEXICAL_REF_SRC,
  103. SCM_EXPANDED_LEXICAL_REF_NAME,
  104. SCM_EXPANDED_LEXICAL_REF_GENSYM,
  105. SCM_NUM_EXPANDED_LEXICAL_REF_FIELDS,
  106. };
  107. #define SCM_MAKE_EXPANDED_LEXICAL_REF(src, name, gensym) \
  108. 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))
  109. #define SCM_EXPANDED_LEXICAL_SET_TYPE_NAME "lexical-set"
  110. #define SCM_EXPANDED_LEXICAL_SET_FIELD_NAMES \
  111. { "src", "name", "gensym", "exp", }
  112. enum
  113. {
  114. SCM_EXPANDED_LEXICAL_SET_SRC,
  115. SCM_EXPANDED_LEXICAL_SET_NAME,
  116. SCM_EXPANDED_LEXICAL_SET_GENSYM,
  117. SCM_EXPANDED_LEXICAL_SET_EXP,
  118. SCM_NUM_EXPANDED_LEXICAL_SET_FIELDS,
  119. };
  120. #define SCM_MAKE_EXPANDED_LEXICAL_SET(src, name, gensym, exp) \
  121. 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))
  122. #define SCM_EXPANDED_MODULE_REF_TYPE_NAME "module-ref"
  123. #define SCM_EXPANDED_MODULE_REF_FIELD_NAMES \
  124. { "src", "mod", "name", "public?", }
  125. enum
  126. {
  127. SCM_EXPANDED_MODULE_REF_SRC,
  128. SCM_EXPANDED_MODULE_REF_MOD,
  129. SCM_EXPANDED_MODULE_REF_NAME,
  130. SCM_EXPANDED_MODULE_REF_PUBLIC,
  131. SCM_NUM_EXPANDED_MODULE_REF_FIELDS,
  132. };
  133. #define SCM_MAKE_EXPANDED_MODULE_REF(src, mod, name, public) \
  134. 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))
  135. #define SCM_EXPANDED_MODULE_SET_TYPE_NAME "module-set"
  136. #define SCM_EXPANDED_MODULE_SET_FIELD_NAMES \
  137. { "src", "mod", "name", "public?", "exp", }
  138. enum
  139. {
  140. SCM_EXPANDED_MODULE_SET_SRC,
  141. SCM_EXPANDED_MODULE_SET_MOD,
  142. SCM_EXPANDED_MODULE_SET_NAME,
  143. SCM_EXPANDED_MODULE_SET_PUBLIC,
  144. SCM_EXPANDED_MODULE_SET_EXP,
  145. SCM_NUM_EXPANDED_MODULE_SET_FIELDS,
  146. };
  147. #define SCM_MAKE_EXPANDED_MODULE_SET(src, mod, name, public, exp) \
  148. 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))
  149. #define SCM_EXPANDED_TOPLEVEL_REF_TYPE_NAME "toplevel-ref"
  150. #define SCM_EXPANDED_TOPLEVEL_REF_FIELD_NAMES \
  151. { "src", "name", }
  152. enum
  153. {
  154. SCM_EXPANDED_TOPLEVEL_REF_SRC,
  155. SCM_EXPANDED_TOPLEVEL_REF_NAME,
  156. SCM_NUM_EXPANDED_TOPLEVEL_REF_FIELDS,
  157. };
  158. #define SCM_MAKE_EXPANDED_TOPLEVEL_REF(src, name) \
  159. scm_c_make_struct (exp_vtables[SCM_EXPANDED_TOPLEVEL_REF], 0, SCM_NUM_EXPANDED_TOPLEVEL_REF_FIELDS, SCM_UNPACK (src), SCM_UNPACK (name))
  160. #define SCM_EXPANDED_TOPLEVEL_SET_TYPE_NAME "toplevel-set"
  161. #define SCM_EXPANDED_TOPLEVEL_SET_FIELD_NAMES \
  162. { "src", "name", "exp", }
  163. enum
  164. {
  165. SCM_EXPANDED_TOPLEVEL_SET_SRC,
  166. SCM_EXPANDED_TOPLEVEL_SET_NAME,
  167. SCM_EXPANDED_TOPLEVEL_SET_EXP,
  168. SCM_NUM_EXPANDED_TOPLEVEL_SET_FIELDS,
  169. };
  170. #define SCM_MAKE_EXPANDED_TOPLEVEL_SET(src, name, exp) \
  171. 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))
  172. #define SCM_EXPANDED_TOPLEVEL_DEFINE_TYPE_NAME "toplevel-define"
  173. #define SCM_EXPANDED_TOPLEVEL_DEFINE_FIELD_NAMES \
  174. { "src", "name", "exp", }
  175. enum
  176. {
  177. SCM_EXPANDED_TOPLEVEL_DEFINE_SRC,
  178. SCM_EXPANDED_TOPLEVEL_DEFINE_NAME,
  179. SCM_EXPANDED_TOPLEVEL_DEFINE_EXP,
  180. SCM_NUM_EXPANDED_TOPLEVEL_DEFINE_FIELDS,
  181. };
  182. #define SCM_MAKE_EXPANDED_TOPLEVEL_DEFINE(src, name, exp) \
  183. 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))
  184. #define SCM_EXPANDED_CONDITIONAL_TYPE_NAME "conditional"
  185. #define SCM_EXPANDED_CONDITIONAL_FIELD_NAMES \
  186. { "src", "test", "consequent", "alternate", }
  187. enum
  188. {
  189. SCM_EXPANDED_CONDITIONAL_SRC,
  190. SCM_EXPANDED_CONDITIONAL_TEST,
  191. SCM_EXPANDED_CONDITIONAL_CONSEQUENT,
  192. SCM_EXPANDED_CONDITIONAL_ALTERNATE,
  193. SCM_NUM_EXPANDED_CONDITIONAL_FIELDS,
  194. };
  195. #define SCM_MAKE_EXPANDED_CONDITIONAL(src, test, consequent, alternate) \
  196. 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))
  197. #define SCM_EXPANDED_CALL_TYPE_NAME "call"
  198. #define SCM_EXPANDED_CALL_FIELD_NAMES \
  199. { "src", "proc", "args", }
  200. enum
  201. {
  202. SCM_EXPANDED_CALL_SRC,
  203. SCM_EXPANDED_CALL_PROC,
  204. SCM_EXPANDED_CALL_ARGS,
  205. SCM_NUM_EXPANDED_CALL_FIELDS,
  206. };
  207. #define SCM_MAKE_EXPANDED_CALL(src, proc, args) \
  208. scm_c_make_struct (exp_vtables[SCM_EXPANDED_CALL], 0, SCM_NUM_EXPANDED_CALL_FIELDS, SCM_UNPACK (src), SCM_UNPACK (proc), SCM_UNPACK (args))
  209. #define SCM_EXPANDED_PRIMCALL_TYPE_NAME "primcall"
  210. #define SCM_EXPANDED_PRIMCALL_FIELD_NAMES \
  211. { "src", "name", "args", }
  212. enum
  213. {
  214. SCM_EXPANDED_PRIMCALL_SRC,
  215. SCM_EXPANDED_PRIMCALL_NAME,
  216. SCM_EXPANDED_PRIMCALL_ARGS,
  217. SCM_NUM_EXPANDED_PRIMCALL_FIELDS,
  218. };
  219. #define SCM_MAKE_EXPANDED_PRIMCALL(src, name, args) \
  220. scm_c_make_struct (exp_vtables[SCM_EXPANDED_PRIMCALL], 0, SCM_NUM_EXPANDED_PRIMCALL_FIELDS, SCM_UNPACK (src), SCM_UNPACK (name), SCM_UNPACK (args))
  221. #define SCM_EXPANDED_SEQ_TYPE_NAME "seq"
  222. #define SCM_EXPANDED_SEQ_FIELD_NAMES \
  223. { "src", "head", "tail", }
  224. enum
  225. {
  226. SCM_EXPANDED_SEQ_SRC,
  227. SCM_EXPANDED_SEQ_HEAD,
  228. SCM_EXPANDED_SEQ_TAIL,
  229. SCM_NUM_EXPANDED_SEQ_FIELDS,
  230. };
  231. #define SCM_MAKE_EXPANDED_SEQ(src, head, tail) \
  232. scm_c_make_struct (exp_vtables[SCM_EXPANDED_SEQ], 0, SCM_NUM_EXPANDED_SEQ_FIELDS, SCM_UNPACK (src), SCM_UNPACK (head), SCM_UNPACK (tail))
  233. #define SCM_EXPANDED_LAMBDA_TYPE_NAME "lambda"
  234. #define SCM_EXPANDED_LAMBDA_FIELD_NAMES \
  235. { "src", "meta", "body", }
  236. enum
  237. {
  238. SCM_EXPANDED_LAMBDA_SRC,
  239. SCM_EXPANDED_LAMBDA_META,
  240. SCM_EXPANDED_LAMBDA_BODY,
  241. SCM_NUM_EXPANDED_LAMBDA_FIELDS,
  242. };
  243. #define SCM_MAKE_EXPANDED_LAMBDA(src, meta, body) \
  244. scm_c_make_struct (exp_vtables[SCM_EXPANDED_LAMBDA], 0, SCM_NUM_EXPANDED_LAMBDA_FIELDS, SCM_UNPACK (src), SCM_UNPACK (meta), SCM_UNPACK (body))
  245. #define SCM_EXPANDED_LAMBDA_CASE_TYPE_NAME "lambda-case"
  246. #define SCM_EXPANDED_LAMBDA_CASE_FIELD_NAMES \
  247. { "src", "req", "opt", "rest", "kw", "inits", "gensyms", "body", "alternate", }
  248. enum
  249. {
  250. SCM_EXPANDED_LAMBDA_CASE_SRC,
  251. SCM_EXPANDED_LAMBDA_CASE_REQ,
  252. SCM_EXPANDED_LAMBDA_CASE_OPT,
  253. SCM_EXPANDED_LAMBDA_CASE_REST,
  254. SCM_EXPANDED_LAMBDA_CASE_KW,
  255. SCM_EXPANDED_LAMBDA_CASE_INITS,
  256. SCM_EXPANDED_LAMBDA_CASE_GENSYMS,
  257. SCM_EXPANDED_LAMBDA_CASE_BODY,
  258. SCM_EXPANDED_LAMBDA_CASE_ALTERNATE,
  259. SCM_NUM_EXPANDED_LAMBDA_CASE_FIELDS,
  260. };
  261. #define SCM_MAKE_EXPANDED_LAMBDA_CASE(src, req, opt, rest, kw, inits, gensyms, body, alternate) \
  262. 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))
  263. #define SCM_EXPANDED_LET_TYPE_NAME "let"
  264. #define SCM_EXPANDED_LET_FIELD_NAMES \
  265. { "src", "names", "gensyms", "vals", "body", }
  266. enum
  267. {
  268. SCM_EXPANDED_LET_SRC,
  269. SCM_EXPANDED_LET_NAMES,
  270. SCM_EXPANDED_LET_GENSYMS,
  271. SCM_EXPANDED_LET_VALS,
  272. SCM_EXPANDED_LET_BODY,
  273. SCM_NUM_EXPANDED_LET_FIELDS,
  274. };
  275. #define SCM_MAKE_EXPANDED_LET(src, names, gensyms, vals, body) \
  276. 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))
  277. #define SCM_EXPANDED_LETREC_TYPE_NAME "letrec"
  278. #define SCM_EXPANDED_LETREC_FIELD_NAMES \
  279. { "src", "in-order?", "names", "gensyms", "vals", "body", }
  280. enum
  281. {
  282. SCM_EXPANDED_LETREC_SRC,
  283. SCM_EXPANDED_LETREC_IN_ORDER_P,
  284. SCM_EXPANDED_LETREC_NAMES,
  285. SCM_EXPANDED_LETREC_GENSYMS,
  286. SCM_EXPANDED_LETREC_VALS,
  287. SCM_EXPANDED_LETREC_BODY,
  288. SCM_NUM_EXPANDED_LETREC_FIELDS,
  289. };
  290. #define SCM_MAKE_EXPANDED_LETREC(src, in_order_p, names, gensyms, vals, body) \
  291. 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))
  292. #define SCM_EXPANDED_DYNLET_TYPE_NAME "dynlet"
  293. #define SCM_EXPANDED_DYNLET_FIELD_NAMES \
  294. { "src", "fluids", "vals", "body", }
  295. enum
  296. {
  297. SCM_EXPANDED_DYNLET_SRC,
  298. SCM_EXPANDED_DYNLET_FLUIDS,
  299. SCM_EXPANDED_DYNLET_VALS,
  300. SCM_EXPANDED_DYNLET_BODY,
  301. SCM_NUM_EXPANDED_DYNLET_FIELDS,
  302. };
  303. #define SCM_MAKE_EXPANDED_DYNLET(src, fluids, vals, body) \
  304. scm_c_make_struct (exp_vtables[SCM_EXPANDED_DYNLET], 0, SCM_NUM_EXPANDED_DYNLET_FIELDS, SCM_UNPACK (src), SCM_UNPACK (fluids), SCM_UNPACK (vals), SCM_UNPACK (body))
  305. #endif /* BUILDING_LIBGUILE */
  306. SCM_INTERNAL SCM scm_macroexpand (SCM exp);
  307. SCM_INTERNAL SCM scm_macroexpanded_p (SCM exp);
  308. SCM_INTERNAL void scm_init_expand (void);
  309. #endif /* SCM_EXPAND_H */
  310. /*
  311. Local Variables:
  312. c-file-style: "gnu"
  313. End:
  314. */