Skip to content

Instantly share code, notes, and snippets.

Avatar
💭
I can't believe github has status now; why would I put my status here

Phil Hagelberg technomancy

💭
I can't believe github has status now; why would I put my status here
View GitHub Profile
View gist:efe7b120abe93d56984474e6c8473233
phil@localhost:~/lunatest$ ~/.luarocks/bin/luacheck lunatest.lua | grep -v unused | grep -v whitespace
Checking lunatest.lua 40 warnings
lunatest.lua:46:29: variable setmetatable was previously defined on line 42
lunatest.lua:64:7: variable debug was previously defined on line 38
lunatest.lua:489:1: setting non-standard global variable default_hooks
lunatest.lua:512:1: setting non-standard global variable verbose_hooks
lunatest.lua:540:14: accessing undefined variable verbose_hooks
lunatest.lua:540:40: accessing undefined variable default_hooks
lunatest.lua:656:10: variable arg was previously defined as an argument on line 655
View logging-is-weird.clj
;; works
(let [factory clojure.tools.logging/*logger-factory*]
(try
(alter-var-root #'clojure.tools.logging/*logger-factory*
(constantly clojure.tools.logging.impl/disabled-logger-factory))
(is (thrown-with-msg? Exception #"Message not processed"
(test-utils/process-message! msg 2)))
(finally
(alter-var-root #'clojure.tools.logging/*logger-factory* factory))))
@technomancy
technomancy / crash.log
Created Dec 26, 2017
urn crash in luaj
View crash.log
~/src/urn $ make test LUA=luaj
luaj bin/urn.lua tests/compiler/codegen/precedence --run -o /tmp/tmp.9mEtsMxCet -fstrict-structs --
org.luaj.vm2.LuaError: bin/urn.lua:2034 vm error: java.lang.ArrayIndexOutOfBoundsException: -1
stack traceback:
bin/urn.lua:2034: in function 'parseDocstring1'
bin/urn.lua:10481: in function 'validate'
bin/urn.lua:10501: in function 'run'
bin/urn.lua:2858: in function 'runPass1'
bin/urn.lua:10583: in function '?'
bin/urn.lua:11332: in main chunk
@technomancy
technomancy / gist:cc0e7800878c39e4c245fc041c11df4b
Last active Apr 18, 2020
Clojure namespaces, spec, and why they're confusing
View gist:cc0e7800878c39e4c245fc041c11df4b

To me, "require-and-automatically-visible" is violating the beauty of namespace. But, maybe I felt this way because I don't understand Clojure's registry or how require works.

I thought about this more, and I think I have a better understanding of why this feels strange. Clojure has one thing called "namespaces" which are clojure.lang.Namespace objects created by the ns macro. Functionally speaking they are a storage location which mostly just contain vars and references to vars in other namespaces. They are used for code organization: specifically for organizing vars and occasionally Java classes and interfaces.

Clojure also has a completely different thing called "namespaces" which are prefixes that get attached to keywords and symbols. These can interact with ns namespaces thru the reader in a handful of ways (for instance, ::double-colon keywords and symbols inside backtick forms are resolved according to the current clojure.lang.Namespace) but for the most part should be considered a di

View planet_noise.lua
local lg = love.graphics
local lm = love.math
local pmethods={}
local function earth(u)
local cr,cb,cg
if u < 0.5 then
cb = u + 0.5
cr=0
View lein-plugins.md

Leiningen Plugins

Leiningen tasks are simply functions named $TASK in a leiningen.$TASK namespace. So writing a Leiningen plugin is just a matter of creating a project that contains such a function, but much of this documentation applies equally to the tasks that ship with Leiningen itself.

Using the plugin is a matter of declaring it in the :plugins entry of the project map. If a plugin is a matter of user convenience rather

View gist:310638ce84d94131c56351cc67322ec4
~/src/slamhound $ head -n 1 project.clj
(defproject slamhound (or (System/getenv "CIRCLE_BUILD_NUM") "0.0.0-SNAPSHOT")
~/src/slamhound $ CIRCLE_BUILD_NUM=751 lein pprint :version
"751"
~/src/slamhound $ lein pprint :version
"0.0.0-SNAPSHOT"
View test.el
(defvar clj-last-test "user")
(defun clj-run-tests (run-last)
(interactive "P")
(monroe-send-eval-string
(format "%s" `(circleci.test/run-tests
(quote ,(if run-last
clj-last-test
(setq clj-last-test (clojure-find-ns))))))
(monroe-make-response-handler)))
@technomancy
technomancy / conj-2017.md
Last active Jul 4, 2017
Clojure Conj talk proposal
View conj-2017.md

Clojure Conj 2017 Talk: Dev Tools as Data

Abstract (5 sentences max)

In the Clojure community we love to say "it's just data", and this enables us to compose things in unique and often-unexpected ways.

One place where that maxim hasn't been thoroughly applied is developer tooling. Representing things like tracers, test runners, and refactoring tools with a unified declarative model allows us to construct powerful meta-tools for various development environments and avoid reinventing the wheel for building interfaces for each editor one at a time.

Let's do some cross-runtime metaprogramming for greater Clojure/editor symbiosis!

View gist:34734a26e336c7e5ab9e25ebe847ad96
phil@localhost ~ $ openssl speed blowfish
Doing blowfish cbc for 3s on 16 size blocks: 15260699 blowfish cbc's in 2.97s
Doing blowfish cbc for 3s on 64 size blocks: 4019394 blowfish cbc's in 2.99s
Doing blowfish cbc for 3s on 256 size blocks: 1027156 blowfish cbc's in 3.00s
Doing blowfish cbc for 3s on 1024 size blocks: 258836 blowfish cbc's in 3.00s
Doing blowfish cbc for 3s on 8192 size blocks: 32246 blowfish cbc's in 3.00s
OpenSSL 1.0.1t 3 May 2016
built on: Thu Jan 26 23:29:15 2017
options:bn(64,64) rc4(16x,int) des(idx,cisc,16,int) aes(partial) blowfish(idx)
compiler: gcc -I. -I.. -I../include -fPIC -DOPENSSL_PIC -DOPENSSL_THREADS -D_REENTRANT -DDSO_DLFCN -DHAVE_DLFCN_H -m64 -DL_ENDIAN -DTERMIO -g -O2 -fstack-protector-strong -Wformat -Werror=format-security -D_FORTIFY_SOURCE=2 -Wl,-z,relro -Wa,--noexecstack -Wall -DMD32_REG_T=int -DOPENSSL_IA32_SSE2 -DOPENSSL_BN_ASM_MONT -DOPENSSL_BN_ASM_MONT5 -DOPENSSL_BN_ASM_GF2m -DSHA1_ASM -DSHA256_ASM -DSHA512_ASM -DMD5_ASM -DAES_ASM -DVPAES_ASM -DBSAES_ASM -DWHI
You can’t perform that action at this time.