Hi!
On 23/09/13 17:59, Matthias Felleisen wrote:
Is the following code really that much more complicated that define-macro? --
Matthias
Well, it certainly might not! But I don't find confident enough with
syntax-case (less with syntax-parse), and I also have some code I will
reuse that uses define-macro. So, any chance I can get null inserted?
Anyway, thanks for the pointer and example. At some point I will do all my
macros with syntax-case/-parse.
Regards,
diego.
#lang racket
(require (for-syntax syntax/parse))
(define-syntax (new-field stx)
(syntax-parse stx
[(_ f:id) #'(new-field f null)]
[(_ f:id default-value)
(define field-name (append-id stx "-" #'f))
(define set-name (append-id stx #'f "-set!"))
#`(begin
(field [#,field-name default-value])
(define/public (f) #,field-name)
(define/public (#,set-name new-value)
(set! #,field-name new-value)))]))
;; Syntax (U String Syntax/Identifier) -> Syntax/Identifier
(define-for-syntax (append-id stx x y)
(define x:str (if (string? x) x (symbol->string (syntax-e x))))
(define y:str (if (string? y) y (symbol->string (syntax-e y))))
(datum->syntax stx (string->symbol (string-append x:str y:str))))
;; -----------------------------------------------------------------------------
;; some small test
(module+ test
(require rackunit)
(define foo%
(class object%
(super-new)
(new-field f)
(new-field g 10)))
(define foo (new foo%))
(check-equal? (send foo f) null)
(check-equal? (send foo g) 10)
(check-equal? (begin (send foo g-set! 20) (send foo g)) 20))
On Sep 23, 2013, at 5:20 AM, Diego Sevilla Ruiz <dsevi...@ditec.um.es> wrote:
Dear all:
I've been developing a library that needs some macro coding. As I come
from Common-Lisp and Elisp, I find more pleasing the old-style define-macro.
The following function is used as a part of the result building of another
define-macro:
(define (new-field-mono f-name (default-value null))
(let ((field-name (append-id "-" f-name))
(set-name (append-id f-name "-set!")))
`(begin
(field [,field-name ,default-value])
(define/public (,f-name) ,field-name)
(define/public (,set-name value)
(set! ,field-name value)))))
The problem is in the line of the "field". As default-value is null "()", the
field declaration gets:
(field -xxx ())
Then, the expansions sees this "()", and thinks it is an application of
no-function, getting the error:
#%app: missing procedure expression;
probably originally (), which is an illegal empty application in: (#%app)
So how could I specify some default value in that function so that the
field gets its default value as null? Using '() as default-value doesn't work
either, but however, if I generate exactly:
(field [,field-name null])
it works, so I'm expecting that more macro conversion steps are executed to the
unquote operator, but my knowledge doesn't go that far.
Thanks,
diego.
--
Diego Sevilla Ruiz -- http://ditec.um.es/~dsevilla/ -- dsevi...@um.es _.___
Dep. Ingeniería y Tecnología de Computadores, Facultad de Informática D|TEC
Univ.de Murcia,Campus Espinardo,30080 Murcia (SPAIN),Tel.+34868887571
____________________
Racket Users list:
http://lists.racket-lang.org/users
--
Diego Sevilla Ruiz -- http://ditec.um.es/~dsevilla/ -- dsevi...@um.es _.___
Dep. Ingeniería y Tecnología de Computadores, Facultad de Informática D|TEC
Univ.de Murcia,Campus Espinardo,30080 Murcia (SPAIN),Tel.+34868887571
____________________
Racket Users list:
http://lists.racket-lang.org/users