* Added the procedure expand:
(expand <expr> <environment>) expands the expression in environment and returns two values: an expanded core expression and a list of libraries that must be invoked before the core expression is evaluated.
This commit is contained in:
parent
ca2be2436a
commit
2eaaa77615
BIN
src/ikarus.boot
BIN
src/ikarus.boot
Binary file not shown.
|
@ -7,7 +7,7 @@
|
||||||
|
|
||||||
(library (ikarus syntax)
|
(library (ikarus syntax)
|
||||||
(export identifier? syntax-dispatch environment environment?
|
(export identifier? syntax-dispatch environment environment?
|
||||||
eval generate-temporaries free-identifier=?
|
eval expand generate-temporaries free-identifier=?
|
||||||
bound-identifier=? syntax-error datum->syntax
|
bound-identifier=? syntax-error datum->syntax
|
||||||
syntax->datum make-variable-transformer
|
syntax->datum make-variable-transformer
|
||||||
eval-r6rs-top-level boot-library-expand eval-top-level
|
eval-r6rs-top-level boot-library-expand eval-top-level
|
||||||
|
@ -2363,6 +2363,21 @@
|
||||||
(seal-rib! rib)
|
(seal-rib! rib)
|
||||||
(for-each invoke-library (rtc))
|
(for-each invoke-library (rtc))
|
||||||
(eval-core x)))))))
|
(eval-core x)))))))
|
||||||
|
(define expand
|
||||||
|
(lambda (x env)
|
||||||
|
(unless (eval-environment? env)
|
||||||
|
(error 'expand "~s is not an environment" env))
|
||||||
|
(let ([subst (eval-environment-subst env)])
|
||||||
|
(let ([rib (make-top-rib subst)])
|
||||||
|
(let ([x (stx x top-mark* (list rib))]
|
||||||
|
[rtc (make-collector)]
|
||||||
|
[vtc (make-collector)])
|
||||||
|
(let ([x
|
||||||
|
(parameterize ([inv-collector rtc]
|
||||||
|
[vis-collector vtc])
|
||||||
|
(chi-expr x '() '()))])
|
||||||
|
(seal-rib! rib)
|
||||||
|
(values x (rtc))))))))
|
||||||
(define (visit! macro*)
|
(define (visit! macro*)
|
||||||
(for-each (lambda (x)
|
(for-each (lambda (x)
|
||||||
(let ([loc (car x)] [proc (cadr x)])
|
(let ([loc (car x)] [proc (cadr x)])
|
||||||
|
|
|
@ -652,6 +652,7 @@
|
||||||
[assembler-output i]
|
[assembler-output i]
|
||||||
[new-cafe i]
|
[new-cafe i]
|
||||||
[eval i ev]
|
[eval i ev]
|
||||||
|
[expand i]
|
||||||
[environment i ev]
|
[environment i ev]
|
||||||
[null-environment i]
|
[null-environment i]
|
||||||
[environment? i]
|
[environment? i]
|
||||||
|
|
Loading…
Reference in New Issue