1 <?xml version="1.0" encoding="UTF-8"?>
2 <!-- Step 8: Macros -->
3 <!-- input document must be in the following format -->
6 <stdin>...stdin text...</stdin>
7 <stdout> ... ignored, omitted ... </stdout>
8 <state> contains env and atoms </state>
11 <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fn="http://www.w3.org/2005/02/xpath-functions" xmlns:env="ENV" xmlns:core="CORE" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:map="http://www.w3.org/2005/xpath-functions/map" version="3.0" exclude-result-prefixes="fn xs map env core">
12 <xsl:import href="reader.xslt"/>
13 <xsl:import href="printer.xslt"/>
14 <xsl:import href="env.xslt"/>
15 <xsl:import href="core.xslt"/>
16 <xsl:output method="xml" encoding="utf-8" indent="yes"/>
17 <xsl:template match="mal" name="rep">
18 <xsl:param name="display" select="false()" />
20 <xsl:when test="string(state/env/@data) = ''">
21 <xsl:variable name="argv">
24 <xsl:for-each select="argv/arg/text()">
25 <malval kind="string" value="{.}"/>
30 <xsl:variable name="vstate">
33 <env data="{env:serialise(env:empty() => env:bind-all(core:ns()/@name, core:ns()) => env:set('*ARGV*', $argv) => env:toReplEnv())}"/>
36 <stdin>(do (def! not (fn* (a) (if a false true))) (def! load-file (fn* (f) (eval (read-string (str "(do " (slurp f) "\nnil)"))))) (defmacro! cond (fn* (& xs) (if (> (count xs) 0) (list 'if (first xs) (if (> (count xs) 1) (nth xs 1) (throw "odd number of forms to cond")) (cons 'cond (rest (rest xs))))))))</stdin>
39 <xsl:variable name="new-state">
40 <xsl:for-each select="$vstate/mal">
41 <xsl:call-template name="rep"/>
44 <xsl:variable name="state-v">
45 <xsl:sequence select="$new-state/mal/state"/>
46 <xsl:sequence select="stdin"/>
48 <xsl:for-each select="$state-v">
49 <xsl:call-template name="rep">
50 <xsl:with-param name="display" select="$display"/>
56 <xsl:variable name="env" as="map(*)">
57 <xsl:sequence select="env:deserialise(state/env/@data)"/>
59 <xsl:sequence select="stdin"/>
60 <xsl:variable name="_read">
61 <xsl:call-template name="READ"/>
63 <xsl:variable name="_eval">
64 <xsl:for-each select="$_read">
65 <xsl:call-template name="EVAL">
66 <xsl:with-param name="env" select="$env"/>
70 <xsl:for-each select="$_eval">
71 <xsl:variable name="_print">
72 <xsl:variable name="data">
73 <xsl:sequence select="data/value"/>
74 <xsl:sequence select="atoms[1]"/>
76 <xsl:for-each select="$data">
77 <xsl:call-template name="PRINT"/>
80 <xsl:if test="$display">
82 <request kind="display" value="{$_print}"/>
86 <env data="{env/@data}"/>
87 <xsl:sequence select="atoms[1]"/>
94 <xsl:template name="PRINT">
95 <xsl:variable name="str">
96 <xsl:call-template name="malprinter-pr_str">
97 <xsl:with-param name="readably" select="true()"/>
100 <xsl:value-of select="$str"/>
102 <xsl:template name="eval_ast">
103 <xsl:param name="env"/>
104 <xsl:param name="atoms"/>
106 <xsl:when test="value/malval/@kind = 'symbol'">
107 <xsl:variable name="val">
108 <xsl:sequence select="env:get($env, value/malval/@value)"/>
111 <xsl:sequence select="$val"/>
114 <xsl:when test="value/malval/@kind = 'list' or value/malval/@kind = 'vector' or value/malval/@kind = 'hash'">
115 <xsl:variable name="myctx">
116 <xsl:iterate select="value/malval/lvalue/malval">
117 <xsl:param name="atoms" select="$atoms"/>
118 <xsl:param name="xctx" select="()"/>
120 <xsl:sequence select="$xctx/value/malval"/>
121 <xsl:sequence select="$atoms"/>
123 <xsl:variable name="ctx">
125 <xsl:sequence select="."/>
127 <xsl:sequence select="$atoms"/>
129 <xsl:variable name="xctxy">
130 <xsl:for-each select="$ctx">
131 <xsl:variable name="val">
132 <xsl:call-template name="EVAL">
133 <xsl:with-param name="env" select="$env"/>
134 <xsl:with-param name="encode-env" select="false()"/>
137 <xsl:sequence select="$val/data/value"/>
138 <xsl:sequence select="$val/atoms"/>
142 <xsl:with-param name="atoms" select="$xctxy/atoms"/>
143 <xsl:with-param name="xctx" select="$xctx, $xctxy"/>
144 </xsl:next-iteration>
148 <malval kind="{value/malval/@kind}">
150 <xsl:sequence select="$myctx/malval"/>
154 <xsl:sequence select="$myctx/atoms"/>
157 <xsl:sequence select="."/>
158 <xsl:sequence select="$atoms"/>
162 <!-- uapply[env, fn, args] -->
163 <xsl:template name="uapply">
164 <xsl:param name="func"/>
165 <xsl:param name="args"/>
166 <xsl:param name="env"/>
167 <xsl:variable name="nenv" select="$env => env:hier(env:deserialise($func/malval/env/@data)) => env:close-with-binds($func/malval/binds/malval/@value, $args/value/malval/lvalue/malval)"/>
168 <xsl:variable name="body">
170 <xsl:sequence select="$func/malval/body/malval"/>
172 <xsl:sequence select="atoms[1]"/>
174 <xsl:variable name="result">
175 <xsl:for-each select="$body">
176 <xsl:call-template name="EVAL">
177 <xsl:with-param name="env" select="$nenv"/>
181 <xsl:sequence select="$result/data/value"/>
182 <env data="{env:serialise(env:swap-replEnv($env, env:deserialise($result/env/@data) => env:replEnv()))}"/>
183 <xsl:sequence select="$result/atoms[1]"/>
185 <xsl:template name="quasiquote">
186 <xsl:param name="ast"/>
187 <xsl:variable name="result">
189 <xsl:when test="fn:is-pair($ast)">
191 <xsl:when test="let $fst := $ast/lvalue/malval[1] return $fst/@kind = 'symbol' and $fst/@value = 'unquote'">
192 <xsl:sequence select="$ast/lvalue/malval[2]"/>
194 <xsl:when test="let $fst := $ast/lvalue/malval[1] return fn:is-pair($fst) and (let $fstfst := $fst/lvalue/malval[1] return $fstfst/@kind = 'symbol' and $fstfst/@value = 'splice-unquote')">
197 <malval kind="symbol" value="concat"/>
198 <xsl:sequence select="$ast/lvalue/malval[1]/lvalue/malval[2]"/>
199 <xsl:variable name="rest" select="$ast/lvalue/malval[position() > 1]"/>
200 <xsl:variable name="rest-">
203 <xsl:sequence select="$rest"/>
207 <xsl:call-template name="quasiquote">
208 <xsl:with-param name="ast" select="$rest-"/>
216 <malval kind="symbol" value="cons"/>
217 <xsl:variable name="first" select="$ast/lvalue/malval[1]"/>
218 <xsl:variable name="rest" select="$ast/lvalue/malval[position() > 1]"/>
219 <xsl:variable name="rest-">
222 <xsl:sequence select="$rest"/>
226 <xsl:call-template name="quasiquote">
227 <xsl:with-param name="ast" select="$first"/>
229 <xsl:call-template name="quasiquote">
230 <xsl:with-param name="ast" select="$rest-/malval"/>
240 <malval kind="symbol" value="quote"/>
241 <xsl:sequence select="$ast"/>
247 <xsl:sequence select="$result"/>
249 <xsl:template name="macroexpand">
250 <xsl:param name="ast"/>
251 <xsl:param name="env"/>
252 <xsl:param name="encode-env"/>
254 <xsl:when test="fn:is-macro-call($ast, $env)">
255 <xsl:variable name="fn" select="env:get($env, $ast/lvalue/malval[1]/@value)"/>
256 <xsl:variable name="args">
260 <xsl:sequence select="$ast/lvalue/malval[position() > 1]"/>
265 <xsl:variable name="new">
266 <xsl:call-template name="uapply">
267 <xsl:with-param name="func" select="$fn"/>
268 <xsl:with-param name="args" select="$args"/>
269 <xsl:with-param name="env" select="$env"/>
272 <xsl:call-template name="macroexpand">
273 <xsl:with-param name="ast" select="$new/value/malval"/>
274 <xsl:with-param name="env" select="$env"/>
275 <xsl:with-param name="encode-env" select="$encode-env"/>
280 <xsl:sequence select="$ast"/>
282 <xsl:sequence select="atoms[1]"/>
283 <xsl:if test="$encode-env">
284 <env data="{$env => env:serialise()}"/>
289 <xsl:template name="EVAL">
290 <xsl:param name="env"/>
291 <xsl:param name="encode-env" select="true()"/>
292 <xsl:variable name="atoms" select="atoms[1]"/>
293 <xsl:variable name="data">
295 <xsl:when test="value/malval/@kind = 'list'">
297 <xsl:when test="count(value/malval/lvalue/malval) = 0">
298 <xsl:sequence select="."/>
299 <xsl:if test="$encode-env">
300 <env data="{env:serialise($env)}"/>
302 <xsl:sequence select="$atoms"/>
305 <xsl:variable name="mexp">
306 <xsl:call-template name="macroexpand">
307 <xsl:with-param name="ast" select="value/malval"/>
308 <xsl:with-param name="env" select="$env"/>
309 <xsl:with-param name="encode-env" select="$encode-env"/>
312 <xsl:for-each select="$mexp">
314 <xsl:when test="value/malval/@kind != 'list'">
315 <xsl:variable name="ctx">
316 <xsl:sequence select="value"/>
318 <xsl:for-each select="$ctx">
319 <xsl:call-template name="eval_ast">
320 <xsl:with-param name="atoms" select="$atoms"/>
321 <xsl:with-param name="env" select="$env"/>
323 <xsl:if test="$encode-env">
324 <env data="{env:serialise($env)}"/>
326 <!-- <xsl:sequence select="$atoms"/> -->
329 <xsl:when test="let $fn := value/malval/lvalue/malval[1] return $fn/@kind = 'symbol' and $fn/@value = 'def!'">
330 <xsl:variable name="name">
331 <xsl:value-of select="value/malval/lvalue/malval[2]/@value"/>
333 <xsl:variable name="xvalue">
335 <xsl:sequence select="value/malval/lvalue/malval[3]"/>
337 <xsl:sequence select="$atoms"/>
339 <xsl:variable name="value">
340 <xsl:for-each select="$xvalue">
341 <xsl:call-template name="EVAL">
342 <xsl:with-param name="env" select="$env"/>
343 <xsl:with-param name="encode-env" select="false()"/>
347 <xsl:sequence select="$value/data/value"/>
348 <xsl:if test="$encode-env">
349 <env data="{env:serialise(env:set($env, $name, $value/data/value/malval))}"/>
351 <xsl:sequence select="$value/atoms[1]"/>
353 <xsl:when test="let $fn := value/malval/lvalue/malval[1] return $fn/@kind = 'symbol' and $fn/@value = 'defmacro!'">
354 <xsl:variable name="name">
355 <xsl:value-of select="value/malval/lvalue/malval[2]/@value"/>
357 <xsl:variable name="xvalue">
359 <xsl:sequence select="value/malval/lvalue/malval[3]"/>
361 <xsl:sequence select="$atoms"/>
363 <xsl:variable name="value">
364 <xsl:for-each select="$xvalue">
365 <xsl:call-template name="EVAL">
366 <xsl:with-param name="env" select="$env"/>
367 <xsl:with-param name="encode-env" select="false()"/>
371 <xsl:variable name="resv">
373 <malval kind="{$value/data/value/malval/@kind}" value="{$value/data/value/malval/@value}">
374 <xsl:sequence select="$value/data/value/malval/*[name() != 'is_macro']"/>
375 <is_macro>true</is_macro>
379 <xsl:sequence select="$resv"/>
380 <xsl:if test="$encode-env">
381 <env data="{env:serialise(env:set($env, $name, $resv/value/malval))}"/>
383 <xsl:sequence select="$resv/atoms[1]"/>
385 <xsl:when test="let $fn := value/malval/lvalue/malval[1] return $fn/@kind = 'symbol' and $fn/@value = 'let*'">
386 <xsl:variable name="xvalue">
388 <xsl:sequence select="value/malval/lvalue/malval[3]"/>
390 <xsl:sequence select="$atoms"/>
392 <xsl:iterate select="fn:group_consec(value/malval/lvalue/malval[2]/lvalue/malval)">
393 <xsl:param name="new_env" select="env:close($env)"/>
394 <xsl:param name="new_atoms" select="$atoms"/>
396 <xsl:variable name="xvalue">
397 <xsl:sequence select="$xvalue/value"/>
398 <xsl:sequence select="$new_atoms"/>
400 <xsl:variable name="value">
401 <xsl:for-each select="$xvalue">
402 <xsl:call-template name="EVAL">
403 <xsl:with-param name="env" select="$new_env"/>
404 <xsl:with-param name="encode-env" select="$encode-env"/>
408 <xsl:sequence select="$value/data/value"/>
409 <xsl:if test="$encode-env">
410 <env data="{env:serialise(env:swap-replEnv($env, env:deserialise($value/env/@data) => env:replEnv()))}"/>
412 <xsl:sequence select="$value/atoms[1]"/>
414 <xsl:variable name="name">
415 <xsl:value-of select="node()[name() = 'first']/malval/@value"/>
417 <xsl:variable name="xvalue">
419 <xsl:sequence select="node()[name() = 'second']/malval"/>
421 <xsl:sequence select="$new_atoms"/>
423 <xsl:variable name="value">
424 <xsl:for-each select="$xvalue">
425 <xsl:call-template name="EVAL">
426 <xsl:with-param name="env" select="$new_env"/>
427 <xsl:with-param name="encode-env" select="false()"/>
432 <xsl:with-param name="new_env" select="env:set($new_env, $name, $value/data/value/malval)"/>
433 <xsl:with-param name="new_atoms" select="$value/atoms[1]"/>
434 </xsl:next-iteration>
437 <xsl:when test="let $fn := value/malval/lvalue/malval[1] return $fn/@kind = 'symbol' and $fn/@value = 'do'">
438 <xsl:iterate select="value/malval/lvalue/malval[position() > 1]">
439 <xsl:param name="new_env" select="$env"/>
440 <xsl:param name="atoms" select="$atoms"/>
441 <xsl:param name="previous_res" select="()"/>
443 <xsl:sequence select="$previous_res"/>
444 <xsl:if test="$encode-env">
445 <env data="{env:serialise($new_env)}"/>
447 <xsl:sequence select="$atoms"/>
449 <xsl:variable name="xvalue">
451 <xsl:sequence select="."/>
453 <xsl:sequence select="$atoms"/>
455 <xsl:variable name="value">
456 <xsl:for-each select="$xvalue">
457 <xsl:call-template name="EVAL">
458 <xsl:with-param name="env" select="$new_env"/>
463 <xsl:with-param name="new_env" select="env:deserialise($value/env/@data)"/>
464 <xsl:with-param name="previous_res" select="$value/data/value"/>
465 <xsl:with-param name="atoms" select="$value/atoms[1]"/>
466 </xsl:next-iteration>
469 <xsl:when test="let $fn := value/malval/lvalue/malval[1] return $fn/@kind = 'symbol' and $fn/@value = 'if'">
470 <xsl:variable name="cond">
471 <xsl:for-each select="value/malval/lvalue/malval[2]">
472 <xsl:variable name="context">
474 <xsl:sequence select="."/>
476 <xsl:sequence select="$atoms"/>
478 <xsl:for-each select="$context">
479 <xsl:call-template name="EVAL">
480 <xsl:with-param name="env" select="$env"/>
481 <xsl:with-param name="encode-env" select="false()"/>
486 <xsl:variable name="ptrue">
487 <xsl:for-each select="value/malval/lvalue/malval[3]">
489 <xsl:sequence select="."/>
491 <xsl:sequence select="$cond/atoms[1]"/>
494 <xsl:variable name="pfalse">
495 <xsl:for-each select="value/malval/lvalue/malval[4]">
497 <xsl:sequence select="."/>
499 <xsl:sequence select="$cond/atoms[1]"/>
502 <xsl:variable name="xfalse">
504 <xsl:when test="empty($pfalse/value)">
508 <xsl:sequence select="$cond/atoms[1]"/>
511 <xsl:sequence select="$pfalse/value"/>
512 <xsl:sequence select="$pfalse/atoms[1]"/>
516 <xsl:variable name="res">
518 <xsl:when test="let $kind := $cond/data/value/malval/@kind return $kind = 'nil' or $kind = 'false'">
519 <xsl:for-each select="$xfalse">
520 <xsl:call-template name="EVAL">
521 <xsl:with-param name="env" select="$env"/>
522 <xsl:with-param name="encode-env" select="$encode-env"/>
527 <xsl:for-each select="$ptrue">
528 <xsl:call-template name="EVAL">
529 <xsl:with-param name="env" select="$env"/>
530 <xsl:with-param name="encode-env" select="$encode-env"/>
536 <xsl:sequence select="$res/data/value"/>
537 <xsl:if test="$encode-env">
538 <env data="{env:serialise($env)}"/>
540 <xsl:sequence select="$res/atoms[1]"/>
542 <xsl:when test="let $fn := value/malval/lvalue/malval[1] return $fn/@kind = 'symbol' and $fn/@value = 'fn*'">
544 <malval kind="userfunction">
545 <is_macro>false</is_macro>
547 <xsl:sequence select="value/malval/lvalue/malval[2]/lvalue/malval"/>
550 <xsl:sequence select="value/malval/lvalue/malval[3]"/>
552 <env data="{env:serialise(env:noReplEnv($env))}"/>
553 <!-- capture current env -->
556 <xsl:if test="$encode-env">
557 <env data="{env:serialise($env)}"/>
559 <xsl:sequence select="$atoms"/>
561 <xsl:when test="let $fn := value/malval/lvalue/malval[1] return $fn/@kind = 'symbol' and $fn/@value = 'quote'">
563 <xsl:sequence select="value/malval/lvalue/malval[2]"/>
565 <xsl:if test="$encode-env">
566 <env data="{env:serialise($env)}"/>
568 <xsl:sequence select="$atoms"/>
570 <xsl:when test="let $fn := value/malval/lvalue/malval[1] return $fn/@kind = 'symbol' and $fn/@value = 'quasiquote'">
571 <xsl:variable name="exp">
573 <xsl:call-template name="quasiquote">
574 <xsl:with-param name="ast" select="value/malval/lvalue/malval[2]"/>
577 <xsl:sequence select="$atoms"/>
579 <xsl:variable name="res">
580 <xsl:for-each select="$exp">
581 <xsl:call-template name="EVAL">
582 <xsl:with-param name="env" select="$env"/>
583 <xsl:with-param name="encode-env" select="$encode-env"/>
587 <xsl:sequence select="$res/data/value"/>
588 <xsl:if test="$encode-env">
589 <xsl:sequence select="$res/env"/>
591 <xsl:sequence select="$res/atoms[1]"/>
593 <xsl:when test="let $fn := value/malval/lvalue/malval[1] return $fn/@kind = 'symbol' and $fn/@value = 'macroexpand'">
594 <xsl:variable name="exp">
595 <xsl:call-template name="macroexpand">
596 <xsl:with-param name="ast" select="value/malval/lvalue/malval[2]"/>
597 <xsl:with-param name="env" select="$env"/>
598 <xsl:with-param name="encode-env" select="false()"/>
600 <xsl:sequence select="$atoms"/>
602 <xsl:sequence select="$exp/value"/>
603 <xsl:if test="$encode-env">
604 <env data="{env:serialise($env)}"/>
606 <xsl:sequence select="$atoms"/>
609 <xsl:variable name="new_list">
610 <xsl:call-template name="eval_ast">
611 <xsl:with-param name="atoms" select="$atoms"/>
612 <xsl:with-param name="env" select="$env"/>
615 <xsl:variable name="func">
616 <xsl:for-each select="$new_list">
617 <xsl:sequence select="value/malval/lvalue/malval[1]"/>
620 <xsl:variable name="args">
621 <xsl:for-each select="$new_list">
625 <xsl:for-each select="value/malval/lvalue/node()[position() != 1]">
626 <xsl:sequence select="."/>
631 <xsl:sequence select="$new_list/atoms"/>
634 <xsl:variable name="resultv">
636 <xsl:when test="$func/malval/@kind = 'userfunction'">
637 <xsl:call-template name="uapply">
638 <xsl:with-param name="env" select="$env"/>
639 <xsl:with-param name="func" select="$func"/>
640 <xsl:with-param name="args" select="$args"/>
645 <xsl:when test="$func/malval/@name = 'env??'">
646 <!-- needs access to env -->
647 <xsl:variable name="nev" select="env:dump($env)"/>
648 <xsl:variable name="value">
649 <malval kind="string" value="{$env => serialize(map{'method':'json'})}"/>
652 <xsl:sequence select="$value"/>
654 <xsl:if test="$encode-env">
655 <env data="{env:serialise($env)}"/>
657 <xsl:sequence select="$value/atoms[1]"/>
659 <xsl:when test="$func/malval/@name = 'eval'">
660 <!-- needs access to env -->
661 <xsl:variable name="venv" select="env:replEnv($env)"/>
662 <xsl:variable name="form">
664 <xsl:sequence select="$args/value/malval/lvalue/malval[1]"/>
666 <xsl:sequence select="$atoms"/>
668 <xsl:variable name="value">
669 <xsl:for-each select="$form">
670 <xsl:call-template name="EVAL">
671 <xsl:with-param name="env" select="$venv"/>
672 <xsl:with-param name="encode-env" select="$encode-env"/>
676 <xsl:sequence select="$value/data/value"/>
677 <xsl:if test="$encode-env">
678 <env data="{env:serialise(env:swap-replEnv($env, env:deserialise($value/env/@data)))}"/>
680 <xsl:sequence select="$value/atoms[1]"/>
682 <xsl:when test="$func/malval/@name = 'atom'">
683 <!-- needs access to atoms -->
684 <xsl:variable name="atom-ident" select="count($atoms/atom)"/>
686 <malval kind="atom" value="{$atom-ident}"/>
689 <xsl:for-each select="$atoms/atom">
690 <xsl:sequence select="."/>
692 <atom identity="{$atom-ident}">
693 <xsl:sequence select="$args/value/malval/lvalue/malval[1]"/>
697 <xsl:when test="$func/malval/@name = 'deref'">
698 <!-- needs access to atoms -->
700 <xsl:sequence select="$atoms/atom[@identity = $args/value/malval/lvalue/malval[1]/@value]/malval"/>
702 <xsl:sequence select="$atoms"/>
704 <xsl:when test="$func/malval/@name = 'reset!'">
705 <!-- needs access to atoms -->
706 <xsl:variable name="atom-ident" select="$args/value/malval/lvalue/malval[1]/@value"/>
707 <xsl:variable name="newv" select="$args/value/malval/lvalue/malval[2]"/>
709 <xsl:sequence select="$newv"/>
712 <xsl:for-each select="$atoms/atom[@identity != $atom-ident]">
713 <xsl:sequence select="."/>
715 <atom identity="{$atom-ident}">
716 <xsl:sequence select="$newv"/>
720 <xsl:when test="$func/malval/@name = 'swap!'">
721 <!-- needs access to atoms -->
722 <xsl:variable name="atom-ident" select="$args/value/malval/lvalue/malval[1]/@value"/>
723 <xsl:variable name="atom-value" select="$atoms/atom[@identity = $atom-ident]/malval"/>
724 <xsl:variable name="fn" select="$args/value/malval/lvalue/malval[2]"/>
725 <xsl:variable name="newlist">
729 <xsl:sequence select="$fn"/>
730 <xsl:sequence select="$atom-value"/>
731 <xsl:sequence select="$args/value/malval/lvalue/malval[position() > 2]"/>
735 <xsl:sequence select="$atoms"/>
737 <xsl:variable name="newv">
738 <xsl:for-each select="$newlist">
739 <xsl:call-template name="EVAL">
740 <xsl:with-param name="env" select="$env"/>
741 <xsl:with-param name="encode-env" select="false()"/>
745 <xsl:sequence select="$newv/data/value"/>
747 <xsl:for-each select="$newv/atoms[1]/atom[@identity != $atom-ident]">
748 <xsl:sequence select="."/>
750 <atom identity="{$atom-ident}">
751 <xsl:sequence select="$newv/data/value/malval"/>
754 <xsl:sequence select="$newv/env"/>
757 <xsl:call-template name="core-apply">
758 <xsl:with-param name="func" select="$func"/>
759 <xsl:with-param name="args" select="$args"/>
761 <xsl:sequence select="$atoms"/>
767 <xsl:for-each select="$resultv">
769 <xsl:when test="empty(env)">
770 <xsl:if test="$encode-env">
771 <env data="{env:serialise($env)}"/>
775 <xsl:sequence select="env"/>
778 <xsl:sequence select="atoms[1]"/>
779 <xsl:sequence select="value"/>
788 <xsl:call-template name="eval_ast">
789 <xsl:with-param name="atoms" select="$atoms"/>
790 <xsl:with-param name="env" select="$env"/>
792 <xsl:if test="$encode-env">
793 <env data="{env:serialise($env)}"/>
795 <!-- <xsl:sequence select="$atoms"/> -->
800 <xsl:sequence select="$data/value"/>
802 <xsl:if test="$encode-env">
803 <env data="{$data/env/@data}"/>
805 <xsl:sequence select="$data/atoms[1]"/>
807 <xsl:template name="READ">
808 <xsl:variable name="context">
810 <xsl:copy-of select="stdin/text()"/>
813 <xsl:variable name="form">
814 <xsl:sequence select="state/atoms[1]"/>
815 <xsl:for-each select="$context">
816 <xsl:call-template name="malreader-read_str"/>
819 <xsl:for-each select="$form">
820 <xsl:if test="error">
821 <xsl:value-of select="error(QName('MAL', 'Error'), string(error))"/>
823 <xsl:sequence select="."/>
826 <xsl:function name="fn:group_consec">
827 <xsl:param name="nodes"/>
828 <xsl:variable name="groups">
829 <xsl:for-each-group select="$nodes" group-by="position() mod 2">
831 <xsl:when test="position() = 1">
833 <xsl:sequence select="current-group()"/>
838 <xsl:sequence select="current-group()"/>
842 </xsl:for-each-group>
844 <xsl:iterate select="1 to count($groups/first/*)">
846 <xsl:variable name="idx" select="number(.)"/>
848 <xsl:sequence select="$groups/first/node()[position() = $idx]"/>
851 <xsl:sequence select="$groups/second/node()[position() = $idx]"/>
856 <xsl:function name="fn:is-pair">
857 <xsl:param name="list"/>
858 <xsl:sequence select="($list/@kind = 'list' or $list/@kind = 'vector') and count($list/lvalue/malval) != 0"/>
860 <xsl:function name="fn:is-macro-call">
861 <xsl:param name="ast"/>
862 <xsl:param name="env"/>
863 <xsl:variable name="res" select="$ast/@kind = 'list' and $ast/lvalue/malval[1]/@kind = 'symbol' and (let $fn := env:get-noerror($env, $ast/lvalue/malval[1]/@value) return not(empty($fn)) and $fn/malval/is_macro/text() = 'true')"/>
864 <xsl:sequence select="$res"/>