lib.html 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343
  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <!-- This file is generated by Nim. -->
  4. <html xmlns="https://www.w3.org/1999/xhtml" xml:lang="en" lang="en" data-theme="auto">
  5. <head>
  6. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  7. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  8. <title>Nim Standard Library</title>
  9. <!-- Google fonts -->
  10. <link href='https://fonts.googleapis.com/css?family=Lato:400,600,900' rel='stylesheet' type='text/css'/>
  11. <link href='https://fonts.googleapis.com/css?family=Source+Code+Pro:400,500,600' rel='stylesheet' type='text/css'/>
  12. <!-- Favicon -->
  13. <link rel="shortcut icon" href=""/>
  14. <link rel="icon" type="image/png" sizes="32x32" href="">
  15. <!-- CSS -->
  16. <link rel="stylesheet" type="text/css" href="nimdoc.out.css?v=2.3.1">
  17. <!-- JS -->
  18. <script type="text/javascript" src="dochack.js?v=2.3.1"></script>
  19. </head>
  20. <body>
  21. <div class="document" id="documentId">
  22. <div class="container">
  23. <h1 class="title">Nim Standard Library</h1>
  24. <div class="row">
  25. <div class="three columns">
  26. <div class="theme-select-wrapper">
  27. <label for="theme-select">Theme:&nbsp;</label>
  28. <select id="theme-select" onchange="setTheme(this.value)">
  29. <option value="auto">🌗 Match OS</option>
  30. <option value="dark">🌑 Dark</option>
  31. <option value="light">🌕 Light</option>
  32. </select>
  33. </div>
  34. <div id="global-links">
  35. <ul class="simple-boot">
  36. <li><a href="manual.html">Manual</a></li>
  37. <li><a href="lib.html">Standard library</a></li>
  38. <li> <a id="indexLink" href="theindex.html">Index</a></li>
  39. <li><a href="compiler/theindex.html">Compiler docs</a></li>
  40. <li><a href="https://nim-lang.github.io/fusion/theindex.html">Fusion docs</a></li>
  41. <li><a href="https://nim-lang.github.io/Nim/">devel</a>, <a href="https://nim-lang.org/documentation.html">stable</a></li>
  42. </ul>
  43. </div>
  44. <div id="searchInputDiv">
  45. Search: <input type="search" id="searchInput"
  46. oninput="search()" />
  47. </div>
  48. <div class="search-groupby">
  49. Group by:
  50. <select onchange="groupBy(this.value)">
  51. <option value="section">Section</option>
  52. <option value="type">Type</option>
  53. </select>
  54. </div>
  55. <ul class="simple simple-toc" id="toc-list">
  56. <li><a class="reference" id="nimble_toc" href="#nimble">Nimble</a></li>
  57. <li><a class="reference" id="pure-libraries_toc" href="#pure-libraries">Pure libraries</a></li>
  58. <ul class="simple"><li><a class="reference" id="pure-libraries-automatic-imports_toc" href="#pure-libraries-automatic-imports">Automatic imports</a></li>
  59. <li><a class="reference" id="pure-libraries-core_toc" href="#pure-libraries-core">Core</a></li>
  60. <li><a class="reference" id="pure-libraries-algorithms_toc" href="#pure-libraries-algorithms">Algorithms</a></li>
  61. <li><a class="reference" id="pure-libraries-collections_toc" href="#pure-libraries-collections">Collections</a></li>
  62. <li><a class="reference" id="pure-libraries-string-handling_toc" href="#pure-libraries-string-handling">String handling</a></li>
  63. <li><a class="reference" id="pure-libraries-time-handling_toc" href="#pure-libraries-time-handling">Time handling</a></li>
  64. <li><a class="reference" id="pure-libraries-generic-operating-system-services_toc" href="#pure-libraries-generic-operating-system-services">Generic Operating System Services</a></li>
  65. <li><a class="reference" id="pure-libraries-math-libraries_toc" href="#pure-libraries-math-libraries">Math libraries</a></li>
  66. <li><a class="reference" id="pure-libraries-internet-protocols-and-support_toc" href="#pure-libraries-internet-protocols-and-support">Internet Protocols and Support</a></li>
  67. <li><a class="reference" id="pure-libraries-threading_toc" href="#pure-libraries-threading">Threading</a></li>
  68. <li><a class="reference" id="pure-libraries-parsers_toc" href="#pure-libraries-parsers">Parsers</a></li>
  69. <li><a class="reference" id="pure-libraries-docutils_toc" href="#pure-libraries-docutils">Docutils</a></li>
  70. <li><a class="reference" id="pure-libraries-xml-processing_toc" href="#pure-libraries-xml-processing">XML Processing</a></li>
  71. <li><a class="reference" id="pure-libraries-generators_toc" href="#pure-libraries-generators">Generators</a></li>
  72. <li><a class="reference" id="pure-libraries-hashing_toc" href="#pure-libraries-hashing">Hashing</a></li>
  73. <li><a class="reference" id="pure-libraries-serialization_toc" href="#pure-libraries-serialization">Serialization</a></li>
  74. <li><a class="reference" id="pure-libraries-miscellaneous_toc" href="#pure-libraries-miscellaneous">Miscellaneous</a></li>
  75. <li><a class="reference" id="pure-libraries-modules-for-the-javascript-backend_toc" href="#pure-libraries-modules-for-the-javascript-backend">Modules for the JavaScript backend</a></li>
  76. </ul><li><a class="reference" id="impure-libraries_toc" href="#impure-libraries">Impure libraries</a></li>
  77. <ul class="simple"><li><a class="reference" id="impure-libraries-regular-expressions_toc" href="#impure-libraries-regular-expressions">Regular expressions</a></li>
  78. <li><a class="reference" id="impure-libraries-database-support_toc" href="#impure-libraries-database-support">Database support</a></li>
  79. <li><a class="reference" id="impure-libraries-generic-operating-system-services_toc" href="#impure-libraries-generic-operating-system-services">Generic Operating System Services</a></li>
  80. </ul><li><a class="reference" id="wrappers_toc" href="#wrappers">Wrappers</a></li>
  81. <ul class="simple"><li><a class="reference" id="wrappers-windowsminusspecific_toc" href="#wrappers-windowsminusspecific">Windows-specific</a></li>
  82. <li><a class="reference" id="wrappers-unix-specific_toc" href="#wrappers-unix-specific">UNIX specific</a></li>
  83. <li><a class="reference" id="wrappers-regular-expressions_toc" href="#wrappers-regular-expressions">Regular expressions</a></li>
  84. <li><a class="reference" id="wrappers-database-support_toc" href="#wrappers-database-support">Database support</a></li>
  85. <li><a class="reference" id="wrappers-network-programming-and-internet-protocols_toc" href="#wrappers-network-programming-and-internet-protocols">Network Programming and Internet Protocols</a></li>
  86. </ul>
  87. </ul>
  88. </div>
  89. <div class="nine columns" id="content">
  90. <a href="https://github.com/nim-lang/Nim/tree/devel/doc/lib.md#L1" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  91. <a href="https://github.com/nim-lang/Nim/edit/devel/doc/lib.md#L1" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  92. <div id="tocRoot"></div>
  93. <p class="module-desc"><table class="docinfo" frame="void" rules="none"><col class="docinfo-name" /><col class="docinfo-content" /><tbody valign="top"><tr><th class="docinfo-name">Author:</th><td>Andreas Rumpf</td></tr>
  94. <tr><th class="docinfo-name">Version:</th><td>2.3.1</td></tr>
  95. </tbody></table><p>Nim's library is divided into <em>pure libraries</em>, <em>impure libraries</em>, and <em>wrappers</em>.</p>
  96. <p>Pure libraries do not depend on any external <tt class="docutils literal"><span class="pre">*.dll</span></tt> or <tt class="docutils literal"><span class="pre">lib*.so</span></tt> binary while impure libraries do. A wrapper is an impure library that is a very low-level interface to a C library.</p>
  97. <p>Read <a class="reference external" href="apis.html">this document</a> for a quick overview of the API design.</p>
  98. <h1><a class="toc-backref" id="nimble" href="#nimble">Nimble</a></h1><p>Nim's standard library only covers the basics, check out <a class="reference external" href="https://nimble.directory/">https://nimble.directory/</a> for a list of 3rd party packages.</p>
  99. <h1><a class="toc-backref" id="pure-libraries" href="#pure-libraries">Pure libraries</a></h1>
  100. <h2><a class="toc-backref" id="pure-libraries-automatic-imports" href="#pure-libraries-automatic-imports">Automatic imports</a></h2><ul class="simple"><li><a class="reference external" href="system.html">system</a> Basic procs and operators that every program needs. It also provides IO facilities for reading and writing text and binary files. It is imported implicitly by the compiler. Do not import it directly. It relies on compiler magic to work.</li>
  101. </ul>
  102. <h2><a class="toc-backref" id="pure-libraries-core" href="#pure-libraries-core">Core</a></h2><ul class="simple"><li><a class="reference external" href="atomics.html">atomics</a> Types and operations for atomic operations and lockless algorithms.</li>
  103. <li><a class="reference external" href="bitops.html">bitops</a> Provides a series of low-level methods for bit manipulation.</li>
  104. <li><a class="reference external" href="compilesettings.html">compilesettings</a> Querying the compiler about diverse configuration settings from code.</li>
  105. <li><a class="reference external" href="cpuinfo.html">cpuinfo</a> Procs to determine the number of CPUs / cores.</li>
  106. <li><a class="reference external" href="effecttraits.html">effecttraits</a> Access to the inferred .raises effects for Nim's macro system.</li>
  107. <li><a class="reference external" href="endians.html">endians</a> Helpers that deal with different byte orders.</li>
  108. <li><a class="reference external" href="locks.html">locks</a> Locks and condition variables for Nim.</li>
  109. <li><a class="reference external" href="macrocache.html">macrocache</a> Provides an API for macros to collect compile-time information across modules.</li>
  110. <li><a class="reference external" href="macros.html">macros</a> Contains the AST API and documentation of Nim for writing macros.</li>
  111. <li><a class="reference external" href="rlocks.html">rlocks</a> Reentrant locks for Nim.</li>
  112. <li><a class="reference external" href="typeinfo.html">typeinfo</a> Provides (unsafe) access to Nim's run-time type information.</li>
  113. <li><a class="reference external" href="typetraits.html">typetraits</a> Compile-time reflection procs for working with types.</li>
  114. <li><a class="reference external" href="volatile.html">volatile</a> Code for generating volatile loads and stores, which are useful in embedded and systems programming.</li>
  115. </ul>
  116. <h2><a class="toc-backref" id="pure-libraries-algorithms" href="#pure-libraries-algorithms">Algorithms</a></h2><ul class="simple"><li><a class="reference external" href="algorithm.html">algorithm</a> Some common generic algorithms like sort or binary search.</li>
  117. <li><a class="reference external" href="enumutils.html">enumutils</a> Additional functionality for the built-in <tt class="docutils literal"><span class="pre"><span class="Keyword">enum</span></span></tt> type.</li>
  118. <li><a class="reference external" href="sequtils.html">sequtils</a> Operations for the built-in <tt class="docutils literal"><span class="pre"><span class="Identifier">seq</span></span></tt> type which were inspired by functional programming languages.</li>
  119. <li><a class="reference external" href="setutils.html">setutils</a> Additional functionality for the built-in <tt class="docutils literal"><span class="pre"><span class="Identifier">set</span></span></tt> type.</li>
  120. </ul>
  121. <h2><a class="toc-backref" id="pure-libraries-collections" href="#pure-libraries-collections">Collections</a></h2><ul class="simple"><li><a class="reference external" href="critbits.html">critbits</a> A <em>crit bit tree</em> which is an efficient container for a sorted set of strings, or a sorted mapping of strings.</li>
  122. <li><a class="reference external" href="deques.html">deques</a> Implementation of a double-ended queue. The underlying implementation uses a <tt class="docutils literal"><span class="pre"><span class="Identifier">seq</span></span></tt>.</li>
  123. <li><a class="reference external" href="heapqueue.html">heapqueue</a> Implementation of a binary heap data structure that can be used as a priority queue.</li>
  124. <li><a class="reference external" href="intsets.html">intsets</a> Efficient implementation of a set of ints as a sparse bit set.</li>
  125. <li><a class="reference external" href="lists.html">lists</a> Nim linked list support. Contains singly and doubly linked lists and circular lists (&quot;rings&quot;).</li>
  126. <li><a class="reference external" href="options.html">options</a> The option type encapsulates an optional value.</li>
  127. <li><a class="reference external" href="packedsets.html">packedsets</a> Efficient implementation of a set of ordinals as a sparse bit set.</li>
  128. <li><a class="reference external" href="ropes.html">ropes</a> A <em>rope</em> data type. Ropes can represent very long strings efficiently; in particular, concatenation is done in O(1) instead of O(n).</li>
  129. <li><a class="reference external" href="sets.html">sets</a> Nim hash set support.</li>
  130. <li><a class="reference external" href="strtabs.html">strtabs</a> The <tt class="docutils literal"><span class="pre"><span class="Identifier">strtabs</span></span></tt> module implements an efficient hash table that is a mapping from strings to strings. Supports a case-sensitive, case-insensitive and style-insensitive modes.</li>
  131. <li><a class="reference external" href="tables.html">tables</a> Nim hash table support. Contains tables, ordered tables, and count tables.</li>
  132. </ul>
  133. <h2><a class="toc-backref" id="pure-libraries-string-handling" href="#pure-libraries-string-handling">String handling</a></h2><ul class="simple"><li><a class="reference external" href="cstrutils.html">cstrutils</a> Utilities for <tt class="docutils literal"><span class="pre"><span class="Identifier">cstring</span></span></tt> handling.</li>
  134. <li><a class="reference external" href="editdistance.html">editdistance</a> An algorithm to compute the edit distance between two Unicode strings.</li>
  135. <li><a class="reference external" href="encodings.html">encodings</a> Converts between different character encodings. On UNIX, this uses the <tt class="docutils literal"><span class="pre"><span class="Identifier">iconv</span></span></tt> library, on Windows the Windows API.</li>
  136. <li><a class="reference external" href="formatfloat.html">formatfloat</a> Formatting floats as strings.</li>
  137. <li><a class="reference external" href="objectdollar.html">objectdollar</a> A generic <tt class="docutils literal"><span class="pre"><span class="Operator">$</span></span></tt> operator to convert objects to strings.</li>
  138. <li><a class="reference external" href="punycode.html">punycode</a> Implements a representation of Unicode with the limited ASCII character subset.</li>
  139. <li><a class="reference external" href="strbasics.html">strbasics</a> Some high performance string operations.</li>
  140. <li><a class="reference external" href="strformat.html">strformat</a> Macro based standard string interpolation/formatting. Inspired by Python's f-strings.
  141. <strong>Note:</strong> if you need templating, consider using Nim <a class="reference external" href="filters.html">Source Code Filters (SCF)</a>.</li>
  142. <li><a class="reference external" href="strmisc.html">strmisc</a> Uncommon string handling operations that do not fit with the commonly used operations in <a class="reference external" href="strutils.html">strutils</a>.</li>
  143. <li><a class="reference external" href="strscans.html">strscans</a> A <tt class="docutils literal"><span class="pre"><span class="Identifier">scanf</span></span></tt> macro for convenient parsing of mini languages.</li>
  144. <li><a class="reference external" href="strutils.html">strutils</a> Common string handling operations like changing case of a string, splitting a string into substrings, searching for substrings, replacing substrings.</li>
  145. <li><a class="reference external" href="unicode.html">unicode</a> Support for handling the Unicode UTF-8 encoding.</li>
  146. <li><a class="reference external" href="unidecode.html">unidecode</a> It provides a single proc that does Unicode to ASCII transliterations. Based on Python's Unidecode module.</li>
  147. <li><a class="reference external" href="widestrs.html">widestrs</a> Nim support for C/C++'s wide strings.</li>
  148. <li><a class="reference external" href="wordwrap.html">wordwrap</a> An algorithm for word-wrapping Unicode strings.</li>
  149. </ul>
  150. <h2><a class="toc-backref" id="pure-libraries-time-handling" href="#pure-libraries-time-handling">Time handling</a></h2><ul class="simple"><li><a class="reference external" href="monotimes.html">monotimes</a> The <tt class="docutils literal"><span class="pre"><span class="Identifier">monotimes</span></span></tt> module implements monotonic timestamps.</li>
  151. <li><a class="reference external" href="times.html">times</a> The <tt class="docutils literal"><span class="pre"><span class="Identifier">times</span></span></tt> module contains support for working with time.</li>
  152. </ul>
  153. <h2><a class="toc-backref" id="pure-libraries-generic-operating-system-services" href="#pure-libraries-generic-operating-system-services">Generic Operating System Services</a></h2><ul class="simple"><li><a class="reference external" href="appdirs.html">appdirs</a> Helpers for determining special directories used by apps.</li>
  154. <li><a class="reference external" href="cmdline.html">cmdline</a> System facilities for reading command line parameters.</li>
  155. <li><a class="reference external" href="dirs.html">dirs</a> Directory handling.</li>
  156. <li><a class="reference external" href="distros.html">distros</a> Basics for OS distribution (&quot;distro&quot;) detection and the OS's native package manager. Its primary purpose is to produce output for Nimble packages, but it also contains the widely used <strong>Distribution</strong> enum that is useful for writing platform-specific code. See <a class="reference external" href="packaging.html">packaging</a> for hints on distributing Nim using OS packages.</li>
  157. <li><a class="reference external" href="dynlib.html">dynlib</a> Accessing symbols from shared libraries.</li>
  158. <li><a class="reference external" href="envvars.html">envvars</a> Environment variable handling.</li>
  159. <li><a class="reference external" href="exitprocs.html">exitprocs</a> Adding hooks to program exit.</li>
  160. <li><a class="reference external" href="files.html">files</a> File handling.</li>
  161. <li><a class="reference external" href="memfiles.html">memfiles</a> Support for memory-mapped files (Posix's <tt class="docutils literal"><span class="pre"><span class="Identifier">mmap</span></span></tt>) on the different operating systems.</li>
  162. <li><a class="reference external" href="os.html">os</a> Basic operating system facilities like retrieving environment variables, reading command line arguments, working with directories, running shell commands, etc.</li>
  163. <li><a class="reference external" href="oserrors.html">oserrors</a> OS error reporting.</li>
  164. <li><a class="reference external" href="osproc.html">osproc</a> Module for process communication beyond <tt class="docutils literal"><span class="pre"><span class="Identifier">os</span><span class="Operator">.</span><span class="Identifier">execShellCmd</span></span></tt>.</li>
  165. <li><a class="reference external" href="paths.html">paths</a> Path handling.</li>
  166. <li><a class="reference external" href="reservedmem.html">reservedmem</a> Utilities for reserving portions of the address space of a program without consuming physical memory.</li>
  167. <li><a class="reference external" href="streams.html">streams</a> A stream interface and two implementations thereof: the <tt class="docutils literal"><span class="pre"><span class="Identifier">FileStream</span></span></tt> and the <tt class="docutils literal"><span class="pre"><span class="Identifier">StringStream</span></span></tt> which implement the stream interface for Nim file objects (<tt class="docutils literal"><span class="pre"><span class="Identifier">File</span></span></tt>) and strings. Other modules may provide other implementations for this standard stream interface.</li>
  168. <li><a class="reference external" href="symlinks.html">symlinks</a> Symlink handling.</li>
  169. <li><a class="reference external" href="syncio.html">syncio</a> Various synchronized I/O operations.</li>
  170. <li><a class="reference external" href="terminal.html">terminal</a> A module to control the terminal output (also called <em>console</em>).</li>
  171. <li><a class="reference external" href="tempfiles.html">tempfiles</a> Some utilities for generating temporary path names and creating temporary files and directories.</li>
  172. </ul>
  173. <h2><a class="toc-backref" id="pure-libraries-math-libraries" href="#pure-libraries-math-libraries">Math libraries</a></h2><ul class="simple"><li><a class="reference external" href="complex.html">complex</a> Complex numbers and relevant mathematical operations.</li>
  174. <li><a class="reference external" href="fenv.html">fenv</a> Floating-point environment. Handling of floating-point rounding and exceptions (overflow, zero-divide, etc.).</li>
  175. <li><a class="reference external" href="lenientops.html">lenientops</a> Binary operators for mixed integer/float expressions for convenience.</li>
  176. <li><a class="reference external" href="math.html">math</a> Mathematical operations like cosine, square root.</li>
  177. <li><a class="reference external" href="random.html">random</a> Fast and tiny random number generator.</li>
  178. <li><a class="reference external" href="rationals.html">rationals</a> Rational numbers and relevant mathematical operations.</li>
  179. <li><a class="reference external" href="stats.html">stats</a> Statistical analysis.</li>
  180. <li><a class="reference external" href="sysrand.html">sysrand</a> Cryptographically secure pseudorandom number generator.</li>
  181. </ul>
  182. <h2><a class="toc-backref" id="pure-libraries-internet-protocols-and-support" href="#pure-libraries-internet-protocols-and-support">Internet Protocols and Support</a></h2><ul class="simple"><li><a class="reference external" href="async.html">async</a> Exports <tt class="docutils literal"><span class="pre"><span class="Identifier">asyncmacro</span></span></tt> and <tt class="docutils literal"><span class="pre"><span class="Identifier">asyncfutures</span></span></tt> for native backends, and <tt class="docutils literal"><span class="pre"><span class="Identifier">asyncjs</span></span></tt> on the JS backend.</li>
  183. <li><a class="reference external" href="asyncdispatch.html">asyncdispatch</a> An asynchronous dispatcher for IO operations.</li>
  184. <li><a class="reference external" href="asyncfile.html">asyncfile</a> An asynchronous file reading and writing using <tt class="docutils literal"><span class="pre"><span class="Identifier">asyncdispatch</span></span></tt>.</li>
  185. <li><a class="reference external" href="asyncftpclient.html">asyncftpclient</a> An asynchronous FTP client using the <tt class="docutils literal"><span class="pre"><span class="Identifier">asyncnet</span></span></tt> module.</li>
  186. <li><a class="reference external" href="asynchttpserver.html">asynchttpserver</a> An asynchronous HTTP server using the <tt class="docutils literal"><span class="pre"><span class="Identifier">asyncnet</span></span></tt> module.</li>
  187. <li><a class="reference external" href="asyncmacro.html">asyncmacro</a> <tt class="docutils literal"><span class="pre"><span class="Identifier">async</span></span></tt> and <tt class="docutils literal"><span class="pre"><span class="Identifier">multisync</span></span></tt> macros for <tt class="docutils literal"><span class="pre"><span class="Identifier">asyncdispatch</span></span></tt>.</li>
  188. <li><a class="reference external" href="asyncnet.html">asyncnet</a> Asynchronous sockets based on the <tt class="docutils literal"><span class="pre"><span class="Identifier">asyncdispatch</span></span></tt> module.</li>
  189. <li><a class="reference external" href="asyncstreams.html">asyncstreams</a> <tt class="docutils literal"><span class="pre"><span class="Identifier">FutureStream</span></span></tt> - a future that acts as a queue.</li>
  190. <li><a class="reference external" href="cgi.html">cgi</a> Helpers for CGI applications.</li>
  191. <li><a class="reference external" href="cookies.html">cookies</a> Helper procs for parsing and generating cookies.</li>
  192. <li><a class="reference external" href="httpclient.html">httpclient</a> A simple HTTP client with support for both synchronous and asynchronous retrieval of web pages.</li>
  193. <li><a class="reference external" href="mimetypes.html">mimetypes</a> A mimetypes database.</li>
  194. <li><a class="reference external" href="nativesockets.html">nativesockets</a> A low-level sockets API.</li>
  195. <li><a class="reference external" href="net.html">net</a> A high-level sockets API.</li>
  196. <li><a class="reference external" href="selectors.html">selectors</a> A selector API with backends specific to each OS. Supported OS primitives: <tt class="docutils literal"><span class="pre"><span class="Identifier">epoll</span></span></tt>, <tt class="docutils literal"><span class="pre"><span class="Identifier">kqueue</span></span></tt>, <tt class="docutils literal"><span class="pre"><span class="Identifier">poll</span></span></tt>, and <tt class="docutils literal"><span class="pre"><span class="Identifier">select</span></span></tt> on Windows.</li>
  197. <li><a class="reference external" href="smtp.html">smtp</a> A simple SMTP client with support for both synchronous and asynchronous operation.</li>
  198. <li><a class="reference external" href="socketstreams.html">socketstreams</a> An implementation of the streams interface for sockets.</li>
  199. <li><a class="reference external" href="uri.html">uri</a> Functions for working with URIs and URLs.</li>
  200. </ul>
  201. <h2><a class="toc-backref" id="pure-libraries-threading" href="#pure-libraries-threading">Threading</a></h2><ul class="simple"><li><a class="reference external" href="isolation.html">isolation</a> The <tt class="docutils literal"><span class="pre"><span class="Identifier">Isolated</span><span class="Punctuation">[</span><span class="Identifier">T</span><span class="Punctuation">]</span></span></tt> type for safe construction of isolated subgraphs that can be passed efficiently to different channels and threads.</li>
  202. <li><a class="reference external" href="tasks.html">tasks</a> Basic primitives for creating parallel programs.</li>
  203. <li><a class="reference external" href="threadpool.html">threadpool</a> Implements Nim's <a class="reference external" href="manual_experimental.html#parallel-amp-spawn">spawn</a>.</li>
  204. <li><a class="reference external" href="typedthreads.html">typedthreads</a> Basic Nim thread support.</li>
  205. </ul>
  206. <h2><a class="toc-backref" id="pure-libraries-parsers" href="#pure-libraries-parsers">Parsers</a></h2><ul class="simple"><li><a class="reference external" href="htmlparser.html">htmlparser</a> HTML document parser that creates a XML tree representation.</li>
  207. <li><a class="reference external" href="json.html">json</a> High-performance JSON parser.</li>
  208. <li><a class="reference external" href="lexbase.html">lexbase</a> A low-level module that implements an extremely efficient buffering scheme for lexers and parsers. This is used by the diverse parsing modules.</li>
  209. <li><a class="reference external" href="parsecfg.html">parsecfg</a> The <tt class="docutils literal"><span class="pre"><span class="Identifier">parsecfg</span></span></tt> module implements a high-performance configuration file parser. The configuration file's syntax is similar to the Windows <tt class="docutils literal"><span class="pre">.ini</span></tt> format, but much more powerful, as it is not a line based parser. String literals, raw string literals, and triple quote string literals are supported as in the Nim programming language.</li>
  210. <li><a class="reference external" href="parsecsv.html">parsecsv</a> The <tt class="docutils literal"><span class="pre"><span class="Identifier">parsecsv</span></span></tt> module implements a simple high-performance CSV parser.</li>
  211. <li><a class="reference external" href="parsejson.html">parsejson</a> A JSON parser. It is used and exported by the <a class="reference external" href="json.html">json</a> module, but can also be used in its own right.</li>
  212. <li><a class="reference external" href="parseopt.html">parseopt</a> The <tt class="docutils literal"><span class="pre"><span class="Identifier">parseopt</span></span></tt> module implements a command line option parser.</li>
  213. <li><a class="reference external" href="parsesql.html">parsesql</a> The <tt class="docutils literal"><span class="pre"><span class="Identifier">parsesql</span></span></tt> module implements a simple high-performance SQL parser.</li>
  214. <li><a class="reference external" href="parseutils.html">parseutils</a> Helpers for parsing tokens, numbers, identifiers, etc.</li>
  215. <li><a class="reference external" href="parsexml.html">parsexml</a> The <tt class="docutils literal"><span class="pre"><span class="Identifier">parsexml</span></span></tt> module implements a simple high performance XML/HTML parser. The only encoding that is supported is UTF-8. The parser has been designed to be somewhat error-correcting, so that even some &quot;wild HTML&quot; found on the web can be parsed with it.</li>
  216. <li><a class="reference external" href="pegs.html">pegs</a> Procedures and operators for handling PEGs.</li>
  217. </ul>
  218. <h2><a class="toc-backref" id="pure-libraries-docutils" href="#pure-libraries-docutils">Docutils</a></h2><ul class="simple"><li><a class="reference external" href="highlite.html">packages/docutils/highlite</a> Source highlighter for programming or markup languages. Currently, only a few languages are supported, other languages may be added. The interface supports one language nested in another.</li>
  219. <li><a class="reference external" href="rst.html">packages/docutils/rst</a> A reStructuredText parser. A large subset is implemented. Some features of the markdown wiki syntax are also supported.</li>
  220. <li><a class="reference external" href="rstast.html">packages/docutils/rstast</a> An AST for the reStructuredText parser.</li>
  221. <li><a class="reference external" href="rstgen.html">packages/docutils/rstgen</a> A generator of HTML/Latex from reStructuredText.</li>
  222. </ul>
  223. <h2><a class="toc-backref" id="pure-libraries-xml-processing" href="#pure-libraries-xml-processing">XML Processing</a></h2><ul class="simple"><li><a class="reference external" href="xmltree.html">xmltree</a> A simple XML tree. More efficient and simpler than the DOM. It also contains a macro for XML/HTML code generation.</li>
  224. <li><a class="reference external" href="xmlparser.html">xmlparser</a> XML document parser that creates a XML tree representation.</li>
  225. </ul>
  226. <h2><a class="toc-backref" id="pure-libraries-generators" href="#pure-libraries-generators">Generators</a></h2><ul class="simple"><li><a class="reference external" href="genasts.html">genasts</a> AST generation using captured variables for macros.</li>
  227. <li><a class="reference external" href="htmlgen.html">htmlgen</a> A simple XML and HTML code generator. Each commonly used HTML tag has a corresponding macro that generates a string with its HTML representation.</li>
  228. </ul>
  229. <h2><a class="toc-backref" id="pure-libraries-hashing" href="#pure-libraries-hashing">Hashing</a></h2><ul class="simple"><li><a class="reference external" href="base64.html">base64</a> A Base64 encoder and decoder.</li>
  230. <li><a class="reference external" href="hashes.html">hashes</a> Efficient computations of hash values for diverse Nim types.</li>
  231. <li><a class="reference external" href="md5.html">md5</a> The MD5 checksum algorithm.</li>
  232. <li><a class="reference external" href="oids.html">oids</a> An OID is a global ID that consists of a timestamp, a unique counter, and a random value. This combination should suffice to produce a globally distributed unique ID.</li>
  233. <li><a class="reference external" href="sha1.html">sha1</a> The SHA-1 checksum algorithm.</li>
  234. </ul>
  235. <h2><a class="toc-backref" id="pure-libraries-serialization" href="#pure-libraries-serialization">Serialization</a></h2><ul class="simple"><li><a class="reference external" href="jsonutils.html">jsonutils</a> Hookable (de)serialization for arbitrary types using JSON.</li>
  236. <li><a class="reference external" href="marshal.html">marshal</a> Contains procs for serialization and deserialization of arbitrary Nim data structures.</li>
  237. </ul>
  238. <h2><a class="toc-backref" id="pure-libraries-miscellaneous" href="#pure-libraries-miscellaneous">Miscellaneous</a></h2><ul class="simple"><li><a class="reference external" href="assertions.html">assertions</a> Assertion handling.</li>
  239. <li><a class="reference external" href="browsers.html">browsers</a> Procs for opening URLs with the user's default browser.</li>
  240. <li><a class="reference external" href="colors.html">colors</a> Color handling.</li>
  241. <li><a class="reference external" href="coro.html">coro</a> Experimental coroutines in Nim.</li>
  242. <li><a class="reference external" href="decls.html">decls</a> Syntax sugar for some declarations.</li>
  243. <li><a class="reference external" href="enumerate.html">enumerate</a> <tt class="docutils literal"><span class="pre"><span class="Identifier">enumerate</span></span></tt> syntactic sugar based on Nim's macro system.</li>
  244. <li><a class="reference external" href="importutils.html">importutils</a> Utilities related to import and symbol resolution.</li>
  245. <li><a class="reference external" href="logging.html">logging</a> A simple logger.</li>
  246. <li><a class="reference external" href="segfaults.html">segfaults</a> Turns access violations or segfaults into a <tt class="docutils literal"><span class="pre"><span class="Identifier">NilAccessDefect</span></span></tt> exception.</li>
  247. <li><a class="reference external" href="sugar.html">sugar</a> Nice syntactic sugar based on Nim's macro system.</li>
  248. <li><a class="reference external" href="unittest.html">unittest</a> Implements a Unit testing DSL.</li>
  249. <li><a class="reference external" href="varints.html">varints</a> Decode variable-length integers that are compatible with SQLite.</li>
  250. <li><a class="reference external" href="with.html">with</a> The <tt class="docutils literal"><span class="pre"><span class="Identifier">with</span></span></tt> macro for easy function chaining.</li>
  251. <li><a class="reference external" href="wrapnils.html">wrapnils</a> Allows evaluating expressions safely against nil dereferences.</li>
  252. </ul>
  253. <h2><a class="toc-backref" id="pure-libraries-modules-for-the-javascript-backend" href="#pure-libraries-modules-for-the-javascript-backend">Modules for the JavaScript backend</a></h2><ul class="simple"><li><a class="reference external" href="asyncjs.html">asyncjs</a> Types and macros for writing asynchronous procedures in JavaScript.</li>
  254. <li><a class="reference external" href="dom.html">dom</a> Declaration of the Document Object Model for the JS backend.</li>
  255. <li><a class="reference external" href="jsbigints.html">jsbigints</a> Arbitrary precision integers.</li>
  256. <li><a class="reference external" href="jsconsole.html">jsconsole</a> Wrapper for the <tt class="docutils literal"><span class="pre"><span class="Identifier">console</span></span></tt> object.</li>
  257. <li><a class="reference external" href="jscore.html">jscore</a> The wrapper of core JavaScript functions. For most purposes, you should be using the <tt class="docutils literal"><span class="pre"><span class="Identifier">math</span></span></tt>, <tt class="docutils literal"><span class="pre"><span class="Identifier">json</span></span></tt>, and <tt class="docutils literal"><span class="pre"><span class="Identifier">times</span></span></tt> stdlib modules instead of this module.</li>
  258. <li><a class="reference external" href="jsfetch.html">jsfetch</a> Wrapper for <tt class="docutils literal"><span class="pre"><span class="Identifier">fetch</span></span></tt>.</li>
  259. <li><a class="reference external" href="jsffi.html">jsffi</a> Types and macros for easier interaction with JavaScript.</li>
  260. <li><a class="reference external" href="jsre.html">jsre</a> Regular Expressions for the JavaScript target.</li>
  261. </ul>
  262. <h1><a class="toc-backref" id="impure-libraries" href="#impure-libraries">Impure libraries</a></h1>
  263. <h2><a class="toc-backref" id="impure-libraries-regular-expressions" href="#impure-libraries-regular-expressions">Regular expressions</a></h2><ul class="simple"><li><a class="reference external" href="re.html">re</a> Procedures and operators for handling regular expressions. The current implementation uses PCRE.</li>
  264. <li><p><a class="reference external" href="nre.html">nre</a></p>
  265. <p>Many help functions for handling regular expressions. The current implementation uses PCRE.</p>
  266. </li>
  267. </ul>
  268. <h2><a class="toc-backref" id="impure-libraries-database-support" href="#impure-libraries-database-support">Database support</a></h2><ul class="simple"><li><a class="reference external" href="db_mysql.html">db_mysql</a> A higher level MySQL database wrapper. The same interface is implemented for other databases too.</li>
  269. <li><a class="reference external" href="db_odbc.html">db_odbc</a> A higher level ODBC database wrapper. The same interface is implemented for other databases too.</li>
  270. <li><a class="reference external" href="db_postgres.html">db_postgres</a> A higher level PostgreSQL database wrapper. The same interface is implemented for other databases too.</li>
  271. <li><a class="reference external" href="db_sqlite.html">db_sqlite</a> A higher level SQLite database wrapper. The same interface is implemented for other databases too.</li>
  272. </ul>
  273. <h2><a class="toc-backref" id="impure-libraries-generic-operating-system-services" href="#impure-libraries-generic-operating-system-services">Generic Operating System Services</a></h2><ul class="simple"><li><a class="reference external" href="rdstdin.html">rdstdin</a> Code for reading user input from stdin.</li>
  274. </ul>
  275. <h1><a class="toc-backref" id="wrappers" href="#wrappers">Wrappers</a></h1><p>The generated HTML for some of these wrappers is so huge that it is not contained in the distribution. You can then find them on the website.</p>
  276. <h2><a class="toc-backref" id="wrappers-windowsminusspecific" href="#wrappers-windowsminusspecific">Windows-specific</a></h2><ul class="simple"><li><a class="reference external" href="winlean.html">winlean</a> Wrapper for a small subset of the Win32 API.</li>
  277. <li><a class="reference external" href="registry.html">registry</a> Windows registry support.</li>
  278. </ul>
  279. <h2><a class="toc-backref" id="wrappers-unix-specific" href="#wrappers-unix-specific">UNIX specific</a></h2><ul class="simple"><li><a class="reference external" href="posix.html">posix</a> Wrapper for the POSIX standard.</li>
  280. <li><a class="reference external" href="posix_utils.html">posix_utils</a> Contains helpers for the POSIX standard or specialized for Linux and BSDs.</li>
  281. </ul>
  282. <h2><a class="toc-backref" id="wrappers-regular-expressions" href="#wrappers-regular-expressions">Regular expressions</a></h2><ul class="simple"><li><a class="reference external" href="pcre.html">pcre</a> Wrapper for the PCRE library.</li>
  283. </ul>
  284. <h2><a class="toc-backref" id="wrappers-database-support" href="#wrappers-database-support">Database support</a></h2><ul class="simple"><li><a class="reference external" href="mysql.html">mysql</a> Wrapper for the mySQL API.</li>
  285. <li><a class="reference external" href="odbcsql.html">odbcsql</a> interface to the ODBC driver.</li>
  286. <li><a class="reference external" href="postgres.html">postgres</a> Wrapper for the PostgreSQL API.</li>
  287. <li><a class="reference external" href="sqlite3.html">sqlite3</a> Wrapper for the SQLite 3 API.</li>
  288. </ul>
  289. <h2><a class="toc-backref" id="wrappers-network-programming-and-internet-protocols" href="#wrappers-network-programming-and-internet-protocols">Network Programming and Internet Protocols</a></h2><ul class="simple"><li><a class="reference external" href="openssl.html">openssl</a> Wrapper for OpenSSL.</li>
  290. </ul>
  291. </p>
  292. </div>
  293. </div>
  294. <div class="twelve-columns footer">
  295. <span class="nim-sprite"></span>
  296. <br>
  297. <small style="color: var(--hint);">Made with Nim. Generated: 2025-01-09 11:59:39 UTC</small>
  298. </div>
  299. </div>
  300. </div>
  301. <script defer data-domain="nim-lang.org" src="https://plausible.io/js/plausible.js"></script>
  302. </body>
  303. </html>