mirror of
https://github.com/status-im/timbre.git
synced 2025-01-16 23:11:21 +00:00
Merge pull request #33 from aperiodic/profiling-fixes
Compile->runtime profiling keyword names (aperiodic)
This commit is contained in:
commit
a29879d1f9
@ -26,13 +26,12 @@
|
|||||||
the raw profiling stats under a special :profiling-stats key (useful for
|
the raw profiling stats under a special :profiling-stats key (useful for
|
||||||
queryable db logging)."
|
queryable db logging)."
|
||||||
[level name & body]
|
[level name & body]
|
||||||
(let [name (utils/fq-keyword name)]
|
`(let [{result# :result stats# :stats} (with-pdata ~level ~@body)]
|
||||||
`(let [{result# :result stats# :stats} (with-pdata ~level ~@body)]
|
(when stats#
|
||||||
(when stats#
|
(timbre/log* print-str ~level {:profile-stats stats#}
|
||||||
(timbre/log* print-str ~level {:profile-stats stats#}
|
(str "Profiling " (utils/fq-keyword ~name))
|
||||||
(str "Profiling " ~name)
|
(str "\n" (format-pdata stats#))))
|
||||||
(str "\n" (format-pdata stats#))))
|
result#))
|
||||||
result#)))
|
|
||||||
|
|
||||||
(defmacro sampling-profile
|
(defmacro sampling-profile
|
||||||
"Like `profile`, but only enables profiling every 1/`proportion` calls.
|
"Like `profile`, but only enables profiling every 1/`proportion` calls.
|
||||||
@ -46,16 +45,15 @@
|
|||||||
"Profile spy. When in the context of a *pdata* binding, records execution time
|
"Profile spy. When in the context of a *pdata* binding, records execution time
|
||||||
of named body. Always returns the body's result."
|
of named body. Always returns the body's result."
|
||||||
[name & body]
|
[name & body]
|
||||||
(let [name (utils/fq-keyword name)]
|
`(if-not *pdata*
|
||||||
`(if-not *pdata*
|
(do ~@body)
|
||||||
(do ~@body)
|
(let [name# (utils/fq-keyword ~name)
|
||||||
(let [name# ~name
|
start-time# (System/nanoTime)]
|
||||||
start-time# (System/nanoTime)]
|
(try
|
||||||
(try
|
(do ~@body)
|
||||||
(do ~@body)
|
(finally
|
||||||
(finally
|
(let [elapsed# (- (System/nanoTime) start-time#)]
|
||||||
(let [elapsed# (- (System/nanoTime) start-time#)]
|
(swap! *pdata* #(assoc % name# (conj (% name# []) elapsed#)))))))))
|
||||||
(swap! *pdata* #(assoc % name# (conj (% name# []) elapsed#))))))))))
|
|
||||||
|
|
||||||
(defmacro p [name & body] `(pspy ~name ~@body)) ; Alias
|
(defmacro p [name & body] `(pspy ~name ~@body)) ; Alias
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user