unofficial mirror of guile-user@gnu.org 
 help / color / mirror / Atom feed
* help with define-syntax
@ 2004-01-10 17:54 Viktor Pavlenko
  2004-01-30  0:12 ` Lynn Winebarger
  0 siblings, 1 reply; 2+ messages in thread
From: Viktor Pavlenko @ 2004-01-10 17:54 UTC (permalink / raw)


Hello,

(warning: this is a newbie question, please be patient:)

I'm experimenting with syntax rules and can't figure out how to
achieve something that seems reasonable.

I want to define a syntax to combine each of supplied procedures with
`and' (well my ultimate goal is more ambitious but first things first)
while adding some extra argument to them, and it works fine if done
like this:

--------------------------------------------------------------8<
(use-syntax (ice-9 syncase))

(define (f1 a b c)
  (lambda (ls)
    (format #t "in proc made by f1: ~A/~A~%" (list a b c) ls)
    #t))

(define (f2 a b)
  (lambda (ls)
    (format #t "in proc made by f2: ~A/~A~%" (list a b) ls)
    #t))

(define (f3 a)
  (lambda (ls)
    (format #t "in proc made by f3: ~A/~A~%" (list a) ls)
    #t))

(define-syntax *flt*
  (syntax-rules()
    ((_ (a) (and (f1 a1 ...) (f2 a2 ...) ...))
     (lambda (ls)
       (display "in xxx") (newline)
       (and ((f1 a a1 ...) ls) ((f2 a a2 ...) ls) ...)))))

(define pr
  (*flt* ("arg-a")
	 (and (f3) (f1 "arg-f1-1" "arg-f1-2") (f3) (f2 "arg-f2-1"))))

(pr '(1 2 3))
(pr '(11 22 33))
--------------------------------------------------------------8<

Now, I want to avoid calling f1, f2, ... each time the resulting
procedure is called but rather make a closure with `let', something
like

--------------------------------------------------------------8<
(define-syntax *flt*
  (syntax-rules()
    ((_ (a) (and (f1 a1 ...) (f2 a2 ...) ...))
     (let ((f1-pr (f1 a a1 ...)) (f2-pr (f2 a a2 ...)) ...)
       (lambda (ls)
	 (display "in xxx") (newline)
	 (and (f1-pr ls) (f2-pr ls) ...))))))
--------------------------------------------------------------8<

but it won't work: I get an "extra ellipsis" error in the last `and'
statement, and if I comment it out, `let' will complain about
"duplicate bound variable".

A hint how to do it properly would be much appreciated.

TIA

-- 
Viktor


_______________________________________________
Guile-user mailing list
Guile-user@gnu.org
http://mail.gnu.org/mailman/listinfo/guile-user


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

* Re: help with define-syntax
  2004-01-10 17:54 help with define-syntax Viktor Pavlenko
@ 2004-01-30  0:12 ` Lynn Winebarger
  0 siblings, 0 replies; 2+ messages in thread
From: Lynn Winebarger @ 2004-01-30  0:12 UTC (permalink / raw)


Viktor Pavlenko wrote:
 > Hello,
 >
 > (warning: this is a newbie question, please be patient:)
 >
 > I'm experimenting with syntax rules and can't figure out how to
 > achieve something that seems reasonable.
 >
 > I want to define a syntax to combine each of supplied procedures with
 > `and' (well my ultimate goal is more ambitious but first things first)
 > while adding some extra argument to them, and it works fine if done
 > like this:
 >   [...]
 > (define-syntax *flt*
 >   (syntax-rules()
 >     ((_ (a) (and (f1 a1 ...) (f2 a2 ...) ...))
     Just to make sure, you know the above "and" is a variable for whatever
actually appears there, so the "and" below won't necessarily be 'and
after expansion.
      It seems like unnecessary confusion.  You should probably just match
(_ (a) (a1 ...) (a2 ...)) [because the same thing goes for "f1" and "f2"].

 >      (lambda (ls)
 >        (display "in xxx") (newline)
 >        (and ((f1 a a1 ...) ls) ((f2 a a2 ...) ls) ...)))))
 > [...]
 > --------------------------------------------------------------8<
 >
 > Now, I want to avoid calling f1, f2, ... each time the resulting
 > procedure is called but rather make a closure with `let', something
 > like
 >
 > --------------------------------------------------------------8<
 > (define-syntax *flt*
 >   (syntax-rules()
 >     ((_ (a) (and (f1 a1 ...) (f2 a2 ...) ...))
 >      (let ((f1-pr (f1 a a1 ...)) (f2-pr (f2 a a2 ...)) ...)
 >        (lambda (ls)
 > 	 (display "in xxx") (newline)
 > 	 (and (f1-pr ls) (f2-pr ls) ...))))))
 > --------------------------------------------------------------8<
 >
 > but it won't work: I get an "extra ellipsis" error in the last `and'
 > statement, and if I comment it out, `let' will complain about
 > "duplicate bound variable".

     The extra ellipsis error is because neither f2-pr nor ls are bound in the
pattern.  They're bound by the let, _after_ expansion.
     The duplicate bound variable doesn't have anything to do with the extra ellipsis,
except that not having the extra ellipsis allows expansion of *flt* to occur.
     The reason for the duplicate bound variable is still that f2-pr is not a syntax variable,
so it gets literally reproduced in your template.  I.e.
(*flt* (foo) (bar (k1 x1 x2) (k2 y11 y12 y13) (k3 y21 y22))

will expand to

(let ((f1-pr (k1 x1 x2))
        (f2-pr (k2 y11 y12 y13))
        (f2-pr (k3 y21 y22)))
     [etc])

Lynn





_______________________________________________
Guile-user mailing list
Guile-user@gnu.org
http://mail.gnu.org/mailman/listinfo/guile-user


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

end of thread, other threads:[~2004-01-30  0:12 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2004-01-10 17:54 help with define-syntax Viktor Pavlenko
2004-01-30  0:12 ` Lynn Winebarger

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).