Hi, I have just been playing around with this idea and I got something.
user=> (def some-numbers ‘(2 4 6 8)) #This is my value to test later. #’user/some-numbers user=> (def evens? (partial (when (apply = (map even? some-numbers))))) #’user/evens? user=> (evens? (println “one”)) one NullPointerException user/eval239 (NO_SOURCE_FILE:74) user=> What is my mistake? Thanks. On 12 December 2017 at 07:52, Stephen Feyrer <stephen.fey...@gmail.com> wrote: > Hi Tim, > > Thank you. > > > -- > Kind regards > > Stephen. > > On 11 December 2017 at 23:58, Timothy Baldridge <tbaldri...@gmail.com> > wrote: > >> I talked a bit about this in my video on Boolean Blindness: >> https://www.youtube.com/watch?v=K1LaaJMscCc >> >> Might be worth a watch. >> >> On Mon, Dec 11, 2017 at 4:56 PM, Stephen Feyrer <stephen.fey...@gmail.com >> > wrote: >> >>> Hi there, >>> >>> I have been trying to shake this thought for a while now. Essentially, >>> my thought was if you can return a function why not decision component of >>> an IF, WHEN or SOME statement? That would give you a re-usable named >>> choice. >>> >>> Then you could write: >>> >>> (celebration: do-something do-something-else) >>> >>> >>> This would be equivalent to writing: >>> >>> (def success [apples bananas pears]) >>> >>> (defn celebration: [x y] (if (empty? success) x y)) >>> >>> (celebration: (do-something do-something-else)) >>> >>> >>> I'm reasonably certain of the foolishness of this thought but >>> occasionally, I have doubts. >>> >>> Maybe I'm barking up the wrong tree or possibly I've seen something like >>> this before and forgotten about it. Perhaps, this is just taking things >>> too far... Either way, it's deferring the choice until it's needed. In >>> the right hands it could make for more readable code. >>> >>> For completeness sake, to define the first form above you'd use: >>> >>> (defc celebration: (if (empty? success))) >>> >>> >>> A more usable example might look like: >>> >>> (def nums [1 2 3 4 5 6 7 8]) >>> >>> (defc even-nums: (some (even? nums))) >>> >>> I guess this makes the real question, is it a good thing to be able to >>> defer choice like this? >>> >>> >>> Btw, defc would be like def-choice but other options might be deft - >>> def-test or defp - def-predicate. >>> >>> >>> -- >>> Kind regards >>> >>> Stephen >>> >>> -- >>> You received this message because you are subscribed to the Google >>> Groups "Clojure" group. >>> To post to this group, send email to clojure@googlegroups.com >>> Note that posts from new members are moderated - please be patient with >>> your first post. >>> To unsubscribe from this group, send email to >>> clojure+unsubscr...@googlegroups.com >>> For more options, visit this group at >>> http://groups.google.com/group/clojure?hl=en >>> --- >>> You received this message because you are subscribed to the Google >>> Groups "Clojure" group. >>> To unsubscribe from this group and stop receiving emails from it, send >>> an email to clojure+unsubscr...@googlegroups.com. >>> For more options, visit https://groups.google.com/d/optout. >>> >> >> >> >> -- >> “One of the main causes of the fall of the Roman Empire was that–lacking >> zero–they had no way to indicate successful termination of their C >> programs.” >> (Robert Firth) >> >> -- >> You received this message because you are subscribed to the Google >> Groups "Clojure" group. >> To post to this group, send email to clojure@googlegroups.com >> Note that posts from new members are moderated - please be patient with >> your first post. >> To unsubscribe from this group, send email to >> clojure+unsubscr...@googlegroups.com >> For more options, visit this group at >> http://groups.google.com/group/clojure?hl=en >> --- >> You received this message because you are subscribed to the Google Groups >> "Clojure" group. >> To unsubscribe from this group and stop receiving emails from it, send an >> email to clojure+unsubscr...@googlegroups.com. >> For more options, visit https://groups.google.com/d/optout. >> > > -- You received this message because you are subscribed to the Google Groups "Clojure" group. To post to this group, send email to clojure@googlegroups.com Note that posts from new members are moderated - please be patient with your first post. To unsubscribe from this group, send email to clojure+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/clojure?hl=en --- You received this message because you are subscribed to the Google Groups "Clojure" group. To unsubscribe from this group and stop receiving emails from it, send an email to clojure+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.