2023-10-04 16:04:54 +00:00
<?xml version="1.0" encoding="utf-8" ?>
2023-12-13 18:15:51 +00:00
< !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2023-10-04 16:04:54 +00:00
<!-- This file is generated by Nim. -->
2023-12-13 18:15:51 +00:00
< html xmlns = "http://www.w3.org/1999/xhtml" xml:lang = "en" lang = "en" >
2023-10-04 16:04:54 +00:00
< head >
< meta http-equiv = "Content-Type" content = "text/html; charset=utf-8" / >
2023-12-13 18:15:51 +00:00
2023-10-04 16:04:54 +00:00
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
<!-- Favicon -->
< link rel = "shortcut icon" href = "" / >
< link rel = "icon" type = "image/png" sizes = "32x32" href = "" >
2023-12-13 18:15:51 +00:00
<!-- 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' / >
2023-10-04 16:04:54 +00:00
<!-- CSS -->
2023-12-13 18:15:51 +00:00
< title > libp2p/utils/semaphore< / title >
2023-10-04 16:04:54 +00:00
< link rel = "stylesheet" type = "text/css" href = "../../nimdoc.out.css" >
< script type = "text/javascript" src = "../../dochack.js" > < / script >
2023-12-13 18:15:51 +00:00
< script type = "text/javascript" >
function main() {
var pragmaDots = document.getElementsByClassName("pragmadots");
for (var i = 0; i < pragmaDots.length ; i + + ) {
pragmaDots[i].onclick = function(event) {
// Hide tease
event.target.parentNode.style.display = "none";
// Show actual
event.target.parentNode.nextElementSibling.style.display = "inline";
}
}
function switchTheme(e) {
if (e.target.checked) {
document.documentElement.setAttribute('data-theme', 'dark');
localStorage.setItem('theme', 'dark');
} else {
document.documentElement.setAttribute('data-theme', 'light');
localStorage.setItem('theme', 'light');
}
}
const toggleSwitch = document.querySelector('.theme-switch input[type="checkbox"]');
if (toggleSwitch !== null) {
toggleSwitch.addEventListener('change', switchTheme, false);
}
var currentTheme = localStorage.getItem('theme');
if (!currentTheme & & window.matchMedia('(prefers-color-scheme: dark)').matches) {
currentTheme = 'dark';
}
if (currentTheme) {
document.documentElement.setAttribute('data-theme', currentTheme);
if (currentTheme === 'dark' & & toggleSwitch !== null) {
toggleSwitch.checked = true;
}
}
}
window.addEventListener('DOMContentLoaded', main);
< / script >
2023-10-04 16:04:54 +00:00
< / head >
< body >
2023-12-13 18:15:51 +00:00
< div class = "document" id = "documentId" >
< div class = "container" >
< h1 class = "title" > libp2p/utils/semaphore< / h1 >
< div class = "row" >
2023-10-04 16:04:54 +00:00
< div class = "three columns" >
2023-12-13 18:15:51 +00:00
< div class = "theme-switch-wrapper" >
< label class = "theme-switch" for = "checkbox" >
< input type = "checkbox" id = "checkbox" / >
< div class = "slider round" > < / div >
< / label >
< em > Dark Mode< / em >
< / div >
< div id = "global-links" >
< ul class = "simple" >
< li >
< a href = "../../theindex.html" > Index< / a >
< / li >
< / ul >
< / div >
< div id = "searchInputDiv" >
Search: < input type = "text" 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" >
2023-10-04 16:04:54 +00:00
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 >
2023-12-13 18:15:51 +00:00
< a class = "reference reference-toplevel" href = "#7" id = "57" > Types< / a >
< ul class = "simple simple-toc-section" >
< li > < a class = "reference" href = "#AsyncSemaphore"
title="AsyncSemaphore = ref object of RootObj
size*: int
count: int
queue: seq[Future[void]]">AsyncSemaphore< / a > < / li >
< / ul >
2023-10-04 16:04:54 +00:00
< / li >
< li >
2023-12-13 18:15:51 +00:00
< a class = "reference reference-toplevel" href = "#12" id = "62" > Procs< / a >
< ul class = "simple simple-toc-section" >
2023-10-04 16:04:54 +00:00
< ul class = "simple nested-toc-section" > acquire
2023-12-13 18:15:51 +00:00
< li > < a class = "reference" href = "#acquire%2CAsyncSemaphore"
title="acquire(s: AsyncSemaphore): Future[void]">acquire(s: AsyncSemaphore): Future[void]< / a > < / li >
2023-10-04 16:04:54 +00:00
2023-12-13 18:15:51 +00:00
< / 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 >
2023-10-04 16:04:54 +00:00
2023-12-13 18:15:51 +00:00
< / ul >
< ul class = "simple nested-toc-section" > forceAcquire
< li > < a class = "reference" href = "#forceAcquire%2CAsyncSemaphore"
title="forceAcquire(s: AsyncSemaphore)">forceAcquire(s: AsyncSemaphore)< / a > < / li >
2023-10-04 16:04:54 +00:00
2023-12-13 18:15:51 +00:00
< / 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 >
2023-10-04 16:04:54 +00:00
2023-12-13 18:15:51 +00:00
< / ul >
< ul class = "simple nested-toc-section" > release
< li > < a class = "reference" href = "#release%2CAsyncSemaphore"
title="release(s: AsyncSemaphore)">release(s: AsyncSemaphore)< / a > < / li >
2023-10-04 16:04:54 +00:00
2023-12-13 18:15:51 +00:00
< / 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 >
2023-10-04 16:04:54 +00:00
2023-12-13 18:15:51 +00:00
< / ul >
2023-10-04 16:04:54 +00:00
2023-12-13 18:15:51 +00:00
< / ul >
2023-10-04 16:04:54 +00:00
< / li >
< / ul >
< / div >
2023-12-13 18:15:51 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/bumplibp2p/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 >
2023-10-04 16:04:54 +00:00
< div class = "nine columns" id = "content" >
2023-12-13 18:15:51 +00:00
< 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" >
2023-10-04 16:04:54 +00:00
< 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 >
2023-12-13 18:15:51 +00:00
< span class = "Identifier" > count< / span > < span class = "Other" > :< / span > < span class = "Identifier" > int< / span >
< span class = "Identifier" > queue< / span > < span class = "Other" > :< / span > < span class = "Identifier" > seq< / span > < span class = "Other" > [< / span > < span class = "Identifier" > Future< / span > < span class = "Other" > [< / span > < span class = "Identifier" > void< / span > < span class = "Other" > ]< / span > < span class = "Other" > ]< / span >
< / pre > < / dt >
2023-10-04 16:04:54 +00:00
< dd >
2023-12-13 18:15:51 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/bumplibp2p/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 >
2023-10-04 16:04:54 +00:00
< / dd >
< / div >
2023-12-13 18:15:51 +00:00
< / dl > < / div >
2023-10-04 16:04:54 +00:00
< div class = "section" id = "12" >
2023-12-13 18:15:51 +00:00
< h1 > < a class = "toc-backref" href = "#12" > Procs< / a > < / h1 >
< dl class = "item" >
< 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 > .}< / pre > < / dt >
2023-10-04 16:04:54 +00:00
< 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.
2023-12-13 18:15:51 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/bumplibp2p/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 >
2023-10-04 16:04:54 +00:00
< / dd >
< / div >
2023-12-13 18:15:51 +00:00
< 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 > .}< / pre > < / dt >
2023-10-04 16:04:54 +00:00
< dd >
2023-12-13 18:15:51 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/bumplibp2p/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 >
2023-10-04 16:04:54 +00:00
< / dd >
< / div >
2023-12-13 18:15:51 +00:00
< 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 > .}< / pre > < / dt >
2023-10-04 16:04:54 +00:00
< 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
2023-12-13 18:15:51 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/bumplibp2p/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 >
2023-10-04 16:04:54 +00:00
< / dd >
< / div >
2023-12-13 18:15:51 +00:00
< 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 > .}< / pre > < / dt >
2023-10-04 16:04:54 +00:00
< dd >
2023-12-13 18:15:51 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/bumplibp2p/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 >
2023-10-04 16:04:54 +00:00
< / dd >
< / div >
2023-12-13 18:15:51 +00:00
< 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 > .}< / pre > < / dt >
2023-10-04 16:04:54 +00:00
< dd >
Release a resource from the semaphore, by picking the first future from the queue and completing it and incrementing the internal resource count
2023-12-13 18:15:51 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/bumplibp2p/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 >
2023-10-04 16:04:54 +00:00
< / dd >
< / div >
2023-12-13 18:15:51 +00:00
< 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 > .}< / pre > < / dt >
2023-10-04 16:04:54 +00:00
< dd >
Attempts to acquire a resource, if successful returns true, otherwise false
2023-12-13 18:15:51 +00:00
< a
href="https://github.com/status-im/nim-libp2p/tree/bumplibp2p/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 >
2023-10-04 16:04:54 +00:00
< / dd >
< / div >
2023-12-13 18:15:51 +00:00
< / dl > < / div >
2023-10-04 16:04:54 +00:00
< / div >
< / div >
2023-12-13 18:15:51 +00:00
< div class = "row" >
2023-10-04 16:04:54 +00:00
< div class = "twelve-columns footer" >
< span class = "nim-sprite" > < / span >
2023-12-13 18:15:51 +00:00
< br / >
< small style = "color: var(--hint);" > Made with Nim. Generated: 2023-12-13 18:15:44 UTC< / small >
2023-10-04 16:04:54 +00:00
< / div >
< / div >
< / div >
2023-12-13 18:15:51 +00:00
< / div >
2023-10-04 16:04:54 +00:00
< / body >
< / html >