Nim-Libp2p Copyright (c) 2020 Status Research & Development GmbH
- Licensed under either of
- Apache License, version 2.0, (LICENSE-APACHE)
- MIT license (LICENSE-MIT)
at your option. This file may not be copied, modified, or distributed except according to those terms.
Types
AsyncSemaphore = ref object of RootObj size*: int count: int queue: seq[Future[void]]
- Source Edit
Procs
proc acquire(s: AsyncSemaphore): Future[void] {....raises: [Defect], tags: [].}
- Acquire a resource and decrement the resource counter. If no more resources are available, the returned future will not complete until the resource count goes above 0. Source Edit
proc count(s: AsyncSemaphore): int {....raises: [Defect], tags: [].}
- Source Edit
proc forceAcquire(s: AsyncSemaphore) {....raises: [Defect], tags: [].}
- ForceAcquire will always succeed, creating a temporary slot if required. This temporary slot will stay usable until there is less acquires than releases Source Edit
proc newAsyncSemaphore(size: int): AsyncSemaphore {....raises: [Defect], tags: [].}
- Source Edit
proc release(s: AsyncSemaphore) {....raises: [Defect], tags: [].}
- Release a resource from the semaphore, by picking the first future from the queue and completing it and incrementing the internal resource count Source Edit
proc tryAcquire(s: AsyncSemaphore): bool {....raises: [Defect], tags: [].}
- Attempts to acquire a resource, if successful returns true, otherwise false Source Edit