2014-01-08 22:54:49 -05:00
|
|
|
(require hy.contrib.loop)
|
|
|
|
(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]
|
2014-01-08 22:54:49 -05:00
|
|
|
(assert true))
|
|
|
|
(else
|
|
|
|
(assert false)))
|
|
|
|
|
|
|
|
;; tco-sum should not fail
|
|
|
|
(try
|
|
|
|
(setv n (tco-sum 100 10000))
|
2015-08-09 00:41:11 -06:00
|
|
|
(except [e RuntimeError]
|
2014-01-08 22:54:49 -05:00
|
|
|
(assert false))
|
|
|
|
(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]
|
2014-01-08 22:54:49 -05:00
|
|
|
(assert true))
|
|
|
|
(else
|
|
|
|
(assert false))))
|