Liking cljdoc? Tell your friends :D

clojure.tools.macro

Tools for writing macros.

Releases and Dependency Information

Latest stable release: 0.1.5

CLI/deps.edn dependency information:

org.clojure/tools.macro {:mvn/version "0.1.5"}

Leiningen dependency information:

[org.clojure/tools.macro "0.1.5"]

Maven dependency information:

<dependency>
  <groupId>org.clojure</groupId>
  <artifactId>tools.macro</artifactId>
  <version>0.1.5</version>
</dependency>

Example Usages

macrolet: local macro definitions

Example:

(macrolet [(foo [form] `(~form ~form))]
  (foo x))

expands to (x x)

symbol-macrolet: local symbol macro definitions

Example:

(symbol-macrolet [def foo]
  (def def def))

expands to (def def foo)

defsymbolmacro, with-symbol-macros: global symbol macro definitions

Example:

(defsymbolmacro sum-2-3 (plus 2 3))
(with-symbol-macros
  (+ 1 sum-2-3))

expands to (+ 1 (plus 2 3))

mexpand-1

like clojure.core/macroexpand-1, but handles symbol macros

mexpand

like clojure.core/macroexpand, but handles symbol macros

mexpand-all

full recursive macro expansion

name-with-attributes

For writing def-like macros. Handles optional docstrings and attribute maps for a name to be defined in a list of macro arguments.

Developer Information

Change Log

  • Release 0.2.0 on 2024.02.06
    • Update Clojure dep to 1.10.3
  • Release 0.1.5 on 2013.09.12
    • Fix macroexpansion of methods in deftype* and reify*
    • Allow only non-qualified symbols in macrolet and symbol-macrolet
    • Fix bug that caused overlooking local macro definitions
  • Release 0.1.4 on 2013.09.07
    • Fix compatibility issue for Clojure 1.3/1.4
  • Release 0.1.2 on 2012.02.18
    • Protect symbols bound by let and letfn against macroexpansion from an outer scope
  • Release 0.1.1 on 2011.05.26
    • Added name-with-attributes
  • Release 0.1.0 on 2011.05.04
    • Version imported from old contrib

Copyright and License

Copyright (c) Rich Hickey. All rights reserved. The use and distribution terms for this software are covered by the Eclipse Public License 1.0 (https://opensource.org/license/epl-1-0/) which can be found in the file epl-v10.html at the root of this distribution. By using this software in any fashion, you are agreeing to be bound bythe terms of this license. You must not remove this notice, or any other, from this software.

Can you improve this documentation? These fine people already did:
Alex Miller, Konrad Hinsen, JarrodCTaylor, Sean Corfield, Fogus, fogus & Stuart Halloway
Edit on GitHub

cljdoc is a website building & hosting documentation for Clojure/Script libraries

× close