aboutsummaryrefslogtreecommitdiffstats
path: root/src/wait-group.lisp
blob: a00c2bbca0de70ac4d1ffdddf53a81d2e7a60181 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
;;;; TODO

(in-package :wait-group)

(defclass wait-group ()
  ((counter
     :initform 0
     :accessor counter
     :documentation "Count of jobs to wait for."))

  (:documentation "Block waiting for jobs to finish."))

(defmethod print-object ((object wait-group) stream)
  (print-unreadable-object (object stream :type t)
    (with-slots (counter) object
      (format stream ":counter ~s" counter))))

(defun make-wait-group ()
  "Make a wait-group instance."
  (make-instance 'wait-group))

(defgeneric add (wait-group &optional amount)
  (:documentation "Track a new job in the group."))

(defmethod add ((wait-group wait-group) &optional (amount 1))
  (incf (counter wait-group) amount))

(defgeneric done (wait-group)
  (:documentation "Stop tracking a job in the group."))

(defmethod done ((wait-group wait-group))
  (decf (counter wait-group)))

(defgeneric wait (wait-group)
  (:documentation "Block waiting for tracked jobs to finish."))

(defmethod wait ((wait-group wait-group))
  (loop until (<= (counter wait-group) 0)))