2017-04-27 14:16:57 -07:00
|
|
|
;; Copyright 2017 the authors.
|
|
|
|
;; This file is part of Hy, which is free software licensed under the Expat
|
|
|
|
;; license. See the LICENSE.
|
|
|
|
|
2015-07-26 14:19:10 -07:00
|
|
|
(import [functools [wraps]])
|
|
|
|
|
|
|
|
|
2017-04-21 08:07:48 -07:00
|
|
|
(defn test-sharp-macro []
|
|
|
|
"Test a basic sharp macro"
|
|
|
|
(defsharp ^ [expr]
|
2013-12-15 17:47:24 +01:00
|
|
|
expr)
|
|
|
|
|
|
|
|
(assert (= #^"works" "works")))
|
|
|
|
|
|
|
|
|
2017-04-21 08:07:48 -07:00
|
|
|
(defn test-sharp-macro-expr []
|
2013-12-15 17:47:24 +01:00
|
|
|
"Test basic exprs like lists and arrays"
|
2017-04-21 08:07:48 -07:00
|
|
|
(defsharp n [expr]
|
2013-12-15 17:47:24 +01:00
|
|
|
(get expr 1))
|
|
|
|
|
|
|
|
(assert (= #n[1 2] 2))
|
|
|
|
(assert (= #n(1 2) 2)))
|
|
|
|
|
|
|
|
|
2017-04-21 08:07:48 -07:00
|
|
|
(defn test-sharp-macro-override []
|
2013-12-15 17:47:24 +01:00
|
|
|
"Test if we can override function symbols"
|
2017-04-21 08:07:48 -07:00
|
|
|
(defsharp + [n]
|
2013-12-15 17:47:24 +01:00
|
|
|
(+ n 1))
|
|
|
|
|
|
|
|
(assert (= #+2 3)))
|
|
|
|
|
|
|
|
|
2017-04-21 08:07:48 -07:00
|
|
|
(defn test-sharp-macros-macros []
|
|
|
|
"Test if defsharp is actually a macro"
|
|
|
|
(defsharp t [expr]
|
2014-01-14 02:38:16 +01:00
|
|
|
`(, ~@expr))
|
|
|
|
|
|
|
|
(def a #t[1 2 3])
|
|
|
|
|
|
|
|
(assert (= (type a) tuple))
|
|
|
|
(assert (= (, 1 2 3) a)))
|
|
|
|
|
|
|
|
|
2017-04-21 08:07:48 -07:00
|
|
|
(defn test-sharp-macro-string-name []
|
|
|
|
"Test if defsharp accepts a string as a macro name."
|
2015-12-17 12:59:33 +01:00
|
|
|
|
2017-04-21 08:07:48 -07:00
|
|
|
(defsharp "." [expr]
|
2015-12-17 12:59:33 +01:00
|
|
|
expr)
|
|
|
|
|
|
|
|
(assert (= #."works" "works")))
|
|
|
|
|
|
|
|
|
2017-04-21 08:07:48 -07:00
|
|
|
(defn test-builtin-decorator-sharp []
|
2015-07-26 14:19:10 -07:00
|
|
|
(defn increment-arguments [func]
|
|
|
|
"Increments each argument passed to the decorated function."
|
2017-03-23 15:11:55 -07:00
|
|
|
((wraps func)
|
|
|
|
(fn [&rest args &kwargs kwargs]
|
2015-07-26 14:19:10 -07:00
|
|
|
(apply func
|
|
|
|
(map inc args)
|
|
|
|
(dict-comp k (inc v) [[k v] (.items kwargs)])))))
|
|
|
|
|
|
|
|
#@(increment-arguments
|
|
|
|
(defn foo [&rest args &kwargs kwargs]
|
|
|
|
"Bar."
|
|
|
|
(, args kwargs)))
|
|
|
|
|
|
|
|
;; The decorator did what it was supposed to
|
|
|
|
(assert (= (, (, 2 3 4) {"quux" 5 "baz" 6})
|
|
|
|
(foo 1 2 3 :quux 4 :baz 5)))
|
|
|
|
|
2015-12-08 14:43:47 +01:00
|
|
|
;; @wraps preserved the docstring and __name__
|
2015-07-26 14:19:10 -07:00
|
|
|
(assert (= "foo" (. foo --name--)))
|
|
|
|
(assert (= "Bar." (. foo --doc--)))
|
|
|
|
|
2017-04-21 08:07:48 -07:00
|
|
|
;; We can use the #@ sharp macro to apply more than one decorator
|
2015-07-26 14:19:10 -07:00
|
|
|
#@(increment-arguments
|
|
|
|
increment-arguments
|
|
|
|
(defn double-foo [&rest args &kwargs kwargs]
|
|
|
|
"Bar."
|
|
|
|
(, args kwargs)))
|
|
|
|
|
|
|
|
(assert (= (, (, 3 4 5) {"quux" 6 "baz" 7})
|
|
|
|
(double-foo 1 2 3 :quux 4 :baz 5))))
|