Give `require` the same features as `import` (#1142)
Give `require` the same features as `import`
You can now do (require foo), (require [foo [a b c]]), (require [foo [*]]), and (require [foo :as bar]). The first and last forms get you macros named foo.a, foo.b, etc. or bar.a, bar.b, etc., respectively. The second form only gets the macros in the list.
Implements #1118 and perhaps partly addresses #277.
N.B. The new meaning of (require foo) will cause all existing code that uses macros to break. Simply replace these forms with (require [foo [*]]) to get your code working again.
There's a bit of a hack involved in the forms (require foo) or (require [foo :as bar]). When you call (foo.a ...) or (bar.a ...), Hy doesn't actually look inside modules. Instead, these (require ...) forms give the macros names that have periods in them, which happens to work fine with the way Hy finds and interprets macro calls.
* Make `require` syntax stricter and add tests
* Update documentation for `require`
* Documentation wording improvements
* Allow :as in `require` name lists
2016-11-03 00:35:58 -07:00
|
|
|
(require [hy.contrib.loop [loop]])
|
2014-01-08 22:54:49 -05:00
|
|
|
(import sys)
|
|
|
|
|
|
|
|
(defn tco-sum [x y]
|
|
|
|
(loop [[x x] [y y]]
|
|
|
|
(cond
|
|
|
|
[(> y 0) (recur (inc x) (dec y))]
|
|
|
|
[(< y 0) (recur (dec x) (inc y))]
|
|
|
|
[True x])))
|
|
|
|
|
|
|
|
(defn non-tco-sum [x y]
|
|
|
|
(cond
|
|
|
|
[(> y 0) (inc (non-tco-sum x (dec y)))]
|
|
|
|
[(< y 0) (dec (non-tco-sum x (inc y)))]
|
|
|
|
[True x]))
|
|
|
|
|
|
|
|
(defn test-loop []
|
|
|
|
;; non-tco-sum should fail
|
|
|
|
(try
|
|
|
|
(setv n (non-tco-sum 100 10000))
|
2015-08-09 00:41:11 -06:00
|
|
|
(except [e RuntimeError]
|
2016-11-23 18:35:17 -08:00
|
|
|
(assert True))
|
2014-01-08 22:54:49 -05:00
|
|
|
(else
|
2016-11-23 18:35:17 -08:00
|
|
|
(assert False)))
|
2014-01-08 22:54:49 -05:00
|
|
|
|
|
|
|
;; tco-sum should not fail
|
|
|
|
(try
|
|
|
|
(setv n (tco-sum 100 10000))
|
2015-08-09 00:41:11 -06:00
|
|
|
(except [e RuntimeError]
|
2016-11-23 18:35:17 -08:00
|
|
|
(assert False))
|
2014-01-08 22:54:49 -05:00
|
|
|
(else
|
|
|
|
(assert (= n 10100)))))
|
|
|
|
|
|
|
|
(defn test-recur-in-wrong-loc []
|
|
|
|
(defn bad-recur [n]
|
|
|
|
(loop [[i n]]
|
|
|
|
(if (= i 0)
|
|
|
|
0
|
|
|
|
(inc (recur (dec i))))))
|
|
|
|
|
|
|
|
(try
|
|
|
|
(bad-recur 3)
|
2015-08-09 00:41:11 -06:00
|
|
|
(except [e TypeError]
|
2016-11-23 18:35:17 -08:00
|
|
|
(assert True))
|
2014-01-08 22:54:49 -05:00
|
|
|
(else
|
2016-11-23 18:35:17 -08:00
|
|
|
(assert False))))
|
2017-03-30 15:49:10 -07:00
|
|
|
|
|
|
|
(defn test-recur-string []
|
|
|
|
"test that `loop` doesn't touch a string named `recur`"
|
|
|
|
(assert (= (loop [] (+ "recur" "1")) "recur1")))
|