2023-10-19 13:34:14 +00:00
<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<!-- This file is generated by Nim. -->
< html xmlns = "https://www.w3.org/1999/xhtml" xml:lang = "en" lang = "en" >
< head >
< meta http-equiv = "Content-Type" content = "text/html; charset=utf-8" / >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
< title > libp2p/utils/semaphore< / title >
<!-- Favicon -->
< link rel = "shortcut icon" href = "" / >
< link rel = "icon" type = "image/png" sizes = "32x32" href = "" >
<!-- CSS -->
< link rel = "stylesheet" type = "text/css" href = "../../nimdoc.out.css" >
<!-- JS -->
< script type = "text/javascript" src = "../../dochack.js" > < / script >
< / head >
< body >
< div class = "document" id = "documentId" >
< div class = "container" >
< h1 class = "title" > libp2p/utils/semaphore< / h1 >
< div class = "row" >
< div class = "three columns" >
< div class = "theme-select-wrapper" >
< label for = "theme-select" > Theme: < / label >
< select id = "theme-select" onchange = "setTheme(this.value)" >
< option value = "auto" > 🌗 Match OS< / option >
< option value = "dark" > 🌑 Dark< / option >
< option value = "light" > 🌕 Light< / option >
< / select >
< / div >
< div id = "global-links" >
< ul class = "simple" >
< li > < a id = "indexLink" href = "../../theindex.html" > Index< / a > < / li >
< / ul >
< / div >
< div id = "searchInputDiv" >
Search: < input type = "search" id = "searchInput" onkeyup = "search()" / >
< / div >
< div >
Group by:
< select onchange = "groupBy(this.value)" >
< option value = "section" > Section< / option >
< option value = "type" > Type< / option >
< / select >
< / div >
< script type = "text/javascript" >
function main2() {
// Create the slider
var firstSlider = document.getElementsByClassName("theme-switch-wrapper")[0];
var newSlider = document.createRange().createContextualFragment(`
< div class = "theme-switch-wrapper" >
< label class = "theme-switch" for = "internalcheckbox" >
< input type = "checkbox" id = "internalcheckbox" >
< div class = "slider round" > < / div >
< / label >
< em > Internal< / em >
< / div >
`);
var sliderInst = firstSlider.after(newSlider);
// Restore slider state from storage
var currentMode = localStorage.getItem('privateMode');
if (currentMode == "private") {
document.getElementById("internalcheckbox").checked = true;
} else {
hidePrivateProcs();
}
document.getElementById("internalcheckbox").onclick = togglePrivateProcs;
}
function hidePrivateProcs() {
var toHide = document.getElementsByClassName("tohide");
for (var i = 0; i < toHide.length ; i + + ) {
var pragmas = toHide[i].querySelectorAll("span.Identifier");
var public = false;
for (var z = 0; z < pragmas.length ; z + + ) {
if (pragmas[z].innerText == "public") {
public = true;
break;
}
}
if (public == false) {
toHide[i].style.display = "none";
toHide[i].classList.add("hidden");
links = document.querySelectorAll("a[href='#" + encodeURIComponent(toHide[i].id) + "']");
for (var y = 0; y < links.length ; y + + ) {
links[y].parentNode.style.display = "none";
links[y].parentNode.classList.add("hidden");
}
}
}
// TOC
var nestedSections = document.getElementsByClassName("nested-toc-section");
for (var i = 0; i < nestedSections.length ; i + + ) {
if (nestedSections[i].querySelectorAll("li:not(.hidden)").length == 0) {
nestedSections[i].style.display = "none";
nestedSections[i].classList.add("hidden");
}
}
var sections = document.getElementsByClassName("simple-toc-section");
for (var i = 0; i < sections.length ; i + + ) {
if (sections[i].querySelectorAll(".nested-toc-section:not(.hidden)").length == 0) {
sections[i].parentNode.style.display = "none";
sections[i].parentNode.classList.add("hidden");
}
}
// Sections
var sections = document.getElementsByClassName("section");
for (var i = 0; i < sections.length ; i + + ) {
if (sections[i].querySelectorAll(".item > div").length == 0) continue;
if (sections[i].querySelectorAll(".item > div:not(.hidden)").length == 0) {
sections[i].style.display = "none";
sections[i].classList.add("hidden");
}
}
}
function showPrivateProcs() {
var toHide = Array.from(document.getElementsByClassName("hidden"));
for (var i = 0; i < toHide.length ; i + + ) {
toHide[i].style.display = "";
toHide[i].classList.remove("hidden");
}
}
function togglePrivateProcs() {
if (document.getElementById("internalcheckbox").checked) {
localStorage.setItem('privateMode', 'private');
showPrivateProcs();
} else {
localStorage.setItem('privateMode', 'public');
hidePrivateProcs();
}
}
window.addEventListener("DOMContentLoaded", main2);
< / script >
< ul class = "simple simple-toc" id = "toc-list" >
< li >
< details open >
< summary > < a class = "reference reference-toplevel" href = "#7" id = "57" > Types< / a > < / summary >
< ul class = "simple simple-toc-section" >
< li > < a class = "reference" href = "#AsyncSemaphore" title = "AsyncSemaphore = ref object of RootObj
size*: int">AsyncSemaphore< / a > < / li >
< / ul >
< / details >
< / li >
< li >
< details open >
< summary > < a class = "reference reference-toplevel" href = "#12" id = "62" > Procs< / a > < / summary >
< ul class = "simple simple-toc-section" >
< ul class = "simple nested-toc-section" > acquire
< li > < a class = "reference" href = "#acquire%2CAsyncSemaphore" title = "acquire(s: AsyncSemaphore): Future[void]" > acquire(s: AsyncSemaphore): Future[void]< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > count
< li > < a class = "reference" href = "#count%2CAsyncSemaphore" title = "count(s: AsyncSemaphore): int" > count(s: AsyncSemaphore): int< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > forceAcquire
< li > < a class = "reference" href = "#forceAcquire%2CAsyncSemaphore" title = "forceAcquire(s: AsyncSemaphore)" > forceAcquire(s: AsyncSemaphore)< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > newAsyncSemaphore
< li > < a class = "reference" href = "#newAsyncSemaphore%2Cint" title = "newAsyncSemaphore(size: int): AsyncSemaphore" > newAsyncSemaphore(size: int): AsyncSemaphore< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > release
< li > < a class = "reference" href = "#release%2CAsyncSemaphore" title = "release(s: AsyncSemaphore)" > release(s: AsyncSemaphore)< / a > < / li >
< / ul >
< ul class = "simple nested-toc-section" > tryAcquire
< li > < a class = "reference" href = "#tryAcquire%2CAsyncSemaphore" title = "tryAcquire(s: AsyncSemaphore): bool" > tryAcquire(s: AsyncSemaphore): bool< / a > < / li >
< / ul >
< / ul >
< / details >
< / li >
< / ul >
< / div >
< div class = "nine columns" id = "content" >
< a href = "https://github.com/status-im/nim-libp2p/tree/nim-devel-workflow/libp2p/utils/semaphore.nim#L1" class = "link-seesrc" target = "_blank" > Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/utils/semaphore.nim#L1" class = "link-seesrc" target = "_blank" > Edit< / a >
< div id = "tocRoot" > < / div >
< p class = "module-desc" > < / p >
< div class = "section" id = "7" >
< h1 > < a class = "toc-backref" href = "#7" > Types< / a > < / h1 >
< dl class = "item" >
< div id = "AsyncSemaphore" class = "tohide" >
< dt > < pre > < a href = "semaphore.html#AsyncSemaphore" > < span class = "Identifier" > AsyncSemaphore< / span > < / a > < span class = "Other" > =< / span > < span class = "Keyword" > ref< / span > < span class = "Keyword" > object< / span > < span class = "Keyword" > of< / span > < span class = "Identifier" > RootObj< / span >
< span class = "Identifier" > size< / span > < span class = "Operator" > *< / span > < span class = "Other" > :< / span > < span class = "Identifier" > int< / span >
< / pre > < / dt >
< dd >
< a href = "https://github.com/status-im/nim-libp2p/tree/nim-devel-workflow/libp2p/utils/semaphore.nim#L21" class = "link-seesrc" target = "_blank" > Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/utils/semaphore.nim#L21" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< / dl >
< / div >
< div class = "section" id = "12" >
< h1 > < a class = "toc-backref" href = "#12" > Procs< / a > < / h1 >
< dl class = "item" >
< div id = "acquire-procs-all" >
< div id = "acquire,AsyncSemaphore" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#acquire%2CAsyncSemaphore" > < span class = "Identifier" > acquire< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > s< / span > < span class = "Other" > :< / span > < a href = "semaphore.html#AsyncSemaphore" > < span class = "Identifier" > AsyncSemaphore< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > Future< / span > < span class = "Other" > [< / span > < span class = "Identifier" > void< / span > < span class = "Other" > ]< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Identifier" > RootEffect< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span >
< span class = "Identifier" > forbids< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
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.
< a href = "https://github.com/status-im/nim-libp2p/tree/nim-devel-workflow/libp2p/utils/semaphore.nim#L41" class = "link-seesrc" target = "_blank" > Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/utils/semaphore.nim#L41" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< / div >
< div id = "count-procs-all" >
< div id = "count,AsyncSemaphore" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#count%2CAsyncSemaphore" > < span class = "Identifier" > count< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > s< / span > < span class = "Other" > :< / span > < a href = "semaphore.html#AsyncSemaphore" > < span class = "Identifier" > AsyncSemaphore< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > int< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > forbids< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
< a href = "https://github.com/status-im/nim-libp2p/tree/nim-devel-workflow/libp2p/utils/semaphore.nim#L29" class = "link-seesrc" target = "_blank" > Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/utils/semaphore.nim#L29" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< / div >
< div id = "forceAcquire-procs-all" >
< div id = "forceAcquire,AsyncSemaphore" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#forceAcquire%2CAsyncSemaphore" > < span class = "Identifier" > forceAcquire< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > s< / span > < span class = "Other" > :< / span > < a href = "semaphore.html#AsyncSemaphore" > < span class = "Identifier" > AsyncSemaphore< / span > < / a > < span class = "Other" > )< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > forbids< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
ForceAcquire will always succeed, creating a temporary slot if required. This temporary slot will stay usable until there is less < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > acquire< / span > < / span > < / tt > s than < tt class = "docutils literal" > < span class = "pre" > < span class = "Identifier" > release< / span > < / span > < / tt > s
< a href = "https://github.com/status-im/nim-libp2p/tree/nim-devel-workflow/libp2p/utils/semaphore.nim#L65" class = "link-seesrc" target = "_blank" > Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/utils/semaphore.nim#L65" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< / div >
< div id = "newAsyncSemaphore-procs-all" >
< div id = "newAsyncSemaphore,int" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#newAsyncSemaphore%2Cint" > < span class = "Identifier" > newAsyncSemaphore< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > size< / span > < span class = "Other" > :< / span > < span class = "Identifier" > int< / span > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < a href = "semaphore.html#AsyncSemaphore" > < span class = "Identifier" > AsyncSemaphore< / span > < / a > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span >
< span class = "Identifier" > forbids< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
< a href = "https://github.com/status-im/nim-libp2p/tree/nim-devel-workflow/libp2p/utils/semaphore.nim#L26" class = "link-seesrc" target = "_blank" > Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/utils/semaphore.nim#L26" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< / div >
< div id = "release-procs-all" >
< div id = "release,AsyncSemaphore" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#release%2CAsyncSemaphore" > < span class = "Identifier" > release< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > s< / span > < span class = "Other" > :< / span > < a href = "semaphore.html#AsyncSemaphore" > < span class = "Identifier" > AsyncSemaphore< / span > < / a > < span class = "Other" > )< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Identifier" > RootEffect< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > forbids< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
Release a resource from the semaphore, by picking the first future from the queue and completing it and incrementing the internal resource count
< a href = "https://github.com/status-im/nim-libp2p/tree/nim-devel-workflow/libp2p/utils/semaphore.nim#L72" class = "link-seesrc" target = "_blank" > Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/utils/semaphore.nim#L72" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< / div >
< div id = "tryAcquire-procs-all" >
< div id = "tryAcquire,AsyncSemaphore" class = "tohide" >
< dt > < pre > < span class = "Keyword" > proc< / span > < a href = "#tryAcquire%2CAsyncSemaphore" > < span class = "Identifier" > tryAcquire< / span > < / a > < span class = "Other" > (< / span > < span class = "Identifier" > s< / span > < span class = "Other" > :< / span > < a href = "semaphore.html#AsyncSemaphore" > < span class = "Identifier" > AsyncSemaphore< / span > < / a > < span class = "Other" > )< / span > < span class = "Other" > :< / span > < span class = "Identifier" > bool< / span > {.< span > < span class = "Other pragmadots" > ...< / span > < / span > < span class = "pragmawrap" > < span class = "Identifier" > raises< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > tags< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < span class = "Other" > ,< / span > < span class = "Identifier" > forbids< / span > < span class = "Other" > :< / span > < span class = "Other" > [< / span > < span class = "Other" > ]< / span > < / span > .}< / pre > < / dt >
< dd >
Attempts to acquire a resource, if successful returns true, otherwise false
< a href = "https://github.com/status-im/nim-libp2p/tree/nim-devel-workflow/libp2p/utils/semaphore.nim#L31" class = "link-seesrc" target = "_blank" > Source< / a >
< a href = "https://github.com/status-im/nim-libp2p/edit/devel/libp2p/utils/semaphore.nim#L31" class = "link-seesrc" target = "_blank" > Edit< / a >
< / dd >
< / div >
< / div >
< / dl >
< / div >
< / div >
< / div >
< div class = "twelve-columns footer" >
< span class = "nim-sprite" > < / span >
< br >
2023-10-20 10:46:11 +00:00
< small style = "color: var(--hint);" > Made with Nim. Generated: 2023-10-20 10:46:06 UTC< / small >
2023-10-19 13:34:14 +00:00
< / div >
< / div >
< / div >
<!-- Google fonts -->
< link href = 'https://fonts.googleapis.com/css?family=Lato:400,600,900' rel = 'stylesheet' type = 'text/css' / >
< link href = 'https://fonts.googleapis.com/css?family=Source+Code+Pro:400,500,600' rel = 'stylesheet' type = 'text/css' / >
< / body >
< / html >