mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-10 14:00:21 +02:00
syntax-parameterize, not fluid-let-syntax
* module/ice-9/psyntax.scm (syntax-parameterize): Rename from fluid-let-syntax. * module/ice-9/boot-9.scm (define-inlinable): Use syntax-parameterize (and define-syntax-parameter).
This commit is contained in:
parent
c2d822de19
commit
ea3ca4e4d0
2 changed files with 11 additions and 11 deletions
|
@ -3663,13 +3663,13 @@ module '(ice-9 q) '(make-q q-length))}."
|
|||
((args ...) (generate-temporaries #'(formals ...))))
|
||||
#`(begin
|
||||
(define (proc-name formals ...)
|
||||
(fluid-let-syntax ((name (identifier-syntax proc-name)))
|
||||
(syntax-parameterize ((name (identifier-syntax proc-name)))
|
||||
body ...))
|
||||
(define-syntax name
|
||||
(define-syntax-parameter name
|
||||
(lambda (x)
|
||||
(syntax-case x ()
|
||||
((_ args ...)
|
||||
#'((fluid-let-syntax ((name (identifier-syntax proc-name)))
|
||||
#'((syntax-parameterize ((name (identifier-syntax proc-name)))
|
||||
(lambda (formals ...)
|
||||
body ...))
|
||||
args ...))
|
||||
|
|
|
@ -51,7 +51,7 @@
|
|||
;;; bound-identifier=?
|
||||
;;; datum->syntax
|
||||
;;; define-syntax
|
||||
;;; fluid-let-syntax
|
||||
;;; syntax-parameterize
|
||||
;;; free-identifier=?
|
||||
;;; generate-temporaries
|
||||
;;; identifier?
|
||||
|
@ -791,13 +791,13 @@
|
|||
|
||||
;; Returns four values: binding type, binding value, the module (for
|
||||
;; resolving toplevel vars), and the name (for possible overriding
|
||||
;; by fluid-let-syntax).
|
||||
;; by syntax-parameterize).
|
||||
(define (resolve-identifier id w r mod)
|
||||
(define (resolve-global var mod)
|
||||
;; `var' is probably a global, but we check the environment
|
||||
;; first anyway because a temporary binding may have been
|
||||
;; established by `fluid-let-syntax'. FIXME: overriding a
|
||||
;; toplevel via fluid-let-syntax using just a symbolic name
|
||||
;; established by `syntax-parameterize'. FIXME: overriding a
|
||||
;; toplevel via syntax-parameterize using just a symbolic name
|
||||
;; (without a module) does not make sense.
|
||||
(let ((b (or (assq-ref r var)
|
||||
(get-global-definition-hook var mod)
|
||||
|
@ -812,7 +812,7 @@
|
|||
(let ((n (id-var-name id w)))
|
||||
(cond
|
||||
((syntax-object? n)
|
||||
;; Recursing allows fluid-let-syntax to override
|
||||
;; Recursing allows syntax-parameterize to override
|
||||
;; macro-introduced bindings, I think.
|
||||
(resolve-identifier n w r mod))
|
||||
((symbol? n)
|
||||
|
@ -1810,7 +1810,7 @@
|
|||
(global-extend 'local-syntax 'let-syntax #f)
|
||||
|
||||
(global-extend
|
||||
'core 'fluid-let-syntax
|
||||
'core 'syntax-parameterize
|
||||
(lambda (e r w s mod)
|
||||
(syntax-case e ()
|
||||
((_ ((var val) ...) e1 e2 ...)
|
||||
|
@ -1822,7 +1822,7 @@
|
|||
(lambda (type value mod name)
|
||||
(case type
|
||||
((displaced-lexical)
|
||||
(syntax-violation 'fluid-let-syntax
|
||||
(syntax-violation 'syntax-parameterize
|
||||
"identifier out of context"
|
||||
e
|
||||
(source-wrap x w s mod)))
|
||||
|
@ -1840,7 +1840,7 @@
|
|||
(extend-env names bindings r)
|
||||
w
|
||||
mod)))
|
||||
(_ (syntax-violation 'fluid-let-syntax "bad syntax"
|
||||
(_ (syntax-violation 'syntax-parameterize "bad syntax"
|
||||
(source-wrap e w s mod))))))
|
||||
|
||||
(global-extend 'core 'quote
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue