* 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:
Abdulaziz Ghuloum 2007-09-11 13:32:14 -04:00
parent ca2be2436a
commit 2eaaa77615
3 changed files with 17 additions and 1 deletions

Binary file not shown.

View File

@ -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)])

View File

@ -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]