nim-chronos/api/chronos/config.html

375 lines
22 KiB
HTML
Raw Permalink Normal View History

<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<!-- This file is generated by Nim. -->
<html xmlns="http://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">
<!-- Favicon -->
<link rel="shortcut icon" href=""/>
<link rel="icon" type="image/png" sizes="32x32" href="">
<!-- 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'/>
<!-- CSS -->
<title>chronos/config</title>
<link rel="stylesheet" type="text/css" href="../nimdoc.out.css">
<script type="text/javascript" src="../dochack.js"></script>
<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>
</head>
<body>
<div class="document" id="documentId">
<div class="container">
<h1 class="title">chronos/config</h1>
<div class="row">
<div class="three columns">
<div class="theme-switch-wrapper">
<label class="theme-switch" for="checkbox">
<input type="checkbox" id="checkbox" />
<div class="slider round"></div>
</label>
&nbsp;&nbsp;&nbsp; <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>
<ul class="simple simple-toc" id="toc-list">
<li>
<a class="reference reference-toplevel" href="#10" id="60">Consts</a>
<ul class="simple simple-toc-section">
<li><a class="reference" href="#chronosDumpAsync"
title="chronosDumpAsync: bool = false">chronosDumpAsync</a></li>
<li><a class="reference" href="#chronosEventEngine"
title="chronosEventEngine: string = &quot;&quot;">chronosEventEngine</a></li>
<li><a class="reference" href="#chronosEventsCount"
title="chronosEventsCount = 64">chronosEventsCount</a></li>
<li><a class="reference" href="#chronosFutureId"
title="chronosFutureId: bool = false">chronosFutureId</a></li>
<li><a class="reference" href="#chronosFutureTracking"
title="chronosFutureTracking: bool = false">chronosFutureTracking</a></li>
<li><a class="reference" href="#chronosHandleException"
title="chronosHandleException: bool = false">chronosHandleException</a></li>
<li><a class="reference" href="#chronosHasRaises"
title="chronosHasRaises = 0">chronosHasRaises</a></li>
<li><a class="reference" href="#chronosInitialSize"
title="chronosInitialSize = 64">chronosInitialSize</a></li>
<li><a class="reference" href="#chronosProcShell"
title="chronosProcShell: string = &quot;/bin/sh&quot;">chronosProcShell</a></li>
<li><a class="reference" href="#chronosStackTrace"
title="chronosStackTrace: bool = false">chronosStackTrace</a></li>
<li><a class="reference" href="#chronosStreamDefaultBufferSize"
title="chronosStreamDefaultBufferSize = 16384">chronosStreamDefaultBufferSize</a></li>
<li><a class="reference" href="#chronosStrictFutureAccess"
title="chronosStrictFutureAccess: bool = false">chronosStrictFutureAccess</a></li>
<li><a class="reference" href="#chronosTLSSessionCacheBufferSize"
title="chronosTLSSessionCacheBufferSize = 4096">chronosTLSSessionCacheBufferSize</a></li>
<li><a class="reference" href="#chronosTransportDefaultBufferSize"
title="chronosTransportDefaultBufferSize = 16384">chronosTransportDefaultBufferSize</a></li>
</ul>
</li>
<li>
<a class="reference reference-toplevel" href="#18" id="68">Templates</a>
<ul class="simple simple-toc-section">
<ul class="simple nested-toc-section">chronosMoveSink
<li><a class="reference" href="#chronosMoveSink.t%2Cauto"
title="chronosMoveSink(val: auto): untyped">chronosMoveSink(val: auto): untyped</a></li>
</ul>
</ul>
</li>
</ul>
</div>
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L1"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L1" class="link-seesrc" target="_blank" >Edit</a>
<div class="nine columns" id="content">
<div id="tocRoot"></div>
<p class="module-desc"><p>Compile-time configuration options for chronos that control the availability of various strictness and debuggability options. In general, debug helpers are enabled when <tt class="docutils literal"><span class="pre"><span class="Identifier">debug</span></span></tt> is defined while strictness options are introduced in transition periods leading up to a breaking release that starts enforcing them and removes the option.</p>
<p><tt class="docutils literal"><span class="pre"><span class="Identifier">chronosPreviewV4</span></span></tt> is a preview flag to enable v4 semantics - in particular, it enables strict exception checking and disables parts of the deprecated API and other changes being prepared for the upcoming release</p>
<p><tt class="docutils literal"><span class="pre"><span class="Identifier">chronosDebug</span></span></tt> can be defined to enable several debugging helpers that come with a runtime cost - it is recommeneded to not enable these in production code.</p>
<p>In this file we also declare feature flags starting with <tt class="docutils literal"><span class="pre"><span class="Identifier">chronosHas</span><span class="Operator">...</span></span></tt> - these constants are declared when a feature exists in a particular release - each flag is declared as an integer starting at 0 during experimental development, 1 when feature complete and higher numbers when significant functionality has been added. If a feature ends up being removed (or changed in a backwards-incompatible way), the feature flag will be removed or renamed also - you can use <tt class="docutils literal"><span class="pre"><span class="Keyword">when</span> <span class="Identifier">declared</span><span class="Punctuation">(</span><span class="Identifier">chronosHasXxx</span><span class="Punctuation">)</span><span class="Punctuation">:</span> <span class="Keyword">when</span> <span class="Identifier">chronosHasXxx</span> <span class="Operator">&gt;=</span> <span class="Identifier">N</span><span class="Punctuation">:</span></span></tt> to require a particular version.</p>
</p>
<div class="section" id="10">
<h1><a class="toc-backref" href="#10">Consts</a></h1>
<dl class="item">
<div id="chronosDumpAsync">
<dt><pre><a href="config.html#chronosDumpAsync"><span class="Identifier">chronosDumpAsync</span></a><span class="Other">:</span> <span class="Identifier">bool</span> <span class="Other">=</span> <span class="DecNumber">false</span></pre></dt>
<dd>
Print code generated by {.async.} transformation
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L51"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L51" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosEventEngine">
<dt><pre><a href="config.html#chronosEventEngine"><span class="Identifier">chronosEventEngine</span></a><span class="Other">:</span> <span class="Identifier">string</span> <span class="Other">=</span> <span class="StringLit">&quot;&quot;</span></pre></dt>
<dd>
OS polling engine type which is going to be used by chronos.
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L74"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L74" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosEventsCount">
<dt><pre><a href="config.html#chronosEventsCount"><span class="Identifier">chronosEventsCount</span></a> <span class="Other">=</span> <span class="DecNumber">64</span></pre></dt>
<dd>
Number of OS poll events retrieved by syscall (epoll, kqueue, poll).
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L68"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L68" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosFutureId">
<dt><pre><a href="config.html#chronosFutureId"><span class="Identifier">chronosFutureId</span></a><span class="Other">:</span> <span class="Identifier">bool</span> <span class="Other">=</span> <span class="DecNumber">false</span></pre></dt>
<dd>
Generate a unique <tt class="docutils literal"><span class="pre"><span class="Identifier">id</span></span></tt> for every future - when disabled, the address of the future will be used instead
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L43"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L43" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosFutureTracking">
<dt><pre><a href="config.html#chronosFutureTracking"><span class="Identifier">chronosFutureTracking</span></a><span class="Other">:</span> <span class="Identifier">bool</span> <span class="Other">=</span> <span class="DecNumber">false</span></pre></dt>
<dd>
Keep track of all pending futures and allow iterating over them - useful for detecting hung tasks
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L47"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L47" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosHandleException">
<dt><pre><a href="config.html#chronosHandleException"><span class="Identifier">chronosHandleException</span></a><span class="Other">:</span> <span class="Identifier">bool</span> <span class="Other">=</span> <span class="DecNumber">false</span></pre></dt>
<dd>
<p>Remap <tt class="docutils literal"><span class="pre"><span class="Identifier">Exception</span></span></tt> to <tt class="docutils literal"><span class="pre"><span class="Identifier">AsyncExceptionError</span></span></tt> for all <tt class="docutils literal"><span class="pre"><span class="Identifier">async</span></span></tt> functions.</p>
<p>This modes provides backwards compatibility when using functions with inaccurate <tt class="docutils literal"><span class="pre"><span class="Punctuation">{</span><span class="Operator">.</span><span class="Identifier">raises</span><span class="Operator">.</span><span class="Punctuation">}</span></span></tt> effects such as unannotated forward declarations, methods and <tt class="docutils literal"><span class="pre"><span class="Keyword">proc</span></span></tt> types - it is recommened to annotate such code explicitly as the <tt class="docutils literal"><span class="pre"><span class="Identifier">Exception</span></span></tt> handling mode may introduce surprising behavior in exception handlers, should <tt class="docutils literal"><span class="pre"><span class="Identifier">Exception</span></span></tt> actually be raised.</p>
<p>The setting provides the default for the per-function-based <tt class="docutils literal"><span class="pre"><span class="Identifier">handleException</span></span></tt> parameter which has precedence over this global setting.</p>
<p><tt class="docutils literal"><span class="pre"><span class="Identifier">Exception</span></span></tt> handling may be removed in future chronos versions.</p>
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L24"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L24" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosHasRaises">
<dt><pre><a href="config.html#chronosHasRaises"><span class="Identifier">chronosHasRaises</span></a> <span class="Other">=</span> <span class="DecNumber">0</span></pre></dt>
<dd>
raises effect support via <tt class="docutils literal"><span class="pre"><span class="Identifier">async</span><span class="Punctuation">:</span> <span class="Punctuation">(</span><span class="Identifier">raises</span><span class="Punctuation">:</span> <span class="Punctuation">[</span><span class="Punctuation">]</span><span class="Punctuation">)</span></span></tt>
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L91"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L91" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosInitialSize">
<dt><pre><a href="config.html#chronosInitialSize"><span class="Identifier">chronosInitialSize</span></a> <span class="Other">=</span> <span class="DecNumber">64</span></pre></dt>
<dd>
Initial size of Selector[T]'s array of file descriptors.
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L71"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L71" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosProcShell">
<dt><pre><a href="config.html#chronosProcShell"><span class="Identifier">chronosProcShell</span></a><span class="Other">:</span> <span class="Identifier">string</span> <span class="Other">=</span> <span class="StringLit">&quot;/bin/sh&quot;</span></pre></dt>
<dd>
<p>Default shell binary path.</p>
<p>The shell is used as command for command line when process started using <tt class="docutils literal"><span class="pre"><span class="Identifier">AsyncProcessOption</span><span class="Operator">.</span><span class="Identifier">EvalCommand</span></span></tt> and API calls such as <tt class="docutils literal"><span class="pre">execCommand(command)</span></tt> and <tt class="docutils literal"><span class="pre">execCommandEx(command)</span></tt>.</p>
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L54"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L54" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosStackTrace">
<dt><pre><a href="config.html#chronosStackTrace"><span class="Identifier">chronosStackTrace</span></a><span class="Other">:</span> <span class="Identifier">bool</span> <span class="Other">=</span> <span class="DecNumber">false</span></pre></dt>
<dd>
Include stack traces in futures for creation and completion points
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L40"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L40" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosStreamDefaultBufferSize">
<dt><pre><a href="config.html#chronosStreamDefaultBufferSize"><span class="Identifier">chronosStreamDefaultBufferSize</span></a> <span class="Other">=</span> <span class="DecNumber">16384</span></pre></dt>
<dd>
Default size of chronos async stream internal buffer.
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L97"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L97" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosStrictFutureAccess">
<dt><pre><a href="config.html#chronosStrictFutureAccess"><span class="Identifier">chronosStrictFutureAccess</span></a><span class="Other">:</span> <span class="Identifier">bool</span> <span class="Other">=</span> <span class="DecNumber">false</span></pre></dt>
<dd>
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L38"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L38" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosTLSSessionCacheBufferSize">
<dt><pre><a href="config.html#chronosTLSSessionCacheBufferSize"><span class="Identifier">chronosTLSSessionCacheBufferSize</span></a> <span class="Other">=</span> <span class="DecNumber">4096</span></pre></dt>
<dd>
Default size of chronos TLS Session cache's internal buffer.
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L100"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L100" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
<div id="chronosTransportDefaultBufferSize">
<dt><pre><a href="config.html#chronosTransportDefaultBufferSize"><span class="Identifier">chronosTransportDefaultBufferSize</span></a> <span class="Other">=</span> <span class="DecNumber">16384</span></pre></dt>
<dd>
Default size of chronos transport internal buffer.
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L94"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L94" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
</dl></div>
<div class="section" id="18">
<h1><a class="toc-backref" href="#18">Templates</a></h1>
<dl class="item">
<div id="chronosMoveSink.t,auto">
<dt><pre><span class="Keyword">template</span> <a href="#chronosMoveSink.t%2Cauto"><span class="Identifier">chronosMoveSink</span></a><span class="Other">(</span><span class="Identifier">val</span><span class="Other">:</span> <span class="Identifier">auto</span><span class="Other">)</span><span class="Other">:</span> <span class="Identifier">untyped</span></pre></dt>
<dd>
&nbsp;&nbsp;<a
href="https://github.com/status-im/nim-chronos/tree/master/chronos/config.nim#L158"
class="link-seesrc" target="_blank">Source</a>
&nbsp;&nbsp;<a href="https://github.com/status-im/nim-chronos/edit/devel/chronos/config.nim#L158" class="link-seesrc" target="_blank" >Edit</a>
</dd>
</div>
</dl></div>
</div>
</div>
<div class="row">
<div class="twelve-columns footer">
<span class="nim-sprite"></span>
<br/>
<small style="color: var(--hint);">Made with Nim. Generated: 2024-11-28 08:22:46 UTC</small>
</div>
</div>
</div>
</div>
</body>
</html>