event_t *event;
this->mutex->lock(this->mutex);
- event = this->events->get(this->events, name);
- if (event)
+ while (TRUE)
{
- array_insert(event->clients, ARRAY_TAIL, &id);
+ event = this->events->get(this->events, name);
+ if (!event)
+ {
+ break;
+ }
+ if (!event->uses)
+ {
+ array_insert(event->clients, ARRAY_TAIL, &id);
+ break;
+ }
+ this->cond->wait(this->cond, this->mutex);
}
this->mutex->unlock(this->mutex);
bool found = FALSE;
this->mutex->lock(this->mutex);
- event = this->events->get(this->events, name);
- if (event)
+ while (TRUE)
{
- enumerator = array_create_enumerator(event->clients);
- while (enumerator->enumerate(enumerator, ¤t))
+ event = this->events->get(this->events, name);
+ if (!event)
{
- if (*current == id)
+ break;
+ }
+ if (!event->uses)
+ {
+ enumerator = array_create_enumerator(event->clients);
+ while (enumerator->enumerate(enumerator, ¤t))
{
- array_remove_at(event->clients, enumerator);
- found = TRUE;
- break;
+ if (*current == id)
+ {
+ array_remove_at(event->clients, enumerator);
+ found = TRUE;
+ break;
+ }
}
+ enumerator->destroy(enumerator);
+ break;
}
- enumerator->destroy(enumerator);
+ this->cond->wait(this->cond, this->mutex);
}
this->mutex->unlock(this->mutex);
event_t *event;
u_int *current;
- /* deregister all clients */
+ /* deregister client from all events */
this->mutex->lock(this->mutex);
events = this->events->create_enumerator(this->events);
while (events->enumerate(events, NULL, &event))
{
+ while (event->uses)
+ {
+ this->cond->wait(this->cond, this->mutex);
+ }
ids = array_create_enumerator(event->clients);
while (ids->enumerate(ids, ¤t))
{