structured-outputs 0.1.0-beta.2 → 0.1.0-beta.21

Sign up to get free protection for your applications and to get access to all the features.
Files changed (391) hide show
  1. package/README.md +77 -6
  2. package/esm/ResponseFormat.d.ts +18 -11
  3. package/esm/ResponseFormat.d.ts.map +1 -1
  4. package/esm/ResponseFormat.js +57 -5
  5. package/esm/ResponseFormat.js.map +1 -1
  6. package/esm/Tool.d.ts +13 -0
  7. package/esm/Tool.d.ts.map +1 -0
  8. package/esm/Tool.js +17 -0
  9. package/esm/Tool.js.map +1 -0
  10. package/esm/_dnt.polyfills.d.ts +12 -0
  11. package/esm/_dnt.polyfills.d.ts.map +1 -0
  12. package/esm/_dnt.polyfills.js +16 -0
  13. package/esm/_dnt.polyfills.js.map +1 -0
  14. package/esm/deps/jsr.io/@std/collections/1.0.9/_utils.d.ts +6 -0
  15. package/esm/deps/jsr.io/@std/collections/1.0.9/_utils.d.ts.map +1 -0
  16. package/esm/deps/jsr.io/@std/collections/1.0.9/_utils.js +19 -0
  17. package/esm/deps/jsr.io/@std/collections/1.0.9/_utils.js.map +1 -0
  18. package/esm/deps/jsr.io/@std/collections/1.0.9/aggregate_groups.d.ts +41 -0
  19. package/esm/deps/jsr.io/@std/collections/1.0.9/aggregate_groups.d.ts.map +1 -0
  20. package/esm/deps/jsr.io/@std/collections/1.0.9/aggregate_groups.js +51 -0
  21. package/esm/deps/jsr.io/@std/collections/1.0.9/aggregate_groups.js.map +1 -0
  22. package/esm/deps/jsr.io/@std/collections/1.0.9/associate_by.d.ts +37 -0
  23. package/esm/deps/jsr.io/@std/collections/1.0.9/associate_by.d.ts.map +1 -0
  24. package/esm/deps/jsr.io/@std/collections/1.0.9/associate_by.js +45 -0
  25. package/esm/deps/jsr.io/@std/collections/1.0.9/associate_by.js.map +1 -0
  26. package/esm/deps/jsr.io/@std/collections/1.0.9/associate_with.d.ts +33 -0
  27. package/esm/deps/jsr.io/@std/collections/1.0.9/associate_with.d.ts.map +1 -0
  28. package/esm/deps/jsr.io/@std/collections/1.0.9/associate_with.js +41 -0
  29. package/esm/deps/jsr.io/@std/collections/1.0.9/associate_with.js.map +1 -0
  30. package/esm/deps/jsr.io/@std/collections/1.0.9/chunk.d.ts +38 -0
  31. package/esm/deps/jsr.io/@std/collections/1.0.9/chunk.d.ts.map +1 -0
  32. package/esm/deps/jsr.io/@std/collections/1.0.9/chunk.js +51 -0
  33. package/esm/deps/jsr.io/@std/collections/1.0.9/chunk.js.map +1 -0
  34. package/esm/deps/jsr.io/@std/collections/1.0.9/deep_merge.d.ts +322 -0
  35. package/esm/deps/jsr.io/@std/collections/1.0.9/deep_merge.d.ts.map +1 -0
  36. package/esm/deps/jsr.io/@std/collections/1.0.9/deep_merge.js +96 -0
  37. package/esm/deps/jsr.io/@std/collections/1.0.9/deep_merge.js.map +1 -0
  38. package/esm/deps/jsr.io/@std/collections/1.0.9/distinct.d.ts +23 -0
  39. package/esm/deps/jsr.io/@std/collections/1.0.9/distinct.d.ts.map +1 -0
  40. package/esm/deps/jsr.io/@std/collections/1.0.9/distinct.js +28 -0
  41. package/esm/deps/jsr.io/@std/collections/1.0.9/distinct.js.map +1 -0
  42. package/esm/deps/jsr.io/@std/collections/1.0.9/distinct_by.d.ts +26 -0
  43. package/esm/deps/jsr.io/@std/collections/1.0.9/distinct_by.d.ts.map +1 -0
  44. package/esm/deps/jsr.io/@std/collections/1.0.9/distinct_by.js +39 -0
  45. package/esm/deps/jsr.io/@std/collections/1.0.9/distinct_by.js.map +1 -0
  46. package/esm/deps/jsr.io/@std/collections/1.0.9/drop_last_while.d.ts +26 -0
  47. package/esm/deps/jsr.io/@std/collections/1.0.9/drop_last_while.d.ts.map +1 -0
  48. package/esm/deps/jsr.io/@std/collections/1.0.9/drop_last_while.js +33 -0
  49. package/esm/deps/jsr.io/@std/collections/1.0.9/drop_last_while.js.map +1 -0
  50. package/esm/deps/jsr.io/@std/collections/1.0.9/drop_while.d.ts +25 -0
  51. package/esm/deps/jsr.io/@std/collections/1.0.9/drop_while.d.ts.map +1 -0
  52. package/esm/deps/jsr.io/@std/collections/1.0.9/drop_while.js +34 -0
  53. package/esm/deps/jsr.io/@std/collections/1.0.9/drop_while.js.map +1 -0
  54. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_entries.d.ts +32 -0
  55. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_entries.d.ts.map +1 -0
  56. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_entries.js +43 -0
  57. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_entries.js.map +1 -0
  58. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_keys.d.ts +36 -0
  59. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_keys.d.ts.map +1 -0
  60. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_keys.js +46 -0
  61. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_keys.js.map +1 -0
  62. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_values.d.ts +35 -0
  63. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_values.d.ts.map +1 -0
  64. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_values.js +46 -0
  65. package/esm/deps/jsr.io/@std/collections/1.0.9/filter_values.js.map +1 -0
  66. package/esm/deps/jsr.io/@std/collections/1.0.9/find_single.d.ts +31 -0
  67. package/esm/deps/jsr.io/@std/collections/1.0.9/find_single.d.ts.map +1 -0
  68. package/esm/deps/jsr.io/@std/collections/1.0.9/find_single.js +45 -0
  69. package/esm/deps/jsr.io/@std/collections/1.0.9/find_single.js.map +1 -0
  70. package/esm/deps/jsr.io/@std/collections/1.0.9/first_not_nullish_of.d.ts +32 -0
  71. package/esm/deps/jsr.io/@std/collections/1.0.9/first_not_nullish_of.d.ts.map +1 -0
  72. package/esm/deps/jsr.io/@std/collections/1.0.9/first_not_nullish_of.js +42 -0
  73. package/esm/deps/jsr.io/@std/collections/1.0.9/first_not_nullish_of.js.map +1 -0
  74. package/esm/deps/jsr.io/@std/collections/1.0.9/includes_value.d.ts +29 -0
  75. package/esm/deps/jsr.io/@std/collections/1.0.9/includes_value.d.ts.map +1 -0
  76. package/esm/deps/jsr.io/@std/collections/1.0.9/includes_value.js +39 -0
  77. package/esm/deps/jsr.io/@std/collections/1.0.9/includes_value.js.map +1 -0
  78. package/esm/deps/jsr.io/@std/collections/1.0.9/intersect.d.ts +25 -0
  79. package/esm/deps/jsr.io/@std/collections/1.0.9/intersect.d.ts.map +1 -0
  80. package/esm/deps/jsr.io/@std/collections/1.0.9/intersect.js +36 -0
  81. package/esm/deps/jsr.io/@std/collections/1.0.9/intersect.js.map +1 -0
  82. package/esm/deps/jsr.io/@std/collections/1.0.9/invert.d.ts +29 -0
  83. package/esm/deps/jsr.io/@std/collections/1.0.9/invert.d.ts.map +1 -0
  84. package/esm/deps/jsr.io/@std/collections/1.0.9/invert.js +29 -0
  85. package/esm/deps/jsr.io/@std/collections/1.0.9/invert.js.map +1 -0
  86. package/esm/deps/jsr.io/@std/collections/1.0.9/invert_by.d.ts +34 -0
  87. package/esm/deps/jsr.io/@std/collections/1.0.9/invert_by.d.ts.map +1 -0
  88. package/esm/deps/jsr.io/@std/collections/1.0.9/invert_by.js +46 -0
  89. package/esm/deps/jsr.io/@std/collections/1.0.9/invert_by.js.map +1 -0
  90. package/esm/deps/jsr.io/@std/collections/1.0.9/join_to_string.d.ts +75 -0
  91. package/esm/deps/jsr.io/@std/collections/1.0.9/join_to_string.d.ts.map +1 -0
  92. package/esm/deps/jsr.io/@std/collections/1.0.9/join_to_string.js +59 -0
  93. package/esm/deps/jsr.io/@std/collections/1.0.9/join_to_string.js.map +1 -0
  94. package/esm/deps/jsr.io/@std/collections/1.0.9/map_entries.d.ts +37 -0
  95. package/esm/deps/jsr.io/@std/collections/1.0.9/map_entries.d.ts.map +1 -0
  96. package/esm/deps/jsr.io/@std/collections/1.0.9/map_entries.js +47 -0
  97. package/esm/deps/jsr.io/@std/collections/1.0.9/map_entries.js.map +1 -0
  98. package/esm/deps/jsr.io/@std/collections/1.0.9/map_keys.d.ts +33 -0
  99. package/esm/deps/jsr.io/@std/collections/1.0.9/map_keys.d.ts.map +1 -0
  100. package/esm/deps/jsr.io/@std/collections/1.0.9/map_keys.js +42 -0
  101. package/esm/deps/jsr.io/@std/collections/1.0.9/map_keys.js.map +1 -0
  102. package/esm/deps/jsr.io/@std/collections/1.0.9/map_not_nullish.d.ts +32 -0
  103. package/esm/deps/jsr.io/@std/collections/1.0.9/map_not_nullish.d.ts.map +1 -0
  104. package/esm/deps/jsr.io/@std/collections/1.0.9/map_not_nullish.js +43 -0
  105. package/esm/deps/jsr.io/@std/collections/1.0.9/map_not_nullish.js.map +1 -0
  106. package/esm/deps/jsr.io/@std/collections/1.0.9/map_values.d.ts +71 -0
  107. package/esm/deps/jsr.io/@std/collections/1.0.9/map_values.d.ts.map +1 -0
  108. package/esm/deps/jsr.io/@std/collections/1.0.9/map_values.js +13 -0
  109. package/esm/deps/jsr.io/@std/collections/1.0.9/map_values.js.map +1 -0
  110. package/esm/deps/jsr.io/@std/collections/1.0.9/max_by.d.ts +117 -0
  111. package/esm/deps/jsr.io/@std/collections/1.0.9/max_by.d.ts.map +1 -0
  112. package/esm/deps/jsr.io/@std/collections/1.0.9/max_by.js +15 -0
  113. package/esm/deps/jsr.io/@std/collections/1.0.9/max_by.js.map +1 -0
  114. package/esm/deps/jsr.io/@std/collections/1.0.9/max_of.d.ts +61 -0
  115. package/esm/deps/jsr.io/@std/collections/1.0.9/max_of.d.ts.map +1 -0
  116. package/esm/deps/jsr.io/@std/collections/1.0.9/max_of.js +17 -0
  117. package/esm/deps/jsr.io/@std/collections/1.0.9/max_of.js.map +1 -0
  118. package/esm/deps/jsr.io/@std/collections/1.0.9/max_with.d.ts +29 -0
  119. package/esm/deps/jsr.io/@std/collections/1.0.9/max_with.d.ts.map +1 -0
  120. package/esm/deps/jsr.io/@std/collections/1.0.9/max_with.js +41 -0
  121. package/esm/deps/jsr.io/@std/collections/1.0.9/max_with.js.map +1 -0
  122. package/esm/deps/jsr.io/@std/collections/1.0.9/min_by.d.ts +115 -0
  123. package/esm/deps/jsr.io/@std/collections/1.0.9/min_by.d.ts.map +1 -0
  124. package/esm/deps/jsr.io/@std/collections/1.0.9/min_by.js +15 -0
  125. package/esm/deps/jsr.io/@std/collections/1.0.9/min_by.js.map +1 -0
  126. package/esm/deps/jsr.io/@std/collections/1.0.9/min_of.d.ts +61 -0
  127. package/esm/deps/jsr.io/@std/collections/1.0.9/min_of.d.ts.map +1 -0
  128. package/esm/deps/jsr.io/@std/collections/1.0.9/min_of.js +17 -0
  129. package/esm/deps/jsr.io/@std/collections/1.0.9/min_of.js.map +1 -0
  130. package/esm/deps/jsr.io/@std/collections/1.0.9/min_with.d.ts +25 -0
  131. package/esm/deps/jsr.io/@std/collections/1.0.9/min_with.d.ts.map +1 -0
  132. package/esm/deps/jsr.io/@std/collections/1.0.9/min_with.js +37 -0
  133. package/esm/deps/jsr.io/@std/collections/1.0.9/min_with.js.map +1 -0
  134. package/esm/deps/jsr.io/@std/collections/1.0.9/mod.d.ts +73 -0
  135. package/esm/deps/jsr.io/@std/collections/1.0.9/mod.d.ts.map +1 -0
  136. package/esm/deps/jsr.io/@std/collections/1.0.9/mod.js +75 -0
  137. package/esm/deps/jsr.io/@std/collections/1.0.9/mod.js.map +1 -0
  138. package/esm/deps/jsr.io/@std/collections/1.0.9/omit.d.ts +24 -0
  139. package/esm/deps/jsr.io/@std/collections/1.0.9/omit.d.ts.map +1 -0
  140. package/esm/deps/jsr.io/@std/collections/1.0.9/omit.js +29 -0
  141. package/esm/deps/jsr.io/@std/collections/1.0.9/omit.js.map +1 -0
  142. package/esm/deps/jsr.io/@std/collections/1.0.9/partition.d.ts +60 -0
  143. package/esm/deps/jsr.io/@std/collections/1.0.9/partition.d.ts.map +1 -0
  144. package/esm/deps/jsr.io/@std/collections/1.0.9/partition.js +16 -0
  145. package/esm/deps/jsr.io/@std/collections/1.0.9/partition.js.map +1 -0
  146. package/esm/deps/jsr.io/@std/collections/1.0.9/partition_entries.d.ts +39 -0
  147. package/esm/deps/jsr.io/@std/collections/1.0.9/partition_entries.d.ts.map +1 -0
  148. package/esm/deps/jsr.io/@std/collections/1.0.9/partition_entries.js +54 -0
  149. package/esm/deps/jsr.io/@std/collections/1.0.9/partition_entries.js.map +1 -0
  150. package/esm/deps/jsr.io/@std/collections/1.0.9/permutations.d.ts +27 -0
  151. package/esm/deps/jsr.io/@std/collections/1.0.9/permutations.d.ts.map +1 -0
  152. package/esm/deps/jsr.io/@std/collections/1.0.9/permutations.js +58 -0
  153. package/esm/deps/jsr.io/@std/collections/1.0.9/permutations.js.map +1 -0
  154. package/esm/deps/jsr.io/@std/collections/1.0.9/pick.d.ts +25 -0
  155. package/esm/deps/jsr.io/@std/collections/1.0.9/pick.d.ts.map +1 -0
  156. package/esm/deps/jsr.io/@std/collections/1.0.9/pick.js +33 -0
  157. package/esm/deps/jsr.io/@std/collections/1.0.9/pick.js.map +1 -0
  158. package/esm/deps/jsr.io/@std/collections/1.0.9/reduce_groups.d.ts +35 -0
  159. package/esm/deps/jsr.io/@std/collections/1.0.9/reduce_groups.d.ts.map +1 -0
  160. package/esm/deps/jsr.io/@std/collections/1.0.9/reduce_groups.js +40 -0
  161. package/esm/deps/jsr.io/@std/collections/1.0.9/reduce_groups.js.map +1 -0
  162. package/esm/deps/jsr.io/@std/collections/1.0.9/running_reduce.d.ts +27 -0
  163. package/esm/deps/jsr.io/@std/collections/1.0.9/running_reduce.d.ts.map +1 -0
  164. package/esm/deps/jsr.io/@std/collections/1.0.9/running_reduce.js +32 -0
  165. package/esm/deps/jsr.io/@std/collections/1.0.9/running_reduce.js.map +1 -0
  166. package/esm/deps/jsr.io/@std/collections/1.0.9/sample.d.ts +24 -0
  167. package/esm/deps/jsr.io/@std/collections/1.0.9/sample.d.ts.map +1 -0
  168. package/esm/deps/jsr.io/@std/collections/1.0.9/sample.js +35 -0
  169. package/esm/deps/jsr.io/@std/collections/1.0.9/sample.js.map +1 -0
  170. package/esm/deps/jsr.io/@std/collections/1.0.9/sliding_windows.d.ts +66 -0
  171. package/esm/deps/jsr.io/@std/collections/1.0.9/sliding_windows.d.ts.map +1 -0
  172. package/esm/deps/jsr.io/@std/collections/1.0.9/sliding_windows.js +57 -0
  173. package/esm/deps/jsr.io/@std/collections/1.0.9/sliding_windows.js.map +1 -0
  174. package/esm/deps/jsr.io/@std/collections/1.0.9/sort_by.d.ts +161 -0
  175. package/esm/deps/jsr.io/@std/collections/1.0.9/sort_by.d.ts.map +1 -0
  176. package/esm/deps/jsr.io/@std/collections/1.0.9/sort_by.js +30 -0
  177. package/esm/deps/jsr.io/@std/collections/1.0.9/sort_by.js.map +1 -0
  178. package/esm/deps/jsr.io/@std/collections/1.0.9/sum_of.d.ts +29 -0
  179. package/esm/deps/jsr.io/@std/collections/1.0.9/sum_of.d.ts.map +1 -0
  180. package/esm/deps/jsr.io/@std/collections/1.0.9/sum_of.js +37 -0
  181. package/esm/deps/jsr.io/@std/collections/1.0.9/sum_of.js.map +1 -0
  182. package/esm/deps/jsr.io/@std/collections/1.0.9/take_last_while.d.ts +27 -0
  183. package/esm/deps/jsr.io/@std/collections/1.0.9/take_last_while.d.ts.map +1 -0
  184. package/esm/deps/jsr.io/@std/collections/1.0.9/take_last_while.js +34 -0
  185. package/esm/deps/jsr.io/@std/collections/1.0.9/take_last_while.js.map +1 -0
  186. package/esm/deps/jsr.io/@std/collections/1.0.9/take_while.d.ts +30 -0
  187. package/esm/deps/jsr.io/@std/collections/1.0.9/take_while.d.ts.map +1 -0
  188. package/esm/deps/jsr.io/@std/collections/1.0.9/take_while.js +39 -0
  189. package/esm/deps/jsr.io/@std/collections/1.0.9/take_while.js.map +1 -0
  190. package/esm/deps/jsr.io/@std/collections/1.0.9/union.d.ts +24 -0
  191. package/esm/deps/jsr.io/@std/collections/1.0.9/union.d.ts.map +1 -0
  192. package/esm/deps/jsr.io/@std/collections/1.0.9/union.js +34 -0
  193. package/esm/deps/jsr.io/@std/collections/1.0.9/union.js.map +1 -0
  194. package/esm/deps/jsr.io/@std/collections/1.0.9/unzip.d.ts +32 -0
  195. package/esm/deps/jsr.io/@std/collections/1.0.9/unzip.d.ts.map +1 -0
  196. package/esm/deps/jsr.io/@std/collections/1.0.9/unzip.js +46 -0
  197. package/esm/deps/jsr.io/@std/collections/1.0.9/unzip.js.map +1 -0
  198. package/esm/deps/jsr.io/@std/collections/1.0.9/without_all.d.ts +23 -0
  199. package/esm/deps/jsr.io/@std/collections/1.0.9/without_all.d.ts.map +1 -0
  200. package/esm/deps/jsr.io/@std/collections/1.0.9/without_all.js +28 -0
  201. package/esm/deps/jsr.io/@std/collections/1.0.9/without_all.js.map +1 -0
  202. package/esm/deps/jsr.io/@std/collections/1.0.9/zip.d.ts +34 -0
  203. package/esm/deps/jsr.io/@std/collections/1.0.9/zip.d.ts.map +1 -0
  204. package/esm/deps/jsr.io/@std/collections/1.0.9/zip.js +43 -0
  205. package/esm/deps/jsr.io/@std/collections/1.0.9/zip.js.map +1 -0
  206. package/esm/mod.d.ts +3 -14
  207. package/esm/mod.d.ts.map +1 -1
  208. package/esm/mod.js +3 -10
  209. package/esm/mod.js.map +1 -1
  210. package/esm/oai.d.ts +5 -0
  211. package/esm/oai.d.ts.map +1 -0
  212. package/esm/oai.js +2 -0
  213. package/esm/oai.js.map +1 -0
  214. package/esm/types/Ref.d.ts +4 -0
  215. package/esm/types/Ref.d.ts.map +1 -0
  216. package/esm/types/Ref.js +11 -0
  217. package/esm/types/Ref.js.map +1 -0
  218. package/esm/types/RootTy.d.ts +8 -0
  219. package/esm/types/RootTy.d.ts.map +1 -0
  220. package/esm/types/RootTy.js +19 -0
  221. package/esm/types/RootTy.js.map +1 -0
  222. package/esm/types/Ty.d.ts +27 -0
  223. package/esm/types/Ty.d.ts.map +1 -0
  224. package/esm/types/Ty.js +17 -0
  225. package/esm/types/Ty.js.map +1 -0
  226. package/esm/types/array.d.ts +3 -0
  227. package/esm/types/array.d.ts.map +1 -0
  228. package/esm/types/array.js +9 -0
  229. package/esm/types/array.js.map +1 -0
  230. package/esm/types/constant.d.ts +3 -0
  231. package/esm/types/constant.d.ts.map +1 -0
  232. package/esm/types/constant.js +8 -0
  233. package/esm/types/constant.js.map +1 -0
  234. package/esm/types/constantUnion.d.ts +3 -0
  235. package/esm/types/constantUnion.d.ts.map +1 -0
  236. package/esm/types/constantUnion.js +25 -0
  237. package/esm/types/constantUnion.js.map +1 -0
  238. package/esm/types/leaves.d.ts +6 -0
  239. package/esm/types/leaves.d.ts.map +1 -0
  240. package/esm/types/leaves.js +18 -0
  241. package/esm/types/leaves.js.map +1 -0
  242. package/esm/types/mod.d.ts +11 -0
  243. package/esm/types/mod.d.ts.map +1 -0
  244. package/esm/types/mod.js +11 -0
  245. package/esm/types/mod.js.map +1 -0
  246. package/esm/types/object.d.ts +6 -0
  247. package/esm/types/object.d.ts.map +1 -0
  248. package/esm/{object.js → types/object.js} +4 -4
  249. package/esm/types/object.js.map +1 -0
  250. package/esm/types/std/Option.d.ts +7 -0
  251. package/esm/types/std/Option.d.ts.map +1 -0
  252. package/esm/types/std/Option.js +9 -0
  253. package/esm/types/std/Option.js.map +1 -0
  254. package/esm/types/std/Wrapper.d.ts +7 -0
  255. package/esm/types/std/Wrapper.d.ts.map +1 -0
  256. package/esm/types/std/Wrapper.js +5 -0
  257. package/esm/types/std/Wrapper.js.map +1 -0
  258. package/esm/types/std/mod.d.ts +3 -0
  259. package/esm/types/std/mod.d.ts.map +1 -0
  260. package/esm/types/std/mod.js +3 -0
  261. package/esm/types/std/mod.js.map +1 -0
  262. package/esm/types/taggedUnion.d.ts +8 -0
  263. package/esm/types/taggedUnion.d.ts.map +1 -0
  264. package/esm/types/taggedUnion.js +20 -0
  265. package/esm/types/taggedUnion.js.map +1 -0
  266. package/esm/util/phantoms.d.ts +2 -0
  267. package/esm/util/phantoms.d.ts.map +1 -0
  268. package/esm/util/phantoms.js +4 -0
  269. package/esm/util/phantoms.js.map +1 -0
  270. package/esm/util/recombineTaggedTemplateArgs.d.ts +2 -0
  271. package/esm/util/recombineTaggedTemplateArgs.d.ts.map +1 -0
  272. package/esm/util/recombineTaggedTemplateArgs.js +4 -0
  273. package/esm/util/recombineTaggedTemplateArgs.js.map +1 -0
  274. package/package.json +7 -9
  275. package/src/ResponseFormat.ts +80 -22
  276. package/src/Tool.ts +38 -0
  277. package/src/_dnt.polyfills.ts +27 -0
  278. package/src/deps/jsr.io/@std/collections/1.0.9/_utils.ts +26 -0
  279. package/src/deps/jsr.io/@std/collections/1.0.9/aggregate_groups.ts +62 -0
  280. package/src/deps/jsr.io/@std/collections/1.0.9/associate_by.ts +50 -0
  281. package/src/deps/jsr.io/@std/collections/1.0.9/associate_with.ts +46 -0
  282. package/src/deps/jsr.io/@std/collections/1.0.9/chunk.ts +56 -0
  283. package/src/deps/jsr.io/@std/collections/1.0.9/deep_merge.ts +578 -0
  284. package/src/deps/jsr.io/@std/collections/1.0.9/distinct.ts +29 -0
  285. package/src/deps/jsr.io/@std/collections/1.0.9/distinct_by.ts +42 -0
  286. package/src/deps/jsr.io/@std/collections/1.0.9/drop_last_while.ts +36 -0
  287. package/src/deps/jsr.io/@std/collections/1.0.9/drop_while.ts +39 -0
  288. package/src/deps/jsr.io/@std/collections/1.0.9/filter_entries.ts +48 -0
  289. package/src/deps/jsr.io/@std/collections/1.0.9/filter_keys.ts +51 -0
  290. package/src/deps/jsr.io/@std/collections/1.0.9/filter_values.ts +51 -0
  291. package/src/deps/jsr.io/@std/collections/1.0.9/find_single.ts +48 -0
  292. package/src/deps/jsr.io/@std/collections/1.0.9/first_not_nullish_of.ts +47 -0
  293. package/src/deps/jsr.io/@std/collections/1.0.9/includes_value.ts +45 -0
  294. package/src/deps/jsr.io/@std/collections/1.0.9/intersect.ts +35 -0
  295. package/src/deps/jsr.io/@std/collections/1.0.9/invert.ts +38 -0
  296. package/src/deps/jsr.io/@std/collections/1.0.9/invert_by.ts +56 -0
  297. package/src/deps/jsr.io/@std/collections/1.0.9/join_to_string.ts +109 -0
  298. package/src/deps/jsr.io/@std/collections/1.0.9/map_entries.ts +53 -0
  299. package/src/deps/jsr.io/@std/collections/1.0.9/map_keys.ts +47 -0
  300. package/src/deps/jsr.io/@std/collections/1.0.9/map_not_nullish.ts +49 -0
  301. package/src/deps/jsr.io/@std/collections/1.0.9/map_values.ts +96 -0
  302. package/src/deps/jsr.io/@std/collections/1.0.9/max_by.ts +153 -0
  303. package/src/deps/jsr.io/@std/collections/1.0.9/max_of.ts +90 -0
  304. package/src/deps/jsr.io/@std/collections/1.0.9/max_with.ts +46 -0
  305. package/src/deps/jsr.io/@std/collections/1.0.9/min_by.ts +151 -0
  306. package/src/deps/jsr.io/@std/collections/1.0.9/min_of.ts +90 -0
  307. package/src/deps/jsr.io/@std/collections/1.0.9/min_with.ts +42 -0
  308. package/src/deps/jsr.io/@std/collections/1.0.9/mod.ts +76 -0
  309. package/src/deps/jsr.io/@std/collections/1.0.9/omit.ts +34 -0
  310. package/src/deps/jsr.io/@std/collections/1.0.9/partition.ts +85 -0
  311. package/src/deps/jsr.io/@std/collections/1.0.9/partition_entries.ts +58 -0
  312. package/src/deps/jsr.io/@std/collections/1.0.9/permutations.ts +66 -0
  313. package/src/deps/jsr.io/@std/collections/1.0.9/pick.ts +34 -0
  314. package/src/deps/jsr.io/@std/collections/1.0.9/reduce_groups.ts +45 -0
  315. package/src/deps/jsr.io/@std/collections/1.0.9/running_reduce.ts +38 -0
  316. package/src/deps/jsr.io/@std/collections/1.0.9/sample.ts +36 -0
  317. package/src/deps/jsr.io/@std/collections/1.0.9/sliding_windows.ts +86 -0
  318. package/src/deps/jsr.io/@std/collections/1.0.9/sort_by.ts +219 -0
  319. package/src/deps/jsr.io/@std/collections/1.0.9/sum_of.ts +42 -0
  320. package/src/deps/jsr.io/@std/collections/1.0.9/take_last_while.ts +37 -0
  321. package/src/deps/jsr.io/@std/collections/1.0.9/take_while.ts +44 -0
  322. package/src/deps/jsr.io/@std/collections/1.0.9/union.ts +36 -0
  323. package/src/deps/jsr.io/@std/collections/1.0.9/unzip.ts +50 -0
  324. package/src/deps/jsr.io/@std/collections/1.0.9/without_all.ts +28 -0
  325. package/src/deps/jsr.io/@std/collections/1.0.9/zip.ts +49 -0
  326. package/src/mod.ts +3 -18
  327. package/src/oai.ts +5 -0
  328. package/src/types/Ref.ts +16 -0
  329. package/src/types/RootTy.ts +40 -0
  330. package/src/types/Ty.ts +57 -0
  331. package/src/types/array.ts +9 -0
  332. package/src/types/constant.ts +8 -0
  333. package/src/types/constantUnion.ts +27 -0
  334. package/src/types/leaves.ts +21 -0
  335. package/src/types/mod.ts +10 -0
  336. package/src/types/object.ts +15 -0
  337. package/src/types/std/Option.ts +15 -0
  338. package/src/types/std/Wrapper.ts +8 -0
  339. package/src/types/std/mod.ts +2 -0
  340. package/src/types/taggedUnion.ts +28 -0
  341. package/src/util/phantoms.ts +3 -0
  342. package/src/util/recombineTaggedTemplateArgs.ts +6 -0
  343. package/esm/F.d.ts +0 -13
  344. package/esm/F.d.ts.map +0 -1
  345. package/esm/F.js +0 -10
  346. package/esm/F.js.map +0 -1
  347. package/esm/_base.d.ts +0 -13
  348. package/esm/_base.d.ts.map +0 -1
  349. package/esm/_base.js +0 -40
  350. package/esm/_base.js.map +0 -1
  351. package/esm/array.d.ts +0 -4
  352. package/esm/array.d.ts.map +0 -1
  353. package/esm/array.js +0 -9
  354. package/esm/array.js.map +0 -1
  355. package/esm/common.d.ts +0 -6
  356. package/esm/common.d.ts.map +0 -1
  357. package/esm/common.js +0 -2
  358. package/esm/common.js.map +0 -1
  359. package/esm/literal.d.ts +0 -4
  360. package/esm/literal.d.ts.map +0 -1
  361. package/esm/literal.js +0 -8
  362. package/esm/literal.js.map +0 -1
  363. package/esm/number.d.ts +0 -4
  364. package/esm/number.d.ts.map +0 -1
  365. package/esm/number.js +0 -8
  366. package/esm/number.js.map +0 -1
  367. package/esm/object.d.ts +0 -7
  368. package/esm/object.d.ts.map +0 -1
  369. package/esm/object.js.map +0 -1
  370. package/esm/schema.d.ts +0 -4
  371. package/esm/schema.d.ts.map +0 -1
  372. package/esm/schema.js +0 -9
  373. package/esm/schema.js.map +0 -1
  374. package/esm/string.d.ts +0 -4
  375. package/esm/string.d.ts.map +0 -1
  376. package/esm/string.js +0 -8
  377. package/esm/string.js.map +0 -1
  378. package/esm/union.d.ts +0 -6
  379. package/esm/union.d.ts.map +0 -1
  380. package/esm/union.js +0 -8
  381. package/esm/union.js.map +0 -1
  382. package/src/F.ts +0 -27
  383. package/src/_base.ts +0 -25
  384. package/src/array.ts +0 -11
  385. package/src/common.ts +0 -6
  386. package/src/literal.ts +0 -10
  387. package/src/number.ts +0 -10
  388. package/src/object.ts +0 -17
  389. package/src/schema.ts +0 -10
  390. package/src/string.ts +0 -10
  391. package/src/union.ts +0 -12
@@ -0,0 +1,40 @@
1
+ // Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
2
+ // This module is browser compatible.
3
+ import { mapValues } from "./map_values.js";
4
+ /**
5
+ * Applies the given reducer to each group in the given grouping, returning the
6
+ * results together with the respective group keys.
7
+ *
8
+ * @typeParam T input type of an item in a group in the given grouping.
9
+ * @typeParam A type of the accumulator value, which will match the returned
10
+ * record's values.
11
+ *
12
+ * @param record The grouping to reduce.
13
+ * @param reducer The reducer function to apply to each group.
14
+ * @param initialValue The initial value of the accumulator.
15
+ *
16
+ * @returns A record with the same keys as the input grouping, where each value
17
+ * is the result of applying the reducer to the respective group.
18
+ *
19
+ * @example Basic usage
20
+ * ```ts
21
+ * import { reduceGroups } from "@std/collections/reduce-groups";
22
+ * import { assertEquals } from "@std/assert";
23
+ *
24
+ * const votes = {
25
+ * Woody: [2, 3, 1, 4],
26
+ * Buzz: [5, 9],
27
+ * };
28
+ *
29
+ * const totalVotes = reduceGroups(votes, (sum, vote) => sum + vote, 0);
30
+ *
31
+ * assertEquals(totalVotes, {
32
+ * Woody: 10,
33
+ * Buzz: 14,
34
+ * });
35
+ * ```
36
+ */
37
+ export function reduceGroups(record, reducer, initialValue) {
38
+ return mapValues(record, (value) => value.reduce(reducer, initialValue));
39
+ }
40
+ //# sourceMappingURL=reduce_groups.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reduce_groups.js","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/reduce_groups.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,qCAAqC;AAErC,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AACH,MAAM,UAAU,YAAY,CAC1B,MAAkD,EAClD,OAA0C,EAC1C,YAAe;IAEf,OAAO,SAAS,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;AAC3E,CAAC"}
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Calls the given reducer on each element of the given collection, passing its
3
+ * result as the accumulator to the next respective call, starting with the
4
+ * given initialValue. Returns all intermediate accumulator results.
5
+ *
6
+ * @typeParam T The type of the elements in the array.
7
+ * @typeParam O The type of the accumulator.
8
+ *
9
+ * @param array The array to reduce.
10
+ * @param reducer The reducer function to apply to each element.
11
+ * @param initialValue The initial value of the accumulator.
12
+ *
13
+ * @returns An array of all intermediate accumulator results.
14
+ *
15
+ * @example Basic usage
16
+ * ```ts
17
+ * import { runningReduce } from "@std/collections/running-reduce";
18
+ * import { assertEquals } from "@std/assert";
19
+ *
20
+ * const numbers = [1, 2, 3, 4, 5];
21
+ * const sumSteps = runningReduce(numbers, (sum, current) => sum + current, 0);
22
+ *
23
+ * assertEquals(sumSteps, [1, 3, 6, 10, 15]);
24
+ * ```
25
+ */
26
+ export declare function runningReduce<T, O>(array: readonly T[], reducer: (accumulator: O, current: T, currentIndex: number) => O, initialValue: O): O[];
27
+ //# sourceMappingURL=running_reduce.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"running_reduce.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/running_reduce.ts"],"names":[],"mappings":"AAGA;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,wBAAgB,aAAa,CAAC,CAAC,EAAE,CAAC,EAChC,KAAK,EAAE,SAAS,CAAC,EAAE,EACnB,OAAO,EAAE,CAAC,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,YAAY,EAAE,MAAM,KAAK,CAAC,EAChE,YAAY,EAAE,CAAC,GACd,CAAC,EAAE,CAKL"}
@@ -0,0 +1,32 @@
1
+ // Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
2
+ // This module is browser compatible.
3
+ /**
4
+ * Calls the given reducer on each element of the given collection, passing its
5
+ * result as the accumulator to the next respective call, starting with the
6
+ * given initialValue. Returns all intermediate accumulator results.
7
+ *
8
+ * @typeParam T The type of the elements in the array.
9
+ * @typeParam O The type of the accumulator.
10
+ *
11
+ * @param array The array to reduce.
12
+ * @param reducer The reducer function to apply to each element.
13
+ * @param initialValue The initial value of the accumulator.
14
+ *
15
+ * @returns An array of all intermediate accumulator results.
16
+ *
17
+ * @example Basic usage
18
+ * ```ts
19
+ * import { runningReduce } from "@std/collections/running-reduce";
20
+ * import { assertEquals } from "@std/assert";
21
+ *
22
+ * const numbers = [1, 2, 3, 4, 5];
23
+ * const sumSteps = runningReduce(numbers, (sum, current) => sum + current, 0);
24
+ *
25
+ * assertEquals(sumSteps, [1, 3, 6, 10, 15]);
26
+ * ```
27
+ */
28
+ export function runningReduce(array, reducer, initialValue) {
29
+ let currentResult = initialValue;
30
+ return array.map((el, currentIndex) => currentResult = reducer(currentResult, el, currentIndex));
31
+ }
32
+ //# sourceMappingURL=running_reduce.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"running_reduce.js","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/running_reduce.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,qCAAqC;AAErC;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,MAAM,UAAU,aAAa,CAC3B,KAAmB,EACnB,OAAgE,EAChE,YAAe;IAEf,IAAI,aAAa,GAAG,YAAY,CAAC;IACjC,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,YAAY,EAAE,EAAE,CACpC,aAAa,GAAG,OAAO,CAAC,aAAa,EAAE,EAAE,EAAE,YAAY,CAAC,CACzD,CAAC;AACJ,CAAC"}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Returns a random element from the given array.
3
+ *
4
+ * @typeParam T The type of the elements in the array.
5
+ * @typeParam O The type of the accumulator.
6
+ *
7
+ * @param array The array to sample from.
8
+ *
9
+ * @returns A random element from the given array, or `undefined` if the array
10
+ * is empty.
11
+ *
12
+ * @example Basic usage
13
+ * ```ts
14
+ * import { sample } from "@std/collections/sample";
15
+ * import { assertArrayIncludes } from "@std/assert";
16
+ *
17
+ * const numbers = [1, 2, 3, 4];
18
+ * const random = sample(numbers);
19
+ *
20
+ * assertArrayIncludes(numbers, [random]);
21
+ * ```
22
+ */
23
+ export declare function sample<T>(array: readonly T[]): T | undefined;
24
+ //# sourceMappingURL=sample.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sample.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/sample.ts"],"names":[],"mappings":"AAUA;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAgB,MAAM,CAAC,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,EAAE,GAAG,CAAC,GAAG,SAAS,CAG5D"}
@@ -0,0 +1,35 @@
1
+ // Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
2
+ // This module is browser compatible.
3
+ /**
4
+ * Produces a random number between the inclusive `lower` and `upper` bounds.
5
+ */
6
+ function randomInteger(lower, upper) {
7
+ return lower + Math.floor(Math.random() * (upper - lower + 1));
8
+ }
9
+ /**
10
+ * Returns a random element from the given array.
11
+ *
12
+ * @typeParam T The type of the elements in the array.
13
+ * @typeParam O The type of the accumulator.
14
+ *
15
+ * @param array The array to sample from.
16
+ *
17
+ * @returns A random element from the given array, or `undefined` if the array
18
+ * is empty.
19
+ *
20
+ * @example Basic usage
21
+ * ```ts
22
+ * import { sample } from "@std/collections/sample";
23
+ * import { assertArrayIncludes } from "@std/assert";
24
+ *
25
+ * const numbers = [1, 2, 3, 4];
26
+ * const random = sample(numbers);
27
+ *
28
+ * assertArrayIncludes(numbers, [random]);
29
+ * ```
30
+ */
31
+ export function sample(array) {
32
+ const length = array.length;
33
+ return length ? array[randomInteger(0, length - 1)] : undefined;
34
+ }
35
+ //# sourceMappingURL=sample.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sample.js","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/sample.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,qCAAqC;AAErC;;GAEG;AACH,SAAS,aAAa,CAAC,KAAa,EAAE,KAAa;IACjD,OAAO,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;AACjE,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,MAAM,UAAU,MAAM,CAAI,KAAmB;IAC3C,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;IAC5B,OAAO,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;AAClE,CAAC"}
@@ -0,0 +1,66 @@
1
+ /** Options for {@linkcode slidingWindows}. */
2
+ export interface SlidingWindowsOptions {
3
+ /**
4
+ * If step is set, each window will start that many elements after the last
5
+ * window's start.
6
+ *
7
+ * @default {1}
8
+ */
9
+ step?: number;
10
+ /**
11
+ * If partial is set, windows will be generated for the last elements of the
12
+ * collection, resulting in some undefined values if size is greater than 1.
13
+ *
14
+ * @default {false}
15
+ */
16
+ partial?: boolean;
17
+ }
18
+ /**
19
+ * Generates sliding views of the given array of the given size and returns a
20
+ * new array containing all of them.
21
+ *
22
+ * If step is set, each window will start that many elements after the last
23
+ * window's start. (Default: 1)
24
+ *
25
+ * If partial is set, windows will be generated for the last elements of the
26
+ * collection, resulting in some undefined values if size is greater than 1.
27
+ *
28
+ * @typeParam T The type of the array elements.
29
+ *
30
+ * @param array The array to generate sliding windows from.
31
+ * @param size The size of the sliding windows.
32
+ * @param options The options for generating sliding windows.
33
+ *
34
+ * @returns A new array containing all sliding windows of the given size.
35
+ *
36
+ * @example Usage
37
+ * ```ts
38
+ * import { slidingWindows } from "@std/collections/sliding-windows";
39
+ * import { assertEquals } from "@std/assert";
40
+ * const numbers = [1, 2, 3, 4, 5];
41
+ *
42
+ * const windows = slidingWindows(numbers, 3);
43
+ * assertEquals(windows, [
44
+ * [1, 2, 3],
45
+ * [2, 3, 4],
46
+ * [3, 4, 5],
47
+ * ]);
48
+ *
49
+ * const windowsWithStep = slidingWindows(numbers, 3, { step: 2 });
50
+ * assertEquals(windowsWithStep, [
51
+ * [1, 2, 3],
52
+ * [3, 4, 5],
53
+ * ]);
54
+ *
55
+ * const windowsWithPartial = slidingWindows(numbers, 3, { partial: true });
56
+ * assertEquals(windowsWithPartial, [
57
+ * [1, 2, 3],
58
+ * [2, 3, 4],
59
+ * [3, 4, 5],
60
+ * [4, 5],
61
+ * [5],
62
+ * ]);
63
+ * ```
64
+ */
65
+ export declare function slidingWindows<T>(array: readonly T[], size: number, options?: SlidingWindowsOptions): T[][];
66
+ //# sourceMappingURL=sliding_windows.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sliding_windows.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/sliding_windows.ts"],"names":[],"mappings":"AAGA,8CAA8C;AAC9C,MAAM,WAAW,qBAAqB;IACpC;;;;;OAKG;IACH,IAAI,CAAC,EAAE,MAAM,CAAC;IACd;;;;;OAKG;IACH,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,wBAAgB,cAAc,CAAC,CAAC,EAC9B,KAAK,EAAE,SAAS,CAAC,EAAE,EACnB,IAAI,EAAE,MAAM,EACZ,OAAO,GAAE,qBAA0B,GAClC,CAAC,EAAE,EAAE,CAaP"}
@@ -0,0 +1,57 @@
1
+ // Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
2
+ // This module is browser compatible.
3
+ /**
4
+ * Generates sliding views of the given array of the given size and returns a
5
+ * new array containing all of them.
6
+ *
7
+ * If step is set, each window will start that many elements after the last
8
+ * window's start. (Default: 1)
9
+ *
10
+ * If partial is set, windows will be generated for the last elements of the
11
+ * collection, resulting in some undefined values if size is greater than 1.
12
+ *
13
+ * @typeParam T The type of the array elements.
14
+ *
15
+ * @param array The array to generate sliding windows from.
16
+ * @param size The size of the sliding windows.
17
+ * @param options The options for generating sliding windows.
18
+ *
19
+ * @returns A new array containing all sliding windows of the given size.
20
+ *
21
+ * @example Usage
22
+ * ```ts
23
+ * import { slidingWindows } from "@std/collections/sliding-windows";
24
+ * import { assertEquals } from "@std/assert";
25
+ * const numbers = [1, 2, 3, 4, 5];
26
+ *
27
+ * const windows = slidingWindows(numbers, 3);
28
+ * assertEquals(windows, [
29
+ * [1, 2, 3],
30
+ * [2, 3, 4],
31
+ * [3, 4, 5],
32
+ * ]);
33
+ *
34
+ * const windowsWithStep = slidingWindows(numbers, 3, { step: 2 });
35
+ * assertEquals(windowsWithStep, [
36
+ * [1, 2, 3],
37
+ * [3, 4, 5],
38
+ * ]);
39
+ *
40
+ * const windowsWithPartial = slidingWindows(numbers, 3, { partial: true });
41
+ * assertEquals(windowsWithPartial, [
42
+ * [1, 2, 3],
43
+ * [2, 3, 4],
44
+ * [3, 4, 5],
45
+ * [4, 5],
46
+ * [5],
47
+ * ]);
48
+ * ```
49
+ */
50
+ export function slidingWindows(array, size, options = {}) {
51
+ const { step = 1, partial = false } = options;
52
+ if (!Number.isInteger(size) || !Number.isInteger(step) || size <= 0 || step <= 0) {
53
+ throw new RangeError("Both size and step must be positive integer.");
54
+ }
55
+ return Array.from({ length: Math.floor((array.length - (partial ? 1 : size)) / step + 1) }, (_, i) => array.slice(i * step, i * step + size));
56
+ }
57
+ //# sourceMappingURL=sliding_windows.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sliding_windows.js","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/sliding_windows.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,qCAAqC;AAoBrC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AACH,MAAM,UAAU,cAAc,CAC5B,KAAmB,EACnB,IAAY,EACZ,UAAiC,EAAE;IAEnC,MAAM,EAAE,IAAI,GAAG,CAAC,EAAE,OAAO,GAAG,KAAK,EAAE,GAAG,OAAO,CAAC;IAE9C,IACE,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,EAC5E,CAAC;QACD,MAAM,IAAI,UAAU,CAAC,8CAA8C,CAAC,CAAC;IACvE,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CACf,EAAE,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC,EAAE,EACxE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,IAAI,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,CAAC,CACjD,CAAC;AACJ,CAAC"}
@@ -0,0 +1,161 @@
1
+ /** Order option for {@linkcode SortByOptions}. */
2
+ export type Order = "asc" | "desc";
3
+ /** Options for {@linkcode sortBy}. */
4
+ export type SortByOptions = {
5
+ /**
6
+ * The order to sort the elements in.
7
+ *
8
+ * @default {"asc"}
9
+ */
10
+ order: Order;
11
+ };
12
+ /**
13
+ * Returns all elements in the given collection, sorted by their result using
14
+ * the given selector. The selector function is called only once for each
15
+ * element. Ascending or descending order can be specified through the `order`
16
+ * option. By default, the elements are sorted in ascending order.
17
+ *
18
+ * Note: If you want to process any iterable, use the new version of
19
+ * `sortBy` from `@std/collections/unstable-sort-by`.
20
+ *
21
+ * @typeParam T The type of the array elements.
22
+ *
23
+ * @param array The array to sort.
24
+ * @param selector The selector function to get the value to sort by.
25
+ * @param options The options for sorting.
26
+ *
27
+ * @returns A new array containing all elements sorted by the selector.
28
+ *
29
+ * @example Usage
30
+ * ```ts
31
+ * import { sortBy } from "@std/collections/sort-by";
32
+ * import { assertEquals } from "@std/assert";
33
+ *
34
+ * const people = [
35
+ * { name: "Anna", age: 34 },
36
+ * { name: "Kim", age: 42 },
37
+ * { name: "John", age: 23 },
38
+ * ];
39
+ * const sortedByAge = sortBy(people, (person) => person.age);
40
+ *
41
+ * assertEquals(sortedByAge, [
42
+ * { name: "John", age: 23 },
43
+ * { name: "Anna", age: 34 },
44
+ * { name: "Kim", age: 42 },
45
+ * ]);
46
+ *
47
+ * const sortedByAgeDesc = sortBy(people, (person) => person.age, { order: "desc" });
48
+ *
49
+ * assertEquals(sortedByAgeDesc, [
50
+ * { name: "Kim", age: 42 },
51
+ * { name: "Anna", age: 34 },
52
+ * { name: "John", age: 23 },
53
+ * ]);
54
+ * ```
55
+ */
56
+ export declare function sortBy<T>(array: readonly T[], selector: (el: T) => number, options?: SortByOptions): T[];
57
+ /**
58
+ * Returns all elements in the given collection, sorted by their result using
59
+ * the given selector. The selector function is called only once for each
60
+ * element. Ascending or descending order can be specified through the `order`
61
+ * option. By default, the elements are sorted in ascending order.
62
+ *
63
+ * @typeParam T The type of the array elements.
64
+ *
65
+ * @param array The array to sort.
66
+ * @param selector The selector function to get the value to sort by.
67
+ * @param options The options for sorting.
68
+ *
69
+ * @returns A new array containing all elements sorted by the selector.
70
+ *
71
+ * @example Usage
72
+ * ```ts
73
+ * import { sortBy } from "@std/collections/sort-by";
74
+ * import { assertEquals } from "@std/assert";
75
+ *
76
+ * const people = [
77
+ * { name: "Anna" },
78
+ * { name: "Kim" },
79
+ * { name: "John" },
80
+ * ];
81
+ * const sortedByName = sortBy(people, (it) => it.name);
82
+ *
83
+ * assertEquals(sortedByName, [
84
+ * { name: "Anna" },
85
+ * { name: "John" },
86
+ * { name: "Kim" },
87
+ * ]);
88
+ * ```
89
+ */
90
+ export declare function sortBy<T>(array: readonly T[], selector: (el: T) => string, options?: SortByOptions): T[];
91
+ /**
92
+ * Returns all elements in the given collection, sorted by their result using
93
+ * the given selector. The selector function is called only once for each
94
+ * element. Ascending or descending order can be specified through the `order`
95
+ * option. By default, the elements are sorted in ascending order.
96
+ *
97
+ * @typeParam T The type of the array elements.
98
+ *
99
+ * @param array The array to sort.
100
+ * @param selector The selector function to get the value to sort by.
101
+ * @param options The options for sorting.
102
+ *
103
+ * @returns A new array containing all elements sorted by the selector.
104
+ *
105
+ * @example Usage
106
+ * ```ts
107
+ * import { sortBy } from "@std/collections/sort-by";
108
+ * import { assertEquals } from "@std/assert";
109
+ *
110
+ * const people = [
111
+ * { name: "Anna", age: 34n },
112
+ * { name: "Kim", age: 42n },
113
+ * { name: "John", age: 23n },
114
+ * ];
115
+ *
116
+ * const sortedByAge = sortBy(people, (person) => person.age);
117
+ *
118
+ * assertEquals(sortedByAge, [
119
+ * { name: "John", age: 23n },
120
+ * { name: "Anna", age: 34n },
121
+ * { name: "Kim", age: 42n },
122
+ * ]);
123
+ * ```
124
+ */
125
+ export declare function sortBy<T>(array: readonly T[], selector: (el: T) => bigint, options?: SortByOptions): T[];
126
+ /**
127
+ * Returns all elements in the given collection, sorted by their result using
128
+ * the given selector. The selector function is called only once for each
129
+ * element. Ascending or descending order can be specified through the `order`
130
+ * option. By default, the elements are sorted in ascending order.
131
+ *
132
+ * @typeParam T The type of the array elements.
133
+ *
134
+ * @param array The array to sort.
135
+ * @param selector The selector function to get the value to sort by.
136
+ * @param options The options for sorting.
137
+ *
138
+ * @returns A new array containing all elements sorted by the selector.
139
+ *
140
+ * @example Usage
141
+ * ```ts
142
+ * import { sortBy } from "@std/collections/sort-by";
143
+ * import { assertEquals } from "@std/assert";
144
+ *
145
+ * const people = [
146
+ * { name: "Anna", startedAt: new Date("2020-01-01") },
147
+ * { name: "Kim", startedAt: new Date("2020-03-01") },
148
+ * { name: "John", startedAt: new Date("2020-06-01") },
149
+ * ];
150
+ *
151
+ * const sortedByStartedAt = sortBy(people, (people) => people.startedAt);
152
+ *
153
+ * assertEquals(sortedByStartedAt, [
154
+ * { name: "Anna", startedAt: new Date("2020-01-01") },
155
+ * { name: "Kim", startedAt: new Date("2020-03-01") },
156
+ * { name: "John", startedAt: new Date("2020-06-01") },
157
+ * ]);
158
+ * ```
159
+ */
160
+ export declare function sortBy<T>(array: readonly T[], selector: (el: T) => Date, options?: SortByOptions): T[];
161
+ //# sourceMappingURL=sort_by.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sort_by.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/sort_by.ts"],"names":[],"mappings":"AAGA,kDAAkD;AAClD,MAAM,MAAM,KAAK,GAAG,KAAK,GAAG,MAAM,CAAC;AAEnC,sCAAsC;AACtC,MAAM,MAAM,aAAa,GAAG;IAC1B;;;;OAIG;IACH,KAAK,EAAE,KAAK,CAAC;CACd,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CG;AACH,wBAAgB,MAAM,CAAC,CAAC,EACtB,KAAK,EAAE,SAAS,CAAC,EAAE,EACnB,QAAQ,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,MAAM,EAC3B,OAAO,CAAC,EAAE,aAAa,GACtB,CAAC,EAAE,CAAC;AACP;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AACH,wBAAgB,MAAM,CAAC,CAAC,EACtB,KAAK,EAAE,SAAS,CAAC,EAAE,EACnB,QAAQ,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,MAAM,EAC3B,OAAO,CAAC,EAAE,aAAa,GACtB,CAAC,EAAE,CAAC;AACP;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AAEH,wBAAgB,MAAM,CAAC,CAAC,EACtB,KAAK,EAAE,SAAS,CAAC,EAAE,EACnB,QAAQ,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,MAAM,EAC3B,OAAO,CAAC,EAAE,aAAa,GACtB,CAAC,EAAE,CAAC;AACP;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AACH,wBAAgB,MAAM,CAAC,CAAC,EACtB,KAAK,EAAE,SAAS,CAAC,EAAE,EACnB,QAAQ,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,IAAI,EACzB,OAAO,CAAC,EAAE,aAAa,GACtB,CAAC,EAAE,CAAC"}
@@ -0,0 +1,30 @@
1
+ // Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
2
+ // This module is browser compatible.
3
+ export function sortBy(array, selector, options) {
4
+ const len = array.length;
5
+ const indexes = new Array(len);
6
+ const selectors = new Array(len);
7
+ const order = options?.order ?? "asc";
8
+ array.forEach((element, index) => {
9
+ indexes[index] = index;
10
+ const selected = selector(element);
11
+ selectors[index] = Number.isNaN(selected) ? null : selected;
12
+ });
13
+ indexes.sort((ai, bi) => {
14
+ let a = selectors[ai];
15
+ let b = selectors[bi];
16
+ if (order === "desc") {
17
+ [a, b] = [b, a];
18
+ }
19
+ if (a === null)
20
+ return 1;
21
+ if (b === null)
22
+ return -1;
23
+ return a > b ? 1 : a < b ? -1 : 0;
24
+ });
25
+ for (let i = 0; i < len; i++) {
26
+ indexes[i] = array[indexes[i]];
27
+ }
28
+ return indexes;
29
+ }
30
+ //# sourceMappingURL=sort_by.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sort_by.js","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/sort_by.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,qCAAqC;AAqLrC,MAAM,UAAU,MAAM,CACpB,KAAmB,EACnB,QAIqB,EACrB,OAAuB;IAEvB,MAAM,GAAG,GAAG,KAAK,CAAC,MAAM,CAAC;IACzB,MAAM,OAAO,GAAG,IAAI,KAAK,CAAS,GAAG,CAAC,CAAC;IACvC,MAAM,SAAS,GAAG,IAAI,KAAK,CAAqC,GAAG,CAAC,CAAC;IACrE,MAAM,KAAK,GAAG,OAAO,EAAE,KAAK,IAAI,KAAK,CAAC;IAEtC,KAAK,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE;QAC/B,OAAO,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;QACvB,MAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC;QACnC,SAAS,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC;IAC9D,CAAC,CAAC,CAAC;IAEH,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE;QACtB,IAAI,CAAC,GAAG,SAAS,CAAC,EAAE,CAAE,CAAC;QACvB,IAAI,CAAC,GAAG,SAAS,CAAC,EAAE,CAAE,CAAC;QACvB,IAAI,KAAK,KAAK,MAAM,EAAE,CAAC;YACrB,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAClB,CAAC;QACD,IAAI,CAAC,KAAK,IAAI;YAAE,OAAO,CAAC,CAAC;QACzB,IAAI,CAAC,KAAK,IAAI;YAAE,OAAO,CAAC,CAAC,CAAC;QAC1B,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;QAC5B,OAA0B,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAE,CAAM,CAAC;IAC3D,CAAC;IAED,OAAO,OAAyB,CAAC;AACnC,CAAC"}
@@ -0,0 +1,29 @@
1
+ /**
2
+ * Applies the given selector to all elements in the given collection and
3
+ * calculates the sum of the results.
4
+ *
5
+ * @typeParam T The type of the array elements.
6
+ *
7
+ * @param array The array to calculate the sum of.
8
+ * @param selector The selector function to get the value to sum.
9
+ *
10
+ * @returns The sum of all elements in the collection.
11
+ *
12
+ * @example Basic usage
13
+ * ```ts
14
+ * import { sumOf } from "@std/collections/sum-of";
15
+ * import { assertEquals } from "@std/assert";
16
+ *
17
+ * const people = [
18
+ * { name: "Anna", age: 34 },
19
+ * { name: "Kim", age: 42 },
20
+ * { name: "John", age: 23 },
21
+ * ];
22
+ *
23
+ * const totalAge = sumOf(people, (person) => person.age);
24
+ *
25
+ * assertEquals(totalAge, 99);
26
+ * ```
27
+ */
28
+ export declare function sumOf<T>(array: Iterable<T>, selector: (el: T) => number): number;
29
+ //# sourceMappingURL=sum_of.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sum_of.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/sum_of.ts"],"names":[],"mappings":"AAGA;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,wBAAgB,KAAK,CAAC,CAAC,EACrB,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,EAClB,QAAQ,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,MAAM,GAC1B,MAAM,CAQR"}
@@ -0,0 +1,37 @@
1
+ // Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
2
+ // This module is browser compatible.
3
+ /**
4
+ * Applies the given selector to all elements in the given collection and
5
+ * calculates the sum of the results.
6
+ *
7
+ * @typeParam T The type of the array elements.
8
+ *
9
+ * @param array The array to calculate the sum of.
10
+ * @param selector The selector function to get the value to sum.
11
+ *
12
+ * @returns The sum of all elements in the collection.
13
+ *
14
+ * @example Basic usage
15
+ * ```ts
16
+ * import { sumOf } from "@std/collections/sum-of";
17
+ * import { assertEquals } from "@std/assert";
18
+ *
19
+ * const people = [
20
+ * { name: "Anna", age: 34 },
21
+ * { name: "Kim", age: 42 },
22
+ * { name: "John", age: 23 },
23
+ * ];
24
+ *
25
+ * const totalAge = sumOf(people, (person) => person.age);
26
+ *
27
+ * assertEquals(totalAge, 99);
28
+ * ```
29
+ */
30
+ export function sumOf(array, selector) {
31
+ let sum = 0;
32
+ for (const i of array) {
33
+ sum += selector(i);
34
+ }
35
+ return sum;
36
+ }
37
+ //# sourceMappingURL=sum_of.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sum_of.js","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/sum_of.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,qCAAqC;AAErC;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,MAAM,UAAU,KAAK,CACnB,KAAkB,EAClB,QAA2B;IAE3B,IAAI,GAAG,GAAG,CAAC,CAAC;IAEZ,KAAK,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC;QACtB,GAAG,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC;IACrB,CAAC;IAED,OAAO,GAAG,CAAC;AACb,CAAC"}
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Returns all elements in the given array after the last element that does not
3
+ * match the given predicate.
4
+ *
5
+ * @typeParam T The type of the array elements.
6
+ *
7
+ * @param array The array to take elements from.
8
+ * @param predicate The predicate function to determine if an element should be
9
+ * included.
10
+ *
11
+ * @returns A new array containing all elements after the last element that does
12
+ * not match the predicate.
13
+ *
14
+ * @example Basic usage
15
+ * ```ts
16
+ * import { takeLastWhile } from "@std/collections/take-last-while";
17
+ * import { assertEquals } from "@std/assert";
18
+ *
19
+ * const numbers = [1, 2, 3, 4, 5, 6];
20
+ *
21
+ * const result = takeLastWhile(numbers, (number) => number > 4);
22
+ *
23
+ * assertEquals(result, [5, 6]);
24
+ * ```
25
+ */
26
+ export declare function takeLastWhile<T>(array: readonly T[], predicate: (el: T) => boolean): T[];
27
+ //# sourceMappingURL=take_last_while.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"take_last_while.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/take_last_while.ts"],"names":[],"mappings":"AAGA;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,wBAAgB,aAAa,CAAC,CAAC,EAC7B,KAAK,EAAE,SAAS,CAAC,EAAE,EACnB,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,OAAO,GAC5B,CAAC,EAAE,CAKL"}
@@ -0,0 +1,34 @@
1
+ // Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
2
+ // This module is browser compatible.
3
+ /**
4
+ * Returns all elements in the given array after the last element that does not
5
+ * match the given predicate.
6
+ *
7
+ * @typeParam T The type of the array elements.
8
+ *
9
+ * @param array The array to take elements from.
10
+ * @param predicate The predicate function to determine if an element should be
11
+ * included.
12
+ *
13
+ * @returns A new array containing all elements after the last element that does
14
+ * not match the predicate.
15
+ *
16
+ * @example Basic usage
17
+ * ```ts
18
+ * import { takeLastWhile } from "@std/collections/take-last-while";
19
+ * import { assertEquals } from "@std/assert";
20
+ *
21
+ * const numbers = [1, 2, 3, 4, 5, 6];
22
+ *
23
+ * const result = takeLastWhile(numbers, (number) => number > 4);
24
+ *
25
+ * assertEquals(result, [5, 6]);
26
+ * ```
27
+ */
28
+ export function takeLastWhile(array, predicate) {
29
+ let offset = array.length;
30
+ while (0 < offset && predicate(array[offset - 1]))
31
+ offset--;
32
+ return array.slice(offset, array.length);
33
+ }
34
+ //# sourceMappingURL=take_last_while.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"take_last_while.js","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/collections/1.0.9/take_last_while.ts"],"names":[],"mappings":"AAAA,0EAA0E;AAC1E,qCAAqC;AAErC;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,MAAM,UAAU,aAAa,CAC3B,KAAmB,EACnB,SAA6B;IAE7B,IAAI,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;IAC1B,OAAO,CAAC,GAAG,MAAM,IAAI,SAAS,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAM,CAAC;QAAE,MAAM,EAAE,CAAC;IAEjE,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;AAC3C,CAAC"}