public inbox for kawa@sourceware.org
 help / color / mirror / Atom feed
* Using environment-bound? in macro definitions
@ 2017-01-02 23:30 Duncan Mak
  2017-01-03 15:46 ` Per Bothner
  0 siblings, 1 reply; 5+ messages in thread
From: Duncan Mak @ 2017-01-02 23:30 UTC (permalink / raw)
  To: kawa mailing list

Hello,

Here's a stripped down version of two define-form macros that I'm working on:

(require 'syntax-utils)
(define-for-syntax known (list))

(define-syntax define-foo
  (lambda (stx)
    (syntax-case stx ()
      ((define-foo a)
       (begin
         (set! known (cons #'a known))
         #'(define a (list)))))))

(define-syntax define-bar
  (lambda (stx)
    (syntax-case stx ()
      ((define-bar a n)
       (if (environment-bound? (apply environment known) #'a)
           #'(set! a (cons n a))
           #'(begin
               (define-foo a)
               (set! a (cons n a))))))))

;; (1) should expand to (define x (list)) and store x in known
(define-foo x)

;; (2) should expand to (set! x (cons 1 x)) since x was previously
;; defined (i.e. can be found in known)
(define-bar x 1)

;; (3) should expand to (begin (define-foo y) (set! y (cons 2 y)))
;; because y is not previous defined
(define-bar y 2)

When I try to run it, I get

test.scm:29:1: evaluating syntax transformer 'define-bar' threw
gnu.text.SyntaxException: <unknown>: unknown library (x)

I must be doing something wrong, is this the right approach?

Thanks!

-- 
Duncan.

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2017-01-04  4:33 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-01-02 23:30 Using environment-bound? in macro definitions Duncan Mak
2017-01-03 15:46 ` Per Bothner
2017-01-03 22:06   ` Duncan Mak
2017-01-04  2:41     ` Duncan Mak
2017-01-04  4:33       ` Per Bothner

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).