Quickly fork, edit online, and submit a pull request for this page.
Requires a signed-in GitHub account. This works well for small changes.
If you'd like to make larger changes you may want to consider using
a local clone.

core.sync.semaphore

The semaphore module provides a general use semaphore for synchronization.

This class represents a general counting semaphore as concieved by Edsger
Dijkstra. As per Mesa type monitors however, "signal" has been replaced
with "notify" to indicate that control is not transferred to the waiter when
a notification is sent.

this(uint count = 0);

Initializes a semaphore object with the specified initial count.

Parameters:

uint count

The initial count for the semaphore.

Throws:

SyncError on error.

void wait();

Wait until the current count is above zero, then atomically decrement
the count by one and return.

Throws:

SyncError on error.

bool wait(Duration period);

Suspends the calling thread until the current count moves above zero or
until the supplied time period has elapsed. If the count moves above
zero in this interval, then atomically decrement the count by one and
return true. Otherwise, return false.

Parameters:

Duration period

The time to wait.

In:period must be non-negative.

Throws:

SyncError on error.

Returns:

true if notified before the timeout and false if not.

void notify();

Atomically increment the current count by one. This will notify one
waiter, if there are any in the queue.

Throws:

SyncError on error.

bool tryWait();

If the current count is equal to zero, return. Otherwise, atomically
decrement the count by one and return true.