Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/randomcorp/thread-first-thread-last-backwards-question-mark-as-arrow-cond-arrow-bang

The exciting new ->->><?as->cond->! macro
https://github.com/randomcorp/thread-first-thread-last-backwards-question-mark-as-arrow-cond-arrow-bang

Last synced: about 2 months ago
JSON representation

The exciting new ->->><?as->cond->! macro

Awesome Lists containing this project

README

        

# ->->>cond->!

_As seen in [Every Clojure Talk Ever](https://www.youtube.com/watch?v=jlPaby7suOc) by [Amperity](https://github.com/amperity)_

This is the bread and butter of randomcorp's Clojure code and we're
excited to share it with the world. Have you been frustrated with
always needing to compose the various types of threading macros?

```clojure
(-> []
(conj 1 2 3)
(->> (mapv inc))
(as-> v
{:vec-of-numbers v})
(cond->
(some-pred) (assoc :other-key "other-val")))
```

It would be nice if there were one single macro to do all that for
you. Well, now there is!

```clojure
(->->>cond->!
[]
:-> (conj 1 2 3)
:->> (mapv inc)
:as-> v {:vec-of-numbers v}
:cond-> (some-pred) (assoc :other-key "other-val"))
```

To short-circuit on nil values (a la `some->`), use `:`:

```clojure
(->->>cond->!
[]
:-> not-empty
:
:-> (conj 1))

;; => nil
```

To make assertions about the values during the threading, use `:!`:

```clojure
(->->>cond->!
2
:-> inc
:! even?)

;; => Error!
```

## License

Free, as in beer.