lists.html 193 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520
  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>std/lists</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">std/lists</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. <ul class="simple simple-toc" id="toc-list">
  49. <li><a class="reference" id="basic-usage_toc" href="#basic-usage">Basic Usage</a></li>
  50. <ul class="simple"><li><a class="reference" id="basic-usage-lists_toc" href="#basic-usage-lists">Lists</a></li>
  51. <li><a class="reference" id="basic-usage-rings_toc" href="#basic-usage-rings">Rings</a></li>
  52. </ul><li><a class="reference" id="see-also_toc" href="#see-also">See also</a></li>
  53. <li>
  54. <a class="reference reference-toplevel" href="#6" id="56">Imports</a>
  55. </li>
  56. <li>
  57. <details open>
  58. <summary><a class="reference reference-toplevel" href="#7" id="57">Types</a></summary>
  59. <ul class="simple simple-toc-section">
  60. <li><a class="reference" href="#DoublyLinkedList" title="DoublyLinkedList[T] = object
  61. head*: DoublyLinkedNode[T]
  62. tail* {.cursor.}: DoublyLinkedNode[T]">DoublyLinkedList</a></li>
  63. <li><a class="reference" href="#DoublyLinkedNode" title="DoublyLinkedNode[T] = ref DoublyLinkedNodeObj[T]">DoublyLinkedNode</a></li>
  64. <li><a class="reference" href="#DoublyLinkedNodeObj" title="DoublyLinkedNodeObj[T] = object
  65. next*: DoublyLinkedNode[T]
  66. prev* {.cursor.}: DoublyLinkedNode[T]
  67. value*: T">DoublyLinkedNodeObj</a></li>
  68. <li><a class="reference" href="#DoublyLinkedRing" title="DoublyLinkedRing[T] = object
  69. head*: DoublyLinkedNode[T]">DoublyLinkedRing</a></li>
  70. <li><a class="reference" href="#SinglyLinkedList" title="SinglyLinkedList[T] = object
  71. head*: SinglyLinkedNode[T]
  72. tail* {.cursor.}: SinglyLinkedNode[T]">SinglyLinkedList</a></li>
  73. <li><a class="reference" href="#SinglyLinkedNode" title="SinglyLinkedNode[T] = ref SinglyLinkedNodeObj[T]">SinglyLinkedNode</a></li>
  74. <li><a class="reference" href="#SinglyLinkedNodeObj" title="SinglyLinkedNodeObj[T] = object
  75. next*: SinglyLinkedNode[T]
  76. value*: T">SinglyLinkedNodeObj</a></li>
  77. <li><a class="reference" href="#SinglyLinkedRing" title="SinglyLinkedRing[T] = object
  78. head*: SinglyLinkedNode[T]
  79. tail* {.cursor.}: SinglyLinkedNode[T]">SinglyLinkedRing</a></li>
  80. <li><a class="reference" href="#SomeLinkedCollection" title="SomeLinkedCollection[T] = SomeLinkedList[T] | SomeLinkedRing[T]">SomeLinkedCollection</a></li>
  81. <li><a class="reference" href="#SomeLinkedList" title="SomeLinkedList[T] = SinglyLinkedList[T] | DoublyLinkedList[T]">SomeLinkedList</a></li>
  82. <li><a class="reference" href="#SomeLinkedNode" title="SomeLinkedNode[T] = SinglyLinkedNode[T] | DoublyLinkedNode[T]">SomeLinkedNode</a></li>
  83. <li><a class="reference" href="#SomeLinkedRing" title="SomeLinkedRing[T] = SinglyLinkedRing[T] | DoublyLinkedRing[T]">SomeLinkedRing</a></li>
  84. </ul>
  85. </details>
  86. </li>
  87. <li>
  88. <details open>
  89. <summary><a class="reference reference-toplevel" href="#12" id="62">Procs</a></summary>
  90. <ul class="simple simple-toc-section">
  91. <ul class="simple nested-toc-section">$
  92. <li><a class="reference" href="#%24%2CSomeLinkedCollection%5BT%5D" title="`$`[T](L: SomeLinkedCollection[T]): string">`$`[T](L: SomeLinkedCollection[T]): string</a></li>
  93. </ul>
  94. <ul class="simple nested-toc-section">add
  95. <li><a class="reference" href="#add%2CT%2CT" title="add[T: SomeLinkedList](a: var T; b: T)">add[T: SomeLinkedList](a: var T; b: T)</a></li>
  96. <li><a class="reference" href="#add%2CDoublyLinkedList%5BT%5D%2CDoublyLinkedNode%5BT%5D" title="add[T](L: var DoublyLinkedList[T]; n: DoublyLinkedNode[T])">add[T](L: var DoublyLinkedList[T]; n: DoublyLinkedNode[T])</a></li>
  97. <li><a class="reference" href="#add%2CDoublyLinkedList%5BT%5D%2CT" title="add[T](L: var DoublyLinkedList[T]; value: T)">add[T](L: var DoublyLinkedList[T]; value: T)</a></li>
  98. <li><a class="reference" href="#add%2CDoublyLinkedRing%5BT%5D%2CDoublyLinkedNode%5BT%5D" title="add[T](L: var DoublyLinkedRing[T]; n: DoublyLinkedNode[T])">add[T](L: var DoublyLinkedRing[T]; n: DoublyLinkedNode[T])</a></li>
  99. <li><a class="reference" href="#add%2CDoublyLinkedRing%5BT%5D%2CT" title="add[T](L: var DoublyLinkedRing[T]; value: T)">add[T](L: var DoublyLinkedRing[T]; value: T)</a></li>
  100. <li><a class="reference" href="#add%2CSinglyLinkedList%5BT%5D%2CSinglyLinkedNode%5BT%5D" title="add[T](L: var SinglyLinkedList[T]; n: SinglyLinkedNode[T])">add[T](L: var SinglyLinkedList[T]; n: SinglyLinkedNode[T])</a></li>
  101. <li><a class="reference" href="#add%2CSinglyLinkedList%5BT%5D%2CT" title="add[T](L: var SinglyLinkedList[T]; value: T)">add[T](L: var SinglyLinkedList[T]; value: T)</a></li>
  102. <li><a class="reference" href="#add%2CSinglyLinkedRing%5BT%5D%2CSinglyLinkedNode%5BT%5D" title="add[T](L: var SinglyLinkedRing[T]; n: SinglyLinkedNode[T])">add[T](L: var SinglyLinkedRing[T]; n: SinglyLinkedNode[T])</a></li>
  103. <li><a class="reference" href="#add%2CSinglyLinkedRing%5BT%5D%2CT" title="add[T](L: var SinglyLinkedRing[T]; value: T)">add[T](L: var SinglyLinkedRing[T]; value: T)</a></li>
  104. </ul>
  105. <ul class="simple nested-toc-section">addMoved
  106. <li><a class="reference" href="#addMoved%2CDoublyLinkedList%5BT%5D%2CDoublyLinkedList%5BT%5D" title="addMoved[T](a, b: var DoublyLinkedList[T])">addMoved[T](a, b: var DoublyLinkedList[T])</a></li>
  107. <li><a class="reference" href="#addMoved%2CSinglyLinkedList%5BT%5D%2CSinglyLinkedList%5BT%5D" title="addMoved[T](a, b: var SinglyLinkedList[T])">addMoved[T](a, b: var SinglyLinkedList[T])</a></li>
  108. </ul>
  109. <ul class="simple nested-toc-section">append
  110. <li><a class="reference" href="#append%2C%2C_2" title="append[T](a: var (DoublyLinkedList[T] | DoublyLinkedRing[T]);
  111. b: DoublyLinkedList[T] | DoublyLinkedNode[T] | T)">append[T](a: var (DoublyLinkedList[T] | DoublyLinkedRing[T]);
  112. b: DoublyLinkedList[T] | DoublyLinkedNode[T] | T)</a></li>
  113. <li><a class="reference" href="#append%2C%2C" title="append[T](a: var (SinglyLinkedList[T] | SinglyLinkedRing[T]);
  114. b: SinglyLinkedList[T] | SinglyLinkedNode[T] | T)">append[T](a: var (SinglyLinkedList[T] | SinglyLinkedRing[T]);
  115. b: SinglyLinkedList[T] | SinglyLinkedNode[T] | T)</a></li>
  116. </ul>
  117. <ul class="simple nested-toc-section">appendMoved
  118. <li><a class="reference" href="#appendMoved%2CT%2CT" title="appendMoved[T: SomeLinkedList](a, b: var T)">appendMoved[T: SomeLinkedList](a, b: var T)</a></li>
  119. </ul>
  120. <ul class="simple nested-toc-section">contains
  121. <li><a class="reference" href="#contains%2CSomeLinkedCollection%5BT%5D%2CT" title="contains[T](L: SomeLinkedCollection[T]; value: T): bool">contains[T](L: SomeLinkedCollection[T]; value: T): bool</a></li>
  122. </ul>
  123. <ul class="simple nested-toc-section">copy
  124. <li><a class="reference" href="#copy%2CDoublyLinkedList%5BT%5D" title="copy[T](a: DoublyLinkedList[T]): DoublyLinkedList[T]">copy[T](a: DoublyLinkedList[T]): DoublyLinkedList[T]</a></li>
  125. <li><a class="reference" href="#copy%2CSinglyLinkedList%5BT%5D" title="copy[T](a: SinglyLinkedList[T]): SinglyLinkedList[T]">copy[T](a: SinglyLinkedList[T]): SinglyLinkedList[T]</a></li>
  126. </ul>
  127. <ul class="simple nested-toc-section">find
  128. <li><a class="reference" href="#find%2CSomeLinkedCollection%5BT%5D%2CT" title="find[T](L: SomeLinkedCollection[T]; value: T): SomeLinkedNode[T]">find[T](L: SomeLinkedCollection[T]; value: T): SomeLinkedNode[T]</a></li>
  129. </ul>
  130. <ul class="simple nested-toc-section">initDoublyLinkedList
  131. <li><a class="reference" href="#initDoublyLinkedList" title="initDoublyLinkedList[T](): DoublyLinkedList[T]">initDoublyLinkedList[T](): DoublyLinkedList[T]</a></li>
  132. </ul>
  133. <ul class="simple nested-toc-section">initDoublyLinkedRing
  134. <li><a class="reference" href="#initDoublyLinkedRing" title="initDoublyLinkedRing[T](): DoublyLinkedRing[T]">initDoublyLinkedRing[T](): DoublyLinkedRing[T]</a></li>
  135. </ul>
  136. <ul class="simple nested-toc-section">initSinglyLinkedList
  137. <li><a class="reference" href="#initSinglyLinkedList" title="initSinglyLinkedList[T](): SinglyLinkedList[T]">initSinglyLinkedList[T](): SinglyLinkedList[T]</a></li>
  138. </ul>
  139. <ul class="simple nested-toc-section">initSinglyLinkedRing
  140. <li><a class="reference" href="#initSinglyLinkedRing" title="initSinglyLinkedRing[T](): SinglyLinkedRing[T]">initSinglyLinkedRing[T](): SinglyLinkedRing[T]</a></li>
  141. </ul>
  142. <ul class="simple nested-toc-section">newDoublyLinkedNode
  143. <li><a class="reference" href="#newDoublyLinkedNode%2CT" title="newDoublyLinkedNode[T](value: T): DoublyLinkedNode[T]">newDoublyLinkedNode[T](value: T): DoublyLinkedNode[T]</a></li>
  144. </ul>
  145. <ul class="simple nested-toc-section">newSinglyLinkedNode
  146. <li><a class="reference" href="#newSinglyLinkedNode%2CT" title="newSinglyLinkedNode[T](value: T): SinglyLinkedNode[T]">newSinglyLinkedNode[T](value: T): SinglyLinkedNode[T]</a></li>
  147. </ul>
  148. <ul class="simple nested-toc-section">prepend
  149. <li><a class="reference" href="#prepend%2CT%2CT" title="prepend[T: SomeLinkedList](a: var T; b: T)">prepend[T: SomeLinkedList](a: var T; b: T)</a></li>
  150. <li><a class="reference" href="#prepend%2CDoublyLinkedList%5BT%5D%2CDoublyLinkedNode%5BT%5D" title="prepend[T](L: var DoublyLinkedList[T]; n: DoublyLinkedNode[T])">prepend[T](L: var DoublyLinkedList[T]; n: DoublyLinkedNode[T])</a></li>
  151. <li><a class="reference" href="#prepend%2CDoublyLinkedList%5BT%5D%2CT" title="prepend[T](L: var DoublyLinkedList[T]; value: T)">prepend[T](L: var DoublyLinkedList[T]; value: T)</a></li>
  152. <li><a class="reference" href="#prepend%2CDoublyLinkedRing%5BT%5D%2CDoublyLinkedNode%5BT%5D" title="prepend[T](L: var DoublyLinkedRing[T]; n: DoublyLinkedNode[T])">prepend[T](L: var DoublyLinkedRing[T]; n: DoublyLinkedNode[T])</a></li>
  153. <li><a class="reference" href="#prepend%2CDoublyLinkedRing%5BT%5D%2CT" title="prepend[T](L: var DoublyLinkedRing[T]; value: T)">prepend[T](L: var DoublyLinkedRing[T]; value: T)</a></li>
  154. <li><a class="reference" href="#prepend%2CSinglyLinkedList%5BT%5D%2CSinglyLinkedNode%5BT%5D" title="prepend[T](L: var SinglyLinkedList[T]; n: SinglyLinkedNode[T])">prepend[T](L: var SinglyLinkedList[T]; n: SinglyLinkedNode[T])</a></li>
  155. <li><a class="reference" href="#prepend%2CSinglyLinkedList%5BT%5D%2CT" title="prepend[T](L: var SinglyLinkedList[T]; value: T)">prepend[T](L: var SinglyLinkedList[T]; value: T)</a></li>
  156. <li><a class="reference" href="#prepend%2CSinglyLinkedRing%5BT%5D%2CSinglyLinkedNode%5BT%5D" title="prepend[T](L: var SinglyLinkedRing[T]; n: SinglyLinkedNode[T])">prepend[T](L: var SinglyLinkedRing[T]; n: SinglyLinkedNode[T])</a></li>
  157. <li><a class="reference" href="#prepend%2CSinglyLinkedRing%5BT%5D%2CT" title="prepend[T](L: var SinglyLinkedRing[T]; value: T)">prepend[T](L: var SinglyLinkedRing[T]; value: T)</a></li>
  158. </ul>
  159. <ul class="simple nested-toc-section">prependMoved
  160. <li><a class="reference" href="#prependMoved%2CT%2CT" title="prependMoved[T: SomeLinkedList](a, b: var T)">prependMoved[T: SomeLinkedList](a, b: var T)</a></li>
  161. </ul>
  162. <ul class="simple nested-toc-section">remove
  163. <li><a class="reference" href="#remove%2CDoublyLinkedList%5BT%5D%2CDoublyLinkedNode%5BT%5D" title="remove[T](L: var DoublyLinkedList[T]; n: DoublyLinkedNode[T])">remove[T](L: var DoublyLinkedList[T]; n: DoublyLinkedNode[T])</a></li>
  164. <li><a class="reference" href="#remove%2CDoublyLinkedRing%5BT%5D%2CDoublyLinkedNode%5BT%5D" title="remove[T](L: var DoublyLinkedRing[T]; n: DoublyLinkedNode[T])">remove[T](L: var DoublyLinkedRing[T]; n: DoublyLinkedNode[T])</a></li>
  165. <li><a class="reference" href="#remove%2CSinglyLinkedList%5BT%5D%2CSinglyLinkedNode%5BT%5D" title="remove[T](L: var SinglyLinkedList[T]; n: SinglyLinkedNode[T]): bool">remove[T](L: var SinglyLinkedList[T]; n: SinglyLinkedNode[T]): bool</a></li>
  166. </ul>
  167. <ul class="simple nested-toc-section">toDoublyLinkedList
  168. <li><a class="reference" href="#toDoublyLinkedList%2CopenArray%5BT%5D" title="toDoublyLinkedList[T](elems: openArray[T]): DoublyLinkedList[T]">toDoublyLinkedList[T](elems: openArray[T]): DoublyLinkedList[T]</a></li>
  169. </ul>
  170. <ul class="simple nested-toc-section">toDoublyLinkedRing
  171. <li><a class="reference" href="#toDoublyLinkedRing%2CopenArray%5BT%5D" title="toDoublyLinkedRing[T](elems: openArray[T]): DoublyLinkedRing[T]">toDoublyLinkedRing[T](elems: openArray[T]): DoublyLinkedRing[T]</a></li>
  172. </ul>
  173. <ul class="simple nested-toc-section">toSinglyLinkedList
  174. <li><a class="reference" href="#toSinglyLinkedList%2CopenArray%5BT%5D" title="toSinglyLinkedList[T](elems: openArray[T]): SinglyLinkedList[T]">toSinglyLinkedList[T](elems: openArray[T]): SinglyLinkedList[T]</a></li>
  175. </ul>
  176. <ul class="simple nested-toc-section">toSinglyLinkedRing
  177. <li><a class="reference" href="#toSinglyLinkedRing%2CopenArray%5BT%5D" title="toSinglyLinkedRing[T](elems: openArray[T]): SinglyLinkedRing[T]">toSinglyLinkedRing[T](elems: openArray[T]): SinglyLinkedRing[T]</a></li>
  178. </ul>
  179. </ul>
  180. </details>
  181. </li>
  182. <li>
  183. <details open>
  184. <summary><a class="reference reference-toplevel" href="#15" id="65">Iterators</a></summary>
  185. <ul class="simple simple-toc-section">
  186. <ul class="simple nested-toc-section">items
  187. <li><a class="reference" href="#items.i%2CSomeLinkedList%5BT%5D" title="items[T](L: SomeLinkedList[T]): T">items[T](L: SomeLinkedList[T]): T</a></li>
  188. <li><a class="reference" href="#items.i%2CSomeLinkedRing%5BT%5D" title="items[T](L: SomeLinkedRing[T]): T">items[T](L: SomeLinkedRing[T]): T</a></li>
  189. </ul>
  190. <ul class="simple nested-toc-section">mitems
  191. <li><a class="reference" href="#mitems.i%2CSomeLinkedList%5BT%5D" title="mitems[T](L: var SomeLinkedList[T]): var T">mitems[T](L: var SomeLinkedList[T]): var T</a></li>
  192. <li><a class="reference" href="#mitems.i%2CSomeLinkedRing%5BT%5D" title="mitems[T](L: var SomeLinkedRing[T]): var T">mitems[T](L: var SomeLinkedRing[T]): var T</a></li>
  193. </ul>
  194. <ul class="simple nested-toc-section">nodes
  195. <li><a class="reference" href="#nodes.i%2CSomeLinkedList%5BT%5D" title="nodes[T](L: SomeLinkedList[T]): SomeLinkedNode[T]">nodes[T](L: SomeLinkedList[T]): SomeLinkedNode[T]</a></li>
  196. <li><a class="reference" href="#nodes.i%2CSomeLinkedRing%5BT%5D" title="nodes[T](L: SomeLinkedRing[T]): SomeLinkedNode[T]">nodes[T](L: SomeLinkedRing[T]): SomeLinkedNode[T]</a></li>
  197. </ul>
  198. </ul>
  199. </details>
  200. </li>
  201. </ul>
  202. </div>
  203. <div class="nine columns" id="content">
  204. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L1" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  205. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L1" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  206. <div id="tocRoot"></div>
  207. <p class="module-desc">Implementation of:<ul class="simple"><li><a class="reference external" href="#SinglyLinkedList">singly linked lists</a></li>
  208. <li><a class="reference external" href="#DoublyLinkedList">doubly linked lists</a></li>
  209. <li><a class="reference external" href="#SinglyLinkedRing">singly linked rings</a> (circular lists)</li>
  210. <li><a class="reference external" href="#DoublyLinkedRing">doubly linked rings</a> (circular lists)</li>
  211. </ul>
  212. <h1><a class="toc-backref" id="basic-usage" href="#basic-usage">Basic Usage</a></h1><p>Because it makes no sense to do otherwise, the <tt class="docutils literal"><span class="pre"><span class="Identifier">next</span></span></tt> and <tt class="docutils literal"><span class="pre"><span class="Identifier">prev</span></span></tt> pointers are not hidden from you and can be manipulated directly for efficiency.</p>
  213. <h2><a class="toc-backref" id="basic-usage-lists" href="#basic-usage-lists">Lists</a></h2>
  214. <p><strong class="examples_text">Example:</strong></p>
  215. <pre class="listing"><span class="Keyword">import</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">lists</span>
  216. <span class="Keyword">var</span> <span class="Identifier">list</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  217. <span class="Keyword">let</span>
  218. <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">newDoublyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">3</span><span class="Punctuation">)</span>
  219. <span class="Identifier">b</span> <span class="Operator">=</span> <span class="Identifier">newDoublyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">7</span><span class="Punctuation">)</span>
  220. <span class="Identifier">c</span> <span class="Operator">=</span> <span class="Identifier">newDoublyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  221. <span class="Identifier">list</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span>
  222. <span class="Identifier">list</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">b</span><span class="Punctuation">)</span>
  223. <span class="Identifier">list</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="Identifier">c</span><span class="Punctuation">)</span>
  224. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">next</span> <span class="Operator">==</span> <span class="Identifier">b</span>
  225. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prev</span> <span class="Operator">==</span> <span class="Identifier">c</span>
  226. <span class="Identifier">assert</span> <span class="Identifier">c</span><span class="Operator">.</span><span class="Identifier">next</span> <span class="Operator">==</span> <span class="Identifier">a</span>
  227. <span class="Identifier">assert</span> <span class="Identifier">c</span><span class="Operator">.</span><span class="Identifier">next</span><span class="Operator">.</span><span class="Identifier">next</span> <span class="Operator">==</span> <span class="Identifier">b</span>
  228. <span class="Identifier">assert</span> <span class="Identifier">c</span><span class="Operator">.</span><span class="Identifier">prev</span> <span class="Operator">==</span> <span class="Keyword">nil</span>
  229. <span class="Identifier">assert</span> <span class="Identifier">b</span><span class="Operator">.</span><span class="Identifier">next</span> <span class="Operator">==</span> <span class="Keyword">nil</span></pre>
  230. <h2><a class="toc-backref" id="basic-usage-rings" href="#basic-usage-rings">Rings</a></h2>
  231. <p><strong class="examples_text">Example:</strong></p>
  232. <pre class="listing"><span class="Keyword">import</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">lists</span>
  233. <span class="Keyword">var</span> <span class="Identifier">ring</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  234. <span class="Keyword">let</span>
  235. <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">newSinglyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">3</span><span class="Punctuation">)</span>
  236. <span class="Identifier">b</span> <span class="Operator">=</span> <span class="Identifier">newSinglyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">7</span><span class="Punctuation">)</span>
  237. <span class="Identifier">c</span> <span class="Operator">=</span> <span class="Identifier">newSinglyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  238. <span class="Identifier">ring</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span>
  239. <span class="Identifier">ring</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">b</span><span class="Punctuation">)</span>
  240. <span class="Identifier">ring</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="Identifier">c</span><span class="Punctuation">)</span>
  241. <span class="Identifier">assert</span> <span class="Identifier">c</span><span class="Operator">.</span><span class="Identifier">next</span> <span class="Operator">==</span> <span class="Identifier">a</span>
  242. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">next</span> <span class="Operator">==</span> <span class="Identifier">b</span>
  243. <span class="Identifier">assert</span> <span class="Identifier">c</span><span class="Operator">.</span><span class="Identifier">next</span><span class="Operator">.</span><span class="Identifier">next</span> <span class="Operator">==</span> <span class="Identifier">b</span>
  244. <span class="Identifier">assert</span> <span class="Identifier">b</span><span class="Operator">.</span><span class="Identifier">next</span> <span class="Operator">==</span> <span class="Identifier">c</span>
  245. <span class="Identifier">assert</span> <span class="Identifier">c</span><span class="Operator">.</span><span class="Identifier">next</span><span class="Operator">.</span><span class="Identifier">next</span><span class="Operator">.</span><span class="Identifier">next</span> <span class="Operator">==</span> <span class="Identifier">c</span></pre>
  246. <h1><a class="toc-backref" id="see-also" href="#see-also">See also</a></h1><ul class="simple"><li><a class="reference external" href="deques.html">deques module</a> for double-ended queues</li>
  247. </ul>
  248. </p>
  249. <div class="section" id="6">
  250. <h1><a class="toc-backref" href="#6">Imports</a></h1>
  251. <dl class="item">
  252. <a class="reference external" href="since.html">since</a>, <a class="reference external" href="assertions.html">assertions</a>
  253. </dl>
  254. </div>
  255. <div class="section" id="7">
  256. <h1><a class="toc-backref" href="#7">Types</a></h1>
  257. <dl class="item">
  258. <div id="DoublyLinkedList">
  259. <dt><pre><a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <span class="Keyword">object</span>
  260. <span class="Identifier">head</span><span class="Operator">*</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span>
  261. <span class="Identifier">tail</span><span class="Operator">*</span> {.<span class="Identifier">cursor</span>.}<span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  262. <dd>
  263. A doubly linked list.
  264. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L88" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  265. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L88" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  266. </dd>
  267. </div>
  268. <div id="DoublyLinkedNode">
  269. <dt><pre><a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <span class="Keyword">ref</span> <a href="lists.html#DoublyLinkedNodeObj"><span class="Identifier">DoublyLinkedNodeObj</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  270. <dd>
  271. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L73" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  272. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L73" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  273. </dd>
  274. </div>
  275. <div id="DoublyLinkedNodeObj">
  276. <dt><pre><a href="lists.html#DoublyLinkedNodeObj"><span class="Identifier">DoublyLinkedNodeObj</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <span class="Keyword">object</span>
  277. <span class="Identifier">next</span><span class="Operator">*</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span>
  278. <span class="Identifier">prev</span><span class="Operator">*</span> {.<span class="Identifier">cursor</span>.}<span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span>
  279. <span class="Identifier">value</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">T</span></pre></dt>
  280. <dd>
  281. <p>A node of a doubly linked list.</p>
  282. <p>It consists of a <tt class="docutils literal"><span class="pre"><span class="Identifier">value</span></span></tt> field, and pointers to <tt class="docutils literal"><span class="pre"><span class="Identifier">next</span></span></tt> and <tt class="docutils literal"><span class="pre"><span class="Identifier">prev</span></span></tt>.</p>
  283. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L66" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  284. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L66" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  285. </dd>
  286. </div>
  287. <div id="DoublyLinkedRing">
  288. <dt><pre><a href="lists.html#DoublyLinkedRing"><span class="Identifier">DoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <span class="Keyword">object</span>
  289. <span class="Identifier">head</span><span class="Operator">*</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  290. <dd>
  291. A doubly linked ring.
  292. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L98" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  293. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L98" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  294. </dd>
  295. </div>
  296. <div id="SinglyLinkedList">
  297. <dt><pre><a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <span class="Keyword">object</span>
  298. <span class="Identifier">head</span><span class="Operator">*</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span>
  299. <span class="Identifier">tail</span><span class="Operator">*</span> {.<span class="Identifier">cursor</span>.}<span class="Other">:</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  300. <dd>
  301. A singly linked list.
  302. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L83" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  303. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L83" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  304. </dd>
  305. </div>
  306. <div id="SinglyLinkedNode">
  307. <dt><pre><a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <span class="Keyword">ref</span> <a href="lists.html#SinglyLinkedNodeObj"><span class="Identifier">SinglyLinkedNodeObj</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  308. <dd>
  309. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L81" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  310. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L81" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  311. </dd>
  312. </div>
  313. <div id="SinglyLinkedNodeObj">
  314. <dt><pre><a href="lists.html#SinglyLinkedNodeObj"><span class="Identifier">SinglyLinkedNodeObj</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <span class="Keyword">object</span>
  315. <span class="Identifier">next</span><span class="Operator">*</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span>
  316. <span class="Identifier">value</span><span class="Operator">*</span><span class="Other">:</span> <span class="Identifier">T</span></pre></dt>
  317. <dd>
  318. <p>A node of a singly linked list.</p>
  319. <p>It consists of a <tt class="docutils literal"><span class="pre"><span class="Identifier">value</span></span></tt> field, and a pointer to <tt class="docutils literal"><span class="pre"><span class="Identifier">next</span></span></tt>.</p>
  320. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L75" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  321. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L75" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  322. </dd>
  323. </div>
  324. <div id="SinglyLinkedRing">
  325. <dt><pre><a href="lists.html#SinglyLinkedRing"><span class="Identifier">SinglyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <span class="Keyword">object</span>
  326. <span class="Identifier">head</span><span class="Operator">*</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span>
  327. <span class="Identifier">tail</span><span class="Operator">*</span> {.<span class="Identifier">cursor</span>.}<span class="Other">:</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  328. <dd>
  329. A singly linked ring.
  330. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L93" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  331. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L93" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  332. </dd>
  333. </div>
  334. <div id="SomeLinkedCollection">
  335. <dt><pre><a href="lists.html#SomeLinkedCollection"><span class="Identifier">SomeLinkedCollection</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <a href="lists.html#SomeLinkedList"><span class="Identifier">SomeLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Operator">|</span> <a href="lists.html#SomeLinkedRing"><span class="Identifier">SomeLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  336. <dd>
  337. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L106" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  338. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L106" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  339. </dd>
  340. </div>
  341. <div id="SomeLinkedList">
  342. <dt><pre><a href="lists.html#SomeLinkedList"><span class="Identifier">SomeLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Operator">|</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  343. <dd>
  344. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L102" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  345. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L102" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  346. </dd>
  347. </div>
  348. <div id="SomeLinkedNode">
  349. <dt><pre><a href="lists.html#SomeLinkedNode"><span class="Identifier">SomeLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Operator">|</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  350. <dd>
  351. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L108" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  352. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L108" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  353. </dd>
  354. </div>
  355. <div id="SomeLinkedRing">
  356. <dt><pre><a href="lists.html#SomeLinkedRing"><span class="Identifier">SomeLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Other">=</span> <a href="lists.html#SinglyLinkedRing"><span class="Identifier">SinglyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Operator">|</span> <a href="lists.html#DoublyLinkedRing"><span class="Identifier">DoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  357. <dd>
  358. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L104" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  359. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L104" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  360. </dd>
  361. </div>
  362. </dl>
  363. </div>
  364. <div class="section" id="12">
  365. <h1><a class="toc-backref" href="#12">Procs</a></h1>
  366. <dl class="item">
  367. <div id="$-procs-all">
  368. <div id="$,SomeLinkedCollection[T]">
  369. <dt><pre><span class="Keyword">proc</span> <a href="#%24%2CSomeLinkedCollection%5BT%5D"><span class="Identifier">`$`</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <a href="lists.html#SomeLinkedCollection"><span class="Identifier">SomeLinkedCollection</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <a href="system.html#string"><span class="Identifier">string</span></a></pre></dt>
  370. <dd>
  371. Turns a list into its string representation for logging and printing.
  372. <p><strong class="examples_text">Example:</strong></p>
  373. <pre class="listing"><span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  374. <span class="Identifier">assert</span> <span class="Operator">$</span><span class="Identifier">a</span> <span class="Operator">==</span> <span class="StringLit">&quot;[1, 2, 3, 4]&quot;</span></pre>
  375. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L300" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  376. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L300" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  377. </dd>
  378. </div>
  379. </div>
  380. <div id="add-procs-all">
  381. <div id="add,T,T">
  382. <dt><pre><span class="Keyword">proc</span> <a href="#add%2CT%2CT"><span class="Identifier">add</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">:</span> <a href="lists.html#SomeLinkedList"><span class="Identifier">SomeLinkedList</span></a><span class="Other">]</span><span class="Other">(</span><span class="Identifier">a</span><span class="Other">:</span> <span class="Keyword">var</span> <span class="Identifier">T</span><span class="Other">;</span> <span class="Identifier">b</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  383. <dd>
  384. <p>Appends a shallow copy of <tt class="docutils literal"><span class="pre"><span class="Identifier">b</span></span></tt> to the end of <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span></span></tt>.</p>
  385. <p><strong>See also:</strong></p>
  386. <ul class="simple"><li><a class="reference external" href="#addMoved,SinglyLinkedList[T],SinglyLinkedList[T]">addMoved proc</a></li>
  387. <li><a class="reference external" href="#addMoved,DoublyLinkedList[T],DoublyLinkedList[T]">addMoved proc</a> for moving the second list instead of copying</li>
  388. </ul>
  389. <p><strong class="examples_text">Example:</strong></p>
  390. <pre class="listing"><span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sequtils</span> <span class="Keyword">import</span> <span class="Identifier">toSeq</span>
  391. <span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  392. <span class="Keyword">let</span> <span class="Identifier">b</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  393. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">b</span><span class="Punctuation">)</span>
  394. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span>
  395. <span class="Identifier">assert</span> <span class="Identifier">b</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span>
  396. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span>
  397. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span></pre>
  398. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L668" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  399. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L668" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  400. </dd>
  401. </div>
  402. <div id="add,DoublyLinkedList[T],DoublyLinkedNode[T]">
  403. <dt><pre><span class="Keyword">proc</span> <a href="#add%2CDoublyLinkedList%5BT%5D%2CDoublyLinkedNode%5BT%5D"><span class="Identifier">add</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">n</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span></pre></dt>
  404. <dd>
  405. <p>Appends (adds to the end) a node <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  406. <p><strong>See also:</strong></p>
  407. <ul class="simple"><li><a class="reference external" href="#add,DoublyLinkedList[T],T">add proc</a> for appending a value</li>
  408. <li><a class="reference external" href="#prepend,DoublyLinkedList[T],DoublyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  409. <li><a class="reference external" href="#prepend,DoublyLinkedList[T],T">prepend proc</a> for prepending a value</li>
  410. <li><a class="reference external" href="#remove,DoublyLinkedList[T],DoublyLinkedNode[T]">remove proc</a> for removing a node</li>
  411. </ul>
  412. <p><strong class="examples_text">Example:</strong></p>
  413. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  414. <span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">newDoublyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  415. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  416. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  417. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L523" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  418. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L523" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  419. </dd>
  420. </div>
  421. <div id="add,DoublyLinkedList[T],T">
  422. <dt><pre><span class="Keyword">proc</span> <a href="#add%2CDoublyLinkedList%5BT%5D%2CT"><span class="Identifier">add</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  423. <dd>
  424. <p>Appends (adds to the end) a value to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  425. <p><strong>See also:</strong></p>
  426. <ul class="simple"><li><a class="reference external" href="#add,DoublyLinkedList[T],DoublyLinkedNode[T]">add proc</a> for appending a node</li>
  427. <li><a class="reference external" href="#prepend,DoublyLinkedList[T],DoublyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  428. <li><a class="reference external" href="#prepend,DoublyLinkedList[T],T">prepend proc</a> for prepending a value</li>
  429. <li><a class="reference external" href="#remove,DoublyLinkedList[T],DoublyLinkedNode[T]">remove proc</a> for removing a node</li>
  430. </ul>
  431. <p><strong class="examples_text">Example:</strong></p>
  432. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  433. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  434. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">8</span><span class="Punctuation">)</span>
  435. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  436. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L547" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  437. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L547" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  438. </dd>
  439. </div>
  440. <div id="add,DoublyLinkedRing[T],DoublyLinkedNode[T]">
  441. <dt><pre><span class="Keyword">proc</span> <a href="#add%2CDoublyLinkedRing%5BT%5D%2CDoublyLinkedNode%5BT%5D"><span class="Identifier">add</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#DoublyLinkedRing"><span class="Identifier">DoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">n</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span></pre></dt>
  442. <dd>
  443. <p>Appends (adds to the end) a node <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  444. <p><strong>See also:</strong></p>
  445. <ul class="simple"><li><a class="reference external" href="#add,DoublyLinkedRing[T],T">add proc</a> for appending a value</li>
  446. <li><a class="reference external" href="#prepend,DoublyLinkedRing[T],DoublyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  447. <li><a class="reference external" href="#prepend,DoublyLinkedRing[T],T">prepend proc</a> for prepending a value</li>
  448. <li><a class="reference external" href="#remove,DoublyLinkedRing[T],DoublyLinkedNode[T]">remove proc</a> for removing a node</li>
  449. </ul>
  450. <p><strong class="examples_text">Example:</strong></p>
  451. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  452. <span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">newDoublyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  453. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  454. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  455. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L837" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  456. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L837" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  457. </dd>
  458. </div>
  459. <div id="add,DoublyLinkedRing[T],T">
  460. <dt><pre><span class="Keyword">proc</span> <a href="#add%2CDoublyLinkedRing%5BT%5D%2CT"><span class="Identifier">add</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#DoublyLinkedRing"><span class="Identifier">DoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  461. <dd>
  462. <p>Appends (adds to the end) a value to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  463. <p><strong>See also:</strong></p>
  464. <ul class="simple"><li><a class="reference external" href="#add,DoublyLinkedRing[T],DoublyLinkedNode[T]">add proc</a> for appending a node</li>
  465. <li><a class="reference external" href="#prepend,DoublyLinkedRing[T],DoublyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  466. <li><a class="reference external" href="#prepend,DoublyLinkedRing[T],T">prepend proc</a> for prepending a value</li>
  467. <li><a class="reference external" href="#remove,DoublyLinkedRing[T],DoublyLinkedNode[T]">remove proc</a> for removing a node</li>
  468. </ul>
  469. <p><strong class="examples_text">Example:</strong></p>
  470. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  471. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  472. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">8</span><span class="Punctuation">)</span>
  473. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  474. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L863" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  475. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L863" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  476. </dd>
  477. </div>
  478. <div id="add,SinglyLinkedList[T],SinglyLinkedNode[T]">
  479. <dt><pre><span class="Keyword">proc</span> <a href="#add%2CSinglyLinkedList%5BT%5D%2CSinglyLinkedNode%5BT%5D"><span class="Identifier">add</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">n</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span> {.<span class="Identifier">inline</span>.}</pre></dt>
  480. <dd>
  481. <p>Appends (adds to the end) a node <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  482. <p><strong>See also:</strong></p>
  483. <ul class="simple"><li><a class="reference external" href="#add,SinglyLinkedList[T],T">add proc</a> for appending a value</li>
  484. <li><a class="reference external" href="#prepend,SinglyLinkedList[T],SinglyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  485. <li><a class="reference external" href="#prepend,SinglyLinkedList[T],T">prepend proc</a> for prepending a value</li>
  486. </ul>
  487. <p><strong class="examples_text">Example:</strong></p>
  488. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  489. <span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">newSinglyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  490. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  491. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  492. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L393" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  493. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L393" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  494. </dd>
  495. </div>
  496. <div id="add,SinglyLinkedList[T],T">
  497. <dt><pre><span class="Keyword">proc</span> <a href="#add%2CSinglyLinkedList%5BT%5D%2CT"><span class="Identifier">add</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span> {.<span class="Identifier">inline</span>.}</pre></dt>
  498. <dd>
  499. <p>Appends (adds to the end) a value to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  500. <p><strong>See also:</strong></p>
  501. <ul class="simple"><li><a class="reference external" href="#add,SinglyLinkedList[T],T">add proc</a> for appending a value</li>
  502. <li><a class="reference external" href="#prepend,SinglyLinkedList[T],SinglyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  503. <li><a class="reference external" href="#prepend,SinglyLinkedList[T],T">prepend proc</a> for prepending a value</li>
  504. </ul>
  505. <p><strong class="examples_text">Example:</strong></p>
  506. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  507. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  508. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">8</span><span class="Punctuation">)</span>
  509. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  510. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L414" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  511. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L414" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  512. </dd>
  513. </div>
  514. <div id="add,SinglyLinkedRing[T],SinglyLinkedNode[T]">
  515. <dt><pre><span class="Keyword">proc</span> <a href="#add%2CSinglyLinkedRing%5BT%5D%2CSinglyLinkedNode%5BT%5D"><span class="Identifier">add</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SinglyLinkedRing"><span class="Identifier">SinglyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">n</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span></pre></dt>
  516. <dd>
  517. <p>Appends (adds to the end) a node <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  518. <p><strong>See also:</strong></p>
  519. <ul class="simple"><li><a class="reference external" href="#add,SinglyLinkedRing[T],T">add proc</a> for appending a value</li>
  520. <li><a class="reference external" href="#prepend,SinglyLinkedRing[T],SinglyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  521. <li><a class="reference external" href="#prepend,SinglyLinkedRing[T],T">prepend proc</a> for prepending a value</li>
  522. </ul>
  523. <p><strong class="examples_text">Example:</strong></p>
  524. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  525. <span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">newSinglyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  526. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  527. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  528. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L755" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  529. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L755" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  530. </dd>
  531. </div>
  532. <div id="add,SinglyLinkedRing[T],T">
  533. <dt><pre><span class="Keyword">proc</span> <a href="#add%2CSinglyLinkedRing%5BT%5D%2CT"><span class="Identifier">add</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SinglyLinkedRing"><span class="Identifier">SinglyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  534. <dd>
  535. <p>Appends (adds to the end) a value to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  536. <p><strong>See also:</strong></p>
  537. <ul class="simple"><li><a class="reference external" href="#add,SinglyLinkedRing[T],SinglyLinkedNode[T]">add proc</a> for appending a node</li>
  538. <li><a class="reference external" href="#prepend,SinglyLinkedRing[T],SinglyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  539. <li><a class="reference external" href="#prepend,SinglyLinkedRing[T],T">prepend proc</a> for prepending a value</li>
  540. </ul>
  541. <p><strong class="examples_text">Example:</strong></p>
  542. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  543. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  544. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">8</span><span class="Punctuation">)</span>
  545. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  546. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L778" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  547. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L778" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  548. </dd>
  549. </div>
  550. </div>
  551. <div id="addMoved-procs-all">
  552. <div id="addMoved,DoublyLinkedList[T],DoublyLinkedList[T]">
  553. <dt><pre><span class="Keyword">proc</span> <a href="#addMoved%2CDoublyLinkedList%5BT%5D%2CDoublyLinkedList%5BT%5D"><span class="Identifier">addMoved</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">a</span><span class="Other">,</span> <span class="Identifier">b</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span></pre></dt>
  554. <dd>
  555. <p>Moves <tt class="docutils literal"><span class="pre"><span class="Identifier">b</span></span></tt> to the end of <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span></span></tt>. Efficiency: O(1). Note that <tt class="docutils literal"><span class="pre"><span class="Identifier">b</span></span></tt> becomes empty after the operation unless it has the same address as <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span></span></tt>. Self-adding results in a cycle.</p>
  556. <p><strong>See also:</strong></p>
  557. <ul class="simple"><li><a class="reference external" href="#add,T,T">add proc</a> for adding a copy of a list</li>
  558. </ul>
  559. <p><strong class="examples_text">Example:</strong></p>
  560. <pre class="listing"><span class="Keyword">import</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Punctuation">[</span><span class="Identifier">sequtils</span><span class="Punctuation">,</span> <span class="Identifier">enumerate</span><span class="Punctuation">,</span> <span class="Identifier">sugar</span><span class="Punctuation">]</span>
  561. <span class="Keyword">var</span>
  562. <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toDoublyLinkedList</span>
  563. <span class="Identifier">b</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toDoublyLinkedList</span>
  564. <span class="Identifier">c</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toDoublyLinkedList</span>
  565. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">addMoved</span><span class="Punctuation">(</span><span class="Identifier">b</span><span class="Punctuation">)</span>
  566. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span>
  567. <span class="Identifier">assert</span> <span class="Identifier">b</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="Punctuation">]</span>
  568. <span class="Identifier">c</span><span class="Operator">.</span><span class="Identifier">addMoved</span><span class="Punctuation">(</span><span class="Identifier">c</span><span class="Punctuation">)</span>
  569. <span class="Keyword">let</span> <span class="Identifier">s</span> <span class="Operator">=</span> <span class="Identifier">collect</span><span class="Punctuation">:</span>
  570. <span class="Keyword">for</span> <span class="Identifier">i</span><span class="Punctuation">,</span> <span class="Identifier">ci</span> <span class="Keyword">in</span> <span class="Identifier">enumerate</span><span class="Punctuation">(</span><span class="Identifier">c</span><span class="Punctuation">)</span><span class="Punctuation">:</span>
  571. <span class="Keyword">if</span> <span class="Identifier">i</span> <span class="Operator">==</span> <span class="DecNumber">6</span><span class="Punctuation">:</span> <span class="Keyword">break</span>
  572. <span class="Identifier">ci</span>
  573. <span class="Identifier">assert</span> <span class="Identifier">s</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">]</span></pre>
  574. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L633" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  575. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L633" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  576. </dd>
  577. </div>
  578. <div id="addMoved,SinglyLinkedList[T],SinglyLinkedList[T]">
  579. <dt><pre><span class="Keyword">proc</span> <a href="#addMoved%2CSinglyLinkedList%5BT%5D%2CSinglyLinkedList%5BT%5D"><span class="Identifier">addMoved</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">a</span><span class="Other">,</span> <span class="Identifier">b</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span></pre></dt>
  580. <dd>
  581. <p>Moves <tt class="docutils literal"><span class="pre"><span class="Identifier">b</span></span></tt> to the end of <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span></span></tt>. Efficiency: O(1). Note that <tt class="docutils literal"><span class="pre"><span class="Identifier">b</span></span></tt> becomes empty after the operation unless it has the same address as <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span></span></tt>. Self-adding results in a cycle.</p>
  582. <p><strong>See also:</strong></p>
  583. <ul class="simple"><li><a class="reference external" href="#add,T,T">add proc</a> for adding a copy of a list</li>
  584. </ul>
  585. <p><strong class="examples_text">Example:</strong></p>
  586. <pre class="listing"><span class="Keyword">import</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Punctuation">[</span><span class="Identifier">sequtils</span><span class="Punctuation">,</span> <span class="Identifier">enumerate</span><span class="Punctuation">,</span> <span class="Identifier">sugar</span><span class="Punctuation">]</span>
  587. <span class="Keyword">var</span>
  588. <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  589. <span class="Identifier">b</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  590. <span class="Identifier">c</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  591. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">addMoved</span><span class="Punctuation">(</span><span class="Identifier">b</span><span class="Punctuation">)</span>
  592. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span>
  593. <span class="Identifier">assert</span> <span class="Identifier">b</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="Punctuation">]</span>
  594. <span class="Identifier">c</span><span class="Operator">.</span><span class="Identifier">addMoved</span><span class="Punctuation">(</span><span class="Identifier">c</span><span class="Punctuation">)</span>
  595. <span class="Keyword">let</span> <span class="Identifier">s</span> <span class="Operator">=</span> <span class="Identifier">collect</span><span class="Punctuation">:</span>
  596. <span class="Keyword">for</span> <span class="Identifier">i</span><span class="Punctuation">,</span> <span class="Identifier">ci</span> <span class="Keyword">in</span> <span class="Identifier">enumerate</span><span class="Punctuation">(</span><span class="Identifier">c</span><span class="Punctuation">)</span><span class="Punctuation">:</span>
  597. <span class="Keyword">if</span> <span class="Identifier">i</span> <span class="Operator">==</span> <span class="DecNumber">6</span><span class="Punctuation">:</span> <span class="Keyword">break</span>
  598. <span class="Identifier">ci</span>
  599. <span class="Identifier">assert</span> <span class="Identifier">s</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">]</span></pre>
  600. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L490" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  601. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L490" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  602. </dd>
  603. </div>
  604. </div>
  605. <div id="append-procs-all">
  606. <div id="append,,_2">
  607. <dt><pre><span class="Keyword">proc</span> <a href="#append%2C%2C_2"><span class="Identifier">append</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">a</span><span class="Other">:</span> <span class="Keyword">var</span> <span class="Other">(</span><a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Operator">|</span> <a href="lists.html#DoublyLinkedRing"><span class="Identifier">DoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">;</span>
  608. <span class="Identifier">b</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Operator">|</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Operator">|</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  609. <dd>
  610. <p>Alias for <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">b</span><span class="Punctuation">)</span></span></tt>.</p>
  611. <p><strong>See also:</strong></p>
  612. <ul class="simple"><li><a class="reference external" href="#add,DoublyLinkedList[T],DoublyLinkedNode[T]">add proc</a></li>
  613. <li><a class="reference external" href="#add,DoublyLinkedList[T],T">add proc</a></li>
  614. <li><a class="reference external" href="#add,T,T">add proc</a></li>
  615. </ul>
  616. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L959" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  617. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L959" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  618. </dd>
  619. </div>
  620. <div id="append,,">
  621. <dt><pre><span class="Keyword">proc</span> <a href="#append%2C%2C"><span class="Identifier">append</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">a</span><span class="Other">:</span> <span class="Keyword">var</span> <span class="Other">(</span><a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Operator">|</span> <a href="lists.html#SinglyLinkedRing"><span class="Identifier">SinglyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">;</span>
  622. <span class="Identifier">b</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Operator">|</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span> <span class="Operator">|</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  623. <dd>
  624. <p>Alias for <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">b</span><span class="Punctuation">)</span></span></tt>.</p>
  625. <p><strong>See also:</strong></p>
  626. <ul class="simple"><li><a class="reference external" href="#add,SinglyLinkedList[T],SinglyLinkedNode[T]">add proc</a></li>
  627. <li><a class="reference external" href="#add,SinglyLinkedList[T],T">add proc</a></li>
  628. <li><a class="reference external" href="#add,T,T">add proc</a></li>
  629. </ul>
  630. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L949" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  631. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L949" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  632. </dd>
  633. </div>
  634. </div>
  635. <div id="appendMoved-procs-all">
  636. <div id="appendMoved,T,T">
  637. <dt><pre><span class="Keyword">proc</span> <a href="#appendMoved%2CT%2CT"><span class="Identifier">appendMoved</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">:</span> <a href="lists.html#SomeLinkedList"><span class="Identifier">SomeLinkedList</span></a><span class="Other">]</span><span class="Other">(</span><span class="Identifier">a</span><span class="Other">,</span> <span class="Identifier">b</span><span class="Other">:</span> <span class="Keyword">var</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  638. <dd>
  639. <p>Alias for <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">addMoved</span><span class="Punctuation">(</span><span class="Identifier">b</span><span class="Punctuation">)</span></span></tt>.</p>
  640. <p><strong>See also:</strong></p>
  641. <ul class="simple"><li><a class="reference external" href="#addMoved,SinglyLinkedList[T],SinglyLinkedList[T]">addMoved proc</a></li>
  642. <li><a class="reference external" href="#addMoved,DoublyLinkedList[T],DoublyLinkedList[T]">addMoved proc</a></li>
  643. </ul>
  644. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L969" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  645. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L969" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  646. </dd>
  647. </div>
  648. </div>
  649. <div id="contains-procs-all">
  650. <div id="contains,SomeLinkedCollection[T],T">
  651. <dt><pre><span class="Keyword">proc</span> <a href="#contains%2CSomeLinkedCollection%5BT%5D%2CT"><span class="Identifier">contains</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <a href="lists.html#SomeLinkedCollection"><span class="Identifier">SomeLinkedCollection</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span><span class="Other">:</span> <a href="system.html#bool"><span class="Identifier">bool</span></a> {.<span class="Identifier">inline</span>.}</pre></dt>
  652. <dd>
  653. <p>Searches in the list for a value. Returns <tt class="docutils literal"><span class="pre"><span class="Identifier">false</span></span></tt> if the value does not exist, <tt class="docutils literal"><span class="pre"><span class="Identifier">true</span></span></tt> otherwise. This allows the usage of the <tt class="docutils literal"><span class="pre"><span class="Keyword">in</span></span></tt> and <tt class="docutils literal"><span class="pre"><span class="Keyword">notin</span></span></tt> operators.</p>
  654. <p><strong>See also:</strong></p>
  655. <ul class="simple"><li><a class="reference external" href="#find,SomeLinkedCollection[T],T">find proc</a></li>
  656. </ul>
  657. <p><strong class="examples_text">Example:</strong></p>
  658. <pre class="listing"><span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">9</span><span class="Punctuation">,</span> <span class="DecNumber">8</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  659. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  660. <span class="Identifier">assert</span> <span class="DecNumber">8</span> <span class="Keyword">in</span> <span class="Identifier">a</span>
  661. <span class="Identifier">assert</span><span class="Punctuation">(</span><span class="Keyword">not</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">1</span><span class="Punctuation">)</span><span class="Punctuation">)</span>
  662. <span class="Identifier">assert</span> <span class="DecNumber">2</span> <span class="Keyword">notin</span> <span class="Identifier">a</span></pre>
  663. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L330" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  664. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L330" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  665. </dd>
  666. </div>
  667. </div>
  668. <div id="copy-procs-all">
  669. <div id="copy,DoublyLinkedList[T]">
  670. <dt><pre><span class="Keyword">func</span> <a href="#copy%2CDoublyLinkedList%5BT%5D"><span class="Identifier">copy</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">a</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  671. <dd>
  672. Creates a shallow copy of <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span></span></tt>.
  673. <p><strong class="examples_text">Example:</strong></p>
  674. <pre class="listing"><span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sequtils</span> <span class="Keyword">import</span> <span class="Identifier">toSeq</span>
  675. <span class="Keyword">type</span> <span class="Identifier">Foo</span> <span class="Operator">=</span> <span class="Keyword">ref</span> <span class="Keyword">object</span>
  676. <span class="Identifier">x</span><span class="Punctuation">:</span> <span class="Identifier">int</span>
  677. <span class="Keyword">var</span>
  678. <span class="Identifier">f</span> <span class="Operator">=</span> <span class="Identifier">Foo</span><span class="Punctuation">(</span><span class="Identifier">x</span><span class="Punctuation">:</span> <span class="DecNumber">1</span><span class="Punctuation">)</span>
  679. <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="Identifier">f</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toDoublyLinkedList</span>
  680. <span class="Keyword">let</span> <span class="Identifier">b</span> <span class="Operator">=</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">copy</span>
  681. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Punctuation">[</span><span class="Identifier">f</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toDoublyLinkedList</span><span class="Punctuation">)</span>
  682. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="Identifier">f</span><span class="Punctuation">,</span> <span class="Identifier">f</span><span class="Punctuation">]</span>
  683. <span class="Identifier">assert</span> <span class="Identifier">b</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="Identifier">f</span><span class="Punctuation">]</span> <span class="Comment"># b isn't modified...</span>
  684. <span class="Identifier">f</span><span class="Operator">.</span><span class="Identifier">x</span> <span class="Operator">=</span> <span class="DecNumber">42</span>
  685. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">head</span><span class="Operator">.</span><span class="Identifier">value</span><span class="Operator">.</span><span class="Identifier">x</span> <span class="Operator">==</span> <span class="DecNumber">42</span>
  686. <span class="Identifier">assert</span> <span class="Identifier">b</span><span class="Operator">.</span><span class="Identifier">head</span><span class="Operator">.</span><span class="Identifier">value</span><span class="Operator">.</span><span class="Identifier">x</span> <span class="Operator">==</span> <span class="DecNumber">42</span> <span class="Comment"># ... but the elements are not deep copied</span>
  687. <span class="Keyword">let</span> <span class="Identifier">c</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toDoublyLinkedList</span>
  688. <span class="Identifier">assert</span> <span class="Operator">$</span><span class="Identifier">c</span> <span class="Operator">==</span> <span class="Operator">$</span><span class="Identifier">c</span><span class="Operator">.</span><span class="Identifier">copy</span></pre>
  689. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L609" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  690. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L609" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  691. </dd>
  692. </div>
  693. <div id="copy,SinglyLinkedList[T]">
  694. <dt><pre><span class="Keyword">func</span> <a href="#copy%2CSinglyLinkedList%5BT%5D"><span class="Identifier">copy</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">a</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  695. <dd>
  696. Creates a shallow copy of <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span></span></tt>.
  697. <p><strong class="examples_text">Example:</strong></p>
  698. <pre class="listing"><span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sequtils</span> <span class="Keyword">import</span> <span class="Identifier">toSeq</span>
  699. <span class="Keyword">type</span> <span class="Identifier">Foo</span> <span class="Operator">=</span> <span class="Keyword">ref</span> <span class="Keyword">object</span>
  700. <span class="Identifier">x</span><span class="Punctuation">:</span> <span class="Identifier">int</span>
  701. <span class="Keyword">var</span>
  702. <span class="Identifier">f</span> <span class="Operator">=</span> <span class="Identifier">Foo</span><span class="Punctuation">(</span><span class="Identifier">x</span><span class="Punctuation">:</span> <span class="DecNumber">1</span><span class="Punctuation">)</span>
  703. <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="Identifier">f</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  704. <span class="Keyword">let</span> <span class="Identifier">b</span> <span class="Operator">=</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">copy</span>
  705. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Punctuation">[</span><span class="Identifier">f</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span><span class="Punctuation">)</span>
  706. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="Identifier">f</span><span class="Punctuation">,</span> <span class="Identifier">f</span><span class="Punctuation">]</span>
  707. <span class="Identifier">assert</span> <span class="Identifier">b</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="Identifier">f</span><span class="Punctuation">]</span> <span class="Comment"># b isn't modified...</span>
  708. <span class="Identifier">f</span><span class="Operator">.</span><span class="Identifier">x</span> <span class="Operator">=</span> <span class="DecNumber">42</span>
  709. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">head</span><span class="Operator">.</span><span class="Identifier">value</span><span class="Operator">.</span><span class="Identifier">x</span> <span class="Operator">==</span> <span class="DecNumber">42</span>
  710. <span class="Identifier">assert</span> <span class="Identifier">b</span><span class="Operator">.</span><span class="Identifier">head</span><span class="Operator">.</span><span class="Identifier">value</span><span class="Operator">.</span><span class="Identifier">x</span> <span class="Operator">==</span> <span class="DecNumber">42</span> <span class="Comment"># ... but the elements are not deep copied</span>
  711. <span class="Keyword">let</span> <span class="Identifier">c</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  712. <span class="Identifier">assert</span> <span class="Operator">$</span><span class="Identifier">c</span> <span class="Operator">==</span> <span class="Operator">$</span><span class="Identifier">c</span><span class="Operator">.</span><span class="Identifier">copy</span></pre>
  713. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L466" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  714. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L466" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  715. </dd>
  716. </div>
  717. </div>
  718. <div id="find-procs-all">
  719. <div id="find,SomeLinkedCollection[T],T">
  720. <dt><pre><span class="Keyword">proc</span> <a href="#find%2CSomeLinkedCollection%5BT%5D%2CT"><span class="Identifier">find</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <a href="lists.html#SomeLinkedCollection"><span class="Identifier">SomeLinkedCollection</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#SomeLinkedNode"><span class="Identifier">SomeLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  721. <dd>
  722. <p>Searches in the list for a value. Returns <tt class="docutils literal"><span class="pre"><span class="Keyword">nil</span></span></tt> if the value does not exist.</p>
  723. <p><strong>See also:</strong></p>
  724. <ul class="simple"><li><a class="reference external" href="#contains,SomeLinkedCollection[T],T">contains proc</a></li>
  725. </ul>
  726. <p><strong class="examples_text">Example:</strong></p>
  727. <pre class="listing"><span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">9</span><span class="Punctuation">,</span> <span class="DecNumber">8</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  728. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">find</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span><span class="Operator">.</span><span class="Identifier">value</span> <span class="Operator">==</span> <span class="DecNumber">9</span>
  729. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">find</span><span class="Punctuation">(</span><span class="DecNumber">1</span><span class="Punctuation">)</span> <span class="Operator">==</span> <span class="Keyword">nil</span></pre>
  730. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L312" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  731. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L312" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  732. </dd>
  733. </div>
  734. </div>
  735. <div id="initDoublyLinkedList-procs-all">
  736. <div id="initDoublyLinkedList">
  737. <dt><pre><span class="Keyword">proc</span> <a href="#initDoublyLinkedList"><span class="Identifier">initDoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  738. <dd>
  739. <p>Creates a new doubly linked list that is empty.</p>
  740. <p>Doubly linked lists are initialized by default, so it is not necessary to call this function explicitly.</p>
  741. <p><strong class="examples_text">Example:</strong></p>
  742. <pre class="listing"><span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span></pre>
  743. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L120" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  744. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L120" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  745. </dd>
  746. </div>
  747. </div>
  748. <div id="initDoublyLinkedRing-procs-all">
  749. <div id="initDoublyLinkedRing">
  750. <dt><pre><span class="Keyword">proc</span> <a href="#initDoublyLinkedRing"><span class="Identifier">initDoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedRing"><span class="Identifier">DoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  751. <dd>
  752. <p>Creates a new doubly linked ring that is empty.</p>
  753. <p>Doubly linked rings are initialized by default, so it is not necessary to call this function explicitly.</p>
  754. <p><strong class="examples_text">Example:</strong></p>
  755. <pre class="listing"><span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span></pre>
  756. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L140" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  757. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L140" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  758. </dd>
  759. </div>
  760. </div>
  761. <div id="initSinglyLinkedList-procs-all">
  762. <div id="initSinglyLinkedList">
  763. <dt><pre><span class="Keyword">proc</span> <a href="#initSinglyLinkedList"><span class="Identifier">initSinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  764. <dd>
  765. <p>Creates a new singly linked list that is empty.</p>
  766. <p>Singly linked lists are initialized by default, so it is not necessary to call this function explicitly.</p>
  767. <p><strong class="examples_text">Example:</strong></p>
  768. <pre class="listing"><span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span></pre>
  769. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L110" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  770. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L110" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  771. </dd>
  772. </div>
  773. </div>
  774. <div id="initSinglyLinkedRing-procs-all">
  775. <div id="initSinglyLinkedRing">
  776. <dt><pre><span class="Keyword">proc</span> <a href="#initSinglyLinkedRing"><span class="Identifier">initSinglyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedRing"><span class="Identifier">SinglyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  777. <dd>
  778. <p>Creates a new singly linked ring that is empty.</p>
  779. <p>Singly linked rings are initialized by default, so it is not necessary to call this function explicitly.</p>
  780. <p><strong class="examples_text">Example:</strong></p>
  781. <pre class="listing"><span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span></pre>
  782. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L130" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  783. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L130" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  784. </dd>
  785. </div>
  786. </div>
  787. <div id="newDoublyLinkedNode-procs-all">
  788. <div id="newDoublyLinkedNode,T">
  789. <dt><pre><span class="Keyword">proc</span> <a href="#newDoublyLinkedNode%2CT"><span class="Identifier">newDoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  790. <dd>
  791. Creates a new doubly linked node with the given <tt class="docutils literal"><span class="pre"><span class="Identifier">value</span></span></tt>.
  792. <p><strong class="examples_text">Example:</strong></p>
  793. <pre class="listing"><span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">newDoublyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">5</span><span class="Punctuation">)</span>
  794. <span class="Identifier">assert</span> <span class="Identifier">n</span><span class="Operator">.</span><span class="Identifier">value</span> <span class="Operator">==</span> <span class="DecNumber">5</span></pre>
  795. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L150" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  796. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L150" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  797. </dd>
  798. </div>
  799. </div>
  800. <div id="newSinglyLinkedNode-procs-all">
  801. <div id="newSinglyLinkedNode,T">
  802. <dt><pre><span class="Keyword">proc</span> <a href="#newSinglyLinkedNode%2CT"><span class="Identifier">newSinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  803. <dd>
  804. Creates a new singly linked node with the given <tt class="docutils literal"><span class="pre"><span class="Identifier">value</span></span></tt>.
  805. <p><strong class="examples_text">Example:</strong></p>
  806. <pre class="listing"><span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">newSinglyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">5</span><span class="Punctuation">)</span>
  807. <span class="Identifier">assert</span> <span class="Identifier">n</span><span class="Operator">.</span><span class="Identifier">value</span> <span class="Operator">==</span> <span class="DecNumber">5</span></pre>
  808. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L159" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  809. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L159" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  810. </dd>
  811. </div>
  812. </div>
  813. <div id="prepend-procs-all">
  814. <div id="prepend,T,T">
  815. <dt><pre><span class="Keyword">proc</span> <a href="#prepend%2CT%2CT"><span class="Identifier">prepend</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">:</span> <a href="lists.html#SomeLinkedList"><span class="Identifier">SomeLinkedList</span></a><span class="Other">]</span><span class="Other">(</span><span class="Identifier">a</span><span class="Other">:</span> <span class="Keyword">var</span> <span class="Identifier">T</span><span class="Other">;</span> <span class="Identifier">b</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  816. <dd>
  817. <p>Prepends a shallow copy of <tt class="docutils literal"><span class="pre"><span class="Identifier">b</span></span></tt> to the beginning of <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span></span></tt>.</p>
  818. <p><strong>See also:</strong></p>
  819. <ul class="simple"><li><a class="reference external" href="#prependMoved,T,T">prependMoved proc</a> for moving the second list instead of copying</li>
  820. </ul>
  821. <p><strong class="examples_text">Example:</strong></p>
  822. <pre class="listing"><span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sequtils</span> <span class="Keyword">import</span> <span class="Identifier">toSeq</span>
  823. <span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  824. <span class="Keyword">let</span> <span class="Identifier">b</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  825. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="Identifier">b</span><span class="Punctuation">)</span>
  826. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span>
  827. <span class="Identifier">assert</span> <span class="Identifier">b</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">]</span>
  828. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span>
  829. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span></pre>
  830. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L346" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  831. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L346" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  832. </dd>
  833. </div>
  834. <div id="prepend,DoublyLinkedList[T],DoublyLinkedNode[T]">
  835. <dt><pre><span class="Keyword">proc</span> <a href="#prepend%2CDoublyLinkedList%5BT%5D%2CDoublyLinkedNode%5BT%5D"><span class="Identifier">prepend</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">n</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span></pre></dt>
  836. <dd>
  837. <p>Prepends (adds to the beginning) a node <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  838. <p><strong>See also:</strong></p>
  839. <ul class="simple"><li><a class="reference external" href="#add,DoublyLinkedList[T],DoublyLinkedNode[T]">add proc</a> for appending a node</li>
  840. <li><a class="reference external" href="#add,DoublyLinkedList[T],T">add proc</a> for appending a value</li>
  841. <li><a class="reference external" href="#prepend,DoublyLinkedList[T],T">prepend proc</a> for prepending a value</li>
  842. <li><a class="reference external" href="#remove,DoublyLinkedList[T],DoublyLinkedNode[T]">remove proc</a> for removing a node</li>
  843. </ul>
  844. <p><strong class="examples_text">Example:</strong></p>
  845. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  846. <span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">newDoublyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  847. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  848. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  849. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L566" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  850. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L566" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  851. </dd>
  852. </div>
  853. <div id="prepend,DoublyLinkedList[T],T">
  854. <dt><pre><span class="Keyword">proc</span> <a href="#prepend%2CDoublyLinkedList%5BT%5D%2CT"><span class="Identifier">prepend</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  855. <dd>
  856. <p>Prepends (adds to the beginning) a value to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  857. <p><strong>See also:</strong></p>
  858. <ul class="simple"><li><a class="reference external" href="#add,DoublyLinkedList[T],DoublyLinkedNode[T]">add proc</a> for appending a node</li>
  859. <li><a class="reference external" href="#add,DoublyLinkedList[T],T">add proc</a> for appending a value</li>
  860. <li><a class="reference external" href="#prepend,DoublyLinkedList[T],DoublyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  861. <li><a class="reference external" href="#remove,DoublyLinkedList[T],DoublyLinkedNode[T]">remove proc</a> for removing a node</li>
  862. </ul>
  863. <p><strong class="examples_text">Example:</strong></p>
  864. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  865. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  866. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="DecNumber">8</span><span class="Punctuation">)</span>
  867. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  868. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L590" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  869. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L590" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  870. </dd>
  871. </div>
  872. <div id="prepend,DoublyLinkedRing[T],DoublyLinkedNode[T]">
  873. <dt><pre><span class="Keyword">proc</span> <a href="#prepend%2CDoublyLinkedRing%5BT%5D%2CDoublyLinkedNode%5BT%5D"><span class="Identifier">prepend</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#DoublyLinkedRing"><span class="Identifier">DoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">n</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span></pre></dt>
  874. <dd>
  875. <p>Prepends (adds to the beginning) a node <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  876. <p><strong>See also:</strong></p>
  877. <ul class="simple"><li><a class="reference external" href="#add,DoublyLinkedRing[T],DoublyLinkedNode[T]">add proc</a> for appending a node</li>
  878. <li><a class="reference external" href="#add,DoublyLinkedRing[T],T">add proc</a> for appending a value</li>
  879. <li><a class="reference external" href="#prepend,DoublyLinkedRing[T],T">prepend proc</a> for prepending a value</li>
  880. <li><a class="reference external" href="#remove,DoublyLinkedRing[T],DoublyLinkedNode[T]">remove proc</a> for removing a node</li>
  881. </ul>
  882. <p><strong class="examples_text">Example:</strong></p>
  883. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  884. <span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">newDoublyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  885. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  886. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  887. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L882" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  888. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L882" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  889. </dd>
  890. </div>
  891. <div id="prepend,DoublyLinkedRing[T],T">
  892. <dt><pre><span class="Keyword">proc</span> <a href="#prepend%2CDoublyLinkedRing%5BT%5D%2CT"><span class="Identifier">prepend</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#DoublyLinkedRing"><span class="Identifier">DoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  893. <dd>
  894. <p>Prepends (adds to the beginning) a value to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  895. <p><strong>See also:</strong></p>
  896. <ul class="simple"><li><a class="reference external" href="#add,DoublyLinkedRing[T],DoublyLinkedNode[T]">add proc</a> for appending a node</li>
  897. <li><a class="reference external" href="#add,DoublyLinkedRing[T],T">add proc</a> for appending a value</li>
  898. <li><a class="reference external" href="#prepend,DoublyLinkedRing[T],DoublyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  899. <li><a class="reference external" href="#remove,DoublyLinkedRing[T],DoublyLinkedNode[T]">remove proc</a> for removing a node</li>
  900. </ul>
  901. <p><strong class="examples_text">Example:</strong></p>
  902. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  903. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  904. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="DecNumber">8</span><span class="Punctuation">)</span>
  905. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  906. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L908" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  907. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L908" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  908. </dd>
  909. </div>
  910. <div id="prepend,SinglyLinkedList[T],SinglyLinkedNode[T]">
  911. <dt><pre><span class="Keyword">proc</span> <a href="#prepend%2CSinglyLinkedList%5BT%5D%2CSinglyLinkedNode%5BT%5D"><span class="Identifier">prepend</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">n</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span> {.<span class="Identifier">inline</span>.}</pre></dt>
  912. <dd>
  913. <p>Prepends (adds to the beginning) a node to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  914. <p><strong>See also:</strong></p>
  915. <ul class="simple"><li><a class="reference external" href="#add,SinglyLinkedList[T],SinglyLinkedNode[T]">add proc</a> for appending a node</li>
  916. <li><a class="reference external" href="#add,SinglyLinkedList[T],T">add proc</a> for appending a value</li>
  917. <li><a class="reference external" href="#prepend,SinglyLinkedList[T],T">prepend proc</a> for prepending a value</li>
  918. </ul>
  919. <p><strong class="examples_text">Example:</strong></p>
  920. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  921. <span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">newSinglyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  922. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  923. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  924. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L430" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  925. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L430" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  926. </dd>
  927. </div>
  928. <div id="prepend,SinglyLinkedList[T],T">
  929. <dt><pre><span class="Keyword">proc</span> <a href="#prepend%2CSinglyLinkedList%5BT%5D%2CT"><span class="Identifier">prepend</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span> {.<span class="Identifier">inline</span>.}</pre></dt>
  930. <dd>
  931. <p>Prepends (adds to the beginning) a node to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  932. <p><strong>See also:</strong></p>
  933. <ul class="simple"><li><a class="reference external" href="#add,SinglyLinkedList[T],SinglyLinkedNode[T]">add proc</a> for appending a node</li>
  934. <li><a class="reference external" href="#add,SinglyLinkedList[T],T">add proc</a> for appending a value</li>
  935. <li><a class="reference external" href="#prepend,SinglyLinkedList[T],SinglyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  936. </ul>
  937. <p><strong class="examples_text">Example:</strong></p>
  938. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  939. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  940. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="DecNumber">8</span><span class="Punctuation">)</span>
  941. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  942. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L449" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  943. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L449" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  944. </dd>
  945. </div>
  946. <div id="prepend,SinglyLinkedRing[T],SinglyLinkedNode[T]">
  947. <dt><pre><span class="Keyword">proc</span> <a href="#prepend%2CSinglyLinkedRing%5BT%5D%2CSinglyLinkedNode%5BT%5D"><span class="Identifier">prepend</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SinglyLinkedRing"><span class="Identifier">SinglyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">n</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span></pre></dt>
  948. <dd>
  949. <p>Prepends (adds to the beginning) a node <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  950. <p><strong>See also:</strong></p>
  951. <ul class="simple"><li><a class="reference external" href="#add,SinglyLinkedRing[T],SinglyLinkedNode[T]">add proc</a> for appending a node</li>
  952. <li><a class="reference external" href="#add,SinglyLinkedRing[T],T">add proc</a> for appending a value</li>
  953. <li><a class="reference external" href="#prepend,SinglyLinkedRing[T],T">prepend proc</a> for prepending a value</li>
  954. </ul>
  955. <p><strong class="examples_text">Example:</strong></p>
  956. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  957. <span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">newSinglyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  958. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  959. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  960. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L795" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  961. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L795" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  962. </dd>
  963. </div>
  964. <div id="prepend,SinglyLinkedRing[T],T">
  965. <dt><pre><span class="Keyword">proc</span> <a href="#prepend%2CSinglyLinkedRing%5BT%5D%2CT"><span class="Identifier">prepend</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SinglyLinkedRing"><span class="Identifier">SinglyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">value</span><span class="Other">:</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  966. <dd>
  967. <p>Prepends (adds to the beginning) a value to <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1).</p>
  968. <p><strong>See also:</strong></p>
  969. <ul class="simple"><li><a class="reference external" href="#add,SinglyLinkedRing[T],SinglyLinkedNode[T]">add proc</a> for appending a node</li>
  970. <li><a class="reference external" href="#add,SinglyLinkedRing[T],T">add proc</a> for appending a value</li>
  971. <li><a class="reference external" href="#prepend,SinglyLinkedRing[T],SinglyLinkedNode[T]">prepend proc</a> for prepending a node</li>
  972. </ul>
  973. <p><strong class="examples_text">Example:</strong></p>
  974. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  975. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span>
  976. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prepend</span><span class="Punctuation">(</span><span class="DecNumber">8</span><span class="Punctuation">)</span>
  977. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">contains</span><span class="Punctuation">(</span><span class="DecNumber">9</span><span class="Punctuation">)</span></pre>
  978. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L818" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  979. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L818" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  980. </dd>
  981. </div>
  982. </div>
  983. <div id="prependMoved-procs-all">
  984. <div id="prependMoved,T,T">
  985. <dt><pre><span class="Keyword">proc</span> <a href="#prependMoved%2CT%2CT"><span class="Identifier">prependMoved</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">:</span> <a href="lists.html#SomeLinkedList"><span class="Identifier">SomeLinkedList</span></a><span class="Other">]</span><span class="Other">(</span><span class="Identifier">a</span><span class="Other">,</span> <span class="Identifier">b</span><span class="Other">:</span> <span class="Keyword">var</span> <span class="Identifier">T</span><span class="Other">)</span></pre></dt>
  986. <dd>
  987. <p>Moves <tt class="docutils literal"><span class="pre"><span class="Identifier">b</span></span></tt> before the head of <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span></span></tt>. Efficiency: O(1). Note that <tt class="docutils literal"><span class="pre"><span class="Identifier">b</span></span></tt> becomes empty after the operation unless it has the same address as <tt class="docutils literal"><span class="pre"><span class="Identifier">a</span></span></tt>. Self-prepending results in a cycle.</p>
  988. <p><strong>See also:</strong></p>
  989. <ul class="simple"><li><a class="reference external" href="#prepend,T,T">prepend proc</a> for prepending a copy of a list</li>
  990. </ul>
  991. <p><strong class="examples_text">Example:</strong></p>
  992. <pre class="listing"><span class="Keyword">import</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Punctuation">[</span><span class="Identifier">sequtils</span><span class="Punctuation">,</span> <span class="Identifier">enumerate</span><span class="Punctuation">,</span> <span class="Identifier">sugar</span><span class="Punctuation">]</span>
  993. <span class="Keyword">var</span>
  994. <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  995. <span class="Identifier">b</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  996. <span class="Identifier">c</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  997. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">prependMoved</span><span class="Punctuation">(</span><span class="Identifier">b</span><span class="Punctuation">)</span>
  998. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span>
  999. <span class="Identifier">assert</span> <span class="Identifier">b</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="Punctuation">]</span>
  1000. <span class="Identifier">c</span><span class="Operator">.</span><span class="Identifier">prependMoved</span><span class="Punctuation">(</span><span class="Identifier">c</span><span class="Punctuation">)</span>
  1001. <span class="Keyword">let</span> <span class="Identifier">s</span> <span class="Operator">=</span> <span class="Identifier">collect</span><span class="Punctuation">:</span>
  1002. <span class="Keyword">for</span> <span class="Identifier">i</span><span class="Punctuation">,</span> <span class="Identifier">ci</span> <span class="Keyword">in</span> <span class="Identifier">enumerate</span><span class="Punctuation">(</span><span class="Identifier">c</span><span class="Punctuation">)</span><span class="Punctuation">:</span>
  1003. <span class="Keyword">if</span> <span class="Identifier">i</span> <span class="Operator">==</span> <span class="DecNumber">6</span><span class="Punctuation">:</span> <span class="Keyword">break</span>
  1004. <span class="Identifier">ci</span>
  1005. <span class="Identifier">assert</span> <span class="Identifier">s</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">]</span></pre>
  1006. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L366" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1007. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L366" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1008. </dd>
  1009. </div>
  1010. </div>
  1011. <div id="remove-procs-all">
  1012. <div id="remove,DoublyLinkedList[T],DoublyLinkedNode[T]">
  1013. <dt><pre><span class="Keyword">proc</span> <a href="#remove%2CDoublyLinkedList%5BT%5D%2CDoublyLinkedNode%5BT%5D"><span class="Identifier">remove</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">n</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span></pre></dt>
  1014. <dd>
  1015. Removes a node <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> from <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1). This function assumes, for the sake of efficiency, that <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> is contained in <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>, otherwise the effects are undefined. When the list is cyclic, the cycle is preserved after removal.
  1016. <p><strong class="examples_text">Example:</strong></p>
  1017. <pre class="listing"><span class="Keyword">import</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Punctuation">[</span><span class="Identifier">sequtils</span><span class="Punctuation">,</span> <span class="Identifier">enumerate</span><span class="Punctuation">,</span> <span class="Identifier">sugar</span><span class="Punctuation">]</span>
  1018. <span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  1019. <span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">head</span><span class="Operator">.</span><span class="Identifier">next</span>
  1020. <span class="Identifier">assert</span> <span class="Identifier">n</span><span class="Operator">.</span><span class="Identifier">value</span> <span class="Operator">==</span> <span class="DecNumber">1</span>
  1021. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">remove</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  1022. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">]</span>
  1023. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">remove</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  1024. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">]</span>
  1025. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">addMoved</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span> <span class="Comment"># cycle: [0, 2, 0, 2, ...]</span>
  1026. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">remove</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">head</span><span class="Punctuation">)</span>
  1027. <span class="Keyword">let</span> <span class="Identifier">s</span> <span class="Operator">=</span> <span class="Identifier">collect</span><span class="Punctuation">:</span>
  1028. <span class="Keyword">for</span> <span class="Identifier">i</span><span class="Punctuation">,</span> <span class="Identifier">ai</span> <span class="Keyword">in</span> <span class="Identifier">enumerate</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span><span class="Punctuation">:</span>
  1029. <span class="Keyword">if</span> <span class="Identifier">i</span> <span class="Operator">==</span> <span class="DecNumber">4</span><span class="Punctuation">:</span> <span class="Keyword">break</span>
  1030. <span class="Identifier">ai</span>
  1031. <span class="Identifier">assert</span> <span class="Identifier">s</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">]</span></pre>
  1032. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L726" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1033. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L726" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1034. </dd>
  1035. </div>
  1036. <div id="remove,DoublyLinkedRing[T],DoublyLinkedNode[T]">
  1037. <dt><pre><span class="Keyword">proc</span> <a href="#remove%2CDoublyLinkedRing%5BT%5D%2CDoublyLinkedNode%5BT%5D"><span class="Identifier">remove</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#DoublyLinkedRing"><span class="Identifier">DoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">n</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedNode"><span class="Identifier">DoublyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span></pre></dt>
  1038. <dd>
  1039. Removes <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> from <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(1). This function assumes, for the sake of efficiency, that <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> is contained in <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>, otherwise the effects are undefined.
  1040. <p><strong class="examples_text">Example:</strong></p>
  1041. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  1042. <span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">newDoublyLinkedNode</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="DecNumber">5</span><span class="Punctuation">)</span>
  1043. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  1044. <span class="Identifier">assert</span> <span class="DecNumber">5</span> <span class="Keyword">in</span> <span class="Identifier">a</span>
  1045. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">remove</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span>
  1046. <span class="Identifier">assert</span> <span class="DecNumber">5</span> <span class="Keyword">notin</span> <span class="Identifier">a</span></pre>
  1047. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L927" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1048. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L927" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1049. </dd>
  1050. </div>
  1051. <div id="remove,SinglyLinkedList[T],SinglyLinkedNode[T]">
  1052. <dt><pre><span class="Keyword">proc</span> <a href="#remove%2CSinglyLinkedList%5BT%5D%2CSinglyLinkedNode%5BT%5D"><span class="Identifier">remove</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">;</span> <span class="Identifier">n</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedNode"><span class="Identifier">SinglyLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <a href="system.html#bool"><span class="Identifier">bool</span></a> {.
  1053. <span class="Identifier">discardable</span>.}</pre></dt>
  1054. <dd>
  1055. Removes a node <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> from <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Returns <tt class="docutils literal"><span class="pre"><span class="Identifier">true</span></span></tt> if <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> was found in <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>. Efficiency: O(n); the list is traversed until <tt class="docutils literal"><span class="pre"><span class="Identifier">n</span></span></tt> is found. Attempting to remove an element not contained in the list is a no-op. When the list is cyclic, the cycle is preserved after removal.
  1056. <p><strong class="examples_text">Example:</strong></p>
  1057. <pre class="listing"><span class="Keyword">import</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Punctuation">[</span><span class="Identifier">sequtils</span><span class="Punctuation">,</span> <span class="Identifier">enumerate</span><span class="Punctuation">,</span> <span class="Identifier">sugar</span><span class="Punctuation">]</span>
  1058. <span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  1059. <span class="Keyword">let</span> <span class="Identifier">n</span> <span class="Operator">=</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">head</span><span class="Operator">.</span><span class="Identifier">next</span>
  1060. <span class="Identifier">assert</span> <span class="Identifier">n</span><span class="Operator">.</span><span class="Identifier">value</span> <span class="Operator">==</span> <span class="DecNumber">1</span>
  1061. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">remove</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span> <span class="Operator">==</span> <span class="Identifier">true</span>
  1062. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">]</span>
  1063. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">remove</span><span class="Punctuation">(</span><span class="Identifier">n</span><span class="Punctuation">)</span> <span class="Operator">==</span> <span class="Identifier">false</span>
  1064. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">0</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">]</span>
  1065. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">addMoved</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span> <span class="Comment"># cycle: [0, 2, 0, 2, ...]</span>
  1066. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">remove</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">head</span><span class="Punctuation">)</span>
  1067. <span class="Keyword">let</span> <span class="Identifier">s</span> <span class="Operator">=</span> <span class="Identifier">collect</span><span class="Punctuation">:</span>
  1068. <span class="Keyword">for</span> <span class="Identifier">i</span><span class="Punctuation">,</span> <span class="Identifier">ai</span> <span class="Keyword">in</span> <span class="Identifier">enumerate</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span><span class="Punctuation">:</span>
  1069. <span class="Keyword">if</span> <span class="Identifier">i</span> <span class="Operator">==</span> <span class="DecNumber">4</span><span class="Punctuation">:</span> <span class="Keyword">break</span>
  1070. <span class="Identifier">ai</span>
  1071. <span class="Identifier">assert</span> <span class="Identifier">s</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">]</span></pre>
  1072. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L688" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1073. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L688" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1074. </dd>
  1075. </div>
  1076. </div>
  1077. <div id="toDoublyLinkedList-procs-all">
  1078. <div id="toDoublyLinkedList,openArray[T]">
  1079. <dt><pre><span class="Keyword">func</span> <a href="#toDoublyLinkedList%2CopenArray%5BT%5D"><span class="Identifier">toDoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">elems</span><span class="Other">:</span> <a href="system.html#openArray"><span class="Identifier">openArray</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedList"><span class="Identifier">DoublyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  1080. <dd>
  1081. Creates a new <tt class="docutils literal"><span class="pre"><span class="Identifier">DoublyLinkedList</span></span></tt> from the members of <tt class="docutils literal"><span class="pre"><span class="Identifier">elems</span></span></tt>.
  1082. <p><strong class="examples_text">Example:</strong></p>
  1083. <pre class="listing"><span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sequtils</span> <span class="Keyword">import</span> <span class="Identifier">toSeq</span>
  1084. <span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toDoublyLinkedList</span>
  1085. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span></pre>
  1086. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L999" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1087. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L999" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1088. </dd>
  1089. </div>
  1090. </div>
  1091. <div id="toDoublyLinkedRing-procs-all">
  1092. <div id="toDoublyLinkedRing,openArray[T]">
  1093. <dt><pre><span class="Keyword">func</span> <a href="#toDoublyLinkedRing%2CopenArray%5BT%5D"><span class="Identifier">toDoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">elems</span><span class="Other">:</span> <a href="system.html#openArray"><span class="Identifier">openArray</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#DoublyLinkedRing"><span class="Identifier">DoublyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  1094. <dd>
  1095. Creates a new <tt class="docutils literal"><span class="pre"><span class="Identifier">DoublyLinkedRing</span></span></tt> from the members of <tt class="docutils literal"><span class="pre"><span class="Identifier">elems</span></span></tt>.
  1096. <p><strong class="examples_text">Example:</strong></p>
  1097. <pre class="listing"><span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sequtils</span> <span class="Keyword">import</span> <span class="Identifier">toSeq</span>
  1098. <span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toDoublyLinkedRing</span>
  1099. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span></pre>
  1100. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L1010" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1101. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L1010" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1102. </dd>
  1103. </div>
  1104. </div>
  1105. <div id="toSinglyLinkedList-procs-all">
  1106. <div id="toSinglyLinkedList,openArray[T]">
  1107. <dt><pre><span class="Keyword">func</span> <a href="#toSinglyLinkedList%2CopenArray%5BT%5D"><span class="Identifier">toSinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">elems</span><span class="Other">:</span> <a href="system.html#openArray"><span class="Identifier">openArray</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedList"><span class="Identifier">SinglyLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  1108. <dd>
  1109. Creates a new <tt class="docutils literal"><span class="pre"><span class="Identifier">SinglyLinkedList</span></span></tt> from the members of <tt class="docutils literal"><span class="pre"><span class="Identifier">elems</span></span></tt>.
  1110. <p><strong class="examples_text">Example:</strong></p>
  1111. <pre class="listing"><span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sequtils</span> <span class="Keyword">import</span> <span class="Identifier">toSeq</span>
  1112. <span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedList</span>
  1113. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span></pre>
  1114. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L977" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1115. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L977" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1116. </dd>
  1117. </div>
  1118. </div>
  1119. <div id="toSinglyLinkedRing-procs-all">
  1120. <div id="toSinglyLinkedRing,openArray[T]">
  1121. <dt><pre><span class="Keyword">func</span> <a href="#toSinglyLinkedRing%2CopenArray%5BT%5D"><span class="Identifier">toSinglyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">elems</span><span class="Other">:</span> <a href="system.html#openArray"><span class="Identifier">openArray</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#SinglyLinkedRing"><span class="Identifier">SinglyLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  1122. <dd>
  1123. Creates a new <tt class="docutils literal"><span class="pre"><span class="Identifier">SinglyLinkedRing</span></span></tt> from the members of <tt class="docutils literal"><span class="pre"><span class="Identifier">elems</span></span></tt>.
  1124. <p><strong class="examples_text">Example:</strong></p>
  1125. <pre class="listing"><span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sequtils</span> <span class="Keyword">import</span> <span class="Identifier">toSeq</span>
  1126. <span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span><span class="Operator">.</span><span class="Identifier">toSinglyLinkedRing</span>
  1127. <span class="Identifier">assert</span> <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">toSeq</span> <span class="Operator">==</span> <span class="Punctuation">[</span><span class="DecNumber">1</span><span class="Punctuation">,</span> <span class="DecNumber">2</span><span class="Punctuation">,</span> <span class="DecNumber">3</span><span class="Punctuation">,</span> <span class="DecNumber">4</span><span class="Punctuation">,</span> <span class="DecNumber">5</span><span class="Punctuation">]</span></pre>
  1128. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L988" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1129. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L988" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1130. </dd>
  1131. </div>
  1132. </div>
  1133. </dl>
  1134. </div>
  1135. <div class="section" id="15">
  1136. <h1><a class="toc-backref" href="#15">Iterators</a></h1>
  1137. <dl class="item">
  1138. <div id="items-iterators-all">
  1139. <div id="items.i,SomeLinkedList[T]">
  1140. <dt><pre><span class="Keyword">iterator</span> <a href="#items.i%2CSomeLinkedList%5BT%5D"><span class="Identifier">items</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <a href="lists.html#SomeLinkedList"><span class="Identifier">SomeLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <span class="Identifier">T</span></pre></dt>
  1141. <dd>
  1142. <p>Yields every value of <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>.</p>
  1143. <p><strong>See also:</strong></p>
  1144. <ul class="simple"><li><a class="reference external" href="#mitems.i,SomeLinkedList[T]">mitems iterator</a></li>
  1145. <li><a class="reference external" href="#nodes.i,SomeLinkedList[T]">nodes iterator</a></li>
  1146. </ul>
  1147. <p><strong class="examples_text">Example:</strong></p>
  1148. <pre class="listing"><span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sugar</span> <span class="Keyword">import</span> <span class="Identifier">collect</span>
  1149. <span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sequtils</span> <span class="Keyword">import</span> <span class="Identifier">toSeq</span>
  1150. <span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">collect</span><span class="Punctuation">(</span><span class="Identifier">initSinglyLinkedList</span><span class="Punctuation">)</span><span class="Punctuation">:</span>
  1151. <span class="Keyword">for</span> <span class="Identifier">i</span> <span class="Keyword">in</span> <span class="FloatNumber">1.</span><span class="Operator">.</span><span class="DecNumber">3</span><span class="Punctuation">:</span> <span class="DecNumber">10</span> <span class="Operator">*</span> <span class="Identifier">i</span>
  1152. <span class="Identifier">assert</span> <span class="Identifier">toSeq</span><span class="Punctuation">(</span><span class="Identifier">items</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span><span class="Punctuation">)</span> <span class="Operator">==</span> <span class="Identifier">toSeq</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span>
  1153. <span class="Identifier">assert</span> <span class="Identifier">toSeq</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span> <span class="Operator">==</span> <span class="Operator">@</span><span class="Punctuation">[</span><span class="DecNumber">10</span><span class="Punctuation">,</span> <span class="DecNumber">20</span><span class="Punctuation">,</span> <span class="DecNumber">30</span><span class="Punctuation">]</span></pre>
  1154. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L182" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1155. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L182" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1156. </dd>
  1157. </div>
  1158. <div id="items.i,SomeLinkedRing[T]">
  1159. <dt><pre><span class="Keyword">iterator</span> <a href="#items.i%2CSomeLinkedRing%5BT%5D"><span class="Identifier">items</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <a href="lists.html#SomeLinkedRing"><span class="Identifier">SomeLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <span class="Identifier">T</span></pre></dt>
  1160. <dd>
  1161. <p>Yields every value of <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt>.</p>
  1162. <p><strong>See also:</strong></p>
  1163. <ul class="simple"><li><a class="reference external" href="#mitems.i,SomeLinkedRing[T]">mitems iterator</a></li>
  1164. <li><a class="reference external" href="#nodes.i,SomeLinkedRing[T]">nodes iterator</a></li>
  1165. </ul>
  1166. <p><strong class="examples_text">Example:</strong></p>
  1167. <pre class="listing"><span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sugar</span> <span class="Keyword">import</span> <span class="Identifier">collect</span>
  1168. <span class="Keyword">from</span> <span class="Identifier">std</span><span class="Operator">/</span><span class="Identifier">sequtils</span> <span class="Keyword">import</span> <span class="Identifier">toSeq</span>
  1169. <span class="Keyword">let</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">collect</span><span class="Punctuation">(</span><span class="Identifier">initSinglyLinkedRing</span><span class="Punctuation">)</span><span class="Punctuation">:</span>
  1170. <span class="Keyword">for</span> <span class="Identifier">i</span> <span class="Keyword">in</span> <span class="FloatNumber">1.</span><span class="Operator">.</span><span class="DecNumber">3</span><span class="Punctuation">:</span> <span class="DecNumber">10</span> <span class="Operator">*</span> <span class="Identifier">i</span>
  1171. <span class="Identifier">assert</span> <span class="Identifier">toSeq</span><span class="Punctuation">(</span><span class="Identifier">items</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span><span class="Punctuation">)</span> <span class="Operator">==</span> <span class="Identifier">toSeq</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span>
  1172. <span class="Identifier">assert</span> <span class="Identifier">toSeq</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span> <span class="Operator">==</span> <span class="Operator">@</span><span class="Punctuation">[</span><span class="DecNumber">10</span><span class="Punctuation">,</span> <span class="DecNumber">20</span><span class="Punctuation">,</span> <span class="DecNumber">30</span><span class="Punctuation">]</span></pre>
  1173. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L198" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1174. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L198" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1175. </dd>
  1176. </div>
  1177. </div>
  1178. <div id="mitems-iterators-all">
  1179. <div id="mitems.i,SomeLinkedList[T]">
  1180. <dt><pre><span class="Keyword">iterator</span> <a href="#mitems.i%2CSomeLinkedList%5BT%5D"><span class="Identifier">mitems</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SomeLinkedList"><span class="Identifier">SomeLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <span class="Keyword">var</span> <span class="Identifier">T</span></pre></dt>
  1181. <dd>
  1182. <p>Yields every value of <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt> so that you can modify it.</p>
  1183. <p><strong>See also:</strong></p>
  1184. <ul class="simple"><li><a class="reference external" href="#items.i,SomeLinkedList[T]">items iterator</a></li>
  1185. <li><a class="reference external" href="#nodes.i,SomeLinkedList[T]">nodes iterator</a></li>
  1186. </ul>
  1187. <p><strong class="examples_text">Example:</strong></p>
  1188. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  1189. <span class="Keyword">for</span> <span class="Identifier">i</span> <span class="Keyword">in</span> <span class="FloatNumber">1.</span><span class="Operator">.</span><span class="DecNumber">5</span><span class="Punctuation">:</span>
  1190. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">10</span> <span class="Operator">*</span> <span class="Identifier">i</span><span class="Punctuation">)</span>
  1191. <span class="Identifier">assert</span> <span class="Operator">$</span><span class="Identifier">a</span> <span class="Operator">==</span> <span class="StringLit">&quot;[10, 20, 30, 40, 50]&quot;</span>
  1192. <span class="Keyword">for</span> <span class="Identifier">x</span> <span class="Keyword">in</span> <span class="Identifier">mitems</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span><span class="Punctuation">:</span>
  1193. <span class="Identifier">x</span> <span class="Operator">=</span> <span class="DecNumber">5</span> <span class="Operator">*</span> <span class="Identifier">x</span> <span class="Operator">-</span> <span class="DecNumber">1</span>
  1194. <span class="Identifier">assert</span> <span class="Operator">$</span><span class="Identifier">a</span> <span class="Operator">==</span> <span class="StringLit">&quot;[49, 99, 149, 199, 249]&quot;</span></pre>
  1195. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L214" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1196. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L214" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1197. </dd>
  1198. </div>
  1199. <div id="mitems.i,SomeLinkedRing[T]">
  1200. <dt><pre><span class="Keyword">iterator</span> <a href="#mitems.i%2CSomeLinkedRing%5BT%5D"><span class="Identifier">mitems</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <span class="Keyword">var</span> <a href="lists.html#SomeLinkedRing"><span class="Identifier">SomeLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <span class="Keyword">var</span> <span class="Identifier">T</span></pre></dt>
  1201. <dd>
  1202. <p>Yields every value of <tt class="docutils literal"><span class="pre"><span class="Identifier">L</span></span></tt> so that you can modify it.</p>
  1203. <p><strong>See also:</strong></p>
  1204. <ul class="simple"><li><a class="reference external" href="#items.i,SomeLinkedRing[T]">items iterator</a></li>
  1205. <li><a class="reference external" href="#nodes.i,SomeLinkedRing[T]">nodes iterator</a></li>
  1206. </ul>
  1207. <p><strong class="examples_text">Example:</strong></p>
  1208. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initSinglyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  1209. <span class="Keyword">for</span> <span class="Identifier">i</span> <span class="Keyword">in</span> <span class="FloatNumber">1.</span><span class="Operator">.</span><span class="DecNumber">5</span><span class="Punctuation">:</span>
  1210. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">10</span> <span class="Operator">*</span> <span class="Identifier">i</span><span class="Punctuation">)</span>
  1211. <span class="Identifier">assert</span> <span class="Operator">$</span><span class="Identifier">a</span> <span class="Operator">==</span> <span class="StringLit">&quot;[10, 20, 30, 40, 50]&quot;</span>
  1212. <span class="Keyword">for</span> <span class="Identifier">x</span> <span class="Keyword">in</span> <span class="Identifier">mitems</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span><span class="Punctuation">:</span>
  1213. <span class="Identifier">x</span> <span class="Operator">=</span> <span class="DecNumber">5</span> <span class="Operator">*</span> <span class="Identifier">x</span> <span class="Operator">-</span> <span class="DecNumber">1</span>
  1214. <span class="Identifier">assert</span> <span class="Operator">$</span><span class="Identifier">a</span> <span class="Operator">==</span> <span class="StringLit">&quot;[49, 99, 149, 199, 249]&quot;</span></pre>
  1215. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L231" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1216. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L231" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1217. </dd>
  1218. </div>
  1219. </div>
  1220. <div id="nodes-iterators-all">
  1221. <div id="nodes.i,SomeLinkedList[T]">
  1222. <dt><pre><span class="Keyword">iterator</span> <a href="#nodes.i%2CSomeLinkedList%5BT%5D"><span class="Identifier">nodes</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <a href="lists.html#SomeLinkedList"><span class="Identifier">SomeLinkedList</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#SomeLinkedNode"><span class="Identifier">SomeLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  1223. <dd>
  1224. <p>Iterates over every node of <tt class="docutils literal"><span class="pre"><span class="Identifier">x</span></span></tt>. Removing the current node from the list during traversal is supported.</p>
  1225. <p><strong>See also:</strong></p>
  1226. <ul class="simple"><li><a class="reference external" href="#items.i,SomeLinkedList[T]">items iterator</a></li>
  1227. <li><a class="reference external" href="#mitems.i,SomeLinkedList[T]">mitems iterator</a></li>
  1228. </ul>
  1229. <p><strong class="examples_text">Example:</strong></p>
  1230. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedList</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  1231. <span class="Keyword">for</span> <span class="Identifier">i</span> <span class="Keyword">in</span> <span class="FloatNumber">1.</span><span class="Operator">.</span><span class="DecNumber">5</span><span class="Punctuation">:</span>
  1232. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">10</span> <span class="Operator">*</span> <span class="Identifier">i</span><span class="Punctuation">)</span>
  1233. <span class="Identifier">assert</span> <span class="Operator">$</span><span class="Identifier">a</span> <span class="Operator">==</span> <span class="StringLit">&quot;[10, 20, 30, 40, 50]&quot;</span>
  1234. <span class="Keyword">for</span> <span class="Identifier">x</span> <span class="Keyword">in</span> <span class="Identifier">nodes</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span><span class="Punctuation">:</span>
  1235. <span class="Keyword">if</span> <span class="Identifier">x</span><span class="Operator">.</span><span class="Identifier">value</span> <span class="Operator">==</span> <span class="DecNumber">30</span><span class="Punctuation">:</span>
  1236. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">remove</span><span class="Punctuation">(</span><span class="Identifier">x</span><span class="Punctuation">)</span>
  1237. <span class="Keyword">else</span><span class="Punctuation">:</span>
  1238. <span class="Identifier">x</span><span class="Operator">.</span><span class="Identifier">value</span> <span class="Operator">=</span> <span class="DecNumber">5</span> <span class="Operator">*</span> <span class="Identifier">x</span><span class="Operator">.</span><span class="Identifier">value</span> <span class="Operator">-</span> <span class="DecNumber">1</span>
  1239. <span class="Identifier">assert</span> <span class="Operator">$</span><span class="Identifier">a</span> <span class="Operator">==</span> <span class="StringLit">&quot;[49, 99, 199, 249]&quot;</span></pre>
  1240. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L248" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1241. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L248" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1242. </dd>
  1243. </div>
  1244. <div id="nodes.i,SomeLinkedRing[T]">
  1245. <dt><pre><span class="Keyword">iterator</span> <a href="#nodes.i%2CSomeLinkedRing%5BT%5D"><span class="Identifier">nodes</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">(</span><span class="Identifier">L</span><span class="Other">:</span> <a href="lists.html#SomeLinkedRing"><span class="Identifier">SomeLinkedRing</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span><span class="Other">)</span><span class="Other">:</span> <a href="lists.html#SomeLinkedNode"><span class="Identifier">SomeLinkedNode</span></a><span class="Other">[</span><span class="Identifier">T</span><span class="Other">]</span></pre></dt>
  1246. <dd>
  1247. <p>Iterates over every node of <tt class="docutils literal"><span class="pre"><span class="Identifier">x</span></span></tt>. Removing the current node from the list during traversal is supported.</p>
  1248. <p><strong>See also:</strong></p>
  1249. <ul class="simple"><li><a class="reference external" href="#items.i,SomeLinkedRing[T]">items iterator</a></li>
  1250. <li><a class="reference external" href="#mitems.i,SomeLinkedRing[T]">mitems iterator</a></li>
  1251. </ul>
  1252. <p><strong class="examples_text">Example:</strong></p>
  1253. <pre class="listing"><span class="Keyword">var</span> <span class="Identifier">a</span> <span class="Operator">=</span> <span class="Identifier">initDoublyLinkedRing</span><span class="Punctuation">[</span><span class="Identifier">int</span><span class="Punctuation">]</span><span class="Punctuation">(</span><span class="Punctuation">)</span>
  1254. <span class="Keyword">for</span> <span class="Identifier">i</span> <span class="Keyword">in</span> <span class="FloatNumber">1.</span><span class="Operator">.</span><span class="DecNumber">5</span><span class="Punctuation">:</span>
  1255. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">add</span><span class="Punctuation">(</span><span class="DecNumber">10</span> <span class="Operator">*</span> <span class="Identifier">i</span><span class="Punctuation">)</span>
  1256. <span class="Identifier">assert</span> <span class="Operator">$</span><span class="Identifier">a</span> <span class="Operator">==</span> <span class="StringLit">&quot;[10, 20, 30, 40, 50]&quot;</span>
  1257. <span class="Keyword">for</span> <span class="Identifier">x</span> <span class="Keyword">in</span> <span class="Identifier">nodes</span><span class="Punctuation">(</span><span class="Identifier">a</span><span class="Punctuation">)</span><span class="Punctuation">:</span>
  1258. <span class="Keyword">if</span> <span class="Identifier">x</span><span class="Operator">.</span><span class="Identifier">value</span> <span class="Operator">==</span> <span class="DecNumber">30</span><span class="Punctuation">:</span>
  1259. <span class="Identifier">a</span><span class="Operator">.</span><span class="Identifier">remove</span><span class="Punctuation">(</span><span class="Identifier">x</span><span class="Punctuation">)</span>
  1260. <span class="Keyword">else</span><span class="Punctuation">:</span>
  1261. <span class="Identifier">x</span><span class="Operator">.</span><span class="Identifier">value</span> <span class="Operator">=</span> <span class="DecNumber">5</span> <span class="Operator">*</span> <span class="Identifier">x</span><span class="Operator">.</span><span class="Identifier">value</span> <span class="Operator">-</span> <span class="DecNumber">1</span>
  1262. <span class="Identifier">assert</span> <span class="Operator">$</span><span class="Identifier">a</span> <span class="Operator">==</span> <span class="StringLit">&quot;[49, 99, 199, 249]&quot;</span></pre>
  1263. <a href="https://github.com/nim-lang/Nim/tree/devel/lib/pure/collections/lists.nim#L273" class="link-seesrc" target="_blank">Source</a>&nbsp;&nbsp;
  1264. <a href="https://github.com/nim-lang/Nim/edit/devel/lib/pure/collections/lists.nim#L273" class="link-seesrc" target="_blank" >Edit</a>&nbsp;&nbsp;
  1265. </dd>
  1266. </div>
  1267. </div>
  1268. </dl>
  1269. </div>
  1270. </div>
  1271. </div>
  1272. <div class="twelve-columns footer">
  1273. <span class="nim-sprite"></span>
  1274. <br>
  1275. <small style="color: var(--hint);">Made with Nim. Generated: 2025-02-03 14:57:16 UTC</small>
  1276. </div>
  1277. </div>
  1278. </div>
  1279. <script defer data-domain="nim-lang.org" src="https://plausible.io/js/plausible.js"></script>
  1280. </body>
  1281. </html>