@sapphire/iterator-utilities 1.1.0-next.63f6019b.0 → 2.0.0-next.1e7d2dec

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 (468) hide show
  1. package/CHANGELOG.md +32 -0
  2. package/README.md +81 -15
  3. package/dist/cjs/index.cjs +218 -1
  4. package/dist/cjs/index.cjs.map +1 -1
  5. package/dist/cjs/index.d.cts +33 -10
  6. package/dist/cjs/lib/all.cjs +12 -0
  7. package/dist/cjs/lib/all.cjs.map +1 -0
  8. package/dist/cjs/lib/all.d.cts +2 -0
  9. package/dist/cjs/lib/any.cjs +12 -0
  10. package/dist/cjs/lib/any.cjs.map +1 -0
  11. package/dist/cjs/lib/any.d.cts +2 -0
  12. package/dist/cjs/lib/append.cjs +1 -1
  13. package/dist/cjs/lib/append.cjs.map +1 -1
  14. package/dist/cjs/lib/at.cjs +1 -1
  15. package/dist/cjs/lib/at.cjs.map +1 -1
  16. package/dist/cjs/lib/average.cjs +1 -1
  17. package/dist/cjs/lib/average.cjs.map +1 -1
  18. package/dist/cjs/lib/chain.cjs +1 -1
  19. package/dist/cjs/lib/chain.cjs.map +1 -1
  20. package/dist/cjs/lib/chunk.cjs +1 -1
  21. package/dist/cjs/lib/chunk.cjs.map +1 -1
  22. package/dist/cjs/lib/collect.cjs +12 -0
  23. package/dist/cjs/lib/collect.cjs.map +1 -0
  24. package/dist/cjs/lib/collect.d.cts +2 -0
  25. package/dist/cjs/lib/collectInto.cjs +17 -0
  26. package/dist/cjs/lib/collectInto.cjs.map +1 -0
  27. package/dist/cjs/lib/collectInto.d.cts +29 -0
  28. package/dist/cjs/lib/compact.cjs +1 -1
  29. package/dist/cjs/lib/compact.cjs.map +1 -1
  30. package/dist/cjs/lib/compare.cjs +15 -0
  31. package/dist/cjs/lib/compare.cjs.map +1 -0
  32. package/dist/cjs/lib/compare.d.cts +32 -0
  33. package/dist/cjs/lib/compareBy.cjs +26 -0
  34. package/dist/cjs/lib/compareBy.cjs.map +1 -0
  35. package/dist/cjs/lib/compareBy.d.cts +31 -0
  36. package/dist/cjs/lib/compress.cjs +1 -1
  37. package/dist/cjs/lib/compress.cjs.map +1 -1
  38. package/dist/cjs/lib/contains.cjs +2 -3
  39. package/dist/cjs/lib/contains.cjs.map +1 -1
  40. package/dist/cjs/lib/count.cjs +1 -1
  41. package/dist/cjs/lib/count.cjs.map +1 -1
  42. package/dist/cjs/lib/cycle.cjs +1 -1
  43. package/dist/cjs/lib/cycle.cjs.map +1 -1
  44. package/dist/cjs/lib/difference.cjs +1 -1
  45. package/dist/cjs/lib/difference.cjs.map +1 -1
  46. package/dist/cjs/lib/drop.cjs +4 -8
  47. package/dist/cjs/lib/drop.cjs.map +1 -1
  48. package/dist/cjs/lib/drop.d.cts +1 -1
  49. package/dist/cjs/lib/dropLast.cjs +2 -4
  50. package/dist/cjs/lib/dropLast.cjs.map +1 -1
  51. package/dist/cjs/lib/dropLast.d.cts +1 -1
  52. package/dist/cjs/lib/dropWhile.cjs +1 -2
  53. package/dist/cjs/lib/dropWhile.cjs.map +1 -1
  54. package/dist/cjs/lib/dropWhile.d.cts +1 -1
  55. package/dist/cjs/lib/empty.cjs +1 -1
  56. package/dist/cjs/lib/empty.cjs.map +1 -1
  57. package/dist/cjs/lib/enumerate.cjs +1 -1
  58. package/dist/cjs/lib/enumerate.cjs.map +1 -1
  59. package/dist/cjs/lib/equal.cjs +15 -0
  60. package/dist/cjs/lib/equal.cjs.map +1 -0
  61. package/dist/cjs/lib/equal.d.cts +26 -0
  62. package/dist/cjs/lib/equalBy.cjs +23 -0
  63. package/dist/cjs/lib/equalBy.cjs.map +1 -0
  64. package/dist/cjs/lib/equalBy.d.cts +27 -0
  65. package/dist/cjs/lib/every.cjs +2 -3
  66. package/dist/cjs/lib/every.cjs.map +1 -1
  67. package/dist/cjs/lib/filter.cjs +2 -4
  68. package/dist/cjs/lib/filter.cjs.map +1 -1
  69. package/dist/cjs/lib/filter.d.cts +1 -1
  70. package/dist/cjs/lib/find.cjs +1 -1
  71. package/dist/cjs/lib/find.cjs.map +1 -1
  72. package/dist/cjs/lib/findIndex.cjs +1 -1
  73. package/dist/cjs/lib/findIndex.cjs.map +1 -1
  74. package/dist/cjs/lib/first.cjs +1 -1
  75. package/dist/cjs/lib/first.cjs.map +1 -1
  76. package/dist/cjs/lib/flat.cjs +1 -1
  77. package/dist/cjs/lib/flat.cjs.map +1 -1
  78. package/dist/cjs/lib/flatMap.cjs +1 -1
  79. package/dist/cjs/lib/flatMap.cjs.map +1 -1
  80. package/dist/cjs/lib/forEach.cjs +1 -1
  81. package/dist/cjs/lib/forEach.cjs.map +1 -1
  82. package/dist/cjs/lib/from.cjs +1 -1
  83. package/dist/cjs/lib/from.cjs.map +1 -1
  84. package/dist/cjs/lib/fuse.cjs +26 -0
  85. package/dist/cjs/lib/fuse.cjs.map +1 -0
  86. package/dist/cjs/lib/fuse.d.cts +47 -0
  87. package/dist/cjs/lib/greaterOrEqualThan.cjs +17 -0
  88. package/dist/cjs/lib/greaterOrEqualThan.cjs.map +1 -0
  89. package/dist/cjs/lib/greaterOrEqualThan.d.cts +32 -0
  90. package/dist/cjs/lib/greaterThan.cjs +17 -0
  91. package/dist/cjs/lib/greaterThan.cjs.map +1 -0
  92. package/dist/cjs/lib/greaterThan.d.cts +32 -0
  93. package/dist/cjs/lib/indexOf.cjs +1 -2
  94. package/dist/cjs/lib/indexOf.cjs.map +1 -1
  95. package/dist/cjs/lib/indexOf.d.cts +1 -1
  96. package/dist/cjs/lib/inspect.cjs +25 -0
  97. package/dist/cjs/lib/inspect.cjs.map +1 -0
  98. package/dist/cjs/lib/inspect.d.cts +39 -0
  99. package/dist/cjs/lib/intersect.cjs +1 -1
  100. package/dist/cjs/lib/intersect.cjs.map +1 -1
  101. package/dist/cjs/lib/intersperse.cjs +35 -0
  102. package/dist/cjs/lib/intersperse.cjs.map +1 -0
  103. package/dist/cjs/lib/intersperse.d.cts +30 -0
  104. package/dist/cjs/lib/isEmpty.cjs +1 -1
  105. package/dist/cjs/lib/isEmpty.cjs.map +1 -1
  106. package/dist/cjs/lib/isSorted.cjs +15 -0
  107. package/dist/cjs/lib/isSorted.cjs.map +1 -0
  108. package/dist/cjs/lib/isSorted.d.cts +35 -0
  109. package/dist/cjs/lib/isSortedBy.cjs +26 -0
  110. package/dist/cjs/lib/isSortedBy.cjs.map +1 -0
  111. package/dist/cjs/lib/isSortedBy.d.cts +32 -0
  112. package/dist/cjs/lib/isSortedByKey.cjs +29 -0
  113. package/dist/cjs/lib/isSortedByKey.cjs.map +1 -0
  114. package/dist/cjs/lib/isSortedByKey.d.cts +30 -0
  115. package/dist/cjs/lib/last.cjs +1 -1
  116. package/dist/cjs/lib/last.cjs.map +1 -1
  117. package/dist/cjs/lib/lessOrEqualThan.cjs +17 -0
  118. package/dist/cjs/lib/lessOrEqualThan.cjs.map +1 -0
  119. package/dist/cjs/lib/lessOrEqualThan.d.cts +32 -0
  120. package/dist/cjs/lib/lessThan.cjs +17 -0
  121. package/dist/cjs/lib/lessThan.cjs.map +1 -0
  122. package/dist/cjs/lib/lessThan.d.cts +32 -0
  123. package/dist/cjs/lib/map.cjs +1 -1
  124. package/dist/cjs/lib/map.cjs.map +1 -1
  125. package/dist/cjs/lib/max.cjs +4 -9
  126. package/dist/cjs/lib/max.cjs.map +1 -1
  127. package/dist/cjs/lib/max.d.cts +8 -3
  128. package/dist/cjs/lib/maxBy.cjs +27 -0
  129. package/dist/cjs/lib/maxBy.cjs.map +1 -0
  130. package/dist/cjs/lib/maxBy.d.cts +31 -0
  131. package/dist/cjs/lib/maxByKey.cjs +32 -0
  132. package/dist/cjs/lib/maxByKey.cjs.map +1 -0
  133. package/dist/cjs/lib/maxByKey.d.cts +32 -0
  134. package/dist/cjs/lib/min.cjs +4 -9
  135. package/dist/cjs/lib/min.cjs.map +1 -1
  136. package/dist/cjs/lib/min.d.cts +8 -3
  137. package/dist/cjs/lib/minBy.cjs +27 -0
  138. package/dist/cjs/lib/minBy.cjs.map +1 -0
  139. package/dist/cjs/lib/minBy.d.cts +31 -0
  140. package/dist/cjs/lib/minByKey.cjs +32 -0
  141. package/dist/cjs/lib/minByKey.cjs.map +1 -0
  142. package/dist/cjs/lib/minByKey.d.cts +31 -0
  143. package/dist/cjs/lib/notEqual.cjs +15 -0
  144. package/dist/cjs/lib/notEqual.cjs.map +1 -0
  145. package/dist/cjs/lib/notEqual.d.cts +26 -0
  146. package/dist/cjs/lib/nth.cjs +12 -0
  147. package/dist/cjs/lib/nth.cjs.map +1 -0
  148. package/dist/cjs/lib/nth.d.cts +2 -0
  149. package/dist/cjs/lib/partition.cjs +1 -1
  150. package/dist/cjs/lib/partition.cjs.map +1 -1
  151. package/dist/cjs/lib/peekable.cjs +2 -3
  152. package/dist/cjs/lib/peekable.cjs.map +1 -1
  153. package/dist/cjs/lib/peekable.d.cts +1 -1
  154. package/dist/cjs/lib/position.cjs +12 -0
  155. package/dist/cjs/lib/position.cjs.map +1 -0
  156. package/dist/cjs/lib/position.d.cts +2 -0
  157. package/dist/cjs/lib/prepend.cjs +1 -1
  158. package/dist/cjs/lib/prepend.cjs.map +1 -1
  159. package/dist/cjs/lib/product.cjs +1 -1
  160. package/dist/cjs/lib/product.cjs.map +1 -1
  161. package/dist/cjs/lib/range.cjs +1 -1
  162. package/dist/cjs/lib/range.cjs.map +1 -1
  163. package/dist/cjs/lib/reduce.cjs +2 -3
  164. package/dist/cjs/lib/reduce.cjs.map +1 -1
  165. package/dist/cjs/lib/repeat.cjs +1 -1
  166. package/dist/cjs/lib/repeat.cjs.map +1 -1
  167. package/dist/cjs/lib/reverse.cjs +3 -6
  168. package/dist/cjs/lib/reverse.cjs.map +1 -1
  169. package/dist/cjs/lib/shared/_assertFunction.cjs +1 -1
  170. package/dist/cjs/lib/shared/_assertFunction.cjs.map +1 -1
  171. package/dist/cjs/lib/shared/_assertNotNegative.cjs +1 -1
  172. package/dist/cjs/lib/shared/_assertNotNegative.cjs.map +1 -1
  173. package/dist/cjs/lib/shared/_assertPositive.cjs +1 -1
  174. package/dist/cjs/lib/shared/_assertPositive.cjs.map +1 -1
  175. package/dist/cjs/lib/shared/_compare.cjs +36 -0
  176. package/dist/cjs/lib/shared/_compare.cjs.map +1 -0
  177. package/dist/cjs/lib/shared/_compare.d.cts +20 -0
  178. package/dist/cjs/lib/shared/_makeIterableIterator.cjs +1 -1
  179. package/dist/cjs/lib/shared/_makeIterableIterator.cjs.map +1 -1
  180. package/dist/cjs/lib/shared/_toIntegerOrInfinityOrThrow.cjs +4 -7
  181. package/dist/cjs/lib/shared/_toIntegerOrInfinityOrThrow.cjs.map +1 -1
  182. package/dist/cjs/lib/shared/_toIntegerOrThrow.cjs +4 -7
  183. package/dist/cjs/lib/shared/_toIntegerOrThrow.cjs.map +1 -1
  184. package/dist/cjs/lib/shared/_toNumberOrThrow.cjs +1 -1
  185. package/dist/cjs/lib/shared/_toNumberOrThrow.cjs.map +1 -1
  186. package/dist/cjs/lib/shared/comparators.cjs +28 -0
  187. package/dist/cjs/lib/shared/comparators.cjs.map +1 -0
  188. package/dist/cjs/lib/shared/comparators.d.cts +34 -0
  189. package/dist/cjs/lib/skip.cjs +12 -0
  190. package/dist/cjs/lib/skip.cjs.map +1 -0
  191. package/dist/cjs/lib/skip.d.cts +2 -0
  192. package/dist/cjs/lib/skipLast.cjs +12 -0
  193. package/dist/cjs/lib/skipLast.cjs.map +1 -0
  194. package/dist/cjs/lib/skipLast.d.cts +2 -0
  195. package/dist/cjs/lib/skipWhile.cjs +12 -0
  196. package/dist/cjs/lib/skipWhile.cjs.map +1 -0
  197. package/dist/cjs/lib/skipWhile.d.cts +2 -0
  198. package/dist/cjs/lib/slice.cjs +2 -3
  199. package/dist/cjs/lib/slice.cjs.map +1 -1
  200. package/dist/cjs/lib/some.cjs +1 -1
  201. package/dist/cjs/lib/some.cjs.map +1 -1
  202. package/dist/cjs/lib/sorted.cjs +1 -1
  203. package/dist/cjs/lib/sorted.cjs.map +1 -1
  204. package/dist/cjs/lib/starMap.cjs +1 -1
  205. package/dist/cjs/lib/starMap.cjs.map +1 -1
  206. package/dist/cjs/lib/stepBy.cjs +29 -0
  207. package/dist/cjs/lib/stepBy.cjs.map +1 -0
  208. package/dist/cjs/lib/stepBy.d.cts +24 -0
  209. package/dist/cjs/lib/sum.cjs +1 -1
  210. package/dist/cjs/lib/sum.cjs.map +1 -1
  211. package/dist/cjs/lib/take.cjs +2 -3
  212. package/dist/cjs/lib/take.cjs.map +1 -1
  213. package/dist/cjs/lib/takeLast.cjs +3 -5
  214. package/dist/cjs/lib/takeLast.cjs.map +1 -1
  215. package/dist/cjs/lib/takeWhile.cjs +12 -0
  216. package/dist/cjs/lib/takeWhile.cjs.map +1 -0
  217. package/dist/cjs/lib/takeWhile.d.cts +2 -0
  218. package/dist/cjs/lib/tee.cjs +2 -3
  219. package/dist/cjs/lib/tee.cjs.map +1 -1
  220. package/dist/cjs/lib/toArray.cjs +1 -1
  221. package/dist/cjs/lib/toArray.cjs.map +1 -1
  222. package/dist/cjs/lib/toIterableIterator.cjs +1 -1
  223. package/dist/cjs/lib/toIterableIterator.cjs.map +1 -1
  224. package/dist/cjs/lib/union.cjs +1 -1
  225. package/dist/cjs/lib/union.cjs.map +1 -1
  226. package/dist/cjs/lib/union.d.cts +1 -0
  227. package/dist/cjs/lib/unique.cjs +1 -1
  228. package/dist/cjs/lib/unique.cjs.map +1 -1
  229. package/dist/cjs/lib/unzip.cjs +2 -3
  230. package/dist/cjs/lib/unzip.cjs.map +1 -1
  231. package/dist/cjs/lib/zip.cjs +2 -3
  232. package/dist/cjs/lib/zip.cjs.map +1 -1
  233. package/dist/esm/{chunk-G5GHKT7C.mjs → chunk-PAWJFY3S.mjs} +2 -2
  234. package/dist/esm/chunk-PAWJFY3S.mjs.map +1 -0
  235. package/dist/esm/index.d.mts +33 -10
  236. package/dist/esm/index.mjs +32 -1
  237. package/dist/esm/index.mjs.map +1 -1
  238. package/dist/esm/lib/all.d.mts +2 -0
  239. package/dist/esm/lib/all.mjs +4 -0
  240. package/dist/esm/lib/all.mjs.map +1 -0
  241. package/dist/esm/lib/any.d.mts +2 -0
  242. package/dist/esm/lib/any.mjs +4 -0
  243. package/dist/esm/lib/any.mjs.map +1 -0
  244. package/dist/esm/lib/append.mjs +2 -2
  245. package/dist/esm/lib/append.mjs.map +1 -1
  246. package/dist/esm/lib/at.mjs +2 -2
  247. package/dist/esm/lib/at.mjs.map +1 -1
  248. package/dist/esm/lib/average.mjs +2 -2
  249. package/dist/esm/lib/average.mjs.map +1 -1
  250. package/dist/esm/lib/chain.mjs +2 -2
  251. package/dist/esm/lib/chain.mjs.map +1 -1
  252. package/dist/esm/lib/chunk.mjs +2 -2
  253. package/dist/esm/lib/chunk.mjs.map +1 -1
  254. package/dist/esm/lib/collect.d.mts +2 -0
  255. package/dist/esm/lib/collect.mjs +4 -0
  256. package/dist/esm/lib/collect.mjs.map +1 -0
  257. package/dist/esm/lib/collectInto.d.mts +29 -0
  258. package/dist/esm/lib/collectInto.mjs +14 -0
  259. package/dist/esm/lib/collectInto.mjs.map +1 -0
  260. package/dist/esm/lib/compact.mjs +2 -2
  261. package/dist/esm/lib/compact.mjs.map +1 -1
  262. package/dist/esm/lib/compare.d.mts +32 -0
  263. package/dist/esm/lib/compare.mjs +12 -0
  264. package/dist/esm/lib/compare.mjs.map +1 -0
  265. package/dist/esm/lib/compareBy.d.mts +31 -0
  266. package/dist/esm/lib/compareBy.mjs +23 -0
  267. package/dist/esm/lib/compareBy.mjs.map +1 -0
  268. package/dist/esm/lib/compress.mjs +2 -2
  269. package/dist/esm/lib/compress.mjs.map +1 -1
  270. package/dist/esm/lib/contains.mjs +3 -4
  271. package/dist/esm/lib/contains.mjs.map +1 -1
  272. package/dist/esm/lib/count.mjs +2 -2
  273. package/dist/esm/lib/count.mjs.map +1 -1
  274. package/dist/esm/lib/cycle.mjs +2 -2
  275. package/dist/esm/lib/cycle.mjs.map +1 -1
  276. package/dist/esm/lib/difference.mjs +2 -2
  277. package/dist/esm/lib/difference.mjs.map +1 -1
  278. package/dist/esm/lib/drop.d.mts +1 -1
  279. package/dist/esm/lib/drop.mjs +6 -9
  280. package/dist/esm/lib/drop.mjs.map +1 -1
  281. package/dist/esm/lib/dropLast.d.mts +1 -1
  282. package/dist/esm/lib/dropLast.mjs +4 -5
  283. package/dist/esm/lib/dropLast.mjs.map +1 -1
  284. package/dist/esm/lib/dropWhile.d.mts +1 -1
  285. package/dist/esm/lib/dropWhile.mjs +3 -3
  286. package/dist/esm/lib/dropWhile.mjs.map +1 -1
  287. package/dist/esm/lib/empty.mjs +2 -2
  288. package/dist/esm/lib/empty.mjs.map +1 -1
  289. package/dist/esm/lib/enumerate.mjs +2 -2
  290. package/dist/esm/lib/enumerate.mjs.map +1 -1
  291. package/dist/esm/lib/equal.d.mts +26 -0
  292. package/dist/esm/lib/equal.mjs +11 -0
  293. package/dist/esm/lib/equal.mjs.map +1 -0
  294. package/dist/esm/lib/equalBy.d.mts +27 -0
  295. package/dist/esm/lib/equalBy.mjs +19 -0
  296. package/dist/esm/lib/equalBy.mjs.map +1 -0
  297. package/dist/esm/lib/every.mjs +3 -4
  298. package/dist/esm/lib/every.mjs.map +1 -1
  299. package/dist/esm/lib/filter.d.mts +1 -1
  300. package/dist/esm/lib/filter.mjs +4 -5
  301. package/dist/esm/lib/filter.mjs.map +1 -1
  302. package/dist/esm/lib/find.mjs +2 -2
  303. package/dist/esm/lib/find.mjs.map +1 -1
  304. package/dist/esm/lib/findIndex.mjs +2 -2
  305. package/dist/esm/lib/findIndex.mjs.map +1 -1
  306. package/dist/esm/lib/first.mjs +2 -2
  307. package/dist/esm/lib/first.mjs.map +1 -1
  308. package/dist/esm/lib/flat.mjs +2 -2
  309. package/dist/esm/lib/flat.mjs.map +1 -1
  310. package/dist/esm/lib/flatMap.mjs +2 -2
  311. package/dist/esm/lib/flatMap.mjs.map +1 -1
  312. package/dist/esm/lib/forEach.mjs +2 -2
  313. package/dist/esm/lib/forEach.mjs.map +1 -1
  314. package/dist/esm/lib/from.mjs +2 -2
  315. package/dist/esm/lib/from.mjs.map +1 -1
  316. package/dist/esm/lib/fuse.d.mts +47 -0
  317. package/dist/esm/lib/fuse.mjs +23 -0
  318. package/dist/esm/lib/fuse.mjs.map +1 -0
  319. package/dist/esm/lib/greaterOrEqualThan.d.mts +32 -0
  320. package/dist/esm/lib/greaterOrEqualThan.mjs +13 -0
  321. package/dist/esm/lib/greaterOrEqualThan.mjs.map +1 -0
  322. package/dist/esm/lib/greaterThan.d.mts +32 -0
  323. package/dist/esm/lib/greaterThan.mjs +13 -0
  324. package/dist/esm/lib/greaterThan.mjs.map +1 -0
  325. package/dist/esm/lib/indexOf.d.mts +1 -1
  326. package/dist/esm/lib/indexOf.mjs +3 -3
  327. package/dist/esm/lib/indexOf.mjs.map +1 -1
  328. package/dist/esm/lib/inspect.d.mts +39 -0
  329. package/dist/esm/lib/inspect.mjs +22 -0
  330. package/dist/esm/lib/inspect.mjs.map +1 -0
  331. package/dist/esm/lib/intersect.mjs +2 -2
  332. package/dist/esm/lib/intersect.mjs.map +1 -1
  333. package/dist/esm/lib/intersperse.d.mts +30 -0
  334. package/dist/esm/lib/intersperse.mjs +32 -0
  335. package/dist/esm/lib/intersperse.mjs.map +1 -0
  336. package/dist/esm/lib/isEmpty.mjs +2 -2
  337. package/dist/esm/lib/isEmpty.mjs.map +1 -1
  338. package/dist/esm/lib/isSorted.d.mts +35 -0
  339. package/dist/esm/lib/isSorted.mjs +12 -0
  340. package/dist/esm/lib/isSorted.mjs.map +1 -0
  341. package/dist/esm/lib/isSortedBy.d.mts +32 -0
  342. package/dist/esm/lib/isSortedBy.mjs +23 -0
  343. package/dist/esm/lib/isSortedBy.mjs.map +1 -0
  344. package/dist/esm/lib/isSortedByKey.d.mts +30 -0
  345. package/dist/esm/lib/isSortedByKey.mjs +26 -0
  346. package/dist/esm/lib/isSortedByKey.mjs.map +1 -0
  347. package/dist/esm/lib/last.mjs +2 -2
  348. package/dist/esm/lib/last.mjs.map +1 -1
  349. package/dist/esm/lib/lessOrEqualThan.d.mts +32 -0
  350. package/dist/esm/lib/lessOrEqualThan.mjs +13 -0
  351. package/dist/esm/lib/lessOrEqualThan.mjs.map +1 -0
  352. package/dist/esm/lib/lessThan.d.mts +32 -0
  353. package/dist/esm/lib/lessThan.mjs +13 -0
  354. package/dist/esm/lib/lessThan.mjs.map +1 -0
  355. package/dist/esm/lib/map.mjs +2 -2
  356. package/dist/esm/lib/map.mjs.map +1 -1
  357. package/dist/esm/lib/max.d.mts +8 -3
  358. package/dist/esm/lib/max.mjs +5 -10
  359. package/dist/esm/lib/max.mjs.map +1 -1
  360. package/dist/esm/lib/maxBy.d.mts +31 -0
  361. package/dist/esm/lib/maxBy.mjs +24 -0
  362. package/dist/esm/lib/maxBy.mjs.map +1 -0
  363. package/dist/esm/lib/maxByKey.d.mts +32 -0
  364. package/dist/esm/lib/maxByKey.mjs +29 -0
  365. package/dist/esm/lib/maxByKey.mjs.map +1 -0
  366. package/dist/esm/lib/min.d.mts +8 -3
  367. package/dist/esm/lib/min.mjs +5 -10
  368. package/dist/esm/lib/min.mjs.map +1 -1
  369. package/dist/esm/lib/minBy.d.mts +31 -0
  370. package/dist/esm/lib/minBy.mjs +24 -0
  371. package/dist/esm/lib/minBy.mjs.map +1 -0
  372. package/dist/esm/lib/minByKey.d.mts +31 -0
  373. package/dist/esm/lib/minByKey.mjs +29 -0
  374. package/dist/esm/lib/minByKey.mjs.map +1 -0
  375. package/dist/esm/lib/notEqual.d.mts +26 -0
  376. package/dist/esm/lib/notEqual.mjs +11 -0
  377. package/dist/esm/lib/notEqual.mjs.map +1 -0
  378. package/dist/esm/lib/nth.d.mts +2 -0
  379. package/dist/esm/lib/nth.mjs +4 -0
  380. package/dist/esm/lib/nth.mjs.map +1 -0
  381. package/dist/esm/lib/partition.mjs +2 -2
  382. package/dist/esm/lib/partition.mjs.map +1 -1
  383. package/dist/esm/lib/peekable.d.mts +1 -1
  384. package/dist/esm/lib/peekable.mjs +3 -4
  385. package/dist/esm/lib/peekable.mjs.map +1 -1
  386. package/dist/esm/lib/position.d.mts +2 -0
  387. package/dist/esm/lib/position.mjs +4 -0
  388. package/dist/esm/lib/position.mjs.map +1 -0
  389. package/dist/esm/lib/prepend.mjs +2 -2
  390. package/dist/esm/lib/prepend.mjs.map +1 -1
  391. package/dist/esm/lib/product.mjs +2 -2
  392. package/dist/esm/lib/product.mjs.map +1 -1
  393. package/dist/esm/lib/range.mjs +2 -2
  394. package/dist/esm/lib/range.mjs.map +1 -1
  395. package/dist/esm/lib/reduce.mjs +3 -4
  396. package/dist/esm/lib/reduce.mjs.map +1 -1
  397. package/dist/esm/lib/repeat.mjs +2 -2
  398. package/dist/esm/lib/repeat.mjs.map +1 -1
  399. package/dist/esm/lib/reverse.mjs +4 -7
  400. package/dist/esm/lib/reverse.mjs.map +1 -1
  401. package/dist/esm/lib/shared/_assertFunction.mjs +2 -2
  402. package/dist/esm/lib/shared/_assertFunction.mjs.map +1 -1
  403. package/dist/esm/lib/shared/_assertNotNegative.mjs +2 -2
  404. package/dist/esm/lib/shared/_assertNotNegative.mjs.map +1 -1
  405. package/dist/esm/lib/shared/_assertPositive.mjs +2 -2
  406. package/dist/esm/lib/shared/_assertPositive.mjs.map +1 -1
  407. package/dist/esm/lib/shared/_compare.d.mts +20 -0
  408. package/dist/esm/lib/shared/_compare.mjs +30 -0
  409. package/dist/esm/lib/shared/_compare.mjs.map +1 -0
  410. package/dist/esm/lib/shared/_makeIterableIterator.mjs +2 -2
  411. package/dist/esm/lib/shared/_makeIterableIterator.mjs.map +1 -1
  412. package/dist/esm/lib/shared/_toIntegerOrInfinityOrThrow.mjs +5 -8
  413. package/dist/esm/lib/shared/_toIntegerOrInfinityOrThrow.mjs.map +1 -1
  414. package/dist/esm/lib/shared/_toIntegerOrThrow.mjs +5 -8
  415. package/dist/esm/lib/shared/_toIntegerOrThrow.mjs.map +1 -1
  416. package/dist/esm/lib/shared/_toNumberOrThrow.mjs +2 -2
  417. package/dist/esm/lib/shared/_toNumberOrThrow.mjs.map +1 -1
  418. package/dist/esm/lib/shared/comparators.d.mts +34 -0
  419. package/dist/esm/lib/shared/comparators.mjs +21 -0
  420. package/dist/esm/lib/shared/comparators.mjs.map +1 -0
  421. package/dist/esm/lib/skip.d.mts +2 -0
  422. package/dist/esm/lib/skip.mjs +4 -0
  423. package/dist/esm/lib/skip.mjs.map +1 -0
  424. package/dist/esm/lib/skipLast.d.mts +2 -0
  425. package/dist/esm/lib/skipLast.mjs +4 -0
  426. package/dist/esm/lib/skipLast.mjs.map +1 -0
  427. package/dist/esm/lib/skipWhile.d.mts +2 -0
  428. package/dist/esm/lib/skipWhile.mjs +4 -0
  429. package/dist/esm/lib/skipWhile.mjs.map +1 -0
  430. package/dist/esm/lib/slice.mjs +3 -4
  431. package/dist/esm/lib/slice.mjs.map +1 -1
  432. package/dist/esm/lib/some.mjs +2 -2
  433. package/dist/esm/lib/some.mjs.map +1 -1
  434. package/dist/esm/lib/sorted.mjs +2 -2
  435. package/dist/esm/lib/sorted.mjs.map +1 -1
  436. package/dist/esm/lib/starMap.mjs +2 -2
  437. package/dist/esm/lib/starMap.mjs.map +1 -1
  438. package/dist/esm/lib/stepBy.d.mts +24 -0
  439. package/dist/esm/lib/stepBy.mjs +26 -0
  440. package/dist/esm/lib/stepBy.mjs.map +1 -0
  441. package/dist/esm/lib/sum.mjs +2 -2
  442. package/dist/esm/lib/sum.mjs.map +1 -1
  443. package/dist/esm/lib/take.mjs +3 -4
  444. package/dist/esm/lib/take.mjs.map +1 -1
  445. package/dist/esm/lib/takeLast.mjs +4 -6
  446. package/dist/esm/lib/takeLast.mjs.map +1 -1
  447. package/dist/esm/lib/takeWhile.d.mts +2 -0
  448. package/dist/esm/lib/takeWhile.mjs +4 -0
  449. package/dist/esm/lib/takeWhile.mjs.map +1 -0
  450. package/dist/esm/lib/tee.mjs +3 -4
  451. package/dist/esm/lib/tee.mjs.map +1 -1
  452. package/dist/esm/lib/toArray.mjs +2 -2
  453. package/dist/esm/lib/toArray.mjs.map +1 -1
  454. package/dist/esm/lib/toIterableIterator.mjs +2 -2
  455. package/dist/esm/lib/toIterableIterator.mjs.map +1 -1
  456. package/dist/esm/lib/union.d.mts +1 -0
  457. package/dist/esm/lib/union.mjs +2 -2
  458. package/dist/esm/lib/union.mjs.map +1 -1
  459. package/dist/esm/lib/unique.mjs +2 -2
  460. package/dist/esm/lib/unique.mjs.map +1 -1
  461. package/dist/esm/lib/unzip.mjs +3 -4
  462. package/dist/esm/lib/unzip.mjs.map +1 -1
  463. package/dist/esm/lib/zip.mjs +3 -4
  464. package/dist/esm/lib/zip.mjs.map +1 -1
  465. package/dist/iife/index.global.js +413 -95
  466. package/dist/iife/index.global.js.map +1 -1
  467. package/package.json +299 -28
  468. package/dist/esm/chunk-G5GHKT7C.mjs.map +0 -1
@@ -0,0 +1,27 @@
1
+ import { IterableResolvable } from './from.mjs';
2
+
3
+ /**
4
+ * Determines if the elements of both iterators are equal with respect to the specified equality function.
5
+ *
6
+ * @param iterable The iterator to compare.
7
+ * @param other The iterator to compare against.
8
+ * @returns Whether the two iterators are equal with respect to the specified equality function.
9
+ *
10
+ * @example
11
+ * ```typescript
12
+ * import { equalBy } from '@sapphire/iterator-utilities';
13
+ *
14
+ * const x = [1, 2, 3, 4];
15
+ * const y = [1, 4, 9, 16];
16
+ *
17
+ * console.log(equalBy(x, y, (a, b) => a * a === b));
18
+ * // Output: true
19
+ * ```
20
+ *
21
+ * @remarks
22
+ *
23
+ * This function consumes the entire iterator.
24
+ */
25
+ declare function equalBy<const ElementType>(iterable: IterableResolvable<ElementType>, other: IterableResolvable<ElementType>, callbackFn: (x: ElementType, y: ElementType) => boolean): boolean;
26
+
27
+ export { equalBy as eqBy, equalBy };
@@ -0,0 +1,19 @@
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
+ import { from } from './from.mjs';
3
+ import { assertFunction } from './shared/_assertFunction.mjs';
4
+ import { toIterableIterator } from './toIterableIterator.mjs';
5
+
6
+ function equalBy(iterable, other, callbackFn) {
7
+ callbackFn = assertFunction(callbackFn);
8
+ const iterator1 = from(other);
9
+ for (const value0 of toIterableIterator(iterable)) {
10
+ const result1 = iterator1.next();
11
+ if (result1.done || !callbackFn(value0, result1.value)) return false;
12
+ }
13
+ return iterator1.next().done === true;
14
+ }
15
+ __name(equalBy, "equalBy");
16
+
17
+ export { equalBy as eqBy, equalBy };
18
+ //# sourceMappingURL=equalBy.mjs.map
19
+ //# sourceMappingURL=equalBy.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/equalBy.ts"],"names":[],"mappings":";;;;;AA0BO,SAAS,OAAA,CACf,QACA,EAAA,KAAA,EACA,UACU,EAAA;AACV,EAAA,UAAA,GAAa,eAAe,UAAU,CAAA,CAAA;AAEtC,EAAM,MAAA,SAAA,GAAY,KAAK,KAAK,CAAA,CAAA;AAE5B,EAAW,KAAA,MAAA,MAAA,IAAU,kBAAmB,CAAA,QAAQ,CAAG,EAAA;AAClD,IAAM,MAAA,OAAA,GAAU,UAAU,IAAK,EAAA,CAAA;AAC/B,IAAI,IAAA,OAAA,CAAQ,QAAQ,CAAC,UAAA,CAAW,QAAQ,OAAQ,CAAA,KAAK,GAAU,OAAA,KAAA,CAAA;AAAA,GAChE;AAEA,EAAO,OAAA,SAAA,CAAU,IAAK,EAAA,CAAE,IAAS,KAAA,IAAA,CAAA;AAClC,CAAA;AAfgB,MAAA,CAAA,OAAA,EAAA,SAAA,CAAA","file":"equalBy.mjs","sourcesContent":["import { from, type IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Determines if the elements of both iterators are equal with respect to the specified equality function.\n *\n * @param iterable The iterator to compare.\n * @param other The iterator to compare against.\n * @returns Whether the two iterators are equal with respect to the specified equality function.\n *\n * @example\n * ```typescript\n * import { equalBy } from '@sapphire/iterator-utilities';\n *\n * const x = [1, 2, 3, 4];\n * const y = [1, 4, 9, 16];\n *\n * console.log(equalBy(x, y, (a, b) => a * a === b));\n * // Output: true\n * ```\n *\n * @remarks\n *\n * This function consumes the entire iterator.\n */\nexport function equalBy<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tother: IterableResolvable<ElementType>,\n\tcallbackFn: (x: ElementType, y: ElementType) => boolean\n): boolean {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tconst iterator1 = from(other);\n\n\tfor (const value0 of toIterableIterator(iterable)) {\n\t\tconst result1 = iterator1.next();\n\t\tif (result1.done || !callbackFn(value0, result1.value)) return false;\n\t}\n\n\treturn iterator1.next().done === true;\n}\n\nexport { equalBy as eqBy };\n"]}
@@ -1,4 +1,4 @@
1
- import { __name } from '../chunk-G5GHKT7C.mjs';
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
2
  import { assertFunction } from './shared/_assertFunction.mjs';
3
3
  import { toIterableIterator } from './toIterableIterator.mjs';
4
4
 
@@ -6,13 +6,12 @@ function every(iterable, callbackFn) {
6
6
  callbackFn = assertFunction(callbackFn);
7
7
  let index = 0;
8
8
  for (const value of toIterableIterator(iterable)) {
9
- if (!callbackFn(value, index++))
10
- return false;
9
+ if (!callbackFn(value, index++)) return false;
11
10
  }
12
11
  return true;
13
12
  }
14
13
  __name(every, "every");
15
14
 
16
15
  export { every };
17
- //# sourceMappingURL=out.js.map
16
+ //# sourceMappingURL=every.mjs.map
18
17
  //# sourceMappingURL=every.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/every.ts"],"names":[],"mappings":";;;;;AACA,SAAS,sBAAsB;AAC/B,SAAS,0BAA0B;AAiC5B,SAAS,MAAyB,UAA2C,YAA8D;AACjJ,eAAa,eAAe,UAAU;AAEtC,MAAI,QAAQ;AACZ,aAAW,SAAS,mBAAmB,QAAQ,GAAG;AACjD,QAAI,CAAC,WAAW,OAAO,OAAO;AAAG,aAAO;AAAA,EACzC;AAEA,SAAO;AACR;AATgB","sourcesContent":["import type { IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Tests whether all elements in the iterable pass the test implemented by the provided function.\n *\n * @param iterable The iterator to check.\n * @param callbackFn A function to execute for each element produced by the iterator. It should return a truthy value to indicate the element passes the test, and a falsy value otherwise.\n * @returns `true` if callbackFn returns a truthy value for every element. Otherwise, `false`.\n *\n * @example\n * ```typescript\n * import { every } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log(every(iterable, (value) => value < 10));\n * // Output: true\n *\n * console.log(every(iterable, (value) => value < 3));\n * // Output: false\n * ```\n *\n * @remarks\n *\n * This function consumes the entire iterator.\n */\nexport function every<const ElementType, const FilteredType extends ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => element is FilteredType\n): iterable is IterableIterator<FilteredType>;\nexport function every<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): boolean;\nexport function every<const ElementType>(iterable: IterableResolvable<ElementType>, callbackFn: (element: ElementType, index: number) => boolean) {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tlet index = 0;\n\tfor (const value of toIterableIterator(iterable)) {\n\t\tif (!callbackFn(value, index++)) return false;\n\t}\n\n\treturn true;\n}\n"]}
1
+ {"version":3,"sources":["../../../src/lib/every.ts"],"names":[],"mappings":";;;;AAmCO,SAAS,KAAA,CAAyB,UAA2C,UAA8D,EAAA;AACjJ,EAAA,UAAA,GAAa,eAAe,UAAU,CAAA,CAAA;AAEtC,EAAA,IAAI,KAAQ,GAAA,CAAA,CAAA;AACZ,EAAW,KAAA,MAAA,KAAA,IAAS,kBAAmB,CAAA,QAAQ,CAAG,EAAA;AACjD,IAAA,IAAI,CAAC,UAAA,CAAW,KAAO,EAAA,KAAA,EAAO,GAAU,OAAA,KAAA,CAAA;AAAA,GACzC;AAEA,EAAO,OAAA,IAAA,CAAA;AACR,CAAA;AATgB,MAAA,CAAA,KAAA,EAAA,OAAA,CAAA","file":"every.mjs","sourcesContent":["import type { IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Tests whether all elements in the iterable pass the test implemented by the provided function.\n *\n * @param iterable The iterator to check.\n * @param callbackFn A function to execute for each element produced by the iterator. It should return a truthy value to indicate the element passes the test, and a falsy value otherwise.\n * @returns `true` if callbackFn returns a truthy value for every element. Otherwise, `false`.\n *\n * @example\n * ```typescript\n * import { every } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log(every(iterable, (value) => value < 10));\n * // Output: true\n *\n * console.log(every(iterable, (value) => value < 3));\n * // Output: false\n * ```\n *\n * @remarks\n *\n * This function consumes the entire iterator.\n */\nexport function every<const ElementType, const FilteredType extends ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => element is FilteredType\n): iterable is IterableIterator<FilteredType>;\nexport function every<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): boolean;\nexport function every<const ElementType>(iterable: IterableResolvable<ElementType>, callbackFn: (element: ElementType, index: number) => boolean) {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tlet index = 0;\n\tfor (const value of toIterableIterator(iterable)) {\n\t\tif (!callbackFn(value, index++)) return false;\n\t}\n\n\treturn true;\n}\n"]}
@@ -19,4 +19,4 @@ import { IterableResolvable } from './from.mjs';
19
19
  declare function filter<const ElementType, const FilteredType extends ElementType>(iterable: IterableResolvable<ElementType>, callbackFn: (element: ElementType, index: number) => element is FilteredType): IterableIterator<FilteredType>;
20
20
  declare function filter<const ElementType>(iterable: IterableResolvable<ElementType>, callbackFn: (element: ElementType, index: number) => boolean): IterableIterator<ElementType>;
21
21
 
22
- export { filter, filter as takeWhile };
22
+ export { filter };
@@ -1,4 +1,4 @@
1
- import { __name } from '../chunk-G5GHKT7C.mjs';
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
2
  import { assertFunction } from './shared/_assertFunction.mjs';
3
3
  import { toIterableIterator } from './toIterableIterator.mjs';
4
4
 
@@ -6,12 +6,11 @@ function* filter(iterable, callbackFn) {
6
6
  callbackFn = assertFunction(callbackFn);
7
7
  let index = 0;
8
8
  for (const value of toIterableIterator(iterable)) {
9
- if (callbackFn(value, index++))
10
- yield value;
9
+ if (callbackFn(value, index++)) yield value;
11
10
  }
12
11
  }
13
12
  __name(filter, "filter");
14
13
 
15
- export { filter, filter as takeWhile };
16
- //# sourceMappingURL=out.js.map
14
+ export { filter };
15
+ //# sourceMappingURL=filter.mjs.map
17
16
  //# sourceMappingURL=filter.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/filter.ts"],"names":[],"mappings":";;;;;AACA,SAAS,sBAAsB;AAC/B,SAAS,0BAA0B;AA0B5B,UAAU,OAChB,UACA,YACgC;AAChC,eAAa,eAAe,UAAU;AAEtC,MAAI,QAAQ;AACZ,aAAW,SAAS,mBAAmB,QAAQ,GAAG;AACjD,QAAI,WAAW,OAAO,OAAO;AAAG,YAAM;AAAA,EACvC;AACD;AAViB","sourcesContent":["import type { IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Creates an iterable with the elements that pass the test implemented by the provided function.\n *\n * @param iterable The iterator to filter.\n * @param callbackFn A function to execute for each element produced by the iterator. It should return a truthy value to make the element yielded by the iterator helper, and a falsy value otherwise.\n * @returns An iterator that produces elements from the given iterator that satisfy the specified test.\n *\n * @example\n * ```typescript\n * import { filter } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log([...filter(iterable, (value) => value % 2 === 0)]);\n * // Output: [2, 4]\n * ```\n */\nexport function filter<const ElementType, const FilteredType extends ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => element is FilteredType\n): IterableIterator<FilteredType>;\nexport function filter<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): IterableIterator<ElementType>;\nexport function* filter<ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): IterableIterator<ElementType> {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tlet index = 0;\n\tfor (const value of toIterableIterator(iterable)) {\n\t\tif (callbackFn(value, index++)) yield value;\n\t}\n}\n\nexport { filter as takeWhile };\n"]}
1
+ {"version":3,"sources":["../../../src/lib/filter.ts"],"names":[],"mappings":";;;;AA4BO,UAAU,MAAA,CAChB,UACA,UACgC,EAAA;AAChC,EAAA,UAAA,GAAa,eAAe,UAAU,CAAA,CAAA;AAEtC,EAAA,IAAI,KAAQ,GAAA,CAAA,CAAA;AACZ,EAAW,KAAA,MAAA,KAAA,IAAS,kBAAmB,CAAA,QAAQ,CAAG,EAAA;AACjD,IAAA,IAAI,UAAW,CAAA,KAAA,EAAO,KAAO,EAAA,CAAA,EAAS,MAAA,KAAA,CAAA;AAAA,GACvC;AACD,CAAA;AAViB,MAAA,CAAA,MAAA,EAAA,QAAA,CAAA","file":"filter.mjs","sourcesContent":["import type { IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Creates an iterable with the elements that pass the test implemented by the provided function.\n *\n * @param iterable The iterator to filter.\n * @param callbackFn A function to execute for each element produced by the iterator. It should return a truthy value to make the element yielded by the iterator helper, and a falsy value otherwise.\n * @returns An iterator that produces elements from the given iterator that satisfy the specified test.\n *\n * @example\n * ```typescript\n * import { filter } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log([...filter(iterable, (value) => value % 2 === 0)]);\n * // Output: [2, 4]\n * ```\n */\nexport function filter<const ElementType, const FilteredType extends ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => element is FilteredType\n): IterableIterator<FilteredType>;\nexport function filter<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): IterableIterator<ElementType>;\nexport function* filter<ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): IterableIterator<ElementType> {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tlet index = 0;\n\tfor (const value of toIterableIterator(iterable)) {\n\t\tif (callbackFn(value, index++)) yield value;\n\t}\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { __name } from '../chunk-G5GHKT7C.mjs';
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
2
  import { filter } from './filter.mjs';
3
3
  import { first } from './first.mjs';
4
4
 
@@ -8,5 +8,5 @@ function find(iterable, callbackFn) {
8
8
  __name(find, "find");
9
9
 
10
10
  export { find };
11
- //# sourceMappingURL=out.js.map
11
+ //# sourceMappingURL=find.mjs.map
12
12
  //# sourceMappingURL=find.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/find.ts"],"names":[],"mappings":";;;;;AAAA,SAAS,cAAc;AACvB,SAAS,aAAa;AA+Bf,SAAS,KACf,UACA,YAC0B;AAC1B,SAAO,MAAM,OAAO,UAAU,UAAU,CAAC;AAC1C;AALgB","sourcesContent":["import { filter } from './filter';\nimport { first } from './first';\nimport type { IterableResolvable } from './from';\n\n/**\n * Advances the iterable until it finds the element, returning it if it's found and `undefined` otherwise.\n *\n * @param iterable An iterator to search for a value in.\n * @param callbackFn A function that determines if a value is the one being searched for.\n * @returns\n *\n * @example\n * ```typescript\n * import { find } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log(find(iterable, (value) => value % 2 === 0));\n * // Output: 2\n * ```\n *\n * @remarks\n *\n * This function consumes the iterator until the value is found or the iterator is exhausted.\n */\nexport function find<const ElementType, const FilteredType extends ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => element is FilteredType\n): FilteredType | undefined;\nexport function find<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): ElementType | undefined;\nexport function find<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): ElementType | undefined {\n\treturn first(filter(iterable, callbackFn));\n}\n"]}
1
+ {"version":3,"sources":["../../../src/lib/find.ts"],"names":[],"mappings":";;;;AAgCO,SAAS,IAAA,CACf,UACA,UAC0B,EAAA;AAC1B,EAAA,OAAO,KAAM,CAAA,MAAA,CAAO,QAAU,EAAA,UAAU,CAAC,CAAA,CAAA;AAC1C,CAAA;AALgB,MAAA,CAAA,IAAA,EAAA,MAAA,CAAA","file":"find.mjs","sourcesContent":["import { filter } from './filter';\nimport { first } from './first';\nimport type { IterableResolvable } from './from';\n\n/**\n * Advances the iterable until it finds the element, returning it if it's found and `undefined` otherwise.\n *\n * @param iterable An iterator to search for a value in.\n * @param callbackFn A function that determines if a value is the one being searched for.\n * @returns\n *\n * @example\n * ```typescript\n * import { find } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log(find(iterable, (value) => value % 2 === 0));\n * // Output: 2\n * ```\n *\n * @remarks\n *\n * This function consumes the iterator until the value is found or the iterator is exhausted.\n */\nexport function find<const ElementType, const FilteredType extends ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => element is FilteredType\n): FilteredType | undefined;\nexport function find<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): ElementType | undefined;\nexport function find<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): ElementType | undefined {\n\treturn first(filter(iterable, callbackFn));\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { __name } from '../chunk-G5GHKT7C.mjs';
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
2
  import { assertFunction } from './shared/_assertFunction.mjs';
3
3
  import { toIterableIterator } from './toIterableIterator.mjs';
4
4
 
@@ -16,5 +16,5 @@ function findIndex(iterable, callbackFn) {
16
16
  __name(findIndex, "findIndex");
17
17
 
18
18
  export { findIndex };
19
- //# sourceMappingURL=out.js.map
19
+ //# sourceMappingURL=findIndex.mjs.map
20
20
  //# sourceMappingURL=findIndex.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/findIndex.ts"],"names":[],"mappings":";;;;;AACA,SAAS,sBAAsB;AAC/B,SAAS,0BAA0B;AAsB5B,SAAS,UACf,UACA,YACS;AACT,eAAa,eAAe,UAAU;AAEtC,MAAI,QAAQ;AACZ,aAAW,WAAW,mBAAmB,QAAQ,GAAG;AACnD,QAAI,WAAW,SAAS,KAAK,GAAG;AAC/B,aAAO;AAAA,IACR;AAEA;AAAA,EACD;AAEA,SAAO;AACR;AAhBgB","sourcesContent":["import type { IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Advances the iterable until it finds the element, returning its index if it's found and `-1` otherwise.\n *\n * @param iterable An iterator to search for an element in.\n * @param callbackFn A function that determines if an element is the one being searched for.\n * @returns The index of the first element that satisfies the predicate, or `-1` if no elements satisfy the predicate.\n *\n * @example\n * ```typescript\n * import { findIndex } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log(findIndex(iterable, (value) => value % 2 === 0));\n * // Output: 1\n * ```\n *\n * @remarks\n *\n * This function consumes the iterator until the value is found or the iterator is exhausted.\n */\nexport function findIndex<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): number {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tlet index = 0;\n\tfor (const element of toIterableIterator(iterable)) {\n\t\tif (callbackFn(element, index)) {\n\t\t\treturn index;\n\t\t}\n\n\t\tindex++;\n\t}\n\n\treturn -1;\n}\n"]}
1
+ {"version":3,"sources":["../../../src/lib/findIndex.ts"],"names":[],"mappings":";;;;AAwBO,SAAS,SAAA,CACf,UACA,UACS,EAAA;AACT,EAAA,UAAA,GAAa,eAAe,UAAU,CAAA,CAAA;AAEtC,EAAA,IAAI,KAAQ,GAAA,CAAA,CAAA;AACZ,EAAW,KAAA,MAAA,OAAA,IAAW,kBAAmB,CAAA,QAAQ,CAAG,EAAA;AACnD,IAAI,IAAA,UAAA,CAAW,OAAS,EAAA,KAAK,CAAG,EAAA;AAC/B,MAAO,OAAA,KAAA,CAAA;AAAA,KACR;AAEA,IAAA,KAAA,EAAA,CAAA;AAAA,GACD;AAEA,EAAO,OAAA,CAAA,CAAA,CAAA;AACR,CAAA;AAhBgB,MAAA,CAAA,SAAA,EAAA,WAAA,CAAA","file":"findIndex.mjs","sourcesContent":["import type { IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Advances the iterable until it finds the element, returning its index if it's found and `-1` otherwise.\n *\n * @param iterable An iterator to search for an element in.\n * @param callbackFn A function that determines if an element is the one being searched for.\n * @returns The index of the first element that satisfies the predicate, or `-1` if no elements satisfy the predicate.\n *\n * @example\n * ```typescript\n * import { findIndex } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log(findIndex(iterable, (value) => value % 2 === 0));\n * // Output: 1\n * ```\n *\n * @remarks\n *\n * This function consumes the iterator until the value is found or the iterator is exhausted.\n */\nexport function findIndex<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => boolean\n): number {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tlet index = 0;\n\tfor (const element of toIterableIterator(iterable)) {\n\t\tif (callbackFn(element, index)) {\n\t\t\treturn index;\n\t\t}\n\n\t\tindex++;\n\t}\n\n\treturn -1;\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { __name } from '../chunk-G5GHKT7C.mjs';
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
2
  import { from } from './from.mjs';
3
3
 
4
4
  function first(iterable) {
@@ -7,5 +7,5 @@ function first(iterable) {
7
7
  __name(first, "first");
8
8
 
9
9
  export { first };
10
- //# sourceMappingURL=out.js.map
10
+ //# sourceMappingURL=first.mjs.map
11
11
  //# sourceMappingURL=first.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/first.ts"],"names":[],"mappings":";;;;;AAAA,SAAS,YAAqC;AAqBvC,SAAS,MAAyB,UAAoE;AAC5G,SAAO,KAAK,QAAQ,EAAE,KAAK,EAAE;AAC9B;AAFgB","sourcesContent":["import { from, type IterableResolvable } from './from';\n\n/**\n * Consumes the first element of the iterable, returning it if it's found and `undefined` otherwise.\n *\n * @param iterable The iterator to return the first value of.\n * @returns The first value of the iterator, or `undefined` if the iterator is empty.\n *\n * @example\n * ```typescript\n * import { first } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log(first(iterable));\n * // Output: 1\n * ```\n *\n * @remarks\n *\n * This function consumes the first value of the iterator.\n */\nexport function first<const ElementType>(iterable: IterableResolvable<ElementType>): ElementType | undefined {\n\treturn from(iterable).next().value;\n}\n"]}
1
+ {"version":3,"sources":["../../../src/lib/first.ts"],"names":[],"mappings":";;;AAqBO,SAAS,MAAyB,QAAoE,EAAA;AAC5G,EAAA,OAAO,IAAK,CAAA,QAAQ,CAAE,CAAA,IAAA,EAAO,CAAA,KAAA,CAAA;AAC9B,CAAA;AAFgB,MAAA,CAAA,KAAA,EAAA,OAAA,CAAA","file":"first.mjs","sourcesContent":["import { from, type IterableResolvable } from './from';\n\n/**\n * Consumes the first element of the iterable, returning it if it's found and `undefined` otherwise.\n *\n * @param iterable The iterator to return the first value of.\n * @returns The first value of the iterator, or `undefined` if the iterator is empty.\n *\n * @example\n * ```typescript\n * import { first } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log(first(iterable));\n * // Output: 1\n * ```\n *\n * @remarks\n *\n * This function consumes the first value of the iterator.\n */\nexport function first<const ElementType>(iterable: IterableResolvable<ElementType>): ElementType | undefined {\n\treturn from(iterable).next().value;\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { __name } from '../chunk-G5GHKT7C.mjs';
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
2
  import { toIterableIterator } from './toIterableIterator.mjs';
3
3
 
4
4
  function* flat(iterables) {
@@ -9,5 +9,5 @@ function* flat(iterables) {
9
9
  __name(flat, "flat");
10
10
 
11
11
  export { flat };
12
- //# sourceMappingURL=out.js.map
12
+ //# sourceMappingURL=flat.mjs.map
13
13
  //# sourceMappingURL=flat.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/flat.ts"],"names":[],"mappings":";;;;;AACA,SAAS,0BAA0B;AAiB5B,UAAU,KAAwB,WAA+F;AACvI,aAAW,SAAS,mBAAmB,SAAS,GAAG;AAClD,WAAO,mBAAmB,KAAK;AAAA,EAChC;AACD;AAJiB","sourcesContent":["import type { IterableResolvable } from './from';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Creates an iterable that yields the elements of each iterable in the input iterable.\n *\n * @param iterables An iterator to map.\n * @returns An iterator that yields the entries of each iterator.\n *\n * @example\n * ```typescript\n * import { flat } from '@sapphire/iterator-utilities';\n *\n * const iterable = flat([[1, 2], [3, 4], [5, 6]]);\n * console.log([...iterable]);\n * // Output: [1, 2, 3, 4, 5, 6]\n * ```\n */\nexport function* flat<const ElementType>(iterables: IterableResolvable<IterableResolvable<ElementType>>): IterableIterator<ElementType> {\n\tfor (const value of toIterableIterator(iterables)) {\n\t\tyield* toIterableIterator(value);\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../../src/lib/flat.ts"],"names":[],"mappings":";;;AAkBO,UAAU,KAAwB,SAA+F,EAAA;AACvI,EAAW,KAAA,MAAA,KAAA,IAAS,kBAAmB,CAAA,SAAS,CAAG,EAAA;AAClD,IAAA,OAAO,mBAAmB,KAAK,CAAA,CAAA;AAAA,GAChC;AACD,CAAA;AAJiB,MAAA,CAAA,IAAA,EAAA,MAAA,CAAA","file":"flat.mjs","sourcesContent":["import type { IterableResolvable } from './from';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Creates an iterable that yields the elements of each iterable in the input iterable.\n *\n * @param iterables An iterator to map.\n * @returns An iterator that yields the entries of each iterator.\n *\n * @example\n * ```typescript\n * import { flat } from '@sapphire/iterator-utilities';\n *\n * const iterable = flat([[1, 2], [3, 4], [5, 6]]);\n * console.log([...iterable]);\n * // Output: [1, 2, 3, 4, 5, 6]\n * ```\n */\nexport function* flat<const ElementType>(iterables: IterableResolvable<IterableResolvable<ElementType>>): IterableIterator<ElementType> {\n\tfor (const value of toIterableIterator(iterables)) {\n\t\tyield* toIterableIterator(value);\n\t}\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { __name } from '../chunk-G5GHKT7C.mjs';
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
2
  import { assertFunction } from './shared/_assertFunction.mjs';
3
3
  import { toIterableIterator } from './toIterableIterator.mjs';
4
4
 
@@ -12,5 +12,5 @@ function* flatMap(iterable, callbackFn) {
12
12
  __name(flatMap, "flatMap");
13
13
 
14
14
  export { flatMap };
15
- //# sourceMappingURL=out.js.map
15
+ //# sourceMappingURL=flatMap.mjs.map
16
16
  //# sourceMappingURL=flatMap.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/flatMap.ts"],"names":[],"mappings":";;;;;AACA,SAAS,sBAAsB;AAC/B,SAAS,0BAA0B;AAkB5B,UAAU,QAChB,UACA,YAC+B;AAC/B,eAAa,eAAe,UAAU;AAEtC,MAAI,QAAQ;AACZ,aAAW,SAAS,mBAAmB,QAAQ,GAAG;AACjD,WAAO,mBAAmB,WAAW,OAAO,OAAO,CAAC;AAAA,EACrD;AACD;AAViB","sourcesContent":["import type { IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Creates an iterable that yields the elements of each iterable returned by the provided function on each element of the input iterable.\n *\n * @param iterable An iterator to map.\n * @param callbackFn A function to execute for each element produced by the iterator. It should return an iterator or iterable that yields elements to be yielded by `flatMap()`, or a single non-iterator/iterable value to be yielded.\n * @returns An iterator that applies a function to each element of the input iterator and yields the results.\n *\n * @example\n * ```typescript\n * import { flatMap } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3];\n * console.log([...flatMap(iterable, (value) => [value, value * 2])]);\n * // Output: [1, 2, 2, 4, 3, 6]\n * ```\n */\nexport function* flatMap<const ElementType, const MappedType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => IterableResolvable<MappedType>\n): IterableIterator<MappedType> {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tlet index = 0;\n\tfor (const value of toIterableIterator(iterable)) {\n\t\tyield* toIterableIterator(callbackFn(value, index++));\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../../src/lib/flatMap.ts"],"names":[],"mappings":";;;;AAoBO,UAAU,OAAA,CAChB,UACA,UAC+B,EAAA;AAC/B,EAAA,UAAA,GAAa,eAAe,UAAU,CAAA,CAAA;AAEtC,EAAA,IAAI,KAAQ,GAAA,CAAA,CAAA;AACZ,EAAW,KAAA,MAAA,KAAA,IAAS,kBAAmB,CAAA,QAAQ,CAAG,EAAA;AACjD,IAAA,OAAO,kBAAmB,CAAA,UAAA,CAAW,KAAO,EAAA,KAAA,EAAO,CAAC,CAAA,CAAA;AAAA,GACrD;AACD,CAAA;AAViB,MAAA,CAAA,OAAA,EAAA,SAAA,CAAA","file":"flatMap.mjs","sourcesContent":["import type { IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Creates an iterable that yields the elements of each iterable returned by the provided function on each element of the input iterable.\n *\n * @param iterable An iterator to map.\n * @param callbackFn A function to execute for each element produced by the iterator. It should return an iterator or iterable that yields elements to be yielded by `flatMap()`, or a single non-iterator/iterable value to be yielded.\n * @returns An iterator that applies a function to each element of the input iterator and yields the results.\n *\n * @example\n * ```typescript\n * import { flatMap } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3];\n * console.log([...flatMap(iterable, (value) => [value, value * 2])]);\n * // Output: [1, 2, 2, 4, 3, 6]\n * ```\n */\nexport function* flatMap<const ElementType, const MappedType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => IterableResolvable<MappedType>\n): IterableIterator<MappedType> {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tlet index = 0;\n\tfor (const value of toIterableIterator(iterable)) {\n\t\tyield* toIterableIterator(callbackFn(value, index++));\n\t}\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { __name } from '../chunk-G5GHKT7C.mjs';
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
2
  import { assertFunction } from './shared/_assertFunction.mjs';
3
3
  import { toIterableIterator } from './toIterableIterator.mjs';
4
4
 
@@ -12,5 +12,5 @@ function forEach(iterable, callbackFn) {
12
12
  __name(forEach, "forEach");
13
13
 
14
14
  export { forEach };
15
- //# sourceMappingURL=out.js.map
15
+ //# sourceMappingURL=forEach.mjs.map
16
16
  //# sourceMappingURL=forEach.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/forEach.ts"],"names":[],"mappings":";;;;;AACA,SAAS,sBAAsB;AAC/B,SAAS,0BAA0B;AAqB5B,SAAS,QACf,UACA,YACO;AACP,eAAa,eAAe,UAAU;AAEtC,MAAI,QAAQ;AACZ,aAAW,WAAW,mBAAmB,QAAQ,GAAG;AACnD,eAAW,SAAS,OAAO;AAAA,EAC5B;AACD;AAVgB","sourcesContent":["import type { IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Executes a provided function once for each iterable element.\n *\n * @param iterable An iterator to iterate over.\n * @param callbackFn A function to execute for each element produced by the iterator. Its return value is discarded.\n *\n * @example\n * ```typescript\n * import { forEach } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * forEach(iterable, (value) => console.log(value));\n * // Output: 1, 2, 3, 4, 5\n * ```\n *\n * @remarks\n *\n * This function consumes the entire iterator.\n */\nexport function forEach<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => void\n): void {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tlet index = 0;\n\tfor (const element of toIterableIterator(iterable)) {\n\t\tcallbackFn(element, index++);\n\t}\n}\n"]}
1
+ {"version":3,"sources":["../../../src/lib/forEach.ts"],"names":[],"mappings":";;;;AAuBO,SAAS,OAAA,CACf,UACA,UACO,EAAA;AACP,EAAA,UAAA,GAAa,eAAe,UAAU,CAAA,CAAA;AAEtC,EAAA,IAAI,KAAQ,GAAA,CAAA,CAAA;AACZ,EAAW,KAAA,MAAA,OAAA,IAAW,kBAAmB,CAAA,QAAQ,CAAG,EAAA;AACnD,IAAA,UAAA,CAAW,SAAS,KAAO,EAAA,CAAA,CAAA;AAAA,GAC5B;AACD,CAAA;AAVgB,MAAA,CAAA,OAAA,EAAA,SAAA,CAAA","file":"forEach.mjs","sourcesContent":["import type { IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Executes a provided function once for each iterable element.\n *\n * @param iterable An iterator to iterate over.\n * @param callbackFn A function to execute for each element produced by the iterator. Its return value is discarded.\n *\n * @example\n * ```typescript\n * import { forEach } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * forEach(iterable, (value) => console.log(value));\n * // Output: 1, 2, 3, 4, 5\n * ```\n *\n * @remarks\n *\n * This function consumes the entire iterator.\n */\nexport function forEach<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => void\n): void {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tlet index = 0;\n\tfor (const element of toIterableIterator(iterable)) {\n\t\tcallbackFn(element, index++);\n\t}\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { __name } from '../chunk-G5GHKT7C.mjs';
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
2
 
3
3
  // src/lib/from.ts
4
4
  function from(value) {
@@ -18,5 +18,5 @@ function from(value) {
18
18
  __name(from, "from");
19
19
 
20
20
  export { from };
21
- //# sourceMappingURL=out.js.map
21
+ //# sourceMappingURL=from.mjs.map
22
22
  //# sourceMappingURL=from.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/from.ts"],"names":[],"mappings":";;;;;AAmBO,SAAS,KAAK,OAAY;AAChC,MAAI,OAAO,UAAU,YAAY,UAAU,MAAM;AAChD,QAAI,OAAO,MAAM,OAAO,QAAQ,MAAM,YAAY;AACjD,aAAO,MAAM,OAAO,QAAQ,EAAE;AAAA,IAC/B;AAEA,QAAI,OAAO,MAAM,SAAS,YAAY;AACrC,aAAO;AAAA,IACR;AAAA,EACD;AAEA,MAAI,OAAO,UAAU,UAAU;AAC9B,WAAO,MAAM,OAAO,QAAQ,EAAE;AAAA,EAC/B;AAEA,QAAM,IAAI,UAAU,GAAG,OAAO,KAAK,CAAC,qCAAqC;AAC1E;AAhBgB","sourcesContent":["/**\n * Resolves an iterable from an iterable or iterator-like object.\n *\n * @param value The value to convert to an iterator.\n *\n * @example\n * ```typescript\n * import { from } from '@sapphire/iterator-utilities';\n *\n * const iterable = from([1, 2, 3, 4, 5]);\n * for (const element of iterable) {\n * \tconsole.log(element);\n * \t// Output: 1, 2, 3, 4, 5\n * }\n * ```\n */\nexport function from<const ElementType, const ResolvableType extends IterableResolvable<ElementType>>(\n\tvalue: ResolvableType\n): IterableResolved<ResolvableType>;\nexport function from(value: any) {\n\tif (typeof value === 'object' && value !== null) {\n\t\tif (typeof value[Symbol.iterator] === 'function') {\n\t\t\treturn value[Symbol.iterator]();\n\t\t}\n\n\t\tif (typeof value.next === 'function') {\n\t\t\treturn value;\n\t\t}\n\t}\n\n\tif (typeof value === 'string') {\n\t\treturn value[Symbol.iterator]();\n\t}\n\n\tthrow new TypeError(`${String(value)} cannot be converted to an iterable`);\n}\n\nexport type IterableResolvable<ElementType> = Iterable<ElementType> | Iterator<ElementType> | IterableIterator<ElementType>;\n\nexport type IterableResolved<Type> =\n\tType extends IterableIterator<infer Output>\n\t\t? IterableIterator<Output>\n\t\t: Type extends Iterable<infer Output>\n\t\t\t? Iterator<Output>\n\t\t\t: Type extends Iterator<infer Output>\n\t\t\t\t? Iterator<Output>\n\t\t\t\t: never;\n"]}
1
+ {"version":3,"sources":["../../../src/lib/from.ts"],"names":[],"mappings":";;;AAmBO,SAAS,KAAK,KAAY,EAAA;AAChC,EAAA,IAAI,OAAO,KAAA,KAAU,QAAY,IAAA,KAAA,KAAU,IAAM,EAAA;AAChD,IAAA,IAAI,OAAO,KAAA,CAAM,MAAO,CAAA,QAAQ,MAAM,UAAY,EAAA;AACjD,MAAO,OAAA,KAAA,CAAM,MAAO,CAAA,QAAQ,CAAE,EAAA,CAAA;AAAA,KAC/B;AAEA,IAAI,IAAA,OAAO,KAAM,CAAA,IAAA,KAAS,UAAY,EAAA;AACrC,MAAO,OAAA,KAAA,CAAA;AAAA,KACR;AAAA,GACD;AAEA,EAAI,IAAA,OAAO,UAAU,QAAU,EAAA;AAC9B,IAAO,OAAA,KAAA,CAAM,MAAO,CAAA,QAAQ,CAAE,EAAA,CAAA;AAAA,GAC/B;AAEA,EAAA,MAAM,IAAI,SAAU,CAAA,CAAA,EAAG,MAAO,CAAA,KAAK,CAAC,CAAqC,mCAAA,CAAA,CAAA,CAAA;AAC1E,CAAA;AAhBgB,MAAA,CAAA,IAAA,EAAA,MAAA,CAAA","file":"from.mjs","sourcesContent":["/**\n * Resolves an iterable from an iterable or iterator-like object.\n *\n * @param value The value to convert to an iterator.\n *\n * @example\n * ```typescript\n * import { from } from '@sapphire/iterator-utilities';\n *\n * const iterable = from([1, 2, 3, 4, 5]);\n * for (const element of iterable) {\n * \tconsole.log(element);\n * \t// Output: 1, 2, 3, 4, 5\n * }\n * ```\n */\nexport function from<const ElementType, const ResolvableType extends IterableResolvable<ElementType>>(\n\tvalue: ResolvableType\n): IterableResolved<ResolvableType>;\nexport function from(value: any) {\n\tif (typeof value === 'object' && value !== null) {\n\t\tif (typeof value[Symbol.iterator] === 'function') {\n\t\t\treturn value[Symbol.iterator]();\n\t\t}\n\n\t\tif (typeof value.next === 'function') {\n\t\t\treturn value;\n\t\t}\n\t}\n\n\tif (typeof value === 'string') {\n\t\treturn value[Symbol.iterator]();\n\t}\n\n\tthrow new TypeError(`${String(value)} cannot be converted to an iterable`);\n}\n\nexport type IterableResolvable<ElementType> = Iterable<ElementType> | Iterator<ElementType> | IterableIterator<ElementType>;\n\nexport type IterableResolved<Type> =\n\tType extends IterableIterator<infer Output>\n\t\t? IterableIterator<Output>\n\t\t: Type extends Iterable<infer Output>\n\t\t\t? Iterator<Output>\n\t\t\t: Type extends Iterator<infer Output>\n\t\t\t\t? Iterator<Output>\n\t\t\t\t: never;\n"]}
@@ -0,0 +1,47 @@
1
+ import { IterableResolvable } from './from.mjs';
2
+
3
+ /**
4
+ * Creates an iterator which ends after the first `done` result from the original iterator.
5
+ *
6
+ * After an iterator returns a `done` result, future calls may or may not yield additional results again. This function
7
+ * adapts an iterator, ensuring that after a `done` result is given, it will always return a `done` result forever.
8
+ *
9
+ * @param iterable An iterator to fuse.
10
+ *
11
+ * @example
12
+ * ```typescript
13
+ * import { fuse } from '@sapphire/iterator-utilities';
14
+ *
15
+ * const iterable = {
16
+ * state: 0,
17
+ * next() {
18
+ * const value = this.state;
19
+ * this.state += 1;
20
+ *
21
+ * return value % 2 === 0 //
22
+ * ? { done: false, value }
23
+ * : { done: true, value: undefined };
24
+ * }
25
+ * };
26
+ *
27
+ * // We can see our iterator going back and forth
28
+ * assert(iterable.next(), { done: false, value: 0 });
29
+ * assert(iterable.next(), { done: true, value: undefined });
30
+ * assert(iterable.next(), { done: false, value: 2 });
31
+ * assert(iterable.next(), { done: true, value: undefined });
32
+ *
33
+ * // However, once we fuse it...
34
+ * const fused = fuse(iterable);
35
+ *
36
+ * assert(fused.next(), { done: false, value: 4 });
37
+ * assert(fused.next(), { done: true, value: undefined });
38
+ *
39
+ * // It will always return a `done` result after the first time
40
+ * assert(fused.next(), { done: true, value: undefined });
41
+ * assert(fused.next(), { done: true, value: undefined });
42
+ * assert(fused.next(), { done: true, value: undefined });
43
+ * ```
44
+ */
45
+ declare function fuse<const ElementType>(iterable: IterableResolvable<ElementType>): IterableIterator<ElementType>;
46
+
47
+ export { fuse };
@@ -0,0 +1,23 @@
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
+ import { makeIterableIterator } from './shared/_makeIterableIterator.mjs';
3
+ import { toIterableIterator } from './toIterableIterator.mjs';
4
+
5
+ function fuse(iterable) {
6
+ let ended = false;
7
+ const iterator = toIterableIterator(iterable);
8
+ return makeIterableIterator(() => {
9
+ if (ended) {
10
+ return { done: true, value: void 0 };
11
+ }
12
+ const result = iterator.next();
13
+ if (result.done) {
14
+ ended = true;
15
+ }
16
+ return result;
17
+ });
18
+ }
19
+ __name(fuse, "fuse");
20
+
21
+ export { fuse };
22
+ //# sourceMappingURL=fuse.mjs.map
23
+ //# sourceMappingURL=fuse.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/fuse.ts"],"names":[],"mappings":";;;;AA8CO,SAAS,KAAwB,QAA0E,EAAA;AACjH,EAAA,IAAI,KAAQ,GAAA,KAAA,CAAA;AACZ,EAAM,MAAA,QAAA,GAAW,mBAAmB,QAAQ,CAAA,CAAA;AAC5C,EAAA,OAAO,qBAAqB,MAAM;AACjC,IAAA,IAAI,KAAO,EAAA;AACV,MAAA,OAAO,EAAE,IAAA,EAAM,IAAM,EAAA,KAAA,EAAO,KAAU,CAAA,EAAA,CAAA;AAAA,KACvC;AAEA,IAAM,MAAA,MAAA,GAAS,SAAS,IAAK,EAAA,CAAA;AAC7B,IAAA,IAAI,OAAO,IAAM,EAAA;AAChB,MAAQ,KAAA,GAAA,IAAA,CAAA;AAAA,KACT;AAEA,IAAO,OAAA,MAAA,CAAA;AAAA,GACP,CAAA,CAAA;AACF,CAAA;AAfgB,MAAA,CAAA,IAAA,EAAA,MAAA,CAAA","file":"fuse.mjs","sourcesContent":["import type { IterableResolvable } from './from';\nimport { makeIterableIterator } from './shared/_makeIterableIterator';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Creates an iterator which ends after the first `done` result from the original iterator.\n *\n * After an iterator returns a `done` result, future calls may or may not yield additional results again. This function\n * adapts an iterator, ensuring that after a `done` result is given, it will always return a `done` result forever.\n *\n * @param iterable An iterator to fuse.\n *\n * @example\n * ```typescript\n * import { fuse } from '@sapphire/iterator-utilities';\n *\n * const iterable = {\n * state: 0,\n * next() {\n * const value = this.state;\n * this.state += 1;\n *\n * return value % 2 === 0 //\n * ? { done: false, value }\n * : { done: true, value: undefined };\n * }\n * };\n *\n * // We can see our iterator going back and forth\n * assert(iterable.next(), { done: false, value: 0 });\n * assert(iterable.next(), { done: true, value: undefined });\n * assert(iterable.next(), { done: false, value: 2 });\n * assert(iterable.next(), { done: true, value: undefined });\n *\n * // However, once we fuse it...\n * const fused = fuse(iterable);\n *\n * assert(fused.next(), { done: false, value: 4 });\n * assert(fused.next(), { done: true, value: undefined });\n *\n * // It will always return a `done` result after the first time\n * assert(fused.next(), { done: true, value: undefined });\n * assert(fused.next(), { done: true, value: undefined });\n * assert(fused.next(), { done: true, value: undefined });\n * ```\n */\nexport function fuse<const ElementType>(iterable: IterableResolvable<ElementType>): IterableIterator<ElementType> {\n\tlet ended = false;\n\tconst iterator = toIterableIterator(iterable);\n\treturn makeIterableIterator(() => {\n\t\tif (ended) {\n\t\t\treturn { done: true, value: undefined };\n\t\t}\n\n\t\tconst result = iterator.next();\n\t\tif (result.done) {\n\t\t\tended = true;\n\t\t}\n\n\t\treturn result;\n\t});\n}\n"]}
@@ -0,0 +1,32 @@
1
+ import { IterableResolvable } from './from.mjs';
2
+
3
+ /**
4
+ * Determines if the elements of `iterable` are {@link LexicographicComparison lexicographically} greater or equal than
5
+ * those of another.
6
+ *
7
+ * @param iterable The iterator to compare.
8
+ * @param other The iterator to compare against.
9
+ *
10
+ * @example
11
+ * ```typescript
12
+ * import { greaterOrEqualThan } from '@sapphire/iterator-utilities';
13
+ *
14
+ * const x = [1, 2, 3, 4];
15
+ * const y = [1, 4, 9, 16];
16
+ * console.log(greaterOrEqualThan([1], [1]));
17
+ * // Output: true
18
+ * console.log(greaterOrEqualThan([1], [1, 2]));
19
+ * // Output: false
20
+ * console.log(greaterOrEqualThan([1, 2], [1]));
21
+ * // Output: true
22
+ * console.log(greaterOrEqualThan([1, 2], [1, 2]));
23
+ * // Output: true
24
+ * ```
25
+ *
26
+ * @remarks
27
+ *
28
+ * This function consumes the entire iterator.
29
+ */
30
+ declare function greaterOrEqualThan<const ElementType>(iterable: IterableResolvable<ElementType>, other: IterableResolvable<ElementType>): boolean;
31
+
32
+ export { greaterOrEqualThan as ge, greaterOrEqualThan };
@@ -0,0 +1,13 @@
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
+ import { compare } from './compare.mjs';
3
+ import { orderingIsLess } from './shared/_compare.mjs';
4
+
5
+ function greaterOrEqualThan(iterable, other) {
6
+ const result = compare(iterable, other);
7
+ return !orderingIsLess(result);
8
+ }
9
+ __name(greaterOrEqualThan, "greaterOrEqualThan");
10
+
11
+ export { greaterOrEqualThan as ge, greaterOrEqualThan };
12
+ //# sourceMappingURL=greaterOrEqualThan.mjs.map
13
+ //# sourceMappingURL=greaterOrEqualThan.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/greaterOrEqualThan.ts"],"names":[],"mappings":";;;;AA+BO,SAAS,kBAAA,CAAsC,UAA2C,KAAiD,EAAA;AACjJ,EAAM,MAAA,MAAA,GAAS,OAAQ,CAAA,QAAA,EAAU,KAAK,CAAA,CAAA;AACtC,EAAO,OAAA,CAAC,eAAe,MAAM,CAAA,CAAA;AAC9B,CAAA;AAHgB,MAAA,CAAA,kBAAA,EAAA,oBAAA,CAAA","file":"greaterOrEqualThan.mjs","sourcesContent":["import { compare } from './compare';\nimport type { IterableResolvable } from './from';\nimport { orderingIsLess, type LexicographicComparison } from './shared/_compare';\n\n/**\n * Determines if the elements of `iterable` are {@link LexicographicComparison lexicographically} greater or equal than\n * those of another.\n *\n * @param iterable The iterator to compare.\n * @param other The iterator to compare against.\n *\n * @example\n * ```typescript\n * import { greaterOrEqualThan } from '@sapphire/iterator-utilities';\n *\n * const x = [1, 2, 3, 4];\n * const y = [1, 4, 9, 16];\n * console.log(greaterOrEqualThan([1], [1]));\n * // Output: true\n * console.log(greaterOrEqualThan([1], [1, 2]));\n * // Output: false\n * console.log(greaterOrEqualThan([1, 2], [1]));\n * // Output: true\n * console.log(greaterOrEqualThan([1, 2], [1, 2]));\n * // Output: true\n * ```\n *\n * @remarks\n *\n * This function consumes the entire iterator.\n */\nexport function greaterOrEqualThan<const ElementType>(iterable: IterableResolvable<ElementType>, other: IterableResolvable<ElementType>): boolean {\n\tconst result = compare(iterable, other);\n\treturn !orderingIsLess(result);\n}\n\nexport { greaterOrEqualThan as ge };\n"]}
@@ -0,0 +1,32 @@
1
+ import { IterableResolvable } from './from.mjs';
2
+
3
+ /**
4
+ * Determines if the elements of `iterable` are {@link LexicographicComparison lexicographically} greater than those of
5
+ * another.
6
+ *
7
+ * @param iterable The iterator to compare.
8
+ * @param other The iterator to compare against.
9
+ *
10
+ * @example
11
+ * ```typescript
12
+ * import { greaterThan } from '@sapphire/iterator-utilities';
13
+ *
14
+ * const x = [1, 2, 3, 4];
15
+ * const y = [1, 4, 9, 16];
16
+ * console.log(greaterThan([1], [1]));
17
+ * // Output: false
18
+ * console.log(greaterThan([1], [1, 2]));
19
+ * // Output: false
20
+ * console.log(greaterThan([1, 2], [1]));
21
+ * // Output: true
22
+ * console.log(greaterThan([1, 2], [1, 2]));
23
+ * // Output: false
24
+ * ```
25
+ *
26
+ * @remarks
27
+ *
28
+ * This function consumes the entire iterator.
29
+ */
30
+ declare function greaterThan<const ElementType>(iterable: IterableResolvable<ElementType>, other: IterableResolvable<ElementType>): boolean;
31
+
32
+ export { greaterThan, greaterThan as gt };
@@ -0,0 +1,13 @@
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
+ import { compare } from './compare.mjs';
3
+ import { orderingIsGreater } from './shared/_compare.mjs';
4
+
5
+ function greaterThan(iterable, other) {
6
+ const result = compare(iterable, other);
7
+ return orderingIsGreater(result);
8
+ }
9
+ __name(greaterThan, "greaterThan");
10
+
11
+ export { greaterThan, greaterThan as gt };
12
+ //# sourceMappingURL=greaterThan.mjs.map
13
+ //# sourceMappingURL=greaterThan.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/greaterThan.ts"],"names":[],"mappings":";;;;AA+BO,SAAS,WAAA,CAA+B,UAA2C,KAAiD,EAAA;AAC1I,EAAM,MAAA,MAAA,GAAS,OAAQ,CAAA,QAAA,EAAU,KAAK,CAAA,CAAA;AACtC,EAAA,OAAO,kBAAkB,MAAM,CAAA,CAAA;AAChC,CAAA;AAHgB,MAAA,CAAA,WAAA,EAAA,aAAA,CAAA","file":"greaterThan.mjs","sourcesContent":["import { compare } from './compare';\nimport type { IterableResolvable } from './from';\nimport { orderingIsGreater, type LexicographicComparison } from './shared/_compare';\n\n/**\n * Determines if the elements of `iterable` are {@link LexicographicComparison lexicographically} greater than those of\n * another.\n *\n * @param iterable The iterator to compare.\n * @param other The iterator to compare against.\n *\n * @example\n * ```typescript\n * import { greaterThan } from '@sapphire/iterator-utilities';\n *\n * const x = [1, 2, 3, 4];\n * const y = [1, 4, 9, 16];\n * console.log(greaterThan([1], [1]));\n * // Output: false\n * console.log(greaterThan([1], [1, 2]));\n * // Output: false\n * console.log(greaterThan([1, 2], [1]));\n * // Output: true\n * console.log(greaterThan([1, 2], [1, 2]));\n * // Output: false\n * ```\n *\n * @remarks\n *\n * This function consumes the entire iterator.\n */\nexport function greaterThan<const ElementType>(iterable: IterableResolvable<ElementType>, other: IterableResolvable<ElementType>): boolean {\n\tconst result = compare(iterable, other);\n\treturn orderingIsGreater(result);\n}\n\nexport { greaterThan as gt };\n"]}
@@ -22,4 +22,4 @@ import { IterableResolvable } from './from.mjs';
22
22
  */
23
23
  declare function indexOf<const ElementType>(iterable: IterableResolvable<ElementType>, value: ElementType): number;
24
24
 
25
- export { indexOf, indexOf as position };
25
+ export { indexOf };
@@ -1,4 +1,4 @@
1
- import { __name } from '../chunk-G5GHKT7C.mjs';
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
2
  import { toIterableIterator } from './toIterableIterator.mjs';
3
3
 
4
4
  function indexOf(iterable, value) {
@@ -13,6 +13,6 @@ function indexOf(iterable, value) {
13
13
  }
14
14
  __name(indexOf, "indexOf");
15
15
 
16
- export { indexOf, indexOf as position };
17
- //# sourceMappingURL=out.js.map
16
+ export { indexOf };
17
+ //# sourceMappingURL=indexOf.mjs.map
18
18
  //# sourceMappingURL=indexOf.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/indexOf.ts"],"names":[],"mappings":";;;;;AACA,SAAS,0BAA0B;AAsB5B,SAAS,QAA2B,UAA2C,OAA4B;AACjH,MAAI,QAAQ;AACZ,aAAW,WAAW,mBAAmB,QAAQ,GAAG;AACnD,QAAI,YAAY,OAAO;AACtB,aAAO;AAAA,IACR;AAEA;AAAA,EACD;AAEA,SAAO;AACR;AAXgB","sourcesContent":["import type { IterableResolvable } from './from';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Advances the iterable until it finds the element, returning its index if it's found and `-1` otherwise.\n *\n * @param iterable An iterator to search for a value in.\n * @param value The value to search for.\n * @returns The index of the first occurrence of the value in the iterator, or `-1` if the value is not found.\n *\n * @example\n * ```typescript\n * import { indexOf } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log(indexOf(iterable, 3));\n * // Output: 2\n * ```\n *\n * @remarks\n *\n * This function consumes the iterator until the value is found or the iterator is exhausted.\n */\nexport function indexOf<const ElementType>(iterable: IterableResolvable<ElementType>, value: ElementType): number {\n\tlet index = 0;\n\tfor (const element of toIterableIterator(iterable)) {\n\t\tif (element === value) {\n\t\t\treturn index;\n\t\t}\n\n\t\tindex++;\n\t}\n\n\treturn -1;\n}\n\nexport { indexOf as position };\n"]}
1
+ {"version":3,"sources":["../../../src/lib/indexOf.ts"],"names":[],"mappings":";;;AAuBO,SAAS,OAAA,CAA2B,UAA2C,KAA4B,EAAA;AACjH,EAAA,IAAI,KAAQ,GAAA,CAAA,CAAA;AACZ,EAAW,KAAA,MAAA,OAAA,IAAW,kBAAmB,CAAA,QAAQ,CAAG,EAAA;AACnD,IAAA,IAAI,YAAY,KAAO,EAAA;AACtB,MAAO,OAAA,KAAA,CAAA;AAAA,KACR;AAEA,IAAA,KAAA,EAAA,CAAA;AAAA,GACD;AAEA,EAAO,OAAA,CAAA,CAAA,CAAA;AACR,CAAA;AAXgB,MAAA,CAAA,OAAA,EAAA,SAAA,CAAA","file":"indexOf.mjs","sourcesContent":["import type { IterableResolvable } from './from';\nimport { toIterableIterator } from './toIterableIterator';\n\n/**\n * Advances the iterable until it finds the element, returning its index if it's found and `-1` otherwise.\n *\n * @param iterable An iterator to search for a value in.\n * @param value The value to search for.\n * @returns The index of the first occurrence of the value in the iterator, or `-1` if the value is not found.\n *\n * @example\n * ```typescript\n * import { indexOf } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 2, 3, 4, 5];\n * console.log(indexOf(iterable, 3));\n * // Output: 2\n * ```\n *\n * @remarks\n *\n * This function consumes the iterator until the value is found or the iterator is exhausted.\n */\nexport function indexOf<const ElementType>(iterable: IterableResolvable<ElementType>, value: ElementType): number {\n\tlet index = 0;\n\tfor (const element of toIterableIterator(iterable)) {\n\t\tif (element === value) {\n\t\t\treturn index;\n\t\t}\n\n\t\tindex++;\n\t}\n\n\treturn -1;\n}\n"]}
@@ -0,0 +1,39 @@
1
+ import { IterableResolvable } from './from.mjs';
2
+
3
+ /**
4
+ * Does something with each element of an iterator, passing the value on.
5
+ *
6
+ * When using iterators, you'll often chain several of them together. While working on such code, you might want to
7
+ * check out what's happening at various parts in the pipeline. To do that, insert a call to this function.
8
+ *
9
+ * It's more common for this function to be used as a debugging tool than to exist in your final code, but applications
10
+ * may find it useful in certain situations when errors need to be logged before being discarded.
11
+ *
12
+ * @param iterable An iterator to inspect.
13
+ *
14
+ * @example
15
+ * ```typescript
16
+ * import { inspect } from '@sapphire/iterator-utilities';
17
+ *
18
+ * const iterable = [1, 4, 2, 3];
19
+ *
20
+ * let iter = inspect(iter, (value) => console.log(`about to filter: ${value}`));
21
+ * iter = filter(iterable, (value) => value % 2 === 0);
22
+ * iter = inspect(iter, (value) => console.log(`made it through filter: ${value}`));
23
+ *
24
+ * const sum = reduce(iter, (acc, value) => acc + value, 0);
25
+ * console.log(sum);
26
+ *
27
+ * // Output:
28
+ * // about to filter: 1
29
+ * // about to filter: 4
30
+ * // made it through filter: 4
31
+ * // about to filter: 2
32
+ * // made it through filter: 2
33
+ * // about to filter: 3
34
+ * // 6
35
+ * ```
36
+ */
37
+ declare function inspect<const ElementType>(iterable: IterableResolvable<ElementType>, callbackFn: (element: ElementType, index: number) => void): IterableIterator<ElementType>;
38
+
39
+ export { inspect };
@@ -0,0 +1,22 @@
1
+ import { __name } from '../chunk-PAWJFY3S.mjs';
2
+ import { from } from './from.mjs';
3
+ import { assertFunction } from './shared/_assertFunction.mjs';
4
+ import { makeIterableIterator } from './shared/_makeIterableIterator.mjs';
5
+
6
+ function inspect(iterable, callbackFn) {
7
+ callbackFn = assertFunction(callbackFn);
8
+ let index = 0;
9
+ const iterator = from(iterable);
10
+ return makeIterableIterator(() => {
11
+ const result = iterator.next();
12
+ if (!result.done) {
13
+ callbackFn(result.value, index++);
14
+ }
15
+ return result;
16
+ });
17
+ }
18
+ __name(inspect, "inspect");
19
+
20
+ export { inspect };
21
+ //# sourceMappingURL=inspect.mjs.map
22
+ //# sourceMappingURL=inspect.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/lib/inspect.ts"],"names":[],"mappings":";;;;;AAsCO,SAAS,OAAA,CACf,UACA,UACgC,EAAA;AAChC,EAAA,UAAA,GAAa,eAAe,UAAU,CAAA,CAAA;AAEtC,EAAA,IAAI,KAAQ,GAAA,CAAA,CAAA;AACZ,EAAM,MAAA,QAAA,GAAW,KAAK,QAAQ,CAAA,CAAA;AAC9B,EAAA,OAAO,qBAAkC,MAAM;AAC9C,IAAM,MAAA,MAAA,GAAS,SAAS,IAAK,EAAA,CAAA;AAC7B,IAAI,IAAA,CAAC,OAAO,IAAM,EAAA;AACjB,MAAW,UAAA,CAAA,MAAA,CAAO,OAAO,KAAO,EAAA,CAAA,CAAA;AAAA,KACjC;AAEA,IAAO,OAAA,MAAA,CAAA;AAAA,GACP,CAAA,CAAA;AACF,CAAA;AAhBgB,MAAA,CAAA,OAAA,EAAA,SAAA,CAAA","file":"inspect.mjs","sourcesContent":["import { from, type IterableResolvable } from './from';\nimport { assertFunction } from './shared/_assertFunction';\nimport { makeIterableIterator } from './shared/_makeIterableIterator';\n\n/**\n * Does something with each element of an iterator, passing the value on.\n *\n * When using iterators, you'll often chain several of them together. While working on such code, you might want to\n * check out what's happening at various parts in the pipeline. To do that, insert a call to this function.\n *\n * It's more common for this function to be used as a debugging tool than to exist in your final code, but applications\n * may find it useful in certain situations when errors need to be logged before being discarded.\n *\n * @param iterable An iterator to inspect.\n *\n * @example\n * ```typescript\n * import { inspect } from '@sapphire/iterator-utilities';\n *\n * const iterable = [1, 4, 2, 3];\n *\n * let iter = inspect(iter, (value) => console.log(`about to filter: ${value}`));\n * iter = filter(iterable, (value) => value % 2 === 0);\n * iter = inspect(iter, (value) => console.log(`made it through filter: ${value}`));\n *\n * const sum = reduce(iter, (acc, value) => acc + value, 0);\n * console.log(sum);\n *\n * // Output:\n * // about to filter: 1\n * // about to filter: 4\n * // made it through filter: 4\n * // about to filter: 2\n * // made it through filter: 2\n * // about to filter: 3\n * // 6\n * ```\n */\nexport function inspect<const ElementType>(\n\titerable: IterableResolvable<ElementType>,\n\tcallbackFn: (element: ElementType, index: number) => void\n): IterableIterator<ElementType> {\n\tcallbackFn = assertFunction(callbackFn);\n\n\tlet index = 0;\n\tconst iterator = from(iterable);\n\treturn makeIterableIterator<ElementType>(() => {\n\t\tconst result = iterator.next();\n\t\tif (!result.done) {\n\t\t\tcallbackFn(result.value, index++);\n\t\t}\n\n\t\treturn result;\n\t});\n}\n"]}