Liking cljdoc? Tell your friends :D

hara.function.procedure.retry


retryclj

(retry {:keys [retry arglist] :as instance} args e)

sets up arguments if retrying. if no retry, returns nil

(-> (retry {:arglist [:age :gender :retry] :retry {:handlers [{:on {:cats odd?} :apply (fn [state e] (update-in state [:types (type e)] (fnil inc 0))) :wait (fn [state count] 0)}] :on Throwable :count 0 :state {:a 1 :b 2} :limit 10 :wait 100}} [:a :b {}] (ex-info "hello" {:cats 11})) second) => (contains-in [:a :b {:handlers [{:on {:cats odd?}, :apply fn?, :wait fn?}] :on java.lang.Throwable, :count 1, :state {:types {clojure.lang.ExceptionInfo 1}, :b 2, :a 1}, :limit 10, :wait 100}])

sets up arguments if retrying. if no retry, returns nil

(-> (retry {:arglist [:age :gender :retry]
            :retry {:handlers [{:on {:cats odd?}
                                :apply   (fn [state e]
                                           (update-in state [:types (type e)] (fnil inc 0)))
                                :wait    (fn [state count]
                                           0)}]
                    :on Throwable
                    :count 0
                   :state  {:a 1 :b 2}
                    :limit 10
                    :wait  100}}
           [:a :b {}]
           (ex-info "hello" {:cats 11}))
    second)
=> (contains-in
    [:a :b
     {:handlers
      [{:on {:cats odd?}, :apply fn?, :wait fn?}]
      :on java.lang.Throwable,
      :count 1,
      :state {:types {clojure.lang.ExceptionInfo 1},
              :b 2,
              :a 1},
      :limit 10,
      :wait 100}])
raw docstring

retry-argsclj

(retry-args args arglist retry instance)

injects new args based on the instance arglist (retry-args [1 2 {}] [:a :b :retry] {:wait 5} {}) => '(1 2 {:wait 5})

injects new args based on the instance arglist
(retry-args [1 2 {}]
            [:a :b :retry]
            {:wait 5}
            {})
=> '(1 2 {:wait 5})
raw docstring

retry-checkclj

(retry-check {:keys [limit state count] :as handler})

checks to see if a retry is needed

(retry-check {:limit 2 :count 3}) => false

(retry-check {:limit (fn [state count] (> (/ (inc count) (:restarted state)) 2)) :state {:restarted 3} :count 8}) => true

checks to see if a retry is needed

(retry-check {:limit 2 :count 3})
=> false

(retry-check {:limit (fn [state count]
                       (> (/ (inc count) (:restarted state))
                          2))
              :state {:restarted 3}
              :count 8})
=> true
raw docstring

retry-pickclj

(retry-pick {:keys [on] :as handler} e)

chooses the exception handler based upon the exception (retry-pick {:on #{Exception}} (Exception.)) => true

(retry-pick {:on Exception} (Exception.)) => true

(retry-pick {:on {:a #(= :error %)}} (ex-info "error" {:a :error})) => true

chooses the exception handler based upon the exception
(retry-pick {:on #{Exception}} (Exception.))
=> true

(retry-pick {:on Exception} (Exception.))
=> true

(retry-pick {:on {:a #(= :error %)}} (ex-info "error" {:a :error}))
=> true
raw docstring

retry-stateclj

(retry-state {:keys [apply state] :as handler} e)

calculates the next retry state

(retry-state {:apply (fn [state e] (update-in state [:file-errors] (fnil inc 0))) :state {}} (Exception.)) => {:file-errors 1}

calculates the next retry state

(retry-state {:apply (fn [state e]
                       (update-in state [:file-errors] (fnil inc 0)))
              :state {}}
             (Exception.))
=> {:file-errors 1}
raw docstring

retry-waitclj

(retry-wait {:keys [wait state count] :as handler})

waits in milliseconds depending upon the handler

(retry-wait {}) => 0

(retry-wait {:wait 100}) => 100

(retry-wait {:wait (fn [state count] (if (> (:expiry state) count) 1000 0)) :state {:expiry 4} :count 5}) => 0

waits in milliseconds depending upon the handler

(retry-wait {}) => 0

(retry-wait {:wait 100}) => 100

(retry-wait {:wait (fn [state count]
                     (if (> (:expiry state) count)
                       1000
                       0))
             :state {:expiry 4}
             :count 5})
=> 0
raw docstring

cljdoc is a website building & hosting documentation for Clojure/Script libraries

× close