diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2012-03-14 14:38:51 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2012-03-14 14:38:51 -0700 |
commit | 4e1170250c22dbc1938e60538aef9f800cf8af92 (patch) | |
tree | 7b2ebf16559c4cddcfb87860f538f9b5250e08dd /eval.h | |
parent | 0592949de3e274b7d9700ec74466b541055c3bca (diff) | |
download | txr-4e1170250c22dbc1938e60538aef9f800cf8af92.tar.gz txr-4e1170250c22dbc1938e60538aef9f800cf8af92.tar.bz2 txr-4e1170250c22dbc1938e60538aef9f800cf8af92.zip |
Support quasiquoting over vectors also, and a bugfix for hash
quasiquoting. We cannot use the same symbol for the
literal form from the parser, and for the expanded form,
because this creates a confusion when there are multiple
nestings of quasiquote expansion.
* eval.c (vector_lit_s, vector_list_s, hash_lit_s): New symbol
variables.
(hash_construct_s): Relocated here from hash.c.
(expand_qquote): Part of bugfix: look for hash_lit_s
instead of has_construct_s. Translate to a hash_construct_s
form which is no longer recognizes as a hash literal.
Implementing recognition of a quasiquote vector literal,
handled similarly.
(eval_init): Initialize vector_lit_s, vector_list_s,
hash_list_s and hash_lit_s.
Use vector_list_s when registering vector_list function.
* eval.h (vector_lit_s, vector_list_s, hash_lit_s,
hash_constuct_s): Declared.
* hash.c (hash_construct_s): Variable removed
and relocated into eval.c.
(hash_init): Initialization of hash_construct_s removed.
* hash.h (hash_construct_s): Declaration removed.
* parser.y: (vector): Action updated to generate
a (vec-lit ...) form if the object contains unquotes,
otherwise generate a vector object.
(hash): Generate hash-lit form, not a
hash-construct form.
Diffstat (limited to 'eval.h')
-rw-r--r-- | eval.h | 3 |
1 files changed, 2 insertions, 1 deletions
@@ -24,7 +24,8 @@ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. */ -extern val dwim_s; +extern val dwim_s, vector_lit_s, vector_list_s; +extern val hash_lit_s, hash_construct_s; val make_env(val fbindings, val vbindings, val up_env); val env_fbind(val env, val sym, val fun); |