Source

metrics-clojure / metrics-clojure-core / src / metrics / gauges.clj

Full commit
Steve Losh 26d62ce 
Steve Losh 2bf9a78 
Steve Losh 26d62ce 























Steve Losh cf47ec1 
Steve Losh 2934725 
Ian Eure 27c731b 

Steve Losh 9f89ac1 

Steve Losh cf47ec1 
Steve Losh 2bf9a78 





Ian Eure 27c731b 
Steve Losh 26d62ce 





(ns metrics.gauges
  (:use [metrics.utils :only (metric-name desugared-title)])
  (:import (com.yammer.metrics Metrics))
  (:import (com.yammer.metrics.core Gauge)))


; Create ----------------------------------------------------------------------
(defmacro gauge
  "Create a new Gauge metric with the given title.

  The body exprs will be used to retrieve the value of the Gauge when requested."
  [title & body]
  `(Metrics/newGauge (metric-name ~title)
                     (proxy [Gauge] []
                       (value [] (do ~@body)))))

(defn gauge-fn
  "Create a new Gauge metric with the given title.

  The given function will be called (with no arguments) to retrieve the value of
  the Gauge when requested."
  [title f]
  (Metrics/newGauge (metric-name title)
                    (proxy [Gauge] []
                      (value [] (f)))))


(defmacro defgauge
  "Define a new Gauge metric with the given title.

  The rest of the arguments may be a body form or function to call to
  retrieve the value of the Gauge."
  [title & [b & bs :as body]]
  (let [[s title] (desugared-title title)]
    (if (and (empty? bs)
             (symbol? b)
             (fn? (eval b)))
      `(def ~s (gauge-fn ~title ~b))
      `(def ~s (gauge ~title ~@body)))))


; Read ------------------------------------------------------------------------
(defn value
  "Return the value of the given Gauge."
  [^Gauge g]
  (.value g))