From: "Kjetil S. Matheussen" <k.s.matheussen@notam02.no>
To: "Kjetil S. Matheussen" <k.s.matheussen@notam02.no>
Cc: guile-user@gnu.org
Subject: Re: Injecting variables into closures.
Date: Thu, 29 Nov 2007 15:44:50 +0100 (CET) [thread overview]
Message-ID: <Pine.LNX.4.64.0711291543030.9048@ttleush> (raw)
In-Reply-To: <Pine.LNX.4.64.0711291458380.9048@ttleush>
On Thu, 29 Nov 2007, Kjetil S. Matheussen wrote:
>
> Hi,
>
> I need (well) to inject variables into closures, and have
> come up with the following macro to do so:
>
> (define-macro (inject-variable name value)
...
> (cond ((null? (cdr ,env))
...
> ((null? (null? (cdr (car ,env))))
#@^%$^&#!
(define-macro (inject-variable name value)
(define env (gensym))
(define closure (gensym))
(define vars (gensym))
(define secondname (gensym))
(define secondval (gensym))
(define first-env (gensym))
`((procedure->macro
(lambda (,(gensym) ,env)
(define ,first-env (car ,env))
(cond ((null? (cdr ,env))
(let ((,closure ,first-env))
(set-car! ,env (cons ',name ,value))
(set-cdr! ,env (list ,closure))))
((not (pair? (cdr ,first-env)))
(let* ((,vars ,first-env)
(,secondname (car ,vars))
(,secondval (cdr ,vars)))
(set-car! ,env
(list (list ',name ,secondname)
,value ,secondval))))
(else
(set-cdr! ,first-env
(cons ,value (cdr ,first-env)))
(set-car! ,first-env
(cons ',name (car ,first-env)))
(set-car! ,env ,first-env)))))))
Sorry. :-)
_______________________________________________
Guile-user mailing list
Guile-user@gnu.org
http://lists.gnu.org/mailman/listinfo/guile-user
next prev parent reply other threads:[~2007-11-29 14:44 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-11-29 14:04 Injecting variables into closures Kjetil S. Matheussen
2007-11-29 14:44 ` Kjetil S. Matheussen [this message]
2007-11-29 14:54 ` Kjetil S. Matheussen
2007-11-29 16:02 ` Ludovic Courtès
[not found] ` <877ik1dpyj.fsf@unknownlamer.org>
2007-11-29 15:52 ` Kjetil S. Matheussen
2007-11-29 15:53 ` Ludovic Courtès
[not found] <cmu-lmtpd-10256-1196356001-0@mail-imap2.uio.no>
2007-11-29 18:43 ` Kjetil S. Matheussen
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/guile/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=Pine.LNX.4.64.0711291543030.9048@ttleush \
--to=k.s.matheussen@notam02.no \
--cc=guile-user@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).