Merge pull request #1303 from neil-lindquist/single-arg-cond

cond accept single-argument branches
This commit is contained in:
Kodi Arfer 2017-06-10 08:32:46 -07:00 committed by GitHub
commit abb75453cc
5 changed files with 30 additions and 6 deletions

View File

@ -77,3 +77,4 @@
* Charles de Lacombe <ealhad@mail.com> * Charles de Lacombe <ealhad@mail.com>
* John Patterson <john@johnppatterson.com> * John Patterson <john@johnppatterson.com>
* Kai Lüke <kailueke@riseup.net> * Kai Lüke <kailueke@riseup.net>
* Neil Lindquist <archer1mail@gmail.com

1
NEWS
View File

@ -32,6 +32,7 @@ Changes from 0.12.1
`(try 1 (except [ValueError] 2) (else 3))` returns `3`. `(try 1 (except [ValueError] 2) (else 3))` returns `3`.
* xor: If exactly one argument is true, return it * xor: If exactly one argument is true, return it
* hy.core.reserved is now hy.extra.reserved * hy.core.reserved is now hy.extra.reserved
* cond now supports single argument branches
[ Bug Fixes ] [ Bug Fixes ]
* All shadowed operators have the same arities as real operators * All shadowed operators have the same arities as real operators

View File

@ -374,6 +374,18 @@ shows the relationship between the macro and its expansion:
(if condition-1 result-1 (if condition-1 result-1
(if condition-2 result-2)) (if condition-2 result-2))
If only the condition is given in a branch, then the condition is also used as
the result. The expansion of this single argument version is demonstrated
below:
.. code-block:: clj
(cond [condition-1]
[condition-2])
(if condition-1 condition-1
(if condition-2 condition-2))
As shown below, only the first matching result block is executed. As shown below, only the first matching result block is executed.
.. code-block:: clj .. code-block:: clj

View File

@ -56,10 +56,10 @@
(if (not (= (type branch) HyList)) (if (not (= (type branch) HyList))
(macro-error branch "cond branches need to be a list")) (macro-error branch "cond branches need to be a list"))
(if (< (len branch) 2) (if (< (len branch) 2)
(macro-error branch "cond branches need at least two items: a test and one or more code branches")) (do
(setv test (first branch)) (setv g (gensym))
(setv thebranch (cut branch 1)) `(if (do (setv ~g ~(first branch)) ~g) ~g))
`(if ~test (do ~@thebranch))) `(if ~(first branch) (do ~@(cut branch 1)))))
(setv root (check-branch branch)) (setv root (check-branch branch))
(setv latest-branch root) (setv latest-branch root)

View File

@ -291,7 +291,17 @@
(cond (cond
[(= 1 2) (assert (is True False))] [(= 1 2) (assert (is True False))]
[(is None None) (setv x True) (assert x)]) [(is None None) (setv x True) (assert x)])
(assert (= (cond) None))) (assert (= (cond) None))
(assert (= (cond
[False]
[[]]
[8])) 8)
;make sure test is only evaluated once
(setv x 0)
(cond [(do (+= x 1) True)])
(assert (= x 1)))
(defn test-if [] (defn test-if []