blob: 35bb9824fae03d1741b3198af4b591559f649617 (
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
|
(in-package :wait-group)
(defclass wait-group ()
((counter
:initform 0
:accessor counter)))
(defun make-wait-group ()
(make-instance 'wait-group))
(defgeneric add (wait-group &optional amount)
(:documentation ""))
(defmethod add ((wait-group wait-group) &optional (amount 1))
(incf (counter wait-group) amount))
(defgeneric done (wait-group)
(:documentation ""))
(defmethod done ((wait-group wait-group))
(decf (counter wait-group)))
(defgeneric wait (wait-group)
(:documentation ""))
(defmethod wait ((wait-group wait-group))
(loop until (= (counter wait-group) 0)))
|