Skip to content

Instantly share code, notes, and snippets.

Verifying I am +jtmarmon on my passcard. https://onename.com/jtmarmon
user=> (def h "hello")
#'user/h
user=> h
"hello"
user=> 'h
h
user=> (+ 1 2)
3
user=> '(+ 1 2)
(d/transact
datomic
[{:db/id #db/id [:db.part/tx]
:db/txInstant #inst "2011-01-01"}
{:db/id #db/id [:db.part/db]
:db/ident :test/str
:db/valueType :db.type/string
:db/cardinality :db.cardinality/one
@jtmarmon
jtmarmon / gist:0a644fbca15a1742964c
Created May 25, 2015 20:56
Convert datomic entity map into clojure map
(defn emap-to-hash-map [e]
(cond
(or
(-> e class .toString (clojure.string/split #" ") second (= "datomic.query.EntityMap"))
(map? e)) (reduce-kv (fn [m k v] (assoc m k (emap-to-hash-map v))) {} (into {} e))
(coll? e) (map emap-to-hash-map e)
:else e))
{
"paths": {
"/hello": {
"get": {
"responses": {
"200": {
"schema": {
"$ref": "#/definitions/Message"
},
"description": ""
java.lang.StringIndexOutOfBoundsException: String index out of range: 0
String.java:686 java.lang.String.charAt
Compiler.java:6960 clojure.lang.Compiler.maybeResolveIn
core.clj:4026 clojure.core/ns-resolve
core.clj:4023 clojure.core/ns-resolve
backtick.clj:76 backtick/ns-resolve-sym
backtick.clj:94 backtick/resolve-symbol
backtick.clj:87 backtick/resolve-symbol
backtick.clj:87 backtick/resolve-symbol
backtick.clj:87 backtick/resolve-symbol
@jtmarmon
jtmarmon / gist:5980c80ea98cc8cc2b59
Last active August 29, 2015 14:22
if-let-all-each
(defmacro if-let-all-each
"Like if-let-all but allows for a return case in each binding & only has 1 body."
[bindings & body]
(let [pairs (partition 3 bindings)
names (mapv first pairs)
exprs (map second pairs)
fail-vals (map #(nth % 2) pairs)
exprs-in-if-let (fn self [[name1 & more-names] [expr1 & more-exprs] [val1 & more-vals]]
`(if-let [~name1 ~expr1]
@jtmarmon
jtmarmon / gist:cc2b2079cae61e2fd985
Created June 10, 2015 12:16
compojure api compilation stack overflow
java.lang.StackOverflowError
at clojure.lang.Compiler.analyzeSeq(Compiler.java:6651)
at clojure.lang.Compiler.analyze(Compiler.java:6445)
at clojure.lang.Compiler.analyze(Compiler.java:6406)
at clojure.lang.Compiler$InvokeExpr.parse(Compiler.java:3719)
at clojure.lang.Compiler.analyzeSeq(Compiler.java:6646)
at clojure.lang.Compiler.analyze(Compiler.java:6445)
at clojure.lang.Compiler.analyzeSeq(Compiler.java:6632)
at clojure.lang.Compiler.analyze(Compiler.java:6445)
at clojure.lang.Compiler.access$100(Compiler.java:38)
'[:find [?e ...]
:where [?e :foo/bar ?bar]
(or-join [?bar]
[?bar :bar/baz true]
[?bar :bar/boop true])]
;; java.lang.RuntimeException: Unable to resolve symbol: ?bar in this context, compiling:(NO_SOURCE_PATH:0:0)
import {parse, Source} from 'graphql/language'
import {GraphQLSchema, GraphQLObjectType, GraphQLString} from 'graphql/type'
import {graphql} from 'graphql'
const whisperType = new GraphQLObjectType({
name: 'Whisper',
fields: () => ({
whyAreYouWhispering: {
type: GraphQLString
}