@fncts/base 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1681) hide show
  1. package/_cjs/collection/Iterable/api/traverseConc.cjs +43 -0
  2. package/_cjs/collection/Iterable/api/traverseConc.cjs.map +1 -0
  3. package/_cjs/collection/Iterable/api.cjs +857 -0
  4. package/_cjs/collection/Iterable/api.cjs.map +1 -0
  5. package/_cjs/collection/Iterable/constructors.cjs +114 -0
  6. package/_cjs/collection/Iterable/constructors.cjs.map +1 -0
  7. package/_cjs/collection/Iterable/definition.cjs +9 -0
  8. package/_cjs/collection/Iterable/definition.cjs.map +1 -0
  9. package/_cjs/collection/Iterable.cjs +45 -0
  10. package/_cjs/collection/Iterable.cjs.map +1 -0
  11. package/_cjs/collection/compat/Array/api.cjs +72 -0
  12. package/_cjs/collection/compat/Array/api.cjs.map +1 -0
  13. package/_cjs/collection/compat/Array/definition.cjs +9 -0
  14. package/_cjs/collection/compat/Array/definition.cjs.map +1 -0
  15. package/_cjs/collection/compat/Array.cjs +32 -0
  16. package/_cjs/collection/compat/Array.cjs.map +1 -0
  17. package/_cjs/collection/compat/ArrayLike/api.cjs +51 -0
  18. package/_cjs/collection/compat/ArrayLike/api.cjs.map +1 -0
  19. package/_cjs/collection/compat/ArrayLike/definition.cjs +6 -0
  20. package/_cjs/collection/compat/ArrayLike/definition.cjs.map +1 -0
  21. package/_cjs/collection/immutable/Conc/api/empty.cjs +16 -0
  22. package/_cjs/collection/immutable/Conc/api/empty.cjs.map +1 -0
  23. package/_cjs/collection/immutable/Conc/api/makeBy.cjs +34 -0
  24. package/_cjs/collection/immutable/Conc/api/makeBy.cjs.map +1 -0
  25. package/_cjs/collection/immutable/Conc/api/replicate.cjs +20 -0
  26. package/_cjs/collection/immutable/Conc/api/replicate.cjs.map +1 -0
  27. package/_cjs/collection/immutable/Conc/api.cjs +1493 -0
  28. package/_cjs/collection/immutable/Conc/api.cjs.map +1 -0
  29. package/_cjs/collection/immutable/Conc/constructors.cjs +61 -0
  30. package/_cjs/collection/immutable/Conc/constructors.cjs.map +1 -0
  31. package/_cjs/collection/immutable/Conc/definition.cjs +852 -0
  32. package/_cjs/collection/immutable/Conc/definition.cjs.map +1 -0
  33. package/_cjs/collection/immutable/Conc.cjs +84 -0
  34. package/_cjs/collection/immutable/Conc.cjs.map +1 -0
  35. package/_cjs/collection/immutable/Dictionary/api.cjs +84 -0
  36. package/_cjs/collection/immutable/Dictionary/api.cjs.map +1 -0
  37. package/_cjs/collection/immutable/Dictionary/definition.cjs +16 -0
  38. package/_cjs/collection/immutable/Dictionary/definition.cjs.map +1 -0
  39. package/_cjs/collection/immutable/HashMap/api.cjs +873 -0
  40. package/_cjs/collection/immutable/HashMap/api.cjs.map +1 -0
  41. package/_cjs/collection/immutable/HashMap/definition.cjs +135 -0
  42. package/_cjs/collection/immutable/HashMap/definition.cjs.map +1 -0
  43. package/_cjs/collection/immutable/HashMap/internal.cjs +403 -0
  44. package/_cjs/collection/immutable/HashMap/internal.cjs.map +1 -0
  45. package/_cjs/collection/immutable/HashMap.cjs +32 -0
  46. package/_cjs/collection/immutable/HashMap.cjs.map +1 -0
  47. package/_cjs/collection/immutable/HashSet/api.cjs +590 -0
  48. package/_cjs/collection/immutable/HashSet/api.cjs.map +1 -0
  49. package/_cjs/collection/immutable/HashSet/definition.cjs +412 -0
  50. package/_cjs/collection/immutable/HashSet/definition.cjs.map +1 -0
  51. package/_cjs/collection/immutable/HashSet.cjs +32 -0
  52. package/_cjs/collection/immutable/HashSet.cjs.map +1 -0
  53. package/_cjs/collection/immutable/ImmutableArray/api.cjs +1807 -0
  54. package/_cjs/collection/immutable/ImmutableArray/api.cjs.map +1 -0
  55. package/_cjs/collection/immutable/ImmutableArray/constructors.cjs +79 -0
  56. package/_cjs/collection/immutable/ImmutableArray/constructors.cjs.map +1 -0
  57. package/_cjs/collection/immutable/ImmutableArray/definition.cjs +56 -0
  58. package/_cjs/collection/immutable/ImmutableArray/definition.cjs.map +1 -0
  59. package/_cjs/collection/immutable/ImmutableArray/instances.cjs +187 -0
  60. package/_cjs/collection/immutable/ImmutableArray/instances.cjs.map +1 -0
  61. package/_cjs/collection/immutable/ImmutableArray.cjs +58 -0
  62. package/_cjs/collection/immutable/ImmutableArray.cjs.map +1 -0
  63. package/_cjs/collection/immutable/ImmutableNonEmptyArray/api.cjs +634 -0
  64. package/_cjs/collection/immutable/ImmutableNonEmptyArray/api.cjs.map +1 -0
  65. package/_cjs/collection/immutable/ImmutableNonEmptyArray/constructors.cjs +105 -0
  66. package/_cjs/collection/immutable/ImmutableNonEmptyArray/constructors.cjs.map +1 -0
  67. package/_cjs/collection/immutable/ImmutableNonEmptyArray/definition.cjs +27 -0
  68. package/_cjs/collection/immutable/ImmutableNonEmptyArray/definition.cjs.map +1 -0
  69. package/_cjs/collection/immutable/ImmutableNonEmptyArray/destructors.cjs +72 -0
  70. package/_cjs/collection/immutable/ImmutableNonEmptyArray/destructors.cjs.map +1 -0
  71. package/_cjs/collection/immutable/ImmutableNonEmptyArray/instances.cjs +143 -0
  72. package/_cjs/collection/immutable/ImmutableNonEmptyArray/instances.cjs.map +1 -0
  73. package/_cjs/collection/immutable/ImmutableNonEmptyArray.cjs +71 -0
  74. package/_cjs/collection/immutable/ImmutableNonEmptyArray.cjs.map +1 -0
  75. package/_cjs/collection/immutable/List/api/foldLeft.cjs +28 -0
  76. package/_cjs/collection/immutable/List/api/foldLeft.cjs.map +1 -0
  77. package/_cjs/collection/immutable/List/api/unsafeTail.cjs +26 -0
  78. package/_cjs/collection/immutable/List/api/unsafeTail.cjs.map +1 -0
  79. package/_cjs/collection/immutable/List/api.cjs +443 -0
  80. package/_cjs/collection/immutable/List/api.cjs.map +1 -0
  81. package/_cjs/collection/immutable/List/constructors.cjs +92 -0
  82. package/_cjs/collection/immutable/List/constructors.cjs.map +1 -0
  83. package/_cjs/collection/immutable/List/definition.cjs +125 -0
  84. package/_cjs/collection/immutable/List/definition.cjs.map +1 -0
  85. package/_cjs/collection/immutable/List.cjs +71 -0
  86. package/_cjs/collection/immutable/List.cjs.map +1 -0
  87. package/_cjs/collection/immutable/Queue/api.cjs +210 -0
  88. package/_cjs/collection/immutable/Queue/api.cjs.map +1 -0
  89. package/_cjs/collection/immutable/Queue/constructors.cjs +33 -0
  90. package/_cjs/collection/immutable/Queue/constructors.cjs.map +1 -0
  91. package/_cjs/collection/immutable/Queue/definition.cjs +53 -0
  92. package/_cjs/collection/immutable/Queue/definition.cjs.map +1 -0
  93. package/_cjs/collection/immutable/Queue/guards.cjs +20 -0
  94. package/_cjs/collection/immutable/Queue/guards.cjs.map +1 -0
  95. package/_cjs/collection/immutable/Queue.cjs +58 -0
  96. package/_cjs/collection/immutable/Queue.cjs.map +1 -0
  97. package/_cjs/collection/immutable/SortedMap/api.cjs +691 -0
  98. package/_cjs/collection/immutable/SortedMap/api.cjs.map +1 -0
  99. package/_cjs/collection/immutable/SortedMap/definition.cjs +27 -0
  100. package/_cjs/collection/immutable/SortedMap/definition.cjs.map +1 -0
  101. package/_cjs/collection/immutable/SortedMap/internal.cjs +530 -0
  102. package/_cjs/collection/immutable/SortedMap/internal.cjs.map +1 -0
  103. package/_cjs/collection/immutable/SortedMap/iterator.cjs +394 -0
  104. package/_cjs/collection/immutable/SortedMap/iterator.cjs.map +1 -0
  105. package/_cjs/collection/immutable/SortedMap/node.cjs +23 -0
  106. package/_cjs/collection/immutable/SortedMap/node.cjs.map +1 -0
  107. package/_cjs/collection/immutable/SortedMap.cjs +71 -0
  108. package/_cjs/collection/immutable/SortedMap.cjs.map +1 -0
  109. package/_cjs/collection/immutable/Vector/api.cjs +1525 -0
  110. package/_cjs/collection/immutable/Vector/api.cjs.map +1 -0
  111. package/_cjs/collection/immutable/Vector/definition.cjs +105 -0
  112. package/_cjs/collection/immutable/Vector/definition.cjs.map +1 -0
  113. package/_cjs/collection/immutable/Vector/internal.cjs +1665 -0
  114. package/_cjs/collection/immutable/Vector/internal.cjs.map +1 -0
  115. package/_cjs/collection/immutable/Vector.cjs +32 -0
  116. package/_cjs/collection/immutable/Vector.cjs.map +1 -0
  117. package/_cjs/collection/mutable/HashMap.cjs +390 -0
  118. package/_cjs/collection/mutable/HashMap.cjs.map +1 -0
  119. package/_cjs/collection/mutable/HashSet.cjs +308 -0
  120. package/_cjs/collection/mutable/HashSet.cjs.map +1 -0
  121. package/_cjs/collection/mutable/ListBuffer.cjs +156 -0
  122. package/_cjs/collection/mutable/ListBuffer.cjs.map +1 -0
  123. package/_cjs/collection/mutable/internal.cjs +39 -0
  124. package/_cjs/collection/mutable/internal.cjs.map +1 -0
  125. package/_cjs/control/Eval/api/sequenceArray.cjs +22 -0
  126. package/_cjs/control/Eval/api/sequenceArray.cjs.map +1 -0
  127. package/_cjs/control/Eval/api.cjs +148 -0
  128. package/_cjs/control/Eval/api.cjs.map +1 -0
  129. package/_cjs/control/Eval/constructors.cjs +49 -0
  130. package/_cjs/control/Eval/constructors.cjs.map +1 -0
  131. package/_cjs/control/Eval/definition.cjs +68 -0
  132. package/_cjs/control/Eval/definition.cjs.map +1 -0
  133. package/_cjs/control/Eval/instance.cjs +52 -0
  134. package/_cjs/control/Eval/instance.cjs.map +1 -0
  135. package/_cjs/control/Eval/run.cjs +72 -0
  136. package/_cjs/control/Eval/run.cjs.map +1 -0
  137. package/_cjs/control/Eval.cjs +71 -0
  138. package/_cjs/control/Eval.cjs.map +1 -0
  139. package/_cjs/control/LazyValue.cjs +38 -0
  140. package/_cjs/control/LazyValue.cjs.map +1 -0
  141. package/_cjs/control/Z/api.cjs +667 -0
  142. package/_cjs/control/Z/api.cjs.map +1 -0
  143. package/_cjs/control/Z/definition.cjs +227 -0
  144. package/_cjs/control/Z/definition.cjs.map +1 -0
  145. package/_cjs/control/Z/instances.cjs +28 -0
  146. package/_cjs/control/Z/instances.cjs.map +1 -0
  147. package/_cjs/control/Z/runtime.cjs +387 -0
  148. package/_cjs/control/Z/runtime.cjs.map +1 -0
  149. package/_cjs/control/Z.cjs +58 -0
  150. package/_cjs/control/Z.cjs.map +1 -0
  151. package/_cjs/data/Byte.cjs +6 -0
  152. package/_cjs/data/Byte.cjs.map +1 -0
  153. package/_cjs/data/CaseClass.cjs +127 -0
  154. package/_cjs/data/CaseClass.cjs.map +1 -0
  155. package/_cjs/data/Cause/api/fold.cjs +191 -0
  156. package/_cjs/data/Cause/api/fold.cjs.map +1 -0
  157. package/_cjs/data/Cause/api/isEmpty.cjs +83 -0
  158. package/_cjs/data/Cause/api/isEmpty.cjs.map +1 -0
  159. package/_cjs/data/Cause/api/linearize.cjs +32 -0
  160. package/_cjs/data/Cause/api/linearize.cjs.map +1 -0
  161. package/_cjs/data/Cause/api/prettyPrint.cjs +51 -0
  162. package/_cjs/data/Cause/api/prettyPrint.cjs.map +1 -0
  163. package/_cjs/data/Cause/api/unified.cjs +168 -0
  164. package/_cjs/data/Cause/api/unified.cjs.map +1 -0
  165. package/_cjs/data/Cause/api.cjs +1406 -0
  166. package/_cjs/data/Cause/api.cjs.map +1 -0
  167. package/_cjs/data/Cause/definition.cjs +670 -0
  168. package/_cjs/data/Cause/definition.cjs.map +1 -0
  169. package/_cjs/data/Cause.cjs +32 -0
  170. package/_cjs/data/Cause.cjs.map +1 -0
  171. package/_cjs/data/Const/api.cjs +30 -0
  172. package/_cjs/data/Const/api.cjs.map +1 -0
  173. package/_cjs/data/Const/definition.cjs +9 -0
  174. package/_cjs/data/Const/definition.cjs.map +1 -0
  175. package/_cjs/data/Const/instances.cjs +50 -0
  176. package/_cjs/data/Const/instances.cjs.map +1 -0
  177. package/_cjs/data/Const.cjs +45 -0
  178. package/_cjs/data/Const.cjs.map +1 -0
  179. package/_cjs/data/Duration/api.cjs +97 -0
  180. package/_cjs/data/Duration/api.cjs.map +1 -0
  181. package/_cjs/data/Duration/definition.cjs +50 -0
  182. package/_cjs/data/Duration/definition.cjs.map +1 -0
  183. package/_cjs/data/Duration.cjs +32 -0
  184. package/_cjs/data/Duration.cjs.map +1 -0
  185. package/_cjs/data/Either/api/align.cjs +19 -0
  186. package/_cjs/data/Either/api/align.cjs.map +1 -0
  187. package/_cjs/data/Either/api/alignWith.cjs +28 -0
  188. package/_cjs/data/Either/api/alignWith.cjs.map +1 -0
  189. package/_cjs/data/Either/api.cjs +343 -0
  190. package/_cjs/data/Either/api.cjs.map +1 -0
  191. package/_cjs/data/Either/constructors.cjs +95 -0
  192. package/_cjs/data/Either/constructors.cjs.map +1 -0
  193. package/_cjs/data/Either/definition.cjs +56 -0
  194. package/_cjs/data/Either/definition.cjs.map +1 -0
  195. package/_cjs/data/Either/destructors.cjs +24 -0
  196. package/_cjs/data/Either/destructors.cjs.map +1 -0
  197. package/_cjs/data/Either/instances.cjs +85 -0
  198. package/_cjs/data/Either/instances.cjs.map +1 -0
  199. package/_cjs/data/Either.cjs +71 -0
  200. package/_cjs/data/Either.cjs.map +1 -0
  201. package/_cjs/data/Environment/api.cjs +116 -0
  202. package/_cjs/data/Environment/api.cjs.map +1 -0
  203. package/_cjs/data/Environment/definition.cjs +60 -0
  204. package/_cjs/data/Environment/definition.cjs.map +1 -0
  205. package/_cjs/data/Environment.cjs +32 -0
  206. package/_cjs/data/Environment.cjs.map +1 -0
  207. package/_cjs/data/ExecutionStrategy.cjs +73 -0
  208. package/_cjs/data/ExecutionStrategy.cjs.map +1 -0
  209. package/_cjs/data/Exit/api.cjs +259 -0
  210. package/_cjs/data/Exit/api.cjs.map +1 -0
  211. package/_cjs/data/Exit/constructors.cjs +93 -0
  212. package/_cjs/data/Exit/constructors.cjs.map +1 -0
  213. package/_cjs/data/Exit/definition.cjs +139 -0
  214. package/_cjs/data/Exit/definition.cjs.map +1 -0
  215. package/_cjs/data/Exit.cjs +45 -0
  216. package/_cjs/data/Exit.cjs.map +1 -0
  217. package/_cjs/data/FiberId/api.cjs +72 -0
  218. package/_cjs/data/FiberId/api.cjs.map +1 -0
  219. package/_cjs/data/FiberId/constructors.cjs +41 -0
  220. package/_cjs/data/FiberId/constructors.cjs.map +1 -0
  221. package/_cjs/data/FiberId/definition.cjs +130 -0
  222. package/_cjs/data/FiberId/definition.cjs.map +1 -0
  223. package/_cjs/data/FiberId.cjs +45 -0
  224. package/_cjs/data/FiberId.cjs.map +1 -0
  225. package/_cjs/data/Identity/api.cjs +42 -0
  226. package/_cjs/data/Identity/api.cjs.map +1 -0
  227. package/_cjs/data/Identity/definition.cjs +9 -0
  228. package/_cjs/data/Identity/definition.cjs.map +1 -0
  229. package/_cjs/data/Identity/instances.cjs +50 -0
  230. package/_cjs/data/Identity/instances.cjs.map +1 -0
  231. package/_cjs/data/Identity.cjs +45 -0
  232. package/_cjs/data/Identity.cjs.map +1 -0
  233. package/_cjs/data/Maybe/api.cjs +265 -0
  234. package/_cjs/data/Maybe/api.cjs.map +1 -0
  235. package/_cjs/data/Maybe/constructors.cjs +117 -0
  236. package/_cjs/data/Maybe/constructors.cjs.map +1 -0
  237. package/_cjs/data/Maybe/definition.cjs +128 -0
  238. package/_cjs/data/Maybe/definition.cjs.map +1 -0
  239. package/_cjs/data/Maybe/destructors.cjs +19 -0
  240. package/_cjs/data/Maybe/destructors.cjs.map +1 -0
  241. package/_cjs/data/Maybe/instances.cjs +68 -0
  242. package/_cjs/data/Maybe/instances.cjs.map +1 -0
  243. package/_cjs/data/Maybe.cjs +71 -0
  244. package/_cjs/data/Maybe.cjs.map +1 -0
  245. package/_cjs/data/Newtype.cjs +27 -0
  246. package/_cjs/data/Newtype.cjs.map +1 -0
  247. package/_cjs/data/Patch/api.cjs +137 -0
  248. package/_cjs/data/Patch/api.cjs.map +1 -0
  249. package/_cjs/data/Patch/definition.cjs +88 -0
  250. package/_cjs/data/Patch/definition.cjs.map +1 -0
  251. package/_cjs/data/Patch.cjs +32 -0
  252. package/_cjs/data/Patch.cjs.map +1 -0
  253. package/_cjs/data/Predicate/api.cjs +41 -0
  254. package/_cjs/data/Predicate/api.cjs.map +1 -0
  255. package/_cjs/data/Predicate/definition.cjs +6 -0
  256. package/_cjs/data/Predicate/definition.cjs.map +1 -0
  257. package/_cjs/data/Predicate.cjs +32 -0
  258. package/_cjs/data/Predicate.cjs.map +1 -0
  259. package/_cjs/data/Refinement/api.cjs +43 -0
  260. package/_cjs/data/Refinement/api.cjs.map +1 -0
  261. package/_cjs/data/Refinement/definition.cjs +6 -0
  262. package/_cjs/data/Refinement/definition.cjs.map +1 -0
  263. package/_cjs/data/Refinement.cjs +32 -0
  264. package/_cjs/data/Refinement.cjs.map +1 -0
  265. package/_cjs/data/Struct/api.cjs +37 -0
  266. package/_cjs/data/Struct/api.cjs.map +1 -0
  267. package/_cjs/data/Struct/definition.cjs +16 -0
  268. package/_cjs/data/Struct/definition.cjs.map +1 -0
  269. package/_cjs/data/Tag/constructors.cjs +20 -0
  270. package/_cjs/data/Tag/constructors.cjs.map +1 -0
  271. package/_cjs/data/Tag/definition.cjs +57 -0
  272. package/_cjs/data/Tag/definition.cjs.map +1 -0
  273. package/_cjs/data/Tag.cjs +32 -0
  274. package/_cjs/data/Tag.cjs.map +1 -0
  275. package/_cjs/data/These/constructors.cjs +37 -0
  276. package/_cjs/data/These/constructors.cjs.map +1 -0
  277. package/_cjs/data/These/definition.cjs +63 -0
  278. package/_cjs/data/These/definition.cjs.map +1 -0
  279. package/_cjs/data/These/destructors.cjs +29 -0
  280. package/_cjs/data/These/destructors.cjs.map +1 -0
  281. package/_cjs/data/These.cjs +45 -0
  282. package/_cjs/data/These.cjs.map +1 -0
  283. package/_cjs/data/Trace/api.cjs +35 -0
  284. package/_cjs/data/Trace/api.cjs.map +1 -0
  285. package/_cjs/data/Trace/constructors.cjs +32 -0
  286. package/_cjs/data/Trace/constructors.cjs.map +1 -0
  287. package/_cjs/data/Trace/definition.cjs +21 -0
  288. package/_cjs/data/Trace/definition.cjs.map +1 -0
  289. package/_cjs/data/Trace.cjs +45 -0
  290. package/_cjs/data/Trace.cjs.map +1 -0
  291. package/_cjs/data/TraceElement/definition.cjs +75 -0
  292. package/_cjs/data/TraceElement/definition.cjs.map +1 -0
  293. package/_cjs/data/TraceElement.cjs +19 -0
  294. package/_cjs/data/TraceElement.cjs.map +1 -0
  295. package/_cjs/data/exceptions/ArrayIndexOutOfBoundsError.cjs +20 -0
  296. package/_cjs/data/exceptions/ArrayIndexOutOfBoundsError.cjs.map +1 -0
  297. package/_cjs/data/exceptions/IllegalArgumentError.cjs +21 -0
  298. package/_cjs/data/exceptions/IllegalArgumentError.cjs.map +1 -0
  299. package/_cjs/data/exceptions/IllegalStateError.cjs +20 -0
  300. package/_cjs/data/exceptions/IllegalStateError.cjs.map +1 -0
  301. package/_cjs/data/exceptions/IndexOutOfBoundsError.cjs +20 -0
  302. package/_cjs/data/exceptions/IndexOutOfBoundsError.cjs.map +1 -0
  303. package/_cjs/data/exceptions/InterruptedException.cjs +27 -0
  304. package/_cjs/data/exceptions/InterruptedException.cjs.map +1 -0
  305. package/_cjs/data/exceptions/InvalidCapacityError.cjs +23 -0
  306. package/_cjs/data/exceptions/InvalidCapacityError.cjs.map +1 -0
  307. package/_cjs/data/exceptions/NoSuchElementError.cjs +20 -0
  308. package/_cjs/data/exceptions/NoSuchElementError.cjs.map +1 -0
  309. package/_cjs/data/exceptions.cjs +97 -0
  310. package/_cjs/data/exceptions.cjs.map +1 -0
  311. package/_cjs/data/function/api.cjs +52 -0
  312. package/_cjs/data/function/api.cjs.map +1 -0
  313. package/_cjs/data/function/definition.cjs +6 -0
  314. package/_cjs/data/function/definition.cjs.map +1 -0
  315. package/_cjs/data/function/pipe.cjs +74 -0
  316. package/_cjs/data/function/pipe.cjs.map +1 -0
  317. package/_cjs/data/function.cjs +45 -0
  318. package/_cjs/data/function.cjs.map +1 -0
  319. package/_cjs/data/number/api.cjs +14 -0
  320. package/_cjs/data/number/api.cjs.map +1 -0
  321. package/_cjs/data/number/definition.cjs +6 -0
  322. package/_cjs/data/number/definition.cjs.map +1 -0
  323. package/_cjs/data/number/instances.cjs +34 -0
  324. package/_cjs/data/number/instances.cjs.map +1 -0
  325. package/_cjs/data/number.cjs +45 -0
  326. package/_cjs/data/number.cjs.map +1 -0
  327. package/_cjs/data/object/definition.cjs +6 -0
  328. package/_cjs/data/object/definition.cjs.map +1 -0
  329. package/_cjs/data/object.cjs +19 -0
  330. package/_cjs/data/object.cjs.map +1 -0
  331. package/_cjs/data/string/api.cjs +254 -0
  332. package/_cjs/data/string/api.cjs.map +1 -0
  333. package/_cjs/data/string/definition.cjs +6 -0
  334. package/_cjs/data/string/definition.cjs.map +1 -0
  335. package/_cjs/data/string/instances.cjs +55 -0
  336. package/_cjs/data/string/instances.cjs.map +1 -0
  337. package/_cjs/data/string.cjs +45 -0
  338. package/_cjs/data/string.cjs.map +1 -0
  339. package/_cjs/global/api.cjs +11 -0
  340. package/_cjs/global/api.cjs.map +1 -0
  341. package/_cjs/internal/AtomicBoolean.cjs +18 -0
  342. package/_cjs/internal/AtomicBoolean.cjs.map +1 -0
  343. package/_cjs/internal/AtomicNumber.cjs +36 -0
  344. package/_cjs/internal/AtomicNumber.cjs.map +1 -0
  345. package/_cjs/internal/AtomicReference.cjs +40 -0
  346. package/_cjs/internal/AtomicReference.cjs.map +1 -0
  347. package/_cjs/internal/Stack.cjs +69 -0
  348. package/_cjs/internal/Stack.cjs.map +1 -0
  349. package/_cjs/optics/At/api.cjs +24 -0
  350. package/_cjs/optics/At/api.cjs.map +1 -0
  351. package/_cjs/optics/At/definition.cjs +34 -0
  352. package/_cjs/optics/At/definition.cjs.map +1 -0
  353. package/_cjs/optics/At.cjs +32 -0
  354. package/_cjs/optics/At.cjs.map +1 -0
  355. package/_cjs/optics/Fold/definition.cjs +21 -0
  356. package/_cjs/optics/Fold/definition.cjs.map +1 -0
  357. package/_cjs/optics/Fold.cjs +19 -0
  358. package/_cjs/optics/Fold.cjs.map +1 -0
  359. package/_cjs/optics/Getter/definition.cjs +22 -0
  360. package/_cjs/optics/Getter/definition.cjs.map +1 -0
  361. package/_cjs/optics/Getter.cjs +19 -0
  362. package/_cjs/optics/Getter.cjs.map +1 -0
  363. package/_cjs/optics/Index/api.cjs +37 -0
  364. package/_cjs/optics/Index/api.cjs.map +1 -0
  365. package/_cjs/optics/Index/definition.cjs +20 -0
  366. package/_cjs/optics/Index/definition.cjs.map +1 -0
  367. package/_cjs/optics/Index.cjs +32 -0
  368. package/_cjs/optics/Index.cjs.map +1 -0
  369. package/_cjs/optics/Iso/api.cjs +25 -0
  370. package/_cjs/optics/Iso/api.cjs.map +1 -0
  371. package/_cjs/optics/Iso/definition.cjs +54 -0
  372. package/_cjs/optics/Iso/definition.cjs.map +1 -0
  373. package/_cjs/optics/Iso.cjs +32 -0
  374. package/_cjs/optics/Iso.cjs.map +1 -0
  375. package/_cjs/optics/Lens/api.cjs +171 -0
  376. package/_cjs/optics/Lens/api.cjs.map +1 -0
  377. package/_cjs/optics/Lens/definition.cjs +50 -0
  378. package/_cjs/optics/Lens/definition.cjs.map +1 -0
  379. package/_cjs/optics/Lens.cjs +32 -0
  380. package/_cjs/optics/Lens.cjs.map +1 -0
  381. package/_cjs/optics/Optional/api/compose.cjs +27 -0
  382. package/_cjs/optics/Optional/api/compose.cjs.map +1 -0
  383. package/_cjs/optics/Optional/definition.cjs +57 -0
  384. package/_cjs/optics/Optional/definition.cjs.map +1 -0
  385. package/_cjs/optics/Optional.cjs +32 -0
  386. package/_cjs/optics/Optional.cjs.map +1 -0
  387. package/_cjs/optics/Prism/api/compose.cjs +29 -0
  388. package/_cjs/optics/Prism/api/compose.cjs.map +1 -0
  389. package/_cjs/optics/Prism/api/fromNullable.cjs +27 -0
  390. package/_cjs/optics/Prism/api/fromNullable.cjs.map +1 -0
  391. package/_cjs/optics/Prism/api/just.cjs +29 -0
  392. package/_cjs/optics/Prism/api/just.cjs.map +1 -0
  393. package/_cjs/optics/Prism/definition.cjs +48 -0
  394. package/_cjs/optics/Prism/definition.cjs.map +1 -0
  395. package/_cjs/optics/Prism.cjs +58 -0
  396. package/_cjs/optics/Prism.cjs.map +1 -0
  397. package/_cjs/optics/Setter/definition.cjs +33 -0
  398. package/_cjs/optics/Setter/definition.cjs.map +1 -0
  399. package/_cjs/optics/Setter.cjs +19 -0
  400. package/_cjs/optics/Setter.cjs.map +1 -0
  401. package/_cjs/optics/Traversal/api/compose.cjs +22 -0
  402. package/_cjs/optics/Traversal/api/compose.cjs.map +1 -0
  403. package/_cjs/optics/Traversal/api/fromTraversable.cjs +22 -0
  404. package/_cjs/optics/Traversal/api/fromTraversable.cjs.map +1 -0
  405. package/_cjs/optics/Traversal/definition.cjs +53 -0
  406. package/_cjs/optics/Traversal/definition.cjs.map +1 -0
  407. package/_cjs/optics/Traversal.cjs +45 -0
  408. package/_cjs/optics/Traversal.cjs.map +1 -0
  409. package/_cjs/typeclass/Align.cjs +29 -0
  410. package/_cjs/typeclass/Align.cjs.map +1 -0
  411. package/_cjs/typeclass/Alt.cjs +26 -0
  412. package/_cjs/typeclass/Alt.cjs.map +1 -0
  413. package/_cjs/typeclass/Alternative.cjs +32 -0
  414. package/_cjs/typeclass/Alternative.cjs.map +1 -0
  415. package/_cjs/typeclass/Applicative.cjs +31 -0
  416. package/_cjs/typeclass/Applicative.cjs.map +1 -0
  417. package/_cjs/typeclass/ApplicativeExcept.cjs +56 -0
  418. package/_cjs/typeclass/ApplicativeExcept.cjs.map +1 -0
  419. package/_cjs/typeclass/Apply.cjs +136 -0
  420. package/_cjs/typeclass/Apply.cjs.map +1 -0
  421. package/_cjs/typeclass/Chain.cjs +35 -0
  422. package/_cjs/typeclass/Chain.cjs.map +1 -0
  423. package/_cjs/typeclass/Closure.cjs +21 -0
  424. package/_cjs/typeclass/Closure.cjs.map +1 -0
  425. package/_cjs/typeclass/Eq.cjs +21 -0
  426. package/_cjs/typeclass/Eq.cjs.map +1 -0
  427. package/_cjs/typeclass/Equatable/api.cjs +45 -0
  428. package/_cjs/typeclass/Equatable/api.cjs.map +1 -0
  429. package/_cjs/typeclass/Equatable/definition.cjs +28 -0
  430. package/_cjs/typeclass/Equatable/definition.cjs.map +1 -0
  431. package/_cjs/typeclass/Equatable/fast-equals.cjs +520 -0
  432. package/_cjs/typeclass/Equatable/fast-equals.cjs.map +1 -0
  433. package/_cjs/typeclass/Equatable.cjs +45 -0
  434. package/_cjs/typeclass/Equatable.cjs.map +1 -0
  435. package/_cjs/typeclass/Fail.cjs +22 -0
  436. package/_cjs/typeclass/Fail.cjs.map +1 -0
  437. package/_cjs/typeclass/Filterable.cjs +32 -0
  438. package/_cjs/typeclass/Filterable.cjs.map +1 -0
  439. package/_cjs/typeclass/FilterableWithIndex.cjs +35 -0
  440. package/_cjs/typeclass/FilterableWithIndex.cjs.map +1 -0
  441. package/_cjs/typeclass/Foldable.cjs +34 -0
  442. package/_cjs/typeclass/Foldable.cjs.map +1 -0
  443. package/_cjs/typeclass/FoldableWithIndex.cjs +36 -0
  444. package/_cjs/typeclass/FoldableWithIndex.cjs.map +1 -0
  445. package/_cjs/typeclass/Functor.cjs +30 -0
  446. package/_cjs/typeclass/Functor.cjs.map +1 -0
  447. package/_cjs/typeclass/FunctorWithIndex.cjs +30 -0
  448. package/_cjs/typeclass/FunctorWithIndex.cjs.map +1 -0
  449. package/_cjs/typeclass/Has.cjs +17 -0
  450. package/_cjs/typeclass/Has.cjs.map +1 -0
  451. package/_cjs/typeclass/Hash.cjs +18 -0
  452. package/_cjs/typeclass/Hash.cjs.map +1 -0
  453. package/_cjs/typeclass/HashEq.cjs +51 -0
  454. package/_cjs/typeclass/HashEq.cjs.map +1 -0
  455. package/_cjs/typeclass/Hashable/definition.cjs +28 -0
  456. package/_cjs/typeclass/Hashable/definition.cjs.map +1 -0
  457. package/_cjs/typeclass/Hashable/hash.cjs +267 -0
  458. package/_cjs/typeclass/Hashable/hash.cjs.map +1 -0
  459. package/_cjs/typeclass/Hashable.cjs +32 -0
  460. package/_cjs/typeclass/Hashable.cjs.map +1 -0
  461. package/_cjs/typeclass/Monad.cjs +31 -0
  462. package/_cjs/typeclass/Monad.cjs.map +1 -0
  463. package/_cjs/typeclass/MonadExcept.cjs +36 -0
  464. package/_cjs/typeclass/MonadExcept.cjs.map +1 -0
  465. package/_cjs/typeclass/Monoid.cjs +27 -0
  466. package/_cjs/typeclass/Monoid.cjs.map +1 -0
  467. package/_cjs/typeclass/Nil.cjs +6 -0
  468. package/_cjs/typeclass/Nil.cjs.map +1 -0
  469. package/_cjs/typeclass/Ord/api/contramap.cjs +19 -0
  470. package/_cjs/typeclass/Ord/api/contramap.cjs.map +1 -0
  471. package/_cjs/typeclass/Ord/api/max.cjs +15 -0
  472. package/_cjs/typeclass/Ord/api/max.cjs.map +1 -0
  473. package/_cjs/typeclass/Ord/api/min.cjs +15 -0
  474. package/_cjs/typeclass/Ord/api/min.cjs.map +1 -0
  475. package/_cjs/typeclass/Ord/api.cjs +45 -0
  476. package/_cjs/typeclass/Ord/api.cjs.map +1 -0
  477. package/_cjs/typeclass/Ord/definition.cjs +28 -0
  478. package/_cjs/typeclass/Ord/definition.cjs.map +1 -0
  479. package/_cjs/typeclass/Ord/instances.cjs +52 -0
  480. package/_cjs/typeclass/Ord/instances.cjs.map +1 -0
  481. package/_cjs/typeclass/Ord.cjs +45 -0
  482. package/_cjs/typeclass/Ord.cjs.map +1 -0
  483. package/_cjs/typeclass/Ordering.cjs +57 -0
  484. package/_cjs/typeclass/Ordering.cjs.map +1 -0
  485. package/_cjs/typeclass/Pointed.cjs +25 -0
  486. package/_cjs/typeclass/Pointed.cjs.map +1 -0
  487. package/_cjs/typeclass/Semialign.cjs +121 -0
  488. package/_cjs/typeclass/Semialign.cjs.map +1 -0
  489. package/_cjs/typeclass/Semigroup/api.cjs +37 -0
  490. package/_cjs/typeclass/Semigroup/api.cjs.map +1 -0
  491. package/_cjs/typeclass/Semigroup/definition.cjs +18 -0
  492. package/_cjs/typeclass/Semigroup/definition.cjs.map +1 -0
  493. package/_cjs/typeclass/Semigroup.cjs +32 -0
  494. package/_cjs/typeclass/Semigroup.cjs.map +1 -0
  495. package/_cjs/typeclass/Semimonoidal.cjs +24 -0
  496. package/_cjs/typeclass/Semimonoidal.cjs.map +1 -0
  497. package/_cjs/typeclass/Showable/definition.cjs +32 -0
  498. package/_cjs/typeclass/Showable/definition.cjs.map +1 -0
  499. package/_cjs/typeclass/Showable/show.cjs +837 -0
  500. package/_cjs/typeclass/Showable/show.cjs.map +1 -0
  501. package/_cjs/typeclass/Showable/styles.cjs +39 -0
  502. package/_cjs/typeclass/Showable/styles.cjs.map +1 -0
  503. package/_cjs/typeclass/Showable/util.cjs +433 -0
  504. package/_cjs/typeclass/Showable/util.cjs.map +1 -0
  505. package/_cjs/typeclass/Showable.cjs +32 -0
  506. package/_cjs/typeclass/Showable.cjs.map +1 -0
  507. package/_cjs/typeclass/Traversable.cjs +54 -0
  508. package/_cjs/typeclass/Traversable.cjs.map +1 -0
  509. package/_cjs/typeclass/TraversableWithIndex.cjs +49 -0
  510. package/_cjs/typeclass/TraversableWithIndex.cjs.map +1 -0
  511. package/_cjs/typeclass/Witherable.cjs +68 -0
  512. package/_cjs/typeclass/Witherable.cjs.map +1 -0
  513. package/_cjs/typeclass/WitherableWithIndex.cjs +76 -0
  514. package/_cjs/typeclass/WitherableWithIndex.cjs.map +1 -0
  515. package/_cjs/typeclass/builtin/Symbol.cjs +6 -0
  516. package/_cjs/typeclass/builtin/Symbol.cjs.map +1 -0
  517. package/_cjs/typeclass/builtin.cjs +19 -0
  518. package/_cjs/typeclass/builtin.cjs.map +1 -0
  519. package/_cjs/typeclass.cjs +474 -0
  520. package/_cjs/typeclass.cjs.map +1 -0
  521. package/_cjs/types/extractions.cjs +6 -0
  522. package/_cjs/types/extractions.cjs.map +1 -0
  523. package/_cjs/types/test.cjs +6 -0
  524. package/_cjs/types/test.cjs.map +1 -0
  525. package/_cjs/types/utility.cjs +6 -0
  526. package/_cjs/types/utility.cjs.map +1 -0
  527. package/_cjs/types.cjs +45 -0
  528. package/_cjs/types.cjs.map +1 -0
  529. package/_cjs/util/AnsiFormat.cjs +338 -0
  530. package/_cjs/util/AnsiFormat.cjs.map +1 -0
  531. package/_cjs/util/PCGRandom.cjs +177 -0
  532. package/_cjs/util/PCGRandom.cjs.map +1 -0
  533. package/_cjs/util/assert.cjs +24 -0
  534. package/_cjs/util/assert.cjs.map +1 -0
  535. package/_cjs/util/pattern.cjs +23 -0
  536. package/_cjs/util/pattern.cjs.map +1 -0
  537. package/_cjs/util/predicates.cjs +157 -0
  538. package/_cjs/util/predicates.cjs.map +1 -0
  539. package/_cjs/util/rand/Random.cjs +103 -0
  540. package/_cjs/util/rand/Random.cjs.map +1 -0
  541. package/_cjs/util/rand/distribution/Distribution.cjs +6 -0
  542. package/_cjs/util/rand/distribution/Distribution.cjs.map +1 -0
  543. package/_cjs/util/rand/distribution/UniformArrayIntDistribution.cjs +32 -0
  544. package/_cjs/util/rand/distribution/UniformArrayIntDistribution.cjs.map +1 -0
  545. package/_cjs/util/rand/distribution/UniformBigIntDistribution.cjs +50 -0
  546. package/_cjs/util/rand/distribution/UniformBigIntDistribution.cjs.map +1 -0
  547. package/_cjs/util/rand/distribution/UniformIntDistribution.cjs +70 -0
  548. package/_cjs/util/rand/distribution/UniformIntDistribution.cjs.map +1 -0
  549. package/_cjs/util/rand/distribution/internals/ArrayInt.cjs +220 -0
  550. package/_cjs/util/rand/distribution/internals/ArrayInt.cjs.map +1 -0
  551. package/_cjs/util/rand/distribution/internals/UniformArrayIntDistributionInternal.cjs +44 -0
  552. package/_cjs/util/rand/distribution/internals/UniformArrayIntDistributionInternal.cjs.map +1 -0
  553. package/_cjs/util/rand/distribution/internals/UniformIntDistributionInternal.cjs +56 -0
  554. package/_cjs/util/rand/distribution/internals/UniformIntDistributionInternal.cjs.map +1 -0
  555. package/_cjs/util/rand/generator/MersenneTwister.cjs +115 -0
  556. package/_cjs/util/rand/generator/MersenneTwister.cjs.map +1 -0
  557. package/_cjs/util/rand/generator/RandomGenerator.cjs +23 -0
  558. package/_cjs/util/rand/generator/RandomGenerator.cjs.map +1 -0
  559. package/_cjs/util/rand.cjs +88 -0
  560. package/_cjs/util/rand.cjs.map +1 -0
  561. package/_mjs/collection/Iterable/api/traverseConc.mjs +28 -0
  562. package/_mjs/collection/Iterable/api/traverseConc.mjs.map +1 -0
  563. package/_mjs/collection/Iterable/api.mjs +784 -0
  564. package/_mjs/collection/Iterable/api.mjs.map +1 -0
  565. package/_mjs/collection/Iterable/constructors.mjs +100 -0
  566. package/_mjs/collection/Iterable/constructors.mjs.map +1 -0
  567. package/_mjs/collection/Iterable/definition.mjs +2 -0
  568. package/_mjs/collection/Iterable/definition.mjs.map +1 -0
  569. package/_mjs/collection/Iterable.mjs +5 -0
  570. package/_mjs/collection/Iterable.mjs.map +1 -0
  571. package/_mjs/collection/compat/Array/api.mjs +56 -0
  572. package/_mjs/collection/compat/Array/api.mjs.map +1 -0
  573. package/_mjs/collection/compat/Array/definition.mjs +2 -0
  574. package/_mjs/collection/compat/Array/definition.mjs.map +1 -0
  575. package/_mjs/collection/compat/Array.mjs +4 -0
  576. package/_mjs/collection/compat/Array.mjs.map +1 -0
  577. package/_mjs/collection/compat/ArrayLike/api.mjs +40 -0
  578. package/_mjs/collection/compat/ArrayLike/api.mjs.map +1 -0
  579. package/_mjs/collection/compat/ArrayLike/definition.mjs +2 -0
  580. package/_mjs/collection/compat/ArrayLike/definition.mjs.map +1 -0
  581. package/_mjs/collection/immutable/Conc/api/empty.mjs +9 -0
  582. package/_mjs/collection/immutable/Conc/api/empty.mjs.map +1 -0
  583. package/_mjs/collection/immutable/Conc/api/makeBy.mjs +22 -0
  584. package/_mjs/collection/immutable/Conc/api/makeBy.mjs.map +1 -0
  585. package/_mjs/collection/immutable/Conc/api/replicate.mjs +9 -0
  586. package/_mjs/collection/immutable/Conc/api/replicate.mjs.map +1 -0
  587. package/_mjs/collection/immutable/Conc/api.mjs +1340 -0
  588. package/_mjs/collection/immutable/Conc/api.mjs.map +1 -0
  589. package/_mjs/collection/immutable/Conc/constructors.mjs +40 -0
  590. package/_mjs/collection/immutable/Conc/constructors.mjs.map +1 -0
  591. package/_mjs/collection/immutable/Conc/definition.mjs +798 -0
  592. package/_mjs/collection/immutable/Conc/definition.mjs.map +1 -0
  593. package/_mjs/collection/immutable/Conc.mjs +10 -0
  594. package/_mjs/collection/immutable/Conc.mjs.map +1 -0
  595. package/_mjs/collection/immutable/Dictionary/api.mjs +62 -0
  596. package/_mjs/collection/immutable/Dictionary/api.mjs.map +1 -0
  597. package/_mjs/collection/immutable/Dictionary/definition.mjs +3 -0
  598. package/_mjs/collection/immutable/Dictionary/definition.mjs.map +1 -0
  599. package/_mjs/collection/immutable/HashMap/api.mjs +724 -0
  600. package/_mjs/collection/immutable/HashMap/api.mjs.map +1 -0
  601. package/_mjs/collection/immutable/HashMap/definition.mjs +111 -0
  602. package/_mjs/collection/immutable/HashMap/definition.mjs.map +1 -0
  603. package/_mjs/collection/immutable/HashMap/internal.mjs +352 -0
  604. package/_mjs/collection/immutable/HashMap/internal.mjs.map +1 -0
  605. package/_mjs/collection/immutable/HashMap.mjs +4 -0
  606. package/_mjs/collection/immutable/HashMap.mjs.map +1 -0
  607. package/_mjs/collection/immutable/HashSet/api.mjs +515 -0
  608. package/_mjs/collection/immutable/HashSet/api.mjs.map +1 -0
  609. package/_mjs/collection/immutable/HashSet/definition.mjs +370 -0
  610. package/_mjs/collection/immutable/HashSet/definition.mjs.map +1 -0
  611. package/_mjs/collection/immutable/HashSet.mjs +4 -0
  612. package/_mjs/collection/immutable/HashSet.mjs.map +1 -0
  613. package/_mjs/collection/immutable/ImmutableArray/api.mjs +1514 -0
  614. package/_mjs/collection/immutable/ImmutableArray/api.mjs.map +1 -0
  615. package/_mjs/collection/immutable/ImmutableArray/constructors.mjs +56 -0
  616. package/_mjs/collection/immutable/ImmutableArray/constructors.mjs.map +1 -0
  617. package/_mjs/collection/immutable/ImmutableArray/definition.mjs +34 -0
  618. package/_mjs/collection/immutable/ImmutableArray/definition.mjs.map +1 -0
  619. package/_mjs/collection/immutable/ImmutableArray/instances.mjs +142 -0
  620. package/_mjs/collection/immutable/ImmutableArray/instances.mjs.map +1 -0
  621. package/_mjs/collection/immutable/ImmutableArray.mjs +6 -0
  622. package/_mjs/collection/immutable/ImmutableArray.mjs.map +1 -0
  623. package/_mjs/collection/immutable/ImmutableNonEmptyArray/api.mjs +521 -0
  624. package/_mjs/collection/immutable/ImmutableNonEmptyArray/api.mjs.map +1 -0
  625. package/_mjs/collection/immutable/ImmutableNonEmptyArray/constructors.mjs +76 -0
  626. package/_mjs/collection/immutable/ImmutableNonEmptyArray/constructors.mjs.map +1 -0
  627. package/_mjs/collection/immutable/ImmutableNonEmptyArray/definition.mjs +14 -0
  628. package/_mjs/collection/immutable/ImmutableNonEmptyArray/definition.mjs.map +1 -0
  629. package/_mjs/collection/immutable/ImmutableNonEmptyArray/destructors.mjs +52 -0
  630. package/_mjs/collection/immutable/ImmutableNonEmptyArray/destructors.mjs.map +1 -0
  631. package/_mjs/collection/immutable/ImmutableNonEmptyArray/instances.mjs +110 -0
  632. package/_mjs/collection/immutable/ImmutableNonEmptyArray/instances.mjs.map +1 -0
  633. package/_mjs/collection/immutable/ImmutableNonEmptyArray.mjs +7 -0
  634. package/_mjs/collection/immutable/ImmutableNonEmptyArray.mjs.map +1 -0
  635. package/_mjs/collection/immutable/List/api/foldLeft.mjs +17 -0
  636. package/_mjs/collection/immutable/List/api/foldLeft.mjs.map +1 -0
  637. package/_mjs/collection/immutable/List/api/unsafeTail.mjs +14 -0
  638. package/_mjs/collection/immutable/List/api/unsafeTail.mjs.map +1 -0
  639. package/_mjs/collection/immutable/List/api.mjs +388 -0
  640. package/_mjs/collection/immutable/List/api.mjs.map +1 -0
  641. package/_mjs/collection/immutable/List/constructors.mjs +71 -0
  642. package/_mjs/collection/immutable/List/constructors.mjs.map +1 -0
  643. package/_mjs/collection/immutable/List/definition.mjs +106 -0
  644. package/_mjs/collection/immutable/List/definition.mjs.map +1 -0
  645. package/_mjs/collection/immutable/List.mjs +9 -0
  646. package/_mjs/collection/immutable/List.mjs.map +1 -0
  647. package/_mjs/collection/immutable/Queue/api.mjs +165 -0
  648. package/_mjs/collection/immutable/Queue/api.mjs.map +1 -0
  649. package/_mjs/collection/immutable/Queue/constructors.mjs +18 -0
  650. package/_mjs/collection/immutable/Queue/constructors.mjs.map +1 -0
  651. package/_mjs/collection/immutable/Queue/definition.mjs +38 -0
  652. package/_mjs/collection/immutable/Queue/definition.mjs.map +1 -0
  653. package/_mjs/collection/immutable/Queue/guards.mjs +9 -0
  654. package/_mjs/collection/immutable/Queue/guards.mjs.map +1 -0
  655. package/_mjs/collection/immutable/Queue.mjs +6 -0
  656. package/_mjs/collection/immutable/Queue.mjs.map +1 -0
  657. package/_mjs/collection/immutable/SortedMap/api.mjs +631 -0
  658. package/_mjs/collection/immutable/SortedMap/api.mjs.map +1 -0
  659. package/_mjs/collection/immutable/SortedMap/definition.mjs +18 -0
  660. package/_mjs/collection/immutable/SortedMap/definition.mjs.map +1 -0
  661. package/_mjs/collection/immutable/SortedMap/internal.mjs +515 -0
  662. package/_mjs/collection/immutable/SortedMap/internal.mjs.map +1 -0
  663. package/_mjs/collection/immutable/SortedMap/iterator.mjs +373 -0
  664. package/_mjs/collection/immutable/SortedMap/iterator.mjs.map +1 -0
  665. package/_mjs/collection/immutable/SortedMap/node.mjs +13 -0
  666. package/_mjs/collection/immutable/SortedMap/node.mjs.map +1 -0
  667. package/_mjs/collection/immutable/SortedMap.mjs +7 -0
  668. package/_mjs/collection/immutable/SortedMap.mjs.map +1 -0
  669. package/_mjs/collection/immutable/Vector/api.mjs +1367 -0
  670. package/_mjs/collection/immutable/Vector/api.mjs.map +1 -0
  671. package/_mjs/collection/immutable/Vector/definition.mjs +81 -0
  672. package/_mjs/collection/immutable/Vector/definition.mjs.map +1 -0
  673. package/_mjs/collection/immutable/Vector/internal.mjs +1557 -0
  674. package/_mjs/collection/immutable/Vector/internal.mjs.map +1 -0
  675. package/_mjs/collection/immutable/Vector.mjs +4 -0
  676. package/_mjs/collection/immutable/Vector.mjs.map +1 -0
  677. package/_mjs/collection/mutable/HashMap.mjs +370 -0
  678. package/_mjs/collection/mutable/HashMap.mjs.map +1 -0
  679. package/_mjs/collection/mutable/HashSet.mjs +290 -0
  680. package/_mjs/collection/mutable/HashSet.mjs.map +1 -0
  681. package/_mjs/collection/mutable/ListBuffer.mjs +141 -0
  682. package/_mjs/collection/mutable/ListBuffer.mjs.map +1 -0
  683. package/_mjs/collection/mutable/internal.mjs +26 -0
  684. package/_mjs/collection/mutable/internal.mjs.map +1 -0
  685. package/_mjs/control/Eval/api/sequenceArray.mjs +10 -0
  686. package/_mjs/control/Eval/api/sequenceArray.mjs.map +1 -0
  687. package/_mjs/control/Eval/api.mjs +98 -0
  688. package/_mjs/control/Eval/api.mjs.map +1 -0
  689. package/_mjs/control/Eval/constructors.mjs +35 -0
  690. package/_mjs/control/Eval/constructors.mjs.map +1 -0
  691. package/_mjs/control/Eval/definition.mjs +47 -0
  692. package/_mjs/control/Eval/definition.mjs.map +1 -0
  693. package/_mjs/control/Eval/instance.mjs +33 -0
  694. package/_mjs/control/Eval/instance.mjs.map +1 -0
  695. package/_mjs/control/Eval/run.mjs +60 -0
  696. package/_mjs/control/Eval/run.mjs.map +1 -0
  697. package/_mjs/control/Eval.mjs +7 -0
  698. package/_mjs/control/Eval.mjs.map +1 -0
  699. package/_mjs/control/LazyValue.mjs +27 -0
  700. package/_mjs/control/LazyValue.mjs.map +1 -0
  701. package/_mjs/control/Z/api.mjs +541 -0
  702. package/_mjs/control/Z/api.mjs.map +1 -0
  703. package/_mjs/control/Z/definition.mjs +169 -0
  704. package/_mjs/control/Z/definition.mjs.map +1 -0
  705. package/_mjs/control/Z/instances.mjs +14 -0
  706. package/_mjs/control/Z/instances.mjs.map +1 -0
  707. package/_mjs/control/Z/runtime.mjs +354 -0
  708. package/_mjs/control/Z/runtime.mjs.map +1 -0
  709. package/_mjs/control/Z.mjs +6 -0
  710. package/_mjs/control/Z.mjs.map +1 -0
  711. package/_mjs/data/Byte.mjs +2 -0
  712. package/_mjs/data/Byte.mjs.map +1 -0
  713. package/_mjs/data/CaseClass.mjs +103 -0
  714. package/_mjs/data/CaseClass.mjs.map +1 -0
  715. package/_mjs/data/Cause/api/fold.mjs +174 -0
  716. package/_mjs/data/Cause/api/fold.mjs.map +1 -0
  717. package/_mjs/data/Cause/api/isEmpty.mjs +72 -0
  718. package/_mjs/data/Cause/api/isEmpty.mjs.map +1 -0
  719. package/_mjs/data/Cause/api/linearize.mjs +19 -0
  720. package/_mjs/data/Cause/api/linearize.mjs.map +1 -0
  721. package/_mjs/data/Cause/api/prettyPrint.mjs +37 -0
  722. package/_mjs/data/Cause/api/prettyPrint.mjs.map +1 -0
  723. package/_mjs/data/Cause/api/unified.mjs +150 -0
  724. package/_mjs/data/Cause/api/unified.mjs.map +1 -0
  725. package/_mjs/data/Cause/api.mjs +1200 -0
  726. package/_mjs/data/Cause/api.mjs.map +1 -0
  727. package/_mjs/data/Cause/definition.mjs +612 -0
  728. package/_mjs/data/Cause/definition.mjs.map +1 -0
  729. package/_mjs/data/Cause.mjs +4 -0
  730. package/_mjs/data/Cause.mjs.map +1 -0
  731. package/_mjs/data/Const/api.mjs +17 -0
  732. package/_mjs/data/Const/api.mjs.map +1 -0
  733. package/_mjs/data/Const/definition.mjs +2 -0
  734. package/_mjs/data/Const/definition.mjs.map +1 -0
  735. package/_mjs/data/Const/instances.mjs +32 -0
  736. package/_mjs/data/Const/instances.mjs.map +1 -0
  737. package/_mjs/data/Const.mjs +5 -0
  738. package/_mjs/data/Const.mjs.map +1 -0
  739. package/_mjs/data/Duration/api.mjs +70 -0
  740. package/_mjs/data/Duration/api.mjs.map +1 -0
  741. package/_mjs/data/Duration/definition.mjs +29 -0
  742. package/_mjs/data/Duration/definition.mjs.map +1 -0
  743. package/_mjs/data/Duration.mjs +4 -0
  744. package/_mjs/data/Duration.mjs.map +1 -0
  745. package/_mjs/data/Either/api/align.mjs +6 -0
  746. package/_mjs/data/Either/api/align.mjs.map +1 -0
  747. package/_mjs/data/Either/api/alignWith.mjs +16 -0
  748. package/_mjs/data/Either/api/alignWith.mjs.map +1 -0
  749. package/_mjs/data/Either/api.mjs +211 -0
  750. package/_mjs/data/Either/api.mjs.map +1 -0
  751. package/_mjs/data/Either/constructors.mjs +70 -0
  752. package/_mjs/data/Either/constructors.mjs.map +1 -0
  753. package/_mjs/data/Either/definition.mjs +40 -0
  754. package/_mjs/data/Either/definition.mjs.map +1 -0
  755. package/_mjs/data/Either/destructors.mjs +17 -0
  756. package/_mjs/data/Either/destructors.mjs.map +1 -0
  757. package/_mjs/data/Either/instances.mjs +66 -0
  758. package/_mjs/data/Either/instances.mjs.map +1 -0
  759. package/_mjs/data/Either.mjs +7 -0
  760. package/_mjs/data/Either.mjs.map +1 -0
  761. package/_mjs/data/Environment/api.mjs +87 -0
  762. package/_mjs/data/Environment/api.mjs.map +1 -0
  763. package/_mjs/data/Environment/definition.mjs +38 -0
  764. package/_mjs/data/Environment/definition.mjs.map +1 -0
  765. package/_mjs/data/Environment.mjs +4 -0
  766. package/_mjs/data/Environment.mjs.map +1 -0
  767. package/_mjs/data/ExecutionStrategy.mjs +57 -0
  768. package/_mjs/data/ExecutionStrategy.mjs.map +1 -0
  769. package/_mjs/data/Exit/api.mjs +206 -0
  770. package/_mjs/data/Exit/api.mjs.map +1 -0
  771. package/_mjs/data/Exit/constructors.mjs +65 -0
  772. package/_mjs/data/Exit/constructors.mjs.map +1 -0
  773. package/_mjs/data/Exit/definition.mjs +106 -0
  774. package/_mjs/data/Exit/definition.mjs.map +1 -0
  775. package/_mjs/data/Exit.mjs +5 -0
  776. package/_mjs/data/Exit.mjs.map +1 -0
  777. package/_mjs/data/FiberId/api.mjs +55 -0
  778. package/_mjs/data/FiberId/api.mjs.map +1 -0
  779. package/_mjs/data/FiberId/constructors.mjs +24 -0
  780. package/_mjs/data/FiberId/constructors.mjs.map +1 -0
  781. package/_mjs/data/FiberId/definition.mjs +101 -0
  782. package/_mjs/data/FiberId/definition.mjs.map +1 -0
  783. package/_mjs/data/FiberId.mjs +5 -0
  784. package/_mjs/data/FiberId.mjs.map +1 -0
  785. package/_mjs/data/Identity/api.mjs +29 -0
  786. package/_mjs/data/Identity/api.mjs.map +1 -0
  787. package/_mjs/data/Identity/definition.mjs +2 -0
  788. package/_mjs/data/Identity/definition.mjs.map +1 -0
  789. package/_mjs/data/Identity/instances.mjs +32 -0
  790. package/_mjs/data/Identity/instances.mjs.map +1 -0
  791. package/_mjs/data/Identity.mjs +5 -0
  792. package/_mjs/data/Identity.mjs.map +1 -0
  793. package/_mjs/data/Maybe/api.mjs +206 -0
  794. package/_mjs/data/Maybe/api.mjs.map +1 -0
  795. package/_mjs/data/Maybe/constructors.mjs +92 -0
  796. package/_mjs/data/Maybe/constructors.mjs.map +1 -0
  797. package/_mjs/data/Maybe/definition.mjs +99 -0
  798. package/_mjs/data/Maybe/definition.mjs.map +1 -0
  799. package/_mjs/data/Maybe/destructors.mjs +12 -0
  800. package/_mjs/data/Maybe/destructors.mjs.map +1 -0
  801. package/_mjs/data/Maybe/instances.mjs +42 -0
  802. package/_mjs/data/Maybe/instances.mjs.map +1 -0
  803. package/_mjs/data/Maybe.mjs +7 -0
  804. package/_mjs/data/Maybe.mjs.map +1 -0
  805. package/_mjs/data/Newtype.mjs +11 -0
  806. package/_mjs/data/Newtype.mjs.map +1 -0
  807. package/_mjs/data/Patch/api.mjs +111 -0
  808. package/_mjs/data/Patch/api.mjs.map +1 -0
  809. package/_mjs/data/Patch/definition.mjs +61 -0
  810. package/_mjs/data/Patch/definition.mjs.map +1 -0
  811. package/_mjs/data/Patch.mjs +4 -0
  812. package/_mjs/data/Patch.mjs.map +1 -0
  813. package/_mjs/data/Predicate/api.mjs +28 -0
  814. package/_mjs/data/Predicate/api.mjs.map +1 -0
  815. package/_mjs/data/Predicate/definition.mjs +2 -0
  816. package/_mjs/data/Predicate/definition.mjs.map +1 -0
  817. package/_mjs/data/Predicate.mjs +4 -0
  818. package/_mjs/data/Predicate.mjs.map +1 -0
  819. package/_mjs/data/Refinement/api.mjs +30 -0
  820. package/_mjs/data/Refinement/api.mjs.map +1 -0
  821. package/_mjs/data/Refinement/definition.mjs +2 -0
  822. package/_mjs/data/Refinement/definition.mjs.map +1 -0
  823. package/_mjs/data/Refinement.mjs +4 -0
  824. package/_mjs/data/Refinement.mjs.map +1 -0
  825. package/_mjs/data/Struct/api.mjs +26 -0
  826. package/_mjs/data/Struct/api.mjs.map +1 -0
  827. package/_mjs/data/Struct/definition.mjs +3 -0
  828. package/_mjs/data/Struct/definition.mjs.map +1 -0
  829. package/_mjs/data/Tag/constructors.mjs +9 -0
  830. package/_mjs/data/Tag/constructors.mjs.map +1 -0
  831. package/_mjs/data/Tag/definition.mjs +36 -0
  832. package/_mjs/data/Tag/definition.mjs.map +1 -0
  833. package/_mjs/data/Tag.mjs +4 -0
  834. package/_mjs/data/Tag.mjs.map +1 -0
  835. package/_mjs/data/These/constructors.mjs +26 -0
  836. package/_mjs/data/These/constructors.mjs.map +1 -0
  837. package/_mjs/data/These/definition.mjs +46 -0
  838. package/_mjs/data/These/definition.mjs.map +1 -0
  839. package/_mjs/data/These/destructors.mjs +22 -0
  840. package/_mjs/data/These/destructors.mjs.map +1 -0
  841. package/_mjs/data/These.mjs +5 -0
  842. package/_mjs/data/These.mjs.map +1 -0
  843. package/_mjs/data/Trace/api.mjs +19 -0
  844. package/_mjs/data/Trace/api.mjs.map +1 -0
  845. package/_mjs/data/Trace/constructors.mjs +16 -0
  846. package/_mjs/data/Trace/constructors.mjs.map +1 -0
  847. package/_mjs/data/Trace/definition.mjs +12 -0
  848. package/_mjs/data/Trace/definition.mjs.map +1 -0
  849. package/_mjs/data/Trace.mjs +5 -0
  850. package/_mjs/data/Trace.mjs.map +1 -0
  851. package/_mjs/data/TraceElement/definition.mjs +62 -0
  852. package/_mjs/data/TraceElement/definition.mjs.map +1 -0
  853. package/_mjs/data/TraceElement.mjs +3 -0
  854. package/_mjs/data/TraceElement.mjs.map +1 -0
  855. package/_mjs/data/exceptions/ArrayIndexOutOfBoundsError.mjs +10 -0
  856. package/_mjs/data/exceptions/ArrayIndexOutOfBoundsError.mjs.map +1 -0
  857. package/_mjs/data/exceptions/IllegalArgumentError.mjs +11 -0
  858. package/_mjs/data/exceptions/IllegalArgumentError.mjs.map +1 -0
  859. package/_mjs/data/exceptions/IllegalStateError.mjs +10 -0
  860. package/_mjs/data/exceptions/IllegalStateError.mjs.map +1 -0
  861. package/_mjs/data/exceptions/IndexOutOfBoundsError.mjs +10 -0
  862. package/_mjs/data/exceptions/IndexOutOfBoundsError.mjs.map +1 -0
  863. package/_mjs/data/exceptions/InterruptedException.mjs +13 -0
  864. package/_mjs/data/exceptions/InterruptedException.mjs.map +1 -0
  865. package/_mjs/data/exceptions/InvalidCapacityError.mjs +12 -0
  866. package/_mjs/data/exceptions/InvalidCapacityError.mjs.map +1 -0
  867. package/_mjs/data/exceptions/NoSuchElementError.mjs +10 -0
  868. package/_mjs/data/exceptions/NoSuchElementError.mjs.map +1 -0
  869. package/_mjs/data/exceptions.mjs +9 -0
  870. package/_mjs/data/exceptions.mjs.map +1 -0
  871. package/_mjs/data/function/api.mjs +37 -0
  872. package/_mjs/data/function/api.mjs.map +1 -0
  873. package/_mjs/data/function/definition.mjs +2 -0
  874. package/_mjs/data/function/definition.mjs.map +1 -0
  875. package/_mjs/data/function/pipe.mjs +67 -0
  876. package/_mjs/data/function/pipe.mjs.map +1 -0
  877. package/_mjs/data/function.mjs +5 -0
  878. package/_mjs/data/function.mjs.map +1 -0
  879. package/_mjs/data/number/api.mjs +7 -0
  880. package/_mjs/data/number/api.mjs.map +1 -0
  881. package/_mjs/data/number/definition.mjs +2 -0
  882. package/_mjs/data/number/definition.mjs.map +1 -0
  883. package/_mjs/data/number/instances.mjs +20 -0
  884. package/_mjs/data/number/instances.mjs.map +1 -0
  885. package/_mjs/data/number.mjs +5 -0
  886. package/_mjs/data/number.mjs.map +1 -0
  887. package/_mjs/data/object/definition.mjs +2 -0
  888. package/_mjs/data/object/definition.mjs.map +1 -0
  889. package/_mjs/data/object.mjs +3 -0
  890. package/_mjs/data/object.mjs.map +1 -0
  891. package/_mjs/data/string/api.mjs +192 -0
  892. package/_mjs/data/string/api.mjs.map +1 -0
  893. package/_mjs/data/string/definition.mjs +2 -0
  894. package/_mjs/data/string/definition.mjs.map +1 -0
  895. package/_mjs/data/string/instances.mjs +36 -0
  896. package/_mjs/data/string/instances.mjs.map +1 -0
  897. package/_mjs/data/string.mjs +5 -0
  898. package/_mjs/data/string.mjs.map +1 -0
  899. package/_mjs/global/api.mjs +4 -0
  900. package/_mjs/global/api.mjs.map +1 -0
  901. package/_mjs/internal/AtomicBoolean.mjs +8 -0
  902. package/_mjs/internal/AtomicBoolean.mjs.map +1 -0
  903. package/_mjs/internal/AtomicNumber.mjs +26 -0
  904. package/_mjs/internal/AtomicNumber.mjs.map +1 -0
  905. package/_mjs/internal/AtomicReference.mjs +31 -0
  906. package/_mjs/internal/AtomicReference.mjs.map +1 -0
  907. package/_mjs/internal/Stack.mjs +56 -0
  908. package/_mjs/internal/Stack.mjs.map +1 -0
  909. package/_mjs/optics/At/api.mjs +12 -0
  910. package/_mjs/optics/At/api.mjs.map +1 -0
  911. package/_mjs/optics/At/definition.mjs +19 -0
  912. package/_mjs/optics/At/definition.mjs.map +1 -0
  913. package/_mjs/optics/At.mjs +4 -0
  914. package/_mjs/optics/At.mjs.map +1 -0
  915. package/_mjs/optics/Fold/definition.mjs +12 -0
  916. package/_mjs/optics/Fold/definition.mjs.map +1 -0
  917. package/_mjs/optics/Fold.mjs +3 -0
  918. package/_mjs/optics/Fold.mjs.map +1 -0
  919. package/_mjs/optics/Getter/definition.mjs +13 -0
  920. package/_mjs/optics/Getter/definition.mjs.map +1 -0
  921. package/_mjs/optics/Getter.mjs +3 -0
  922. package/_mjs/optics/Getter.mjs.map +1 -0
  923. package/_mjs/optics/Index/api.mjs +22 -0
  924. package/_mjs/optics/Index/api.mjs.map +1 -0
  925. package/_mjs/optics/Index/definition.mjs +11 -0
  926. package/_mjs/optics/Index/definition.mjs.map +1 -0
  927. package/_mjs/optics/Index.mjs +4 -0
  928. package/_mjs/optics/Index.mjs.map +1 -0
  929. package/_mjs/optics/Iso/api.mjs +13 -0
  930. package/_mjs/optics/Iso/api.mjs.map +1 -0
  931. package/_mjs/optics/Iso/definition.mjs +34 -0
  932. package/_mjs/optics/Iso/definition.mjs.map +1 -0
  933. package/_mjs/optics/Iso.mjs +4 -0
  934. package/_mjs/optics/Iso.mjs.map +1 -0
  935. package/_mjs/optics/Lens/api.mjs +140 -0
  936. package/_mjs/optics/Lens/api.mjs.map +1 -0
  937. package/_mjs/optics/Lens/definition.mjs +29 -0
  938. package/_mjs/optics/Lens/definition.mjs.map +1 -0
  939. package/_mjs/optics/Lens.mjs +4 -0
  940. package/_mjs/optics/Lens.mjs.map +1 -0
  941. package/_mjs/optics/Optional/api/compose.mjs +14 -0
  942. package/_mjs/optics/Optional/api/compose.mjs.map +1 -0
  943. package/_mjs/optics/Optional/definition.mjs +35 -0
  944. package/_mjs/optics/Optional/definition.mjs.map +1 -0
  945. package/_mjs/optics/Optional.mjs +6 -0
  946. package/_mjs/optics/Optional.mjs.map +1 -0
  947. package/_mjs/optics/Prism/api/compose.mjs +15 -0
  948. package/_mjs/optics/Prism/api/compose.mjs.map +1 -0
  949. package/_mjs/optics/Prism/api/fromNullable.mjs +14 -0
  950. package/_mjs/optics/Prism/api/fromNullable.mjs.map +1 -0
  951. package/_mjs/optics/Prism/api/just.mjs +15 -0
  952. package/_mjs/optics/Prism/api/just.mjs.map +1 -0
  953. package/_mjs/optics/Prism/definition.mjs +28 -0
  954. package/_mjs/optics/Prism/definition.mjs.map +1 -0
  955. package/_mjs/optics/Prism.mjs +8 -0
  956. package/_mjs/optics/Prism.mjs.map +1 -0
  957. package/_mjs/optics/Setter/definition.mjs +23 -0
  958. package/_mjs/optics/Setter/definition.mjs.map +1 -0
  959. package/_mjs/optics/Setter.mjs +3 -0
  960. package/_mjs/optics/Setter.mjs.map +1 -0
  961. package/_mjs/optics/Traversal/api/compose.mjs +11 -0
  962. package/_mjs/optics/Traversal/api/compose.mjs.map +1 -0
  963. package/_mjs/optics/Traversal/api/fromTraversable.mjs +10 -0
  964. package/_mjs/optics/Traversal/api/fromTraversable.mjs.map +1 -0
  965. package/_mjs/optics/Traversal/definition.mjs +33 -0
  966. package/_mjs/optics/Traversal/definition.mjs.map +1 -0
  967. package/_mjs/optics/Traversal.mjs +7 -0
  968. package/_mjs/optics/Traversal.mjs.map +1 -0
  969. package/_mjs/typeclass/Align.mjs +13 -0
  970. package/_mjs/typeclass/Align.mjs.map +1 -0
  971. package/_mjs/typeclass/Alt.mjs +10 -0
  972. package/_mjs/typeclass/Alt.mjs.map +1 -0
  973. package/_mjs/typeclass/Alternative.mjs +15 -0
  974. package/_mjs/typeclass/Alternative.mjs.map +1 -0
  975. package/_mjs/typeclass/Applicative.mjs +14 -0
  976. package/_mjs/typeclass/Applicative.mjs.map +1 -0
  977. package/_mjs/typeclass/ApplicativeExcept.mjs +33 -0
  978. package/_mjs/typeclass/ApplicativeExcept.mjs.map +1 -0
  979. package/_mjs/typeclass/Apply.mjs +114 -0
  980. package/_mjs/typeclass/Apply.mjs.map +1 -0
  981. package/_mjs/typeclass/Chain.mjs +18 -0
  982. package/_mjs/typeclass/Chain.mjs.map +1 -0
  983. package/_mjs/typeclass/Closure.mjs +12 -0
  984. package/_mjs/typeclass/Closure.mjs.map +1 -0
  985. package/_mjs/typeclass/Eq.mjs +12 -0
  986. package/_mjs/typeclass/Eq.mjs.map +1 -0
  987. package/_mjs/typeclass/Equatable/api.mjs +31 -0
  988. package/_mjs/typeclass/Equatable/api.mjs.map +1 -0
  989. package/_mjs/typeclass/Equatable/definition.mjs +12 -0
  990. package/_mjs/typeclass/Equatable/definition.mjs.map +1 -0
  991. package/_mjs/typeclass/Equatable/fast-equals.mjs +476 -0
  992. package/_mjs/typeclass/Equatable/fast-equals.mjs.map +1 -0
  993. package/_mjs/typeclass/Equatable.mjs +5 -0
  994. package/_mjs/typeclass/Equatable.mjs.map +1 -0
  995. package/_mjs/typeclass/Fail.mjs +11 -0
  996. package/_mjs/typeclass/Fail.mjs.map +1 -0
  997. package/_mjs/typeclass/Filterable.mjs +16 -0
  998. package/_mjs/typeclass/Filterable.mjs.map +1 -0
  999. package/_mjs/typeclass/FilterableWithIndex.mjs +18 -0
  1000. package/_mjs/typeclass/FilterableWithIndex.mjs.map +1 -0
  1001. package/_mjs/typeclass/Foldable.mjs +19 -0
  1002. package/_mjs/typeclass/Foldable.mjs.map +1 -0
  1003. package/_mjs/typeclass/FoldableWithIndex.mjs +20 -0
  1004. package/_mjs/typeclass/FoldableWithIndex.mjs.map +1 -0
  1005. package/_mjs/typeclass/Functor.mjs +15 -0
  1006. package/_mjs/typeclass/Functor.mjs.map +1 -0
  1007. package/_mjs/typeclass/FunctorWithIndex.mjs +14 -0
  1008. package/_mjs/typeclass/FunctorWithIndex.mjs.map +1 -0
  1009. package/_mjs/typeclass/Has.mjs +10 -0
  1010. package/_mjs/typeclass/Has.mjs.map +1 -0
  1011. package/_mjs/typeclass/Hash.mjs +9 -0
  1012. package/_mjs/typeclass/Hash.mjs.map +1 -0
  1013. package/_mjs/typeclass/HashEq.mjs +32 -0
  1014. package/_mjs/typeclass/HashEq.mjs.map +1 -0
  1015. package/_mjs/typeclass/Hashable/definition.mjs +12 -0
  1016. package/_mjs/typeclass/Hashable/definition.mjs.map +1 -0
  1017. package/_mjs/typeclass/Hashable/hash.mjs +242 -0
  1018. package/_mjs/typeclass/Hashable/hash.mjs.map +1 -0
  1019. package/_mjs/typeclass/Hashable.mjs +4 -0
  1020. package/_mjs/typeclass/Hashable.mjs.map +1 -0
  1021. package/_mjs/typeclass/Monad.mjs +14 -0
  1022. package/_mjs/typeclass/Monad.mjs.map +1 -0
  1023. package/_mjs/typeclass/MonadExcept.mjs +17 -0
  1024. package/_mjs/typeclass/MonadExcept.mjs.map +1 -0
  1025. package/_mjs/typeclass/Monoid.mjs +12 -0
  1026. package/_mjs/typeclass/Monoid.mjs.map +1 -0
  1027. package/_mjs/typeclass/Nil.mjs +2 -0
  1028. package/_mjs/typeclass/Nil.mjs.map +1 -0
  1029. package/_mjs/typeclass/Ord/api/contramap.mjs +12 -0
  1030. package/_mjs/typeclass/Ord/api/contramap.mjs.map +1 -0
  1031. package/_mjs/typeclass/Ord/api/max.mjs +8 -0
  1032. package/_mjs/typeclass/Ord/api/max.mjs.map +1 -0
  1033. package/_mjs/typeclass/Ord/api/min.mjs +8 -0
  1034. package/_mjs/typeclass/Ord/api/min.mjs.map +1 -0
  1035. package/_mjs/typeclass/Ord/api.mjs +5 -0
  1036. package/_mjs/typeclass/Ord/api.mjs.map +1 -0
  1037. package/_mjs/typeclass/Ord/definition.mjs +13 -0
  1038. package/_mjs/typeclass/Ord/definition.mjs.map +1 -0
  1039. package/_mjs/typeclass/Ord/instances.mjs +34 -0
  1040. package/_mjs/typeclass/Ord/instances.mjs.map +1 -0
  1041. package/_mjs/typeclass/Ord.mjs +5 -0
  1042. package/_mjs/typeclass/Ord.mjs.map +1 -0
  1043. package/_mjs/typeclass/Ordering.mjs +42 -0
  1044. package/_mjs/typeclass/Ordering.mjs.map +1 -0
  1045. package/_mjs/typeclass/Pointed.mjs +10 -0
  1046. package/_mjs/typeclass/Pointed.mjs.map +1 -0
  1047. package/_mjs/typeclass/Semialign.mjs +84 -0
  1048. package/_mjs/typeclass/Semialign.mjs.map +1 -0
  1049. package/_mjs/typeclass/Semigroup/api.mjs +22 -0
  1050. package/_mjs/typeclass/Semigroup/api.mjs.map +1 -0
  1051. package/_mjs/typeclass/Semigroup/definition.mjs +8 -0
  1052. package/_mjs/typeclass/Semigroup/definition.mjs.map +1 -0
  1053. package/_mjs/typeclass/Semigroup.mjs +4 -0
  1054. package/_mjs/typeclass/Semigroup.mjs.map +1 -0
  1055. package/_mjs/typeclass/Semimonoidal.mjs +9 -0
  1056. package/_mjs/typeclass/Semimonoidal.mjs.map +1 -0
  1057. package/_mjs/typeclass/Showable/definition.mjs +13 -0
  1058. package/_mjs/typeclass/Showable/definition.mjs.map +1 -0
  1059. package/_mjs/typeclass/Showable/show.mjs +796 -0
  1060. package/_mjs/typeclass/Showable/show.mjs.map +1 -0
  1061. package/_mjs/typeclass/Showable/styles.mjs +22 -0
  1062. package/_mjs/typeclass/Showable/styles.mjs.map +1 -0
  1063. package/_mjs/typeclass/Showable/util.mjs +368 -0
  1064. package/_mjs/typeclass/Showable/util.mjs.map +1 -0
  1065. package/_mjs/typeclass/Showable.mjs +3 -0
  1066. package/_mjs/typeclass/Showable.mjs.map +1 -0
  1067. package/_mjs/typeclass/Traversable.mjs +32 -0
  1068. package/_mjs/typeclass/Traversable.mjs.map +1 -0
  1069. package/_mjs/typeclass/TraversableWithIndex.mjs +27 -0
  1070. package/_mjs/typeclass/TraversableWithIndex.mjs.map +1 -0
  1071. package/_mjs/typeclass/Witherable.mjs +40 -0
  1072. package/_mjs/typeclass/Witherable.mjs.map +1 -0
  1073. package/_mjs/typeclass/WitherableWithIndex.mjs +45 -0
  1074. package/_mjs/typeclass/WitherableWithIndex.mjs.map +1 -0
  1075. package/_mjs/typeclass/builtin/Symbol.mjs +2 -0
  1076. package/_mjs/typeclass/builtin/Symbol.mjs.map +1 -0
  1077. package/_mjs/typeclass/builtin.mjs +3 -0
  1078. package/_mjs/typeclass/builtin.mjs.map +1 -0
  1079. package/_mjs/typeclass.mjs +38 -0
  1080. package/_mjs/typeclass.mjs.map +1 -0
  1081. package/_mjs/types/extractions.mjs +2 -0
  1082. package/_mjs/types/extractions.mjs.map +1 -0
  1083. package/_mjs/types/test.mjs +2 -0
  1084. package/_mjs/types/test.mjs.map +1 -0
  1085. package/_mjs/types/utility.mjs +2 -0
  1086. package/_mjs/types/utility.mjs.map +1 -0
  1087. package/_mjs/types.mjs +5 -0
  1088. package/_mjs/types.mjs.map +1 -0
  1089. package/_mjs/util/AnsiFormat.mjs +244 -0
  1090. package/_mjs/util/AnsiFormat.mjs.map +1 -0
  1091. package/_mjs/util/PCGRandom.mjs +166 -0
  1092. package/_mjs/util/PCGRandom.mjs.map +1 -0
  1093. package/_mjs/util/assert.mjs +13 -0
  1094. package/_mjs/util/assert.mjs.map +1 -0
  1095. package/_mjs/util/pattern.mjs +9 -0
  1096. package/_mjs/util/pattern.mjs.map +1 -0
  1097. package/_mjs/util/predicates.mjs +93 -0
  1098. package/_mjs/util/predicates.mjs.map +1 -0
  1099. package/_mjs/util/rand/Random.mjs +92 -0
  1100. package/_mjs/util/rand/Random.mjs.map +1 -0
  1101. package/_mjs/util/rand/distribution/Distribution.mjs +2 -0
  1102. package/_mjs/util/rand/distribution/Distribution.mjs.map +1 -0
  1103. package/_mjs/util/rand/distribution/UniformArrayIntDistribution.mjs +26 -0
  1104. package/_mjs/util/rand/distribution/UniformArrayIntDistribution.mjs.map +1 -0
  1105. package/_mjs/util/rand/distribution/UniformBigIntDistribution.mjs +45 -0
  1106. package/_mjs/util/rand/distribution/UniformBigIntDistribution.mjs.map +1 -0
  1107. package/_mjs/util/rand/distribution/UniformIntDistribution.mjs +62 -0
  1108. package/_mjs/util/rand/distribution/UniformIntDistribution.mjs.map +1 -0
  1109. package/_mjs/util/rand/distribution/internals/ArrayInt.mjs +203 -0
  1110. package/_mjs/util/rand/distribution/internals/ArrayInt.mjs.map +1 -0
  1111. package/_mjs/util/rand/distribution/internals/UniformArrayIntDistributionInternal.mjs +37 -0
  1112. package/_mjs/util/rand/distribution/internals/UniformArrayIntDistributionInternal.mjs.map +1 -0
  1113. package/_mjs/util/rand/distribution/internals/UniformIntDistributionInternal.mjs +49 -0
  1114. package/_mjs/util/rand/distribution/internals/UniformIntDistributionInternal.mjs.map +1 -0
  1115. package/_mjs/util/rand/generator/MersenneTwister.mjs +106 -0
  1116. package/_mjs/util/rand/generator/MersenneTwister.mjs.map +1 -0
  1117. package/_mjs/util/rand/generator/RandomGenerator.mjs +17 -0
  1118. package/_mjs/util/rand/generator/RandomGenerator.mjs.map +1 -0
  1119. package/_mjs/util/rand.mjs +9 -0
  1120. package/_mjs/util/rand.mjs.map +1 -0
  1121. package/_src/collection/Iterable/api/traverseConc.ts +40 -0
  1122. package/_src/collection/Iterable/api.ts +690 -0
  1123. package/_src/collection/Iterable/constructors.ts +73 -0
  1124. package/_src/collection/Iterable/definition.ts +15 -0
  1125. package/_src/collection/Iterable.ts +5 -0
  1126. package/_src/collection/compat/Array/api.ts +53 -0
  1127. package/_src/collection/compat/Array/definition.ts +21 -0
  1128. package/_src/collection/compat/Array.ts +4 -0
  1129. package/_src/collection/compat/ArrayLike/api.ts +26 -0
  1130. package/_src/collection/compat/ArrayLike/definition.ts +11 -0
  1131. package/_src/collection/immutable/Conc/api/empty.ts +8 -0
  1132. package/_src/collection/immutable/Conc/api/makeBy.ts +16 -0
  1133. package/_src/collection/immutable/Conc/api/replicate.ts +6 -0
  1134. package/_src/collection/immutable/Conc/api.ts +1146 -0
  1135. package/_src/collection/immutable/Conc/constructors.ts +38 -0
  1136. package/_src/collection/immutable/Conc/definition.ts +785 -0
  1137. package/_src/collection/immutable/Conc.ts +11 -0
  1138. package/_src/collection/immutable/Dictionary/api.ts +49 -0
  1139. package/_src/collection/immutable/Dictionary/definition.ts +21 -0
  1140. package/_src/collection/immutable/HashMap/api.ts +731 -0
  1141. package/_src/collection/immutable/HashMap/definition.ts +128 -0
  1142. package/_src/collection/immutable/HashMap/internal.ts +380 -0
  1143. package/_src/collection/immutable/HashMap.ts +4 -0
  1144. package/_src/collection/immutable/HashSet/api.ts +481 -0
  1145. package/_src/collection/immutable/HashSet/definition.ts +402 -0
  1146. package/_src/collection/immutable/HashSet.ts +4 -0
  1147. package/_src/collection/immutable/ImmutableArray/api.ts +1519 -0
  1148. package/_src/collection/immutable/ImmutableArray/constructors.ts +47 -0
  1149. package/_src/collection/immutable/ImmutableArray/definition.ts +39 -0
  1150. package/_src/collection/immutable/ImmutableArray/instances.ts +168 -0
  1151. package/_src/collection/immutable/ImmutableArray.ts +6 -0
  1152. package/_src/collection/immutable/ImmutableNonEmptyArray/api.ts +513 -0
  1153. package/_src/collection/immutable/ImmutableNonEmptyArray/constructors.ts +66 -0
  1154. package/_src/collection/immutable/ImmutableNonEmptyArray/definition.ts +31 -0
  1155. package/_src/collection/immutable/ImmutableNonEmptyArray/destructors.ts +41 -0
  1156. package/_src/collection/immutable/ImmutableNonEmptyArray/instances.ts +115 -0
  1157. package/_src/collection/immutable/ImmutableNonEmptyArray.ts +7 -0
  1158. package/_src/collection/immutable/List/api/foldLeft.ts +12 -0
  1159. package/_src/collection/immutable/List/api/unsafeTail.ts +9 -0
  1160. package/_src/collection/immutable/List/api.ts +354 -0
  1161. package/_src/collection/immutable/List/constructors.ts +64 -0
  1162. package/_src/collection/immutable/List/definition.ts +91 -0
  1163. package/_src/collection/immutable/List.ts +10 -0
  1164. package/_src/collection/immutable/Queue/api.ts +142 -0
  1165. package/_src/collection/immutable/Queue/constructors.ts +16 -0
  1166. package/_src/collection/immutable/Queue/definition.ts +34 -0
  1167. package/_src/collection/immutable/Queue/guards.ts +8 -0
  1168. package/_src/collection/immutable/Queue.ts +6 -0
  1169. package/_src/collection/immutable/SortedMap/api.ts +540 -0
  1170. package/_src/collection/immutable/SortedMap/definition.ts +17 -0
  1171. package/_src/collection/immutable/SortedMap/internal.ts +358 -0
  1172. package/_src/collection/immutable/SortedMap/iterator.ts +304 -0
  1173. package/_src/collection/immutable/SortedMap/node.ts +21 -0
  1174. package/_src/collection/immutable/SortedMap.ts +7 -0
  1175. package/_src/collection/immutable/Vector/api.ts +1335 -0
  1176. package/_src/collection/immutable/Vector/definition.ts +96 -0
  1177. package/_src/collection/immutable/Vector/internal.ts +1438 -0
  1178. package/_src/collection/immutable/Vector.ts +4 -0
  1179. package/_src/collection/mutable/HashMap.ts +338 -0
  1180. package/_src/collection/mutable/HashSet.ts +254 -0
  1181. package/_src/collection/mutable/ListBuffer.ts +123 -0
  1182. package/_src/collection/mutable/internal.ts +26 -0
  1183. package/_src/control/Eval/api/sequenceArray.ts +6 -0
  1184. package/_src/control/Eval/api.ts +93 -0
  1185. package/_src/control/Eval/constructors.ts +30 -0
  1186. package/_src/control/Eval/definition.ts +67 -0
  1187. package/_src/control/Eval/instance.ts +31 -0
  1188. package/_src/control/Eval/run.ts +41 -0
  1189. package/_src/control/Eval.ts +7 -0
  1190. package/_src/control/LazyValue.ts +24 -0
  1191. package/_src/control/Z/api.ts +619 -0
  1192. package/_src/control/Z/definition.ts +189 -0
  1193. package/_src/control/Z/instances.ts +14 -0
  1194. package/_src/control/Z/runtime.ts +291 -0
  1195. package/_src/control/Z.ts +6 -0
  1196. package/_src/data/Byte.ts +1 -0
  1197. package/_src/data/CaseClass.ts +112 -0
  1198. package/_src/data/Cause/api/fold.ts +104 -0
  1199. package/_src/data/Cause/api/isEmpty.ts +46 -0
  1200. package/_src/data/Cause/api/linearize.ts +16 -0
  1201. package/_src/data/Cause/api/prettyPrint.ts +38 -0
  1202. package/_src/data/Cause/api/unified.ts +67 -0
  1203. package/_src/data/Cause/api.ts +984 -0
  1204. package/_src/data/Cause/definition.ts +521 -0
  1205. package/_src/data/Cause.ts +4 -0
  1206. package/_src/data/Const/api.ts +16 -0
  1207. package/_src/data/Const/definition.ts +11 -0
  1208. package/_src/data/Const/instances.ts +34 -0
  1209. package/_src/data/Const.ts +5 -0
  1210. package/_src/data/Duration/api.ts +69 -0
  1211. package/_src/data/Duration/definition.ts +25 -0
  1212. package/_src/data/Duration.ts +4 -0
  1213. package/_src/data/Either/api/align.ts +8 -0
  1214. package/_src/data/Either/api/alignWith.ts +21 -0
  1215. package/_src/data/Either/api.ts +200 -0
  1216. package/_src/data/Either/constructors.ts +77 -0
  1217. package/_src/data/Either/definition.ts +48 -0
  1218. package/_src/data/Either/destructors.ts +13 -0
  1219. package/_src/data/Either/instances.ts +80 -0
  1220. package/_src/data/Either.ts +7 -0
  1221. package/_src/data/Environment/api.ts +78 -0
  1222. package/_src/data/Environment/definition.ts +32 -0
  1223. package/_src/data/Environment.ts +4 -0
  1224. package/_src/data/ExecutionStrategy.ts +81 -0
  1225. package/_src/data/Exit/api.ts +172 -0
  1226. package/_src/data/Exit/constructors.ts +55 -0
  1227. package/_src/data/Exit/definition.ts +102 -0
  1228. package/_src/data/Exit.ts +5 -0
  1229. package/_src/data/FiberId/api.ts +45 -0
  1230. package/_src/data/FiberId/constructors.ts +21 -0
  1231. package/_src/data/FiberId/definition.ts +91 -0
  1232. package/_src/data/FiberId.ts +5 -0
  1233. package/_src/data/Identity/api.ts +28 -0
  1234. package/_src/data/Identity/definition.ts +11 -0
  1235. package/_src/data/Identity/instances.ts +21 -0
  1236. package/_src/data/Identity.ts +5 -0
  1237. package/_src/data/Maybe/api.ts +187 -0
  1238. package/_src/data/Maybe/constructors.ts +84 -0
  1239. package/_src/data/Maybe/definition.ts +91 -0
  1240. package/_src/data/Maybe/destructors.ts +11 -0
  1241. package/_src/data/Maybe/instances.ts +53 -0
  1242. package/_src/data/Maybe.ts +7 -0
  1243. package/_src/data/Newtype.ts +66 -0
  1244. package/_src/data/Patch/api.ts +75 -0
  1245. package/_src/data/Patch/definition.ts +58 -0
  1246. package/_src/data/Patch.ts +4 -0
  1247. package/_src/data/Predicate/api.ts +27 -0
  1248. package/_src/data/Predicate/definition.ts +10 -0
  1249. package/_src/data/Predicate.ts +4 -0
  1250. package/_src/data/Refinement/api.ts +29 -0
  1251. package/_src/data/Refinement/definition.ts +13 -0
  1252. package/_src/data/Refinement.ts +4 -0
  1253. package/_src/data/Struct/api.ts +22 -0
  1254. package/_src/data/Struct/definition.ts +23 -0
  1255. package/_src/data/Tag/constructors.ts +6 -0
  1256. package/_src/data/Tag/definition.ts +31 -0
  1257. package/_src/data/Tag.ts +4 -0
  1258. package/_src/data/These/constructors.ts +25 -0
  1259. package/_src/data/These/definition.ts +47 -0
  1260. package/_src/data/These/destructors.ts +20 -0
  1261. package/_src/data/These.ts +5 -0
  1262. package/_src/data/Trace/api.ts +13 -0
  1263. package/_src/data/Trace/constructors.ts +13 -0
  1264. package/_src/data/Trace/definition.ts +9 -0
  1265. package/_src/data/Trace.ts +5 -0
  1266. package/_src/data/TraceElement/definition.ts +69 -0
  1267. package/_src/data/TraceElement.ts +3 -0
  1268. package/_src/data/exceptions/ArrayIndexOutOfBoundsError.ts +9 -0
  1269. package/_src/data/exceptions/IllegalArgumentError.ts +9 -0
  1270. package/_src/data/exceptions/IllegalStateError.ts +9 -0
  1271. package/_src/data/exceptions/IndexOutOfBoundsError.ts +9 -0
  1272. package/_src/data/exceptions/InterruptedException.ts +13 -0
  1273. package/_src/data/exceptions/InvalidCapacityError.ts +12 -0
  1274. package/_src/data/exceptions/NoSuchElementError.ts +9 -0
  1275. package/_src/data/exceptions.ts +9 -0
  1276. package/_src/data/function/api.ts +39 -0
  1277. package/_src/data/function/definition.ts +31 -0
  1278. package/_src/data/function/pipe.ts +301 -0
  1279. package/_src/data/function.ts +5 -0
  1280. package/_src/data/number/api.ts +6 -0
  1281. package/_src/data/number/definition.ts +13 -0
  1282. package/_src/data/number/instances.ts +15 -0
  1283. package/_src/data/number.ts +5 -0
  1284. package/_src/data/object/definition.ts +12 -0
  1285. package/_src/data/object.ts +3 -0
  1286. package/_src/data/string/api.ts +182 -0
  1287. package/_src/data/string/definition.ts +13 -0
  1288. package/_src/data/string/instances.ts +24 -0
  1289. package/_src/data/string.ts +5 -0
  1290. package/_src/global/api.ts +23 -0
  1291. package/_src/internal/AtomicBoolean.ts +7 -0
  1292. package/_src/internal/AtomicNumber.ts +28 -0
  1293. package/_src/internal/AtomicReference.ts +28 -0
  1294. package/_src/internal/Stack.ts +52 -0
  1295. package/_src/optics/At/api.ts +10 -0
  1296. package/_src/optics/At/definition.ts +32 -0
  1297. package/_src/optics/At.ts +4 -0
  1298. package/_src/optics/Fold/definition.ts +38 -0
  1299. package/_src/optics/Fold.ts +3 -0
  1300. package/_src/optics/Getter/definition.ts +34 -0
  1301. package/_src/optics/Getter.ts +3 -0
  1302. package/_src/optics/Index/api.ts +19 -0
  1303. package/_src/optics/Index/definition.ts +24 -0
  1304. package/_src/optics/Index.ts +4 -0
  1305. package/_src/optics/Iso/api.ts +11 -0
  1306. package/_src/optics/Iso/definition.ts +52 -0
  1307. package/_src/optics/Iso.ts +4 -0
  1308. package/_src/optics/Lens/api.ts +132 -0
  1309. package/_src/optics/Lens/definition.ts +51 -0
  1310. package/_src/optics/Lens.ts +4 -0
  1311. package/_src/optics/Optional/api/compose.ts +15 -0
  1312. package/_src/optics/Optional/definition.ts +90 -0
  1313. package/_src/optics/Optional.ts +7 -0
  1314. package/_src/optics/Prism/api/compose.ts +12 -0
  1315. package/_src/optics/Prism/api/fromNullable.ts +12 -0
  1316. package/_src/optics/Prism/api/just.ts +11 -0
  1317. package/_src/optics/Prism/definition.ts +59 -0
  1318. package/_src/optics/Prism.ts +9 -0
  1319. package/_src/optics/Setter/definition.ts +66 -0
  1320. package/_src/optics/Setter.ts +3 -0
  1321. package/_src/optics/Traversal/api/compose.ts +13 -0
  1322. package/_src/optics/Traversal/api/fromTraversable.ts +50 -0
  1323. package/_src/optics/Traversal/definition.ts +73 -0
  1324. package/_src/optics/Traversal.ts +8 -0
  1325. package/_src/typeclass/Align.ts +28 -0
  1326. package/_src/typeclass/Alt.ts +105 -0
  1327. package/_src/typeclass/Alternative.ts +31 -0
  1328. package/_src/typeclass/Applicative.ts +31 -0
  1329. package/_src/typeclass/ApplicativeExcept.ts +226 -0
  1330. package/_src/typeclass/Apply.ts +634 -0
  1331. package/_src/typeclass/Chain.ts +226 -0
  1332. package/_src/typeclass/Closure.ts +36 -0
  1333. package/_src/typeclass/Eq.ts +36 -0
  1334. package/_src/typeclass/Equatable/api.ts +34 -0
  1335. package/_src/typeclass/Equatable/definition.ts +22 -0
  1336. package/_src/typeclass/Equatable/fast-equals.ts +498 -0
  1337. package/_src/typeclass/Equatable.ts +5 -0
  1338. package/_src/typeclass/Fail.ts +40 -0
  1339. package/_src/typeclass/Filterable.ts +139 -0
  1340. package/_src/typeclass/FilterableWithIndex.ts +143 -0
  1341. package/_src/typeclass/Foldable.ts +73 -0
  1342. package/_src/typeclass/FoldableWithIndex.ts +96 -0
  1343. package/_src/typeclass/Functor.ts +76 -0
  1344. package/_src/typeclass/FunctorWithIndex.ts +43 -0
  1345. package/_src/typeclass/Has.ts +19 -0
  1346. package/_src/typeclass/Hash.ts +17 -0
  1347. package/_src/typeclass/HashEq.ts +44 -0
  1348. package/_src/typeclass/Hashable/definition.ts +22 -0
  1349. package/_src/typeclass/Hashable/hash.ts +208 -0
  1350. package/_src/typeclass/Hashable.ts +4 -0
  1351. package/_src/typeclass/Monad.ts +26 -0
  1352. package/_src/typeclass/MonadExcept.ts +47 -0
  1353. package/_src/typeclass/Monoid.ts +31 -0
  1354. package/_src/typeclass/Nil.ts +23 -0
  1355. package/_src/typeclass/Ord/api/contramap.ts +13 -0
  1356. package/_src/typeclass/Ord/api/max.ts +9 -0
  1357. package/_src/typeclass/Ord/api/min.ts +9 -0
  1358. package/_src/typeclass/Ord/api.ts +5 -0
  1359. package/_src/typeclass/Ord/definition.ts +43 -0
  1360. package/_src/typeclass/Ord/instances.ts +30 -0
  1361. package/_src/typeclass/Ord.ts +5 -0
  1362. package/_src/typeclass/Ordering.ts +42 -0
  1363. package/_src/typeclass/Pointed.ts +37 -0
  1364. package/_src/typeclass/Semialign.ts +551 -0
  1365. package/_src/typeclass/Semigroup/api.ts +21 -0
  1366. package/_src/typeclass/Semigroup/definition.ts +24 -0
  1367. package/_src/typeclass/Semigroup.ts +4 -0
  1368. package/_src/typeclass/Semimonoidal.ts +97 -0
  1369. package/_src/typeclass/Showable/definition.ts +23 -0
  1370. package/_src/typeclass/Showable/show.ts +914 -0
  1371. package/_src/typeclass/Showable/styles.ts +57 -0
  1372. package/_src/typeclass/Showable/util.ts +385 -0
  1373. package/_src/typeclass/Showable.ts +2 -0
  1374. package/_src/typeclass/Traversable.ts +177 -0
  1375. package/_src/typeclass/TraversableWithIndex.ts +142 -0
  1376. package/_src/typeclass/Witherable.ts +303 -0
  1377. package/_src/typeclass/WitherableWithIndex.ts +359 -0
  1378. package/_src/typeclass/builtin/Symbol.ts +8 -0
  1379. package/_src/typeclass/builtin.ts +3 -0
  1380. package/_src/typeclass.ts +38 -0
  1381. package/_src/types/extractions.ts +11 -0
  1382. package/_src/types/test.ts +0 -0
  1383. package/_src/types/utility.ts +9 -0
  1384. package/_src/types.ts +5 -0
  1385. package/_src/util/AnsiFormat.ts +259 -0
  1386. package/_src/util/PCGRandom.ts +191 -0
  1387. package/_src/util/assert.ts +11 -0
  1388. package/_src/util/pattern.ts +35 -0
  1389. package/_src/util/predicates.ts +144 -0
  1390. package/_src/util/rand/Random.ts +100 -0
  1391. package/_src/util/rand/distribution/Distribution.ts +10 -0
  1392. package/_src/util/rand/distribution/UniformArrayIntDistribution.ts +49 -0
  1393. package/_src/util/rand/distribution/UniformBigIntDistribution.ts +62 -0
  1394. package/_src/util/rand/distribution/UniformIntDistribution.ts +75 -0
  1395. package/_src/util/rand/distribution/internals/ArrayInt.ts +200 -0
  1396. package/_src/util/rand/distribution/internals/UniformArrayIntDistributionInternal.ts +43 -0
  1397. package/_src/util/rand/distribution/internals/UniformIntDistributionInternal.ts +47 -0
  1398. package/_src/util/rand/generator/MersenneTwister.ts +160 -0
  1399. package/_src/util/rand/generator/RandomGenerator.ts +22 -0
  1400. package/_src/util/rand.ts +20 -0
  1401. package/collection/Iterable/api/traverseConc.d.ts +13 -0
  1402. package/collection/Iterable/api.d.ts +172 -0
  1403. package/collection/Iterable/constructors.d.ts +25 -0
  1404. package/collection/Iterable/definition.d.ts +14 -0
  1405. package/collection/Iterable.d.ts +3 -0
  1406. package/collection/compat/Array/api.d.ts +32 -0
  1407. package/collection/compat/Array/definition.d.ts +20 -0
  1408. package/collection/compat/Array.d.ts +2 -0
  1409. package/collection/compat/ArrayLike/api.d.ts +5 -0
  1410. package/collection/compat/ArrayLike/definition.d.ts +13 -0
  1411. package/collection/immutable/Conc/api/empty.d.ts +6 -0
  1412. package/collection/immutable/Conc/api/makeBy.d.ts +7 -0
  1413. package/collection/immutable/Conc/api/replicate.d.ts +6 -0
  1414. package/collection/immutable/Conc/api.d.ts +368 -0
  1415. package/collection/immutable/Conc/constructors.d.ts +27 -0
  1416. package/collection/immutable/Conc/definition.d.ts +213 -0
  1417. package/collection/immutable/Conc.d.ts +6 -0
  1418. package/collection/immutable/Dictionary/api.d.ts +27 -0
  1419. package/collection/immutable/Dictionary/definition.d.ts +19 -0
  1420. package/collection/immutable/HashMap/api.d.ts +336 -0
  1421. package/collection/immutable/HashMap/definition.d.ts +44 -0
  1422. package/collection/immutable/HashMap/internal.d.ts +67 -0
  1423. package/collection/immutable/HashMap.d.ts +2 -0
  1424. package/collection/immutable/HashSet/api.d.ts +170 -0
  1425. package/collection/immutable/HashSet/definition.d.ts +97 -0
  1426. package/collection/immutable/HashSet.d.ts +2 -0
  1427. package/collection/immutable/ImmutableArray/api.d.ts +680 -0
  1428. package/collection/immutable/ImmutableArray/constructors.d.ts +32 -0
  1429. package/collection/immutable/ImmutableArray/definition.d.ts +25 -0
  1430. package/collection/immutable/ImmutableArray/instances.d.ts +18 -0
  1431. package/collection/immutable/ImmutableArray.d.ts +4 -0
  1432. package/collection/immutable/ImmutableNonEmptyArray/api.d.ts +205 -0
  1433. package/collection/immutable/ImmutableNonEmptyArray/constructors.d.ts +45 -0
  1434. package/collection/immutable/ImmutableNonEmptyArray/definition.d.ts +28 -0
  1435. package/collection/immutable/ImmutableNonEmptyArray/destructors.d.ts +32 -0
  1436. package/collection/immutable/ImmutableNonEmptyArray/instances.d.ts +52 -0
  1437. package/collection/immutable/ImmutableNonEmptyArray.d.ts +5 -0
  1438. package/collection/immutable/List/api/foldLeft.d.ts +6 -0
  1439. package/collection/immutable/List/api/unsafeTail.d.ts +6 -0
  1440. package/collection/immutable/List/api.d.ts +100 -0
  1441. package/collection/immutable/List/constructors.d.ts +27 -0
  1442. package/collection/immutable/List/definition.d.ts +40 -0
  1443. package/collection/immutable/List.d.ts +5 -0
  1444. package/collection/immutable/Queue/api.d.ts +78 -0
  1445. package/collection/immutable/Queue/constructors.d.ts +11 -0
  1446. package/collection/immutable/Queue/definition.d.ts +12 -0
  1447. package/collection/immutable/Queue/guards.d.ts +6 -0
  1448. package/collection/immutable/Queue.d.ts +4 -0
  1449. package/collection/immutable/SortedMap/api.d.ts +134 -0
  1450. package/collection/immutable/SortedMap/definition.d.ts +13 -0
  1451. package/collection/immutable/SortedMap/internal.d.ts +8 -0
  1452. package/collection/immutable/SortedMap/iterator.d.ts +64 -0
  1453. package/collection/immutable/SortedMap/node.d.ts +16 -0
  1454. package/collection/immutable/SortedMap.d.ts +5 -0
  1455. package/collection/immutable/Vector/api.d.ts +596 -0
  1456. package/collection/immutable/Vector/definition.d.ts +66 -0
  1457. package/collection/immutable/Vector/internal.d.ts +199 -0
  1458. package/collection/immutable/Vector.d.ts +2 -0
  1459. package/collection/mutable/HashMap.d.ts +55 -0
  1460. package/collection/mutable/HashSet.d.ts +48 -0
  1461. package/collection/mutable/ListBuffer.d.ts +19 -0
  1462. package/collection/mutable/internal.d.ts +4 -0
  1463. package/control/Eval/api/sequenceArray.d.ts +6 -0
  1464. package/control/Eval/api.d.ts +53 -0
  1465. package/control/Eval/constructors.d.ts +19 -0
  1466. package/control/Eval/definition.d.ts +59 -0
  1467. package/control/Eval/instance.d.ts +17 -0
  1468. package/control/Eval/run.d.ts +7 -0
  1469. package/control/Eval.d.ts +5 -0
  1470. package/control/LazyValue.d.ts +15 -0
  1471. package/control/Z/api.d.ts +343 -0
  1472. package/control/Z/definition.d.ts +135 -0
  1473. package/control/Z/instances.d.ts +7 -0
  1474. package/control/Z/runtime.d.ts +55 -0
  1475. package/control/Z.d.ts +4 -0
  1476. package/data/Byte.d.ts +1 -0
  1477. package/data/CaseClass.d.ts +26 -0
  1478. package/data/Cause/api/fold.d.ts +19 -0
  1479. package/data/Cause/api/isEmpty.d.ts +7 -0
  1480. package/data/Cause/api/linearize.d.ts +7 -0
  1481. package/data/Cause/api/prettyPrint.d.ts +6 -0
  1482. package/data/Cause/api/unified.d.ts +9 -0
  1483. package/data/Cause/api.d.ts +283 -0
  1484. package/data/Cause/definition.d.ts +130 -0
  1485. package/data/Cause.d.ts +2 -0
  1486. package/data/Const/api.d.ts +12 -0
  1487. package/data/Const/definition.d.ts +12 -0
  1488. package/data/Const/instances.d.ts +20 -0
  1489. package/data/Const.d.ts +3 -0
  1490. package/data/Duration/api.d.ts +52 -0
  1491. package/data/Duration/definition.d.ts +16 -0
  1492. package/data/Duration.d.ts +2 -0
  1493. package/data/Either/api/align.d.ts +3 -0
  1494. package/data/Either/api/alignWith.d.ts +7 -0
  1495. package/data/Either/api.d.ts +128 -0
  1496. package/data/Either/constructors.d.ts +50 -0
  1497. package/data/Either/definition.d.ts +40 -0
  1498. package/data/Either/destructors.d.ts +6 -0
  1499. package/data/Either/instances.d.ts +21 -0
  1500. package/data/Either.d.ts +5 -0
  1501. package/data/Environment/api.d.ts +45 -0
  1502. package/data/Environment/definition.d.ts +25 -0
  1503. package/data/Environment.d.ts +2 -0
  1504. package/data/ExecutionStrategy.d.ts +45 -0
  1505. package/data/Exit/api.d.ts +99 -0
  1506. package/data/Exit/constructors.d.ts +45 -0
  1507. package/data/Exit/definition.d.ts +70 -0
  1508. package/data/Exit.d.ts +3 -0
  1509. package/data/FiberId/api.d.ts +17 -0
  1510. package/data/FiberId/constructors.d.ts +17 -0
  1511. package/data/FiberId/definition.d.ts +65 -0
  1512. package/data/FiberId.d.ts +3 -0
  1513. package/data/Identity/api.d.ts +22 -0
  1514. package/data/Identity/definition.d.ts +10 -0
  1515. package/data/Identity/instances.d.ts +21 -0
  1516. package/data/Identity.d.ts +3 -0
  1517. package/data/Maybe/api.d.ts +125 -0
  1518. package/data/Maybe/constructors.d.ts +47 -0
  1519. package/data/Maybe/definition.d.ts +59 -0
  1520. package/data/Maybe/destructors.d.ts +8 -0
  1521. package/data/Maybe/instances.d.ts +15 -0
  1522. package/data/Maybe.d.ts +5 -0
  1523. package/data/Newtype.d.ts +36 -0
  1524. package/data/Patch/api.d.ts +24 -0
  1525. package/data/Patch/definition.d.ts +44 -0
  1526. package/data/Patch.d.ts +2 -0
  1527. package/data/Predicate/api.d.ts +21 -0
  1528. package/data/Predicate/definition.d.ts +9 -0
  1529. package/data/Predicate.d.ts +2 -0
  1530. package/data/Refinement/api.d.ts +23 -0
  1531. package/data/Refinement/definition.d.ts +12 -0
  1532. package/data/Refinement.d.ts +2 -0
  1533. package/data/Struct/api.d.ts +12 -0
  1534. package/data/Struct/definition.d.ts +19 -0
  1535. package/data/Tag/constructors.d.ts +6 -0
  1536. package/data/Tag/definition.d.ts +19 -0
  1537. package/data/Tag.d.ts +2 -0
  1538. package/data/These/constructors.d.ts +19 -0
  1539. package/data/These/definition.d.ts +45 -0
  1540. package/data/These/destructors.d.ts +6 -0
  1541. package/data/These.d.ts +3 -0
  1542. package/data/Trace/api.d.ts +12 -0
  1543. package/data/Trace/constructors.d.ts +14 -0
  1544. package/data/Trace/definition.d.ts +12 -0
  1545. package/data/Trace.d.ts +3 -0
  1546. package/data/TraceElement/definition.d.ts +39 -0
  1547. package/data/TraceElement.d.ts +1 -0
  1548. package/data/exceptions/ArrayIndexOutOfBoundsError.d.ts +5 -0
  1549. package/data/exceptions/IllegalArgumentError.d.ts +6 -0
  1550. package/data/exceptions/IllegalStateError.d.ts +5 -0
  1551. package/data/exceptions/IndexOutOfBoundsError.d.ts +5 -0
  1552. package/data/exceptions/InterruptedException.d.ts +8 -0
  1553. package/data/exceptions/InvalidCapacityError.d.ts +5 -0
  1554. package/data/exceptions/NoSuchElementError.d.ts +5 -0
  1555. package/data/exceptions.d.ts +7 -0
  1556. package/data/function/api.d.ts +27 -0
  1557. package/data/function/definition.d.ts +30 -0
  1558. package/data/function/pipe.d.ts +25 -0
  1559. package/data/function.d.ts +3 -0
  1560. package/data/number/api.d.ts +5 -0
  1561. package/data/number/definition.d.ts +13 -0
  1562. package/data/number/instances.d.ts +11 -0
  1563. package/data/number.d.ts +3 -0
  1564. package/data/object/definition.d.ts +13 -0
  1565. package/data/object.d.ts +1 -0
  1566. package/data/string/api.d.ts +145 -0
  1567. package/data/string/definition.d.ts +13 -0
  1568. package/data/string/instances.d.ts +21 -0
  1569. package/data/string.d.ts +3 -0
  1570. package/global/api.d.ts +8 -0
  1571. package/internal/AtomicBoolean.d.ts +4 -0
  1572. package/internal/AtomicNumber.d.ts +7 -0
  1573. package/internal/AtomicReference.d.ts +9 -0
  1574. package/internal/Stack.d.ts +28 -0
  1575. package/optics/At/api.d.ts +7 -0
  1576. package/optics/At/definition.d.ts +22 -0
  1577. package/optics/At.d.ts +2 -0
  1578. package/optics/Fold/definition.d.ts +28 -0
  1579. package/optics/Fold.d.ts +1 -0
  1580. package/optics/Getter/definition.d.ts +24 -0
  1581. package/optics/Getter.d.ts +1 -0
  1582. package/optics/Index/api.d.ts +14 -0
  1583. package/optics/Index/definition.d.ts +19 -0
  1584. package/optics/Index.d.ts +2 -0
  1585. package/optics/Iso/api.d.ts +6 -0
  1586. package/optics/Iso/definition.d.ts +40 -0
  1587. package/optics/Iso.d.ts +2 -0
  1588. package/optics/Lens/api.d.ts +49 -0
  1589. package/optics/Lens/definition.d.ts +40 -0
  1590. package/optics/Lens.d.ts +2 -0
  1591. package/optics/Optional/api/compose.d.ts +6 -0
  1592. package/optics/Optional/definition.d.ts +62 -0
  1593. package/optics/Optional.d.ts +2 -0
  1594. package/optics/Prism/api/compose.d.ts +6 -0
  1595. package/optics/Prism/api/fromNullable.d.ts +6 -0
  1596. package/optics/Prism/api/just.d.ts +7 -0
  1597. package/optics/Prism/definition.d.ts +42 -0
  1598. package/optics/Prism.d.ts +4 -0
  1599. package/optics/Setter/definition.d.ts +51 -0
  1600. package/optics/Setter.d.ts +1 -0
  1601. package/optics/Traversal/api/compose.d.ts +6 -0
  1602. package/optics/Traversal/api/fromTraversable.d.ts +8 -0
  1603. package/optics/Traversal/definition.d.ts +46 -0
  1604. package/optics/Traversal.d.ts +3 -0
  1605. package/package.json +16 -0
  1606. package/typeclass/Align.d.ts +21 -0
  1607. package/typeclass/Alt.d.ts +30 -0
  1608. package/typeclass/Alternative.d.ts +23 -0
  1609. package/typeclass/Applicative.d.ts +20 -0
  1610. package/typeclass/ApplicativeExcept.d.ts +60 -0
  1611. package/typeclass/Apply.d.ts +103 -0
  1612. package/typeclass/Chain.d.ts +39 -0
  1613. package/typeclass/Closure.d.ts +27 -0
  1614. package/typeclass/Eq.d.ts +27 -0
  1615. package/typeclass/Equatable/api.d.ts +11 -0
  1616. package/typeclass/Equatable/definition.d.ts +18 -0
  1617. package/typeclass/Equatable/fast-equals.d.ts +202 -0
  1618. package/typeclass/Equatable.d.ts +3 -0
  1619. package/typeclass/Fail.d.ts +23 -0
  1620. package/typeclass/Filterable.d.ts +68 -0
  1621. package/typeclass/FilterableWithIndex.d.ts +67 -0
  1622. package/typeclass/Foldable.d.ts +47 -0
  1623. package/typeclass/FoldableWithIndex.d.ts +49 -0
  1624. package/typeclass/Functor.d.ts +37 -0
  1625. package/typeclass/FunctorWithIndex.d.ts +27 -0
  1626. package/typeclass/Has.d.ts +16 -0
  1627. package/typeclass/Hash.d.ts +14 -0
  1628. package/typeclass/HashEq.d.ts +30 -0
  1629. package/typeclass/Hashable/definition.d.ts +18 -0
  1630. package/typeclass/Hashable/hash.d.ts +55 -0
  1631. package/typeclass/Hashable.d.ts +2 -0
  1632. package/typeclass/Monad.d.ts +19 -0
  1633. package/typeclass/MonadExcept.d.ts +32 -0
  1634. package/typeclass/Monoid.d.ts +22 -0
  1635. package/typeclass/Nil.d.ts +13 -0
  1636. package/typeclass/Ord/api/contramap.d.ts +6 -0
  1637. package/typeclass/Ord/api/max.d.ts +7 -0
  1638. package/typeclass/Ord/api/min.d.ts +7 -0
  1639. package/typeclass/Ord/api.d.ts +3 -0
  1640. package/typeclass/Ord/definition.d.ts +31 -0
  1641. package/typeclass/Ord/instances.d.ts +13 -0
  1642. package/typeclass/Ord.d.ts +3 -0
  1643. package/typeclass/Ordering.d.ts +32 -0
  1644. package/typeclass/Pointed.d.ts +21 -0
  1645. package/typeclass/Semialign.d.ts +84 -0
  1646. package/typeclass/Semigroup/api.d.ts +12 -0
  1647. package/typeclass/Semigroup/definition.d.ts +20 -0
  1648. package/typeclass/Semigroup.d.ts +2 -0
  1649. package/typeclass/Semimonoidal.d.ts +25 -0
  1650. package/typeclass/Showable/definition.d.ts +17 -0
  1651. package/typeclass/Showable/show.d.ts +54 -0
  1652. package/typeclass/Showable/styles.d.ts +8 -0
  1653. package/typeclass/Showable/util.d.ts +38 -0
  1654. package/typeclass/Showable.d.ts +2 -0
  1655. package/typeclass/Traversable.d.ts +71 -0
  1656. package/typeclass/TraversableWithIndex.d.ts +64 -0
  1657. package/typeclass/Witherable.d.ts +98 -0
  1658. package/typeclass/WitherableWithIndex.d.ts +114 -0
  1659. package/typeclass/builtin/Symbol.d.ts +8 -0
  1660. package/typeclass/builtin.d.ts +1 -0
  1661. package/typeclass.d.ts +36 -0
  1662. package/types/extractions.d.ts +12 -0
  1663. package/types/test.d.ts +1 -0
  1664. package/types/utility.d.ts +8 -0
  1665. package/types.d.ts +3 -0
  1666. package/util/AnsiFormat.d.ts +107 -0
  1667. package/util/PCGRandom.d.ts +50 -0
  1668. package/util/assert.d.ts +5 -0
  1669. package/util/pattern.d.ts +68 -0
  1670. package/util/predicates.d.ts +36 -0
  1671. package/util/rand/Random.d.ts +69 -0
  1672. package/util/rand/distribution/Distribution.d.ts +9 -0
  1673. package/util/rand/distribution/UniformArrayIntDistribution.d.ts +23 -0
  1674. package/util/rand/distribution/UniformBigIntDistribution.d.ts +22 -0
  1675. package/util/rand/distribution/UniformIntDistribution.d.ts +22 -0
  1676. package/util/rand/distribution/internals/ArrayInt.d.ts +57 -0
  1677. package/util/rand/distribution/internals/UniformArrayIntDistributionInternal.d.ts +12 -0
  1678. package/util/rand/distribution/internals/UniformIntDistributionInternal.d.ts +6 -0
  1679. package/util/rand/generator/MersenneTwister.d.ts +11 -0
  1680. package/util/rand/generator/RandomGenerator.d.ts +10 -0
  1681. package/util/rand.d.ts +9 -0
@@ -0,0 +1,1557 @@
1
+ /*
2
+ * -------------------------------------------------------------------------------------------------
3
+ * Internal
4
+ * -------------------------------------------------------------------------------------------------
5
+ */
6
+
7
+ /**
8
+ * @internal
9
+ */
10
+ export class VectorIterator {
11
+ constructor(l, direction) {
12
+ this.l = l;
13
+ this.result = {
14
+ done: false,
15
+ value: undefined
16
+ };
17
+ this.idx = direction === 1 ? -1 : l.length;
18
+ this.prefixSize = getPrefixSize(l);
19
+ this.middleSize = l.length - getSuffixSize(l);
20
+
21
+ if (l.root !== undefined) {
22
+ const depth = getDepth(l);
23
+ this.stack = new Array(depth + 1);
24
+ this.indices = new Array(depth + 1);
25
+ let currentNode = l.root.array;
26
+
27
+ for (let i = depth; 0 <= i; --i) {
28
+ this.stack[i] = currentNode;
29
+ const idx = direction === 1 ? 0 : currentNode.length - 1;
30
+ this.indices[i] = idx;
31
+ currentNode = currentNode[idx].array;
32
+ }
33
+
34
+ this.indices[0] -= direction;
35
+ }
36
+ }
37
+
38
+ }
39
+ /**
40
+ * @internal
41
+ */
42
+
43
+ export class ForwardVectorIterator extends VectorIterator {
44
+ constructor(l) {
45
+ super(l, 1);
46
+ }
47
+
48
+ nextInTree() {
49
+ for (var i = 0; ++this.indices[i] === this.stack[i].length; ++i) {
50
+ this.indices[i] = 0;
51
+ }
52
+
53
+ for (; 0 < i; --i) {
54
+ this.stack[i - 1] = this.stack[i][this.indices[i]].array;
55
+ }
56
+ }
57
+
58
+ next() {
59
+ let newVal;
60
+ const idx = ++this.idx;
61
+
62
+ if (idx < this.prefixSize) {
63
+ newVal = this.l.prefix[this.prefixSize - idx - 1];
64
+ } else if (idx < this.middleSize) {
65
+ this.nextInTree();
66
+ newVal = this.stack[0][this.indices[0]];
67
+ } else if (idx < this.l.length) {
68
+ newVal = this.l.suffix[idx - this.middleSize];
69
+ } else {
70
+ this.result.done = true;
71
+ }
72
+
73
+ this.result.value = newVal;
74
+ return this.result;
75
+ }
76
+
77
+ }
78
+ /**
79
+ * @internal
80
+ */
81
+
82
+ export class BackwardVectorIterator extends VectorIterator {
83
+ constructor(l) {
84
+ super(l, -1);
85
+ }
86
+
87
+ prevInTree() {
88
+ for (var i = 0; this.indices[i] === 0; ++i) {//
89
+ }
90
+
91
+ --this.indices[i];
92
+
93
+ for (; 0 < i; --i) {
94
+ const n = this.stack[i][this.indices[i]].array;
95
+ this.stack[i - 1] = n;
96
+ this.indices[i - 1] = n.length - 1;
97
+ }
98
+ }
99
+
100
+ next() {
101
+ let newVal;
102
+ const idx = --this.idx;
103
+
104
+ if (this.middleSize <= idx) {
105
+ newVal = this.l.suffix[idx - this.middleSize];
106
+ } else if (this.prefixSize <= idx) {
107
+ this.prevInTree();
108
+ newVal = this.stack[0][this.indices[0]];
109
+ } else if (0 <= idx) {
110
+ newVal = this.l.prefix[this.prefixSize - idx - 1];
111
+ } else {
112
+ this.result.done = true;
113
+ }
114
+
115
+ this.result.value = newVal;
116
+ return this.result;
117
+ }
118
+
119
+ }
120
+ /**
121
+ * @internal
122
+ */
123
+
124
+ const branchingFactor = 32;
125
+ /**
126
+ * @internal
127
+ */
128
+
129
+ export const branchBits = 5;
130
+ /**
131
+ * @internal
132
+ */
133
+
134
+ export const mask = 31;
135
+ /** @internal */
136
+
137
+ export class Node {
138
+ constructor(sizes, array) {
139
+ this.sizes = sizes;
140
+ this.array = array;
141
+ }
142
+
143
+ }
144
+ /**
145
+ * @internal
146
+ */
147
+
148
+ function elementEquals(a, b) {
149
+ return a === b;
150
+ }
151
+ /**
152
+ * @internal
153
+ */
154
+
155
+
156
+ function createPath(depth, value) {
157
+ let current = value;
158
+
159
+ for (let i = 0; i < depth; ++i) {
160
+ current = new Node(undefined, [current]);
161
+ }
162
+
163
+ return current;
164
+ } // Array Helpers
165
+
166
+ /**
167
+ * @internal
168
+ */
169
+
170
+
171
+ export function copyArray(source) {
172
+ const array = [];
173
+
174
+ for (let i = 0; i < source.length; ++i) {
175
+ array[i] = source[i];
176
+ }
177
+
178
+ return array;
179
+ }
180
+ /**
181
+ * @internal
182
+ */
183
+
184
+ function pushElements(source, target, offset, amount) {
185
+ for (let i = offset; i < offset + amount; ++i) {
186
+ target.push(source[i]);
187
+ }
188
+ }
189
+ /**
190
+ * @internal
191
+ */
192
+
193
+
194
+ function copyIndices(source, sourceStart, target, targetStart, length) {
195
+ for (let i = 0; i < length; ++i) {
196
+ target[targetStart + i] = source[sourceStart + i];
197
+ }
198
+ }
199
+ /**
200
+ * @internal
201
+ */
202
+
203
+
204
+ function arrayPrepend(value, array) {
205
+ const newLength = array.length + 1;
206
+ const result = new Array(newLength);
207
+ result[0] = value;
208
+
209
+ for (let i = 1; i < newLength; ++i) {
210
+ result[i] = array[i - 1];
211
+ }
212
+
213
+ return result;
214
+ }
215
+ /**
216
+ * Create a reverse _copy_ of an array.
217
+ * @internal
218
+ */
219
+
220
+
221
+ export function reverseArray(array) {
222
+ return array.slice().reverse();
223
+ }
224
+ /**
225
+ * @internal
226
+ */
227
+
228
+ function arrayFirst(array) {
229
+ return array[0];
230
+ }
231
+ /**
232
+ * @internal
233
+ */
234
+
235
+
236
+ function arrayLast(array) {
237
+ return array[array.length - 1];
238
+ }
239
+
240
+ const pathResult = {
241
+ path: 0,
242
+ index: 0,
243
+ updatedOffset: 0
244
+ };
245
+ /**
246
+ * @internal
247
+ */
248
+
249
+ function getPath(index, offset, depth, sizes) {
250
+ let i = index;
251
+
252
+ if (sizes === undefined && offset !== 0) {
253
+ pathResult.updatedOffset = 0;
254
+ i = handleOffset(depth, offset, i);
255
+ }
256
+
257
+ let path = i >> depth * branchBits & mask;
258
+
259
+ if (sizes !== undefined) {
260
+ while (sizes[path] <= i) {
261
+ path++;
262
+ }
263
+
264
+ const traversed = path === 0 ? 0 : sizes[path - 1];
265
+ i -= traversed;
266
+ pathResult.updatedOffset = offset;
267
+ }
268
+
269
+ pathResult.path = path;
270
+ pathResult.index = i;
271
+ return pathResult;
272
+ }
273
+ /**
274
+ * @internal
275
+ */
276
+
277
+
278
+ export function updateNode(node, depth, index, offset, value) {
279
+ const {
280
+ path,
281
+ index: newIndex,
282
+ updatedOffset
283
+ } = getPath(index, offset, depth, node.sizes);
284
+ const array = copyArray(node.array);
285
+ array[path] = depth > 0 ? updateNode(array[path], depth - 1, newIndex, updatedOffset, value) : value;
286
+ return new Node(node.sizes, array);
287
+ }
288
+ /**
289
+ * @internal
290
+ */
291
+
292
+ function cloneNode({
293
+ sizes,
294
+ array
295
+ }) {
296
+ return new Node(sizes === undefined ? undefined : copyArray(sizes), copyArray(array));
297
+ } // This array should not be mutated. Thus a dummy element is placed in
298
+ // it. Thus the affix will not be owned and thus not mutated.
299
+
300
+ /**
301
+ * @internal
302
+ */
303
+
304
+
305
+ export const emptyAffix = [0]; // We store a bit field in Vector. From right to left, the first five
306
+ // bits are suffix length, the next five are prefix length and the
307
+ // rest is depth. The functions below are for working with the bits in
308
+ // a sane way.
309
+
310
+ /**
311
+ * @internal
312
+ */
313
+
314
+ const affixBits = 6;
315
+ /**
316
+ * @internal
317
+ */
318
+
319
+ const affixMask = 0b111111;
320
+ /**
321
+ * @internal
322
+ */
323
+
324
+ export function getSuffixSize(l) {
325
+ return l.bits & affixMask;
326
+ }
327
+ /**
328
+ * @internal
329
+ */
330
+
331
+ export function getPrefixSize(l) {
332
+ return l.bits >> affixBits & affixMask;
333
+ }
334
+ /**
335
+ * @internal
336
+ */
337
+
338
+ export function getDepth(l) {
339
+ return l.bits >> affixBits * 2;
340
+ }
341
+ /**
342
+ * @internal
343
+ */
344
+
345
+ export function setPrefix(size, bits) {
346
+ return size << affixBits | bits & ~(affixMask << affixBits);
347
+ }
348
+ /**
349
+ * @internal
350
+ */
351
+
352
+ export function setSuffix(size, bits) {
353
+ return size | bits & ~affixMask;
354
+ }
355
+ /**
356
+ * @internal
357
+ */
358
+
359
+ export function setDepth(depth, bits) {
360
+ return depth << affixBits * 2 | bits & (affixMask | affixMask << affixBits);
361
+ }
362
+ /**
363
+ * @internal
364
+ */
365
+
366
+ export function incrementPrefix(bits) {
367
+ return bits + (1 << affixBits);
368
+ }
369
+ /**
370
+ * @internal
371
+ */
372
+
373
+ export function incrementSuffix(bits) {
374
+ return bits + 1;
375
+ }
376
+ /**
377
+ * @internal
378
+ */
379
+
380
+ export function incrementDepth(bits) {
381
+ return bits + (1 << affixBits * 2);
382
+ }
383
+ /**
384
+ * @internal
385
+ */
386
+
387
+ export function decrementDepth(bits) {
388
+ return bits - (1 << affixBits * 2);
389
+ }
390
+ /**
391
+ * Appends the value to the Vector by _mutating_ the Vector and its content.
392
+ *
393
+ * @tsplus fluent fncts.base.MutableVector push
394
+ */
395
+
396
+ export function push(l, value) {
397
+ const suffixSize = getSuffixSize(l);
398
+
399
+ if (l.length === 0) {
400
+ l.bits = setPrefix(1, l.bits);
401
+ l.prefix = [value];
402
+ } else if (suffixSize < 32) {
403
+ l.bits = incrementSuffix(l.bits);
404
+ l.suffix.push(value);
405
+ } else if (l.root === undefined) {
406
+ l.root = new Node(undefined, l.suffix);
407
+ l.suffix = [value];
408
+ l.bits = setSuffix(1, l.bits);
409
+ } else {
410
+ const newNode = new Node(undefined, l.suffix);
411
+ const index = l.length - 1 - 32 + 1;
412
+ let current = l.root;
413
+ let depth = getDepth(l);
414
+ l.suffix = [value];
415
+ l.bits = setSuffix(1, l.bits);
416
+
417
+ if (index - 1 < branchingFactor ** (depth + 1)) {
418
+ for (; depth >= 0; --depth) {
419
+ const path = index >> depth * branchBits & mask;
420
+
421
+ if (path < current.array.length) {
422
+ current = current.array[path];
423
+ } else {
424
+ current.array.push(createPath(depth - 1, newNode));
425
+ break;
426
+ }
427
+ }
428
+ } else {
429
+ l.bits = incrementDepth(l.bits);
430
+ l.root = new Node(undefined, [l.root, createPath(depth, newNode)]);
431
+ }
432
+ }
433
+
434
+ l.length++;
435
+ return l;
436
+ }
437
+ /**
438
+ * @internal
439
+ */
440
+
441
+ export function nodeNthDense(node, depth, index) {
442
+ let current = node; // eslint-disable-next-line no-param-reassign
443
+
444
+ for (; depth >= 0; --depth) {
445
+ current = current.array[index >> depth * branchBits & mask];
446
+ }
447
+
448
+ return current;
449
+ }
450
+ /**
451
+ * @internal
452
+ */
453
+
454
+ export function handleOffset(depth, offset, index) {
455
+ let i = index;
456
+ i += offset; // eslint-disable-next-line no-param-reassign
457
+
458
+ for (; depth >= 0; --depth) {
459
+ i = index - (offset & mask << depth * branchBits);
460
+
461
+ if ((index >> depth * branchBits & mask) !== 0) {
462
+ break;
463
+ }
464
+ }
465
+
466
+ return i;
467
+ }
468
+ /**
469
+ * @internal
470
+ */
471
+
472
+ export function nodeNth(node, depth, offset, index) {
473
+ let path;
474
+ let current = node;
475
+ let i = index;
476
+ let ofs = offset;
477
+ let dep = depth;
478
+
479
+ while (current.sizes !== undefined) {
480
+ path = i >> dep * branchBits & mask;
481
+
482
+ while (current.sizes[path] <= i) {
483
+ path++;
484
+ }
485
+
486
+ if (path !== 0) {
487
+ i -= current.sizes[path - 1];
488
+ ofs = 0; // Offset is discarded if the left spine isn't traversed
489
+ }
490
+
491
+ dep--;
492
+ current = current.array[path];
493
+ }
494
+
495
+ return nodeNthDense(current, dep, ofs === 0 ? i : handleOffset(dep, ofs, i));
496
+ }
497
+ /**
498
+ * @internal
499
+ */
500
+
501
+ export function setSizes(node, height) {
502
+ let sum = 0;
503
+ const sizeTable = [];
504
+
505
+ for (let i = 0; i < node.array.length; ++i) {
506
+ sum += sizeOfSubtree(node.array[i], height - 1);
507
+ sizeTable[i] = sum;
508
+ }
509
+
510
+ node.sizes = sizeTable;
511
+ return node;
512
+ }
513
+ /**
514
+ * Returns the number of elements stored in the node.
515
+ *
516
+ * @internal
517
+ */
518
+
519
+ function sizeOfSubtree(node, height) {
520
+ if (height !== 0) {
521
+ if (node.sizes !== undefined) {
522
+ return arrayLast(node.sizes);
523
+ } else {
524
+ // the node is leftwise dense so all all but the last child are full
525
+ const lastSize = sizeOfSubtree(arrayLast(node.array), height - 1);
526
+ return (node.array.length - 1 << height * branchBits) + lastSize;
527
+ }
528
+ } else {
529
+ return node.array.length;
530
+ }
531
+ } // prepend & append
532
+
533
+ /**
534
+ * @internal
535
+ */
536
+
537
+
538
+ export function affixPush(a, array, length) {
539
+ if (array.length === length) {
540
+ array.push(a);
541
+ return array;
542
+ } else {
543
+ const newArray = [];
544
+ copyIndices(array, 0, newArray, 0, length);
545
+ newArray.push(a);
546
+ return newArray;
547
+ }
548
+ }
549
+ /**
550
+ * Traverses down the left edge of the tree and copies k nodes.
551
+ * Returns the last copied node.
552
+ *
553
+ * @internal
554
+ */
555
+
556
+ function copyLeft(l, k) {
557
+ let currentNode = cloneNode(l.root); // copy root
558
+
559
+ l.root = currentNode; // install copy of root
560
+
561
+ for (let i = 1; i < k; ++i) {
562
+ const index = 0; // go left
563
+
564
+ if (currentNode.sizes !== undefined) {
565
+ for (let i = 0; i < currentNode.sizes.length; ++i) {
566
+ currentNode.sizes[i] += 32;
567
+ }
568
+ }
569
+
570
+ const newNode = cloneNode(currentNode.array[index]); // Install the copied node
571
+
572
+ currentNode.array[index] = newNode;
573
+ currentNode = newNode;
574
+ }
575
+
576
+ return currentNode;
577
+ }
578
+ /**
579
+ * Prepends an element to a node
580
+ *
581
+ * @internal
582
+ */
583
+
584
+
585
+ function nodePrepend(value, size, node) {
586
+ const array = arrayPrepend(value, node.array);
587
+ let sizes = undefined;
588
+
589
+ if (node.sizes !== undefined) {
590
+ sizes = new Array(node.sizes.length + 1);
591
+ sizes[0] = size;
592
+
593
+ for (let i = 0; i < node.sizes.length; ++i) {
594
+ sizes[i + 1] = node.sizes[i] + size;
595
+ }
596
+ }
597
+
598
+ return new Node(sizes, array);
599
+ }
600
+ /**
601
+ * Prepends a node to a tree. Either by shifting the nodes in the root
602
+ * left or by increasing the height
603
+ *
604
+ * @internal
605
+ */
606
+
607
+
608
+ function prependTopTree(l, depth, node) {
609
+ let newOffset;
610
+
611
+ if (l.root.array.length < branchingFactor) {
612
+ // There is space in the root, there is never a size table in this
613
+ // case
614
+ newOffset = 32 ** depth - 32;
615
+ l.root = new Node(undefined, arrayPrepend(createPath(depth - 1, node), l.root.array));
616
+ } else {
617
+ // We need to create a new root
618
+ l.bits = incrementDepth(l.bits);
619
+ const sizes = l.root.sizes === undefined ? undefined : [32, arrayLast(l.root.sizes) + 32];
620
+ newOffset = depth === 0 ? 0 : 32 ** (depth + 1) - 32;
621
+ l.root = new Node(sizes, [createPath(depth, node), l.root]);
622
+ }
623
+
624
+ return newOffset;
625
+ }
626
+ /**
627
+ * Takes a Vector and a node tail. It then prepends the node to the tree
628
+ * of the Vector.
629
+ *
630
+ * @internal
631
+ */
632
+
633
+
634
+ export function prependNodeToTree(l, array) {
635
+ if (l.root === undefined) {
636
+ if (getSuffixSize(l) === 0) {
637
+ // ensure invariant 1
638
+ l.bits = setSuffix(array.length, l.bits);
639
+ l.suffix = array;
640
+ } else {
641
+ l.root = new Node(undefined, array);
642
+ }
643
+
644
+ return l;
645
+ } else {
646
+ const node = new Node(undefined, array);
647
+ const depth = getDepth(l);
648
+ let newOffset = 0;
649
+
650
+ if (l.root.sizes === undefined) {
651
+ if (l.offset !== 0) {
652
+ newOffset = l.offset - branchingFactor;
653
+ l.root = prependDense(l.root, depth, l.offset, node);
654
+ } else {
655
+ // in this case we can be sure that the is not room in the tree
656
+ // for the new node
657
+ newOffset = prependTopTree(l, depth, node);
658
+ }
659
+ } else {
660
+ // represents how many nodes _with size-tables_ that we should copy.
661
+ let copyableCount = 0; // go down while there is size tables
662
+
663
+ let nodesTraversed = 0;
664
+ let currentNode = l.root;
665
+
666
+ while (currentNode.sizes !== undefined && nodesTraversed < depth) {
667
+ ++nodesTraversed;
668
+
669
+ if (currentNode.array.length < 32) {
670
+ // there is room if offset is > 0 or if the first node does not
671
+ // contain as many nodes as it possibly can
672
+ copyableCount = nodesTraversed;
673
+ }
674
+
675
+ currentNode = currentNode.array[0];
676
+ }
677
+
678
+ if (l.offset !== 0) {
679
+ const copiedNode = copyLeft(l, nodesTraversed);
680
+
681
+ for (let i = 0; i < copiedNode.sizes.length; ++i) {
682
+ copiedNode.sizes[i] += branchingFactor;
683
+ }
684
+
685
+ copiedNode.array[0] = prependDense(copiedNode.array[0], depth - nodesTraversed, l.offset, node);
686
+ l.offset = l.offset - branchingFactor;
687
+ return l;
688
+ } else {
689
+ if (copyableCount === 0) {
690
+ l.offset = prependTopTree(l, depth, node);
691
+ } else {
692
+ let parent;
693
+ let prependableNode; // Copy the part of the path with size tables
694
+
695
+ if (copyableCount > 1) {
696
+ parent = copyLeft(l, copyableCount - 1);
697
+ prependableNode = parent.array[0];
698
+ } else {
699
+ parent = undefined;
700
+ prependableNode = l.root;
701
+ }
702
+
703
+ const path = createPath(depth - copyableCount, node); // add offset
704
+
705
+ l.offset = 32 ** (depth - copyableCount + 1) - 32;
706
+ const prepended = nodePrepend(path, 32, prependableNode);
707
+
708
+ if (parent === undefined) {
709
+ l.root = prepended;
710
+ } else {
711
+ parent.array[0] = prepended;
712
+ }
713
+ }
714
+
715
+ return l;
716
+ }
717
+ }
718
+
719
+ l.offset = newOffset;
720
+ return l;
721
+ }
722
+ }
723
+ /**
724
+ * Prepends a node to a dense tree. The given `offset` is never zero.
725
+ *
726
+ * @internal
727
+ */
728
+
729
+ function prependDense(node, depth, offset, value) {
730
+ // We're indexing down `offset - 1`. At each step `path` is either 0 or -1.
731
+ const curOffset = offset >> depth * branchBits & mask;
732
+ const path = (offset - 1 >> depth * branchBits & mask) - curOffset;
733
+
734
+ if (path < 0) {
735
+ return new Node(undefined, arrayPrepend(createPath(depth - 1, value), node.array));
736
+ } else {
737
+ const array = copyArray(node.array);
738
+ array[0] = prependDense(array[0], depth - 1, offset, value);
739
+ return new Node(undefined, array);
740
+ }
741
+ }
742
+ /**
743
+ * Takes a RRB-tree and an affix. It then appends the node to the
744
+ * tree.
745
+ *
746
+ * @internal
747
+ */
748
+
749
+
750
+ export function appendNodeToTree(l, array) {
751
+ if (l.root === undefined) {
752
+ // The old Vector has no content in tree, all content is in affixes
753
+ if (getPrefixSize(l) === 0) {
754
+ l.bits = setPrefix(array.length, l.bits);
755
+ l.prefix = reverseArray(array);
756
+ } else {
757
+ l.root = new Node(undefined, array);
758
+ }
759
+
760
+ return l;
761
+ }
762
+
763
+ const depth = getDepth(l);
764
+ let index = handleOffset(depth, l.offset, l.length - 1 - getPrefixSize(l));
765
+ let nodesToCopy = 0;
766
+ let nodesVisited = 0;
767
+ let shift = depth * 5;
768
+ let currentNode = l.root;
769
+
770
+ if (32 ** (depth + 1) < index) {
771
+ shift = 0; // there is no room
772
+
773
+ nodesVisited = depth;
774
+ }
775
+
776
+ while (shift > 5) {
777
+ let childIndex;
778
+
779
+ if (currentNode.sizes === undefined) {
780
+ // does not have size table
781
+ childIndex = index >> shift & mask;
782
+ index &= ~(mask << shift); // wipe just used bits
783
+ } else {
784
+ childIndex = currentNode.array.length - 1;
785
+ index -= currentNode.sizes[childIndex - 1];
786
+ }
787
+
788
+ nodesVisited++;
789
+
790
+ if (childIndex < mask) {
791
+ // we are not going down the far right path, this implies that
792
+ // there is still room in the current node
793
+ nodesToCopy = nodesVisited;
794
+ }
795
+
796
+ currentNode = currentNode.array[childIndex];
797
+
798
+ if (currentNode === undefined) {
799
+ // This will only happened in a pvec subtree. The index does not
800
+ // exist so we'll have to create a new path from here on.
801
+ nodesToCopy = nodesVisited;
802
+ shift = 5; // Set shift to break out of the while-loop
803
+ }
804
+
805
+ shift -= 5;
806
+ }
807
+
808
+ if (shift !== 0) {
809
+ nodesVisited++;
810
+
811
+ if (currentNode.array.length < branchingFactor) {
812
+ // there is room in the found node
813
+ nodesToCopy = nodesVisited;
814
+ }
815
+ }
816
+
817
+ const node = new Node(undefined, array);
818
+
819
+ if (nodesToCopy === 0) {
820
+ // there was no room in the found node
821
+ const newPath = nodesVisited === 0 ? node : createPath(nodesVisited, node);
822
+ const newRoot = new Node(undefined, [l.root, newPath]);
823
+ l.root = newRoot;
824
+ l.bits = incrementDepth(l.bits);
825
+ } else {
826
+ const copiedNode = copyFirstK(l, nodesToCopy, array.length);
827
+ copiedNode.array.push(createPath(depth - nodesToCopy, node));
828
+ }
829
+
830
+ return l;
831
+ }
832
+ /**
833
+ * Traverses down the right edge of the tree and copies k nodes.
834
+ *
835
+ * @internal
836
+ */
837
+
838
+ function copyFirstK(newVector, k, leafSize) {
839
+ let currentNode = cloneNode(newVector.root); // copy root
840
+
841
+ newVector.root = currentNode; // install root
842
+
843
+ for (let i = 1; i < k; ++i) {
844
+ const index = currentNode.array.length - 1;
845
+
846
+ if (currentNode.sizes !== undefined) {
847
+ currentNode.sizes[index] += leafSize;
848
+ }
849
+
850
+ const newNode = cloneNode(currentNode.array[index]); // Install the copied node
851
+
852
+ currentNode.array[index] = newNode;
853
+ currentNode = newNode;
854
+ }
855
+
856
+ if (currentNode.sizes !== undefined) {
857
+ currentNode.sizes.push(arrayLast(currentNode.sizes) + leafSize);
858
+ }
859
+
860
+ return currentNode;
861
+ }
862
+
863
+ const eMax = 2;
864
+ /**
865
+ * @internal
866
+ */
867
+
868
+ function createConcatPlan(array) {
869
+ const sizes = [];
870
+ let sum = 0;
871
+
872
+ for (let i = 0; i < array.length; ++i) {
873
+ sum += array[i].array.length; // FIXME: maybe only access array once
874
+
875
+ sizes[i] = array[i].array.length;
876
+ }
877
+
878
+ const optimalLength = Math.ceil(sum / branchingFactor);
879
+ let n = array.length;
880
+ let i = 0;
881
+
882
+ if (optimalLength + eMax >= n) {
883
+ return undefined; // no rebalancing needed
884
+ }
885
+
886
+ while (optimalLength + eMax < n) {
887
+ while (sizes[i] > branchingFactor - eMax / 2) {
888
+ // Skip nodes that are already sufficiently balanced
889
+ ++i;
890
+ } // the node at this index is too short
891
+
892
+
893
+ let remaining = sizes[i]; // number of elements to re-distribute
894
+
895
+ do {
896
+ const size = Math.min(remaining + sizes[i + 1], branchingFactor);
897
+ sizes[i] = size;
898
+ remaining = remaining - (size - sizes[i + 1]);
899
+ ++i;
900
+ } while (remaining > 0); // Shift nodes after
901
+
902
+
903
+ for (let j = i; j <= n - 1; ++j) {
904
+ sizes[j] = sizes[j + 1];
905
+ }
906
+
907
+ --i;
908
+ --n;
909
+ }
910
+
911
+ sizes.length = n;
912
+ return sizes;
913
+ }
914
+ /**
915
+ * Combines the children of three nodes into an array. The last child
916
+ * of `left` and the first child of `right is ignored as they've been
917
+ * concatenated into `center`.
918
+ *
919
+ * @internal
920
+ */
921
+
922
+
923
+ function concatNodeMerge(left, center, right) {
924
+ const array = [];
925
+
926
+ if (left !== undefined) {
927
+ for (let i = 0; i < left.array.length - 1; ++i) {
928
+ array.push(left.array[i]);
929
+ }
930
+ }
931
+
932
+ for (let i = 0; i < center.array.length; ++i) {
933
+ array.push(center.array[i]);
934
+ }
935
+
936
+ if (right !== undefined) {
937
+ for (let i = 1; i < right.array.length; ++i) {
938
+ array.push(right.array[i]);
939
+ }
940
+ }
941
+
942
+ return array;
943
+ }
944
+ /**
945
+ * @internal
946
+ */
947
+
948
+
949
+ function executeConcatPlan(merged, plan, height) {
950
+ const result = [];
951
+ let sourceIdx = 0; // the current node we're copying from
952
+
953
+ let offset = 0; // elements in source already used
954
+
955
+ for (let toMove of plan) {
956
+ let source = merged[sourceIdx].array;
957
+
958
+ if (toMove === source.length && offset === 0) {
959
+ // source matches target exactly, reuse source
960
+ result.push(merged[sourceIdx]);
961
+ ++sourceIdx;
962
+ } else {
963
+ const node = new Node(undefined, []);
964
+
965
+ while (toMove > 0) {
966
+ const available = source.length - offset;
967
+ const itemsToCopy = Math.min(toMove, available);
968
+ pushElements(source, node.array, offset, itemsToCopy);
969
+
970
+ if (toMove >= available) {
971
+ ++sourceIdx;
972
+ source = merged[sourceIdx].array;
973
+ offset = 0;
974
+ } else {
975
+ offset += itemsToCopy;
976
+ }
977
+
978
+ toMove -= itemsToCopy;
979
+ }
980
+
981
+ if (height > 1) {
982
+ // Set sizes on children unless they are leaf nodes
983
+ setSizes(node, height - 1);
984
+ }
985
+
986
+ result.push(node);
987
+ }
988
+ }
989
+
990
+ return result;
991
+ }
992
+ /**
993
+ * Takes three nodes and returns a new node with the content of the
994
+ * three nodes. Note: The returned node does not have its size table
995
+ * set correctly. The caller must do that.
996
+ *
997
+ * @internal
998
+ */
999
+
1000
+
1001
+ function rebalance(left, center, right, height, top) {
1002
+ const merged = concatNodeMerge(left, center, right);
1003
+ const plan = createConcatPlan(merged);
1004
+ const balanced = plan !== undefined ? executeConcatPlan(merged, plan, height) : merged;
1005
+
1006
+ if (balanced.length <= branchingFactor) {
1007
+ if (top === true) {
1008
+ return new Node(undefined, balanced);
1009
+ } else {
1010
+ // Return a single node with extra height for balancing at next
1011
+ // level
1012
+ return new Node(undefined, [setSizes(new Node(undefined, balanced), height)]);
1013
+ }
1014
+ } else {
1015
+ return new Node(undefined, [setSizes(new Node(undefined, balanced.slice(0, branchingFactor)), height), setSizes(new Node(undefined, balanced.slice(branchingFactor)), height)]);
1016
+ }
1017
+ }
1018
+ /**
1019
+ * @internal
1020
+ */
1021
+
1022
+
1023
+ export function concatSubTree(left, lDepth, right, rDepth, isTop) {
1024
+ if (lDepth > rDepth) {
1025
+ const c = concatSubTree(arrayLast(left.array), lDepth - 1, right, rDepth, false);
1026
+ return rebalance(left, c, undefined, lDepth, isTop);
1027
+ } else if (lDepth < rDepth) {
1028
+ const c = concatSubTree(left, lDepth, arrayFirst(right.array), rDepth - 1, false);
1029
+ return rebalance(undefined, c, right, rDepth, isTop);
1030
+ } else if (lDepth === 0) {
1031
+ return new Node(undefined, [left, right]);
1032
+ } else {
1033
+ const c = concatSubTree(arrayLast(left.array), lDepth - 1, arrayFirst(right.array), rDepth - 1, false);
1034
+ return rebalance(left, c, right, lDepth, isTop);
1035
+ }
1036
+ }
1037
+ /**
1038
+ * @internal
1039
+ */
1040
+
1041
+ export const concatBuffer = /*#__PURE__*/new Array(3);
1042
+ /**
1043
+ * @internal
1044
+ */
1045
+
1046
+ export function concatAffixes(left, right) {
1047
+ // TODO: Try and find a neat way to reduce the LOC here
1048
+ let nr = 0;
1049
+ let arrIdx = 0;
1050
+ let i = 0;
1051
+ let length = getSuffixSize(left);
1052
+ concatBuffer[nr] = [];
1053
+
1054
+ for (i = 0; i < length; ++i) {
1055
+ concatBuffer[nr][arrIdx++] = left.suffix[i];
1056
+ }
1057
+
1058
+ length = getPrefixSize(right);
1059
+
1060
+ for (i = 0; i < length; ++i) {
1061
+ if (arrIdx === 32) {
1062
+ arrIdx = 0;
1063
+ ++nr;
1064
+ concatBuffer[nr] = [];
1065
+ }
1066
+
1067
+ concatBuffer[nr][arrIdx++] = right.prefix[length - 1 - i];
1068
+ }
1069
+
1070
+ length = getSuffixSize(right);
1071
+
1072
+ for (i = 0; i < length; ++i) {
1073
+ if (arrIdx === 32) {
1074
+ arrIdx = 0;
1075
+ ++nr;
1076
+ concatBuffer[nr] = [];
1077
+ }
1078
+
1079
+ concatBuffer[nr][arrIdx++] = right.suffix[i];
1080
+ }
1081
+
1082
+ return nr;
1083
+ }
1084
+ /**
1085
+ * @internal
1086
+ */
1087
+
1088
+ export function getHeight(node) {
1089
+ if (node.array[0] instanceof Node) {
1090
+ return 1 + getHeight(node.array[0]);
1091
+ } else {
1092
+ return 0;
1093
+ }
1094
+ }
1095
+ /**
1096
+ * @internal
1097
+ */
1098
+
1099
+ export let newAffix; // function getBitsForDepth(n: number, depth: number): number {
1100
+ // return n & ~(~0 << ((depth + 1) * branchBits));
1101
+ // }
1102
+
1103
+ function sliceNode(node, index, depth, pathLeft, pathRight, childLeft, childRight) {
1104
+ const array = node.array.slice(pathLeft, pathRight + 1);
1105
+
1106
+ if (childLeft !== undefined) {
1107
+ array[0] = childLeft;
1108
+ }
1109
+
1110
+ if (childRight !== undefined) {
1111
+ array[array.length - 1] = childRight;
1112
+ }
1113
+
1114
+ let sizes = node.sizes;
1115
+
1116
+ if (sizes !== undefined) {
1117
+ sizes = sizes.slice(pathLeft, pathRight + 1);
1118
+ let slicedOffLeft = pathLeft !== 0 ? node.sizes[pathLeft - 1] : 0;
1119
+
1120
+ if (childLeft !== undefined) {
1121
+ // If the left child has been sliced into a new child we need to know
1122
+ // how many elements have been removed from the child.
1123
+ if (childLeft.sizes !== undefined) {
1124
+ // If the left child has a size table we can simply look at that.
1125
+ const oldChild = node.array[pathLeft];
1126
+ slicedOffLeft += arrayLast(oldChild.sizes) - arrayLast(childLeft.sizes);
1127
+ } else {
1128
+ // If the left child does not have a size table we can
1129
+ // calculate how many elements have been removed from it by
1130
+ // looking at the index. Note that when we slice into a leaf
1131
+ // the leaf is moved up as a prefix. Thus slicing, for
1132
+ // instance, at index 20 will remove 32 elements from the
1133
+ // child. Similarly slicing at index 50 will remove 64
1134
+ // elements at slicing at 64 will remove 92 elements.
1135
+ slicedOffLeft += (index - slicedOffLeft & ~0b011111) + 32;
1136
+ }
1137
+ }
1138
+
1139
+ for (let i = 0; i < sizes.length; ++i) {
1140
+ sizes[i] -= slicedOffLeft;
1141
+ }
1142
+
1143
+ if (childRight !== undefined) {
1144
+ const slicedOffRight = sizeOfSubtree(node.array[pathRight], depth - 1) - sizeOfSubtree(childRight, depth - 1);
1145
+ sizes[sizes.length - 1] -= slicedOffRight;
1146
+ }
1147
+ }
1148
+
1149
+ return new Node(sizes, array);
1150
+ }
1151
+ /**
1152
+ * @internal
1153
+ */
1154
+
1155
+
1156
+ export let newOffset = 0;
1157
+ export function sliceLeft(tree, depth, index, offset, top) {
1158
+ let {
1159
+ index: newIndex,
1160
+ path,
1161
+ updatedOffset
1162
+ } = getPath(index, offset, depth, tree.sizes);
1163
+
1164
+ if (depth === 0) {
1165
+ newAffix = tree.array.slice(path).reverse(); // This leaf node is moved up as a suffix so there is nothing here
1166
+ // after slicing
1167
+
1168
+ return undefined;
1169
+ } else {
1170
+ const child = sliceLeft(tree.array[path], depth - 1, newIndex, updatedOffset, false);
1171
+
1172
+ if (child === undefined) {
1173
+ // There is nothing in the child after slicing so we don't include it
1174
+ ++path;
1175
+
1176
+ if (path === tree.array.length) {
1177
+ return undefined;
1178
+ }
1179
+ } // If we've sliced something away and it's not a the root, update offset
1180
+
1181
+
1182
+ if (tree.sizes === undefined && top === false) {
1183
+ newOffset |= 32 - (tree.array.length - path) << depth * branchBits;
1184
+ }
1185
+
1186
+ return sliceNode(tree, index, depth, path, tree.array.length - 1, child, undefined);
1187
+ }
1188
+ }
1189
+ /** Slice elements off of a tree from the right */
1190
+
1191
+ export function sliceRight(node, depth, index, offset) {
1192
+ let {
1193
+ index: newIndex,
1194
+ path
1195
+ } = getPath(index, offset, depth, node.sizes);
1196
+
1197
+ if (depth === 0) {
1198
+ newAffix = node.array.slice(0, path + 1); // this leaf node is moved up as a suffix so there is nothing here
1199
+ // after slicing
1200
+
1201
+ return undefined;
1202
+ } else {
1203
+ // slice the child, note that we subtract 1 then the radix lookup
1204
+ // algorithm can find the last element that we want to include
1205
+ // and sliceRight will do a slice that is inclusive on the index.
1206
+ const child = sliceRight(node.array[path], depth - 1, newIndex, path === 0 ? offset : 0);
1207
+
1208
+ if (child === undefined) {
1209
+ // there is nothing in the child after slicing so we don't include it
1210
+ --path;
1211
+
1212
+ if (path === -1) {
1213
+ return undefined;
1214
+ }
1215
+ } // note that we add 1 to the path since we want the slice to be
1216
+ // inclusive on the end index. Only at the leaf level do we want
1217
+ // to do an exclusive slice.
1218
+
1219
+
1220
+ const array = node.array.slice(0, path + 1);
1221
+
1222
+ if (child !== undefined) {
1223
+ array[array.length - 1] = child;
1224
+ }
1225
+
1226
+ let sizes = node.sizes;
1227
+
1228
+ if (sizes !== undefined) {
1229
+ sizes = sizes.slice(0, path + 1);
1230
+
1231
+ if (child !== undefined) {
1232
+ const slicedOff = sizeOfSubtree(node.array[path], depth - 1) - sizeOfSubtree(child, depth - 1);
1233
+ sizes[sizes.length - 1] -= slicedOff;
1234
+ }
1235
+ }
1236
+
1237
+ return new Node(sizes, array);
1238
+ }
1239
+ }
1240
+ export function sliceTreeVector(from, to, tree, depth, offset, l) {
1241
+ const sizes = tree.sizes;
1242
+ let {
1243
+ index: newFrom,
1244
+ path: pathLeft
1245
+ } = getPath(from, offset, depth, sizes);
1246
+ let {
1247
+ index: newTo,
1248
+ path: pathRight
1249
+ } = getPath(to, offset, depth, sizes);
1250
+
1251
+ if (depth === 0) {
1252
+ // we are slicing a piece off a leaf node
1253
+ l.prefix = emptyAffix;
1254
+ l.suffix = tree.array.slice(pathLeft, pathRight + 1);
1255
+ l.root = undefined;
1256
+ l.bits = setSuffix(pathRight - pathLeft + 1, 0);
1257
+ return l;
1258
+ } else if (pathLeft === pathRight) {
1259
+ // Both ends are located in the same subtree, this means that we
1260
+ // can reduce the height
1261
+ l.bits = decrementDepth(l.bits);
1262
+ return sliceTreeVector(newFrom, newTo, tree.array[pathLeft], depth - 1, pathLeft === 0 ? offset : 0, l);
1263
+ } else {
1264
+ const childRight = sliceRight(tree.array[pathRight], depth - 1, newTo, 0);
1265
+ l.bits = setSuffix(newAffix.length, l.bits);
1266
+ l.suffix = newAffix;
1267
+
1268
+ if (childRight === undefined) {
1269
+ --pathRight;
1270
+ }
1271
+
1272
+ newOffset = 0;
1273
+ const childLeft = sliceLeft(tree.array[pathLeft], depth - 1, newFrom, pathLeft === 0 ? offset : 0, pathLeft === pathRight);
1274
+ l.offset = newOffset;
1275
+ l.bits = setPrefix(newAffix.length, l.bits);
1276
+ l.prefix = newAffix;
1277
+
1278
+ if (childLeft === undefined) {
1279
+ ++pathLeft;
1280
+ }
1281
+
1282
+ if (pathLeft >= pathRight) {
1283
+ if (pathLeft > pathRight) {
1284
+ // This only happens when `pathLeft` originally was equal to
1285
+ // `pathRight + 1` and `childLeft === childRight === undefined`.
1286
+ // In this case there is no tree left.
1287
+ l.bits = setDepth(0, l.bits);
1288
+ l.root = undefined;
1289
+ } else {
1290
+ // Height can be reduced
1291
+ l.bits = decrementDepth(l.bits);
1292
+ const newRoot = childRight !== undefined ? childRight : childLeft !== undefined ? childLeft : tree.array[pathLeft];
1293
+ l.root = new Node(newRoot.sizes, newRoot.array); // Is this size handling good enough?
1294
+ }
1295
+ } else {
1296
+ l.root = sliceNode(tree, from, depth, pathLeft, pathRight, childLeft, childRight);
1297
+ }
1298
+
1299
+ return l;
1300
+ }
1301
+ }
1302
+ /**
1303
+ * @internal
1304
+ */
1305
+
1306
+ export function zeroOffset() {
1307
+ newOffset = 0;
1308
+ }
1309
+
1310
+ function foldLeftArrayCb(cb, state, array, from, to, offset) {
1311
+ for (var i = from; i < to && cb(array[i], state, i + offset); ++i) {//
1312
+ }
1313
+
1314
+ return [i === to, i + offset + 1];
1315
+ }
1316
+
1317
+ function foldRightArrayCb(cb, state, array, from, to, offset) {
1318
+ // eslint-disable-next-line no-param-reassign
1319
+ for (var i = from - 1; to <= i && cb(array[i], state, offset); --i, offset--) {//
1320
+ }
1321
+
1322
+ return [i === to - 1, offset];
1323
+ }
1324
+
1325
+ function foldLeftNodeCb(cb, state, node, depth, offset) {
1326
+ const {
1327
+ array
1328
+ } = node;
1329
+
1330
+ if (depth === 0) {
1331
+ return foldLeftArrayCb(cb, state, array, 0, array.length, offset);
1332
+ }
1333
+
1334
+ const to = array.length;
1335
+ let j = offset;
1336
+ let cont;
1337
+
1338
+ for (let i = 0; i < to; ++i) {
1339
+ [cont, j] = foldLeftNodeCb(cb, state, array[i], depth - 1, j);
1340
+
1341
+ if (!cont) {
1342
+ return [false, j];
1343
+ }
1344
+ }
1345
+
1346
+ return [true, j];
1347
+ }
1348
+ /**
1349
+ * This function is a lot like a fold. But the reducer function is
1350
+ * supposed to mutate its state instead of returning it. Instead of
1351
+ * returning a new state it returns a boolean that tells wether or not
1352
+ * to continue the fold. `true` indicates that the folding should
1353
+ * continue.
1354
+ */
1355
+
1356
+
1357
+ export function foldLeftCb(cb, state, l) {
1358
+ const prefixSize = getPrefixSize(l);
1359
+ let i = prefixSize - 1;
1360
+ let cont = true;
1361
+ [cont, i] = foldRightArrayCb(cb, state, l.prefix, prefixSize, 0, i);
1362
+
1363
+ if (!cont) {
1364
+ return state;
1365
+ }
1366
+
1367
+ i = prefixSize;
1368
+
1369
+ if (l.root !== undefined) {
1370
+ [cont, i] = foldLeftNodeCb(cb, state, l.root, getDepth(l), i);
1371
+
1372
+ if (!cont) {
1373
+ return state;
1374
+ }
1375
+ }
1376
+
1377
+ const suffixSize = getSuffixSize(l);
1378
+ foldLeftArrayCb(cb, state, l.suffix, 0, suffixSize, i);
1379
+ return state;
1380
+ }
1381
+
1382
+ function foldRightNodeCb(cb, state, node, depth, offset) {
1383
+ const {
1384
+ array
1385
+ } = node;
1386
+
1387
+ if (depth === 0) {
1388
+ return foldRightArrayCb(cb, state, array, array.length, 0, offset);
1389
+ }
1390
+
1391
+ let j = offset;
1392
+ let cont;
1393
+
1394
+ for (let i = array.length - 1; 0 <= i; --i) {
1395
+ [cont, j] = foldRightNodeCb(cb, state, array[i], depth - 1, j);
1396
+
1397
+ if (!cont) {
1398
+ return [false, j];
1399
+ }
1400
+ }
1401
+
1402
+ return [true, j];
1403
+ }
1404
+
1405
+ export function foldRightCb(cb, state, l) {
1406
+ const suffixSize = getSuffixSize(l);
1407
+ const prefixSize = getPrefixSize(l);
1408
+ let i = l.length - 1;
1409
+ let cont = true;
1410
+ [cont, i] = foldRightArrayCb(cb, state, l.suffix, suffixSize, 0, i);
1411
+
1412
+ if (!cont) {
1413
+ return state;
1414
+ }
1415
+
1416
+ if (l.root !== undefined) {
1417
+ [cont, i] = foldRightNodeCb(cb, state, l.root, getDepth(l), i);
1418
+
1419
+ if (!cont) {
1420
+ return state;
1421
+ }
1422
+ }
1423
+
1424
+ const prefix = l.prefix;
1425
+ foldLeftArrayCb(cb, state, l.prefix, prefix.length - prefixSize, prefix.length, prefix.length - 1);
1426
+ return state;
1427
+ }
1428
+ export function foldLeftPrefix(f, b, array, length) {
1429
+ let acc = b;
1430
+ let j = 0;
1431
+
1432
+ for (let i = length - 1; 0 <= i; --i, j++) {
1433
+ acc = f(j, acc, array[i]);
1434
+ }
1435
+
1436
+ return [acc, j];
1437
+ }
1438
+ export function foldLeftNode(f, b, node, depth, offset) {
1439
+ const {
1440
+ array
1441
+ } = node;
1442
+ let acc = b;
1443
+ let j = offset;
1444
+
1445
+ if (depth === 0) {
1446
+ return foldLeftSuffix(f, b, array, array.length, offset);
1447
+ }
1448
+
1449
+ for (let i = 0; i < array.length; ++i) {
1450
+ [acc, j] = foldLeftNode(f, acc, array[i], depth - 1, j);
1451
+ }
1452
+
1453
+ return [acc, j];
1454
+ }
1455
+ export function foldLeftSuffix(f, b, array, length, offset) {
1456
+ let acc = b;
1457
+ let j = offset;
1458
+
1459
+ for (let i = 0; i < length; ++i, j++) {
1460
+ acc = f(j, acc, array[i]);
1461
+ }
1462
+
1463
+ return [acc, j];
1464
+ }
1465
+ export function foldRightPrefix(f, b, array, length, offset) {
1466
+ let acc = b;
1467
+ let j = offset;
1468
+
1469
+ for (let i = 0; i < length; ++i, j--) {
1470
+ acc = f(j, array[i], acc);
1471
+ }
1472
+
1473
+ return [acc, j];
1474
+ }
1475
+ export function foldRightNode(f, b, node, depth, offset) {
1476
+ const {
1477
+ array
1478
+ } = node;
1479
+ let acc = b;
1480
+ let j = offset;
1481
+
1482
+ if (depth === 0) {
1483
+ return foldRightSuffix(f, b, array, array.length, offset);
1484
+ }
1485
+
1486
+ for (let i = array.length - 1; 0 <= i; --i) {
1487
+ [acc, j] = foldRightNode(f, acc, array[i], depth - 1, j);
1488
+ }
1489
+
1490
+ return [acc, j];
1491
+ }
1492
+ export function foldRightSuffix(f, b, array, length, offset) {
1493
+ let acc = b;
1494
+ let j = offset;
1495
+
1496
+ for (let i = length - 1; 0 <= i; --i, j--) {
1497
+ acc = f(j, array[i], acc);
1498
+ }
1499
+
1500
+ return [acc, j];
1501
+ }
1502
+
1503
+ function mapArray(f, array, offset) {
1504
+ const result = new Array(array.length);
1505
+
1506
+ for (let i = 0; i < array.length; ++i) {
1507
+ result[i] = f(offset + i, array[i]);
1508
+ }
1509
+
1510
+ return [result, offset + array.length];
1511
+ }
1512
+
1513
+ export function mapNode(f, node, depth, offset, adjust) {
1514
+ if (depth !== 0) {
1515
+ const {
1516
+ array
1517
+ } = node;
1518
+ let innerOffset = offset;
1519
+ const result = new Array(array.length);
1520
+
1521
+ for (let i = 0; i < array.length; ++i) {
1522
+ const [res, newOffset] = mapNode(f, array[i], depth - 1, innerOffset, adjust * 32);
1523
+ innerOffset = newOffset;
1524
+ result[i] = res;
1525
+ }
1526
+
1527
+ return [new Node(node.sizes, result), innerOffset];
1528
+ } else {
1529
+ const [res, newOffset] = mapArray(f, node.array, offset);
1530
+ return [new Node(undefined, res), newOffset];
1531
+ }
1532
+ }
1533
+ export function mapPrefix(f, prefix, length) {
1534
+ const newPrefix = new Array(length);
1535
+
1536
+ for (let i = length - 1; 0 <= i; --i) {
1537
+ newPrefix[i] = f(length - 1 - i, prefix[i]);
1538
+ }
1539
+
1540
+ return newPrefix;
1541
+ }
1542
+ export function mapAffix(f, suffix, length, totalLength) {
1543
+ const priorLength = totalLength - length;
1544
+ const newSuffix = new Array(length);
1545
+
1546
+ for (let i = 0; i < length; ++i) {
1547
+ newSuffix[i] = f(priorLength + i, suffix[i]);
1548
+ }
1549
+
1550
+ return newSuffix;
1551
+ } // functions based on foldlCb
1552
+
1553
+ export function arrayPush(array, a) {
1554
+ array.push(a);
1555
+ return array;
1556
+ }
1557
+ //# sourceMappingURL=internal.mjs.map