low-syntax.scm 736 B

12345678910111213141516171819202122
  1. ; Copyright (c) 1993-2008 by Richard Kelsey and Jonathan Rees. See file COPYING.
  2. ; Low-level support for different kinds of syntax transformers
  3. ; We just use a vector with a tag in slot 0. (Can't be a pair,
  4. ; because syntax transformers may be pairs of transformer and aux
  5. ; names.)
  6. ; 4-argument version of explicit-renaming transformers
  7. ; (expression name? rename compare)
  8. (define (make-explicit-renaming-transformer/4 proc)
  9. (vector 'explicit-renaming-transformer/4 proc))
  10. (define (explicit-renaming-transformer/4? thing)
  11. (and (vector? thing)
  12. (= 2 (vector-length thing))
  13. (eq? 'explicit-renaming-transformer/4 (vector-ref thing 0))))
  14. (define (explicit-renaming-transformer/4-proc thing)
  15. (vector-ref thing 1))