Hi,

I'd like to write a macro which transforms

(my-macro SomeClass. a b [x y] c [e f])

into

(SomeClass. a b x y c e f)

(the order of collections and single values in the arguments should be arbitrary)

The closest I came was

(defmacro my-macro [func & args]
  `(~func ~@(flatten args)))

This works for simple cases like

(my-macro SomeClass. 1 2 [3 4] 5)

but clearly breaks when I do

(def a [1 2])
(def b [3 4])
(my-macro SomeClass. a b) :

(macroexpand-1 '(my-macro SomeClass. a b))
=> (SomeClass. a b)

"flatten" seems the wrong way to do that. But I somehow need to evaluate the forms in the args before the unqoute splice happens.
How would I do that?
Any ideas would be greatly appreciated.

- thomas

--
You received this message because you are subscribed to the Google
Groups "Clojure" group.
To post to this group, send email to clojure@googlegroups.com
Note that posts from new members are moderated - please be patient with your 
first post.
To unsubscribe from this group, send email to
clojure+unsubscr...@googlegroups.com
For more options, visit this group at
http://groups.google.com/group/clojure?hl=en

Reply via email to