rubico 2.8.0 → 2.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (341) hide show
  1. package/LICENSE +5 -17
  2. package/README.md +1 -1
  3. package/_internal/curryArity.js +21 -1
  4. package/_internal/funcApply2.js +18 -0
  5. package/curry.js +38 -11
  6. package/dist/Transducer.es.js +1 -1
  7. package/dist/Transducer.es.min.js +1 -1
  8. package/dist/Transducer.js +1 -1
  9. package/dist/Transducer.min.js +1 -1
  10. package/dist/Transducer.mjs +1 -1
  11. package/dist/__.es.js +1 -1
  12. package/dist/__.es.min.js +1 -1
  13. package/dist/__.js +1 -1
  14. package/dist/__.min.js +1 -1
  15. package/dist/__.mjs +1 -1
  16. package/dist/all.es.js +1 -1
  17. package/dist/all.es.min.js +1 -1
  18. package/dist/all.js +1 -1
  19. package/dist/all.min.js +1 -1
  20. package/dist/all.mjs +1 -1
  21. package/dist/always.es.js +1 -1
  22. package/dist/always.es.min.js +1 -1
  23. package/dist/always.js +1 -1
  24. package/dist/always.min.js +1 -1
  25. package/dist/always.mjs +1 -1
  26. package/dist/and.es.js +1 -1
  27. package/dist/and.es.min.js +1 -1
  28. package/dist/and.js +1 -1
  29. package/dist/and.min.js +1 -1
  30. package/dist/and.mjs +1 -1
  31. package/dist/assign.es.js +1 -1
  32. package/dist/assign.es.min.js +1 -1
  33. package/dist/assign.js +1 -1
  34. package/dist/assign.min.js +1 -1
  35. package/dist/assign.mjs +1 -1
  36. package/dist/compose.es.js +1 -1
  37. package/dist/compose.es.min.js +1 -1
  38. package/dist/compose.js +1 -1
  39. package/dist/compose.min.js +1 -1
  40. package/dist/compose.mjs +1 -1
  41. package/dist/curry.es.js +132 -3
  42. package/dist/curry.es.min.js +2 -2
  43. package/dist/curry.js +132 -3
  44. package/dist/curry.min.js +2 -2
  45. package/dist/curry.mjs +132 -3
  46. package/dist/eq.es.js +1 -1
  47. package/dist/eq.es.min.js +1 -1
  48. package/dist/eq.js +1 -1
  49. package/dist/eq.min.js +1 -1
  50. package/dist/eq.mjs +1 -1
  51. package/dist/every.es.js +1 -1
  52. package/dist/every.es.min.js +1 -1
  53. package/dist/every.js +1 -1
  54. package/dist/every.min.js +1 -1
  55. package/dist/every.mjs +1 -1
  56. package/dist/filter.es.js +1 -1
  57. package/dist/filter.es.min.js +1 -1
  58. package/dist/filter.js +1 -1
  59. package/dist/filter.min.js +1 -1
  60. package/dist/filter.mjs +1 -1
  61. package/dist/flatMap.es.js +1 -1
  62. package/dist/flatMap.es.min.js +1 -1
  63. package/dist/flatMap.js +1 -1
  64. package/dist/flatMap.min.js +1 -1
  65. package/dist/flatMap.mjs +1 -1
  66. package/dist/forEach.es.js +1 -1
  67. package/dist/forEach.es.min.js +1 -1
  68. package/dist/forEach.js +1 -1
  69. package/dist/forEach.min.js +1 -1
  70. package/dist/forEach.mjs +1 -1
  71. package/dist/get.es.js +1 -1
  72. package/dist/get.es.min.js +1 -1
  73. package/dist/get.js +1 -1
  74. package/dist/get.min.js +1 -1
  75. package/dist/get.mjs +1 -1
  76. package/dist/gt.es.js +1 -1
  77. package/dist/gt.es.min.js +1 -1
  78. package/dist/gt.js +1 -1
  79. package/dist/gt.min.js +1 -1
  80. package/dist/gt.mjs +1 -1
  81. package/dist/gte.es.js +1 -1
  82. package/dist/gte.es.min.js +1 -1
  83. package/dist/gte.js +1 -1
  84. package/dist/gte.min.js +1 -1
  85. package/dist/gte.mjs +1 -1
  86. package/dist/lt.es.js +1 -1
  87. package/dist/lt.es.min.js +1 -1
  88. package/dist/lt.js +1 -1
  89. package/dist/lt.min.js +1 -1
  90. package/dist/lt.mjs +1 -1
  91. package/dist/lte.es.js +1 -1
  92. package/dist/lte.es.min.js +1 -1
  93. package/dist/lte.js +1 -1
  94. package/dist/lte.min.js +1 -1
  95. package/dist/lte.mjs +1 -1
  96. package/dist/map.es.js +41 -2
  97. package/dist/map.es.min.js +2 -2
  98. package/dist/map.js +41 -2
  99. package/dist/map.min.js +2 -2
  100. package/dist/map.mjs +41 -2
  101. package/dist/not.es.js +1 -1
  102. package/dist/not.es.min.js +1 -1
  103. package/dist/not.js +1 -1
  104. package/dist/not.min.js +1 -1
  105. package/dist/not.mjs +1 -1
  106. package/dist/omit.es.js +1 -1
  107. package/dist/omit.es.min.js +1 -1
  108. package/dist/omit.js +1 -1
  109. package/dist/omit.min.js +1 -1
  110. package/dist/omit.mjs +1 -1
  111. package/dist/or.es.js +1 -1
  112. package/dist/or.es.min.js +1 -1
  113. package/dist/or.js +1 -1
  114. package/dist/or.min.js +1 -1
  115. package/dist/or.mjs +1 -1
  116. package/dist/pick.es.js +1 -1
  117. package/dist/pick.es.min.js +1 -1
  118. package/dist/pick.js +1 -1
  119. package/dist/pick.min.js +1 -1
  120. package/dist/pick.mjs +1 -1
  121. package/dist/pipe.es.js +1 -1
  122. package/dist/pipe.es.min.js +1 -1
  123. package/dist/pipe.js +1 -1
  124. package/dist/pipe.min.js +1 -1
  125. package/dist/pipe.mjs +1 -1
  126. package/dist/reduce.es.js +1 -1
  127. package/dist/reduce.es.min.js +1 -1
  128. package/dist/reduce.js +1 -1
  129. package/dist/reduce.min.js +1 -1
  130. package/dist/reduce.mjs +1 -1
  131. package/dist/rubico.es.js +47 -6
  132. package/dist/rubico.es.min.js +2 -2
  133. package/dist/rubico.global.js +47 -6
  134. package/dist/rubico.global.min.js +2 -2
  135. package/dist/rubico.js +47 -6
  136. package/dist/rubico.min.js +2 -2
  137. package/dist/rubico.mjs +47 -6
  138. package/dist/set.es.js +1 -1
  139. package/dist/set.es.min.js +1 -1
  140. package/dist/set.js +1 -1
  141. package/dist/set.min.js +1 -1
  142. package/dist/set.mjs +1 -1
  143. package/dist/some.es.js +1 -1
  144. package/dist/some.es.min.js +1 -1
  145. package/dist/some.js +1 -1
  146. package/dist/some.min.js +1 -1
  147. package/dist/some.mjs +1 -1
  148. package/dist/switchCase.es.js +1 -1
  149. package/dist/switchCase.es.min.js +1 -1
  150. package/dist/switchCase.js +1 -1
  151. package/dist/switchCase.min.js +1 -1
  152. package/dist/switchCase.mjs +1 -1
  153. package/dist/tap.es.js +1 -1
  154. package/dist/tap.es.min.js +1 -1
  155. package/dist/tap.js +1 -1
  156. package/dist/tap.min.js +1 -1
  157. package/dist/tap.mjs +1 -1
  158. package/dist/thunkify.es.js +41 -17
  159. package/dist/thunkify.es.min.js +2 -2
  160. package/dist/thunkify.js +41 -17
  161. package/dist/thunkify.min.js +2 -2
  162. package/dist/thunkify.mjs +41 -17
  163. package/dist/transform.es.js +1 -1
  164. package/dist/transform.es.min.js +1 -1
  165. package/dist/transform.js +1 -1
  166. package/dist/transform.min.js +1 -1
  167. package/dist/transform.mjs +1 -1
  168. package/dist/tryCatch.es.js +1 -1
  169. package/dist/tryCatch.es.min.js +1 -1
  170. package/dist/tryCatch.js +1 -1
  171. package/dist/tryCatch.min.js +1 -1
  172. package/dist/tryCatch.mjs +1 -1
  173. package/dist/x/append.es.js +1 -1
  174. package/dist/x/append.es.min.js +1 -1
  175. package/dist/x/append.js +1 -1
  176. package/dist/x/append.min.js +1 -1
  177. package/dist/x/append.mjs +1 -1
  178. package/dist/x/callProp.es.js +1 -1
  179. package/dist/x/callProp.es.min.js +1 -1
  180. package/dist/x/callProp.js +1 -1
  181. package/dist/x/callProp.min.js +1 -1
  182. package/dist/x/callProp.mjs +1 -1
  183. package/dist/x/defaultsDeep.es.js +1 -1
  184. package/dist/x/defaultsDeep.es.min.js +1 -1
  185. package/dist/x/defaultsDeep.js +1 -1
  186. package/dist/x/defaultsDeep.min.js +1 -1
  187. package/dist/x/defaultsDeep.mjs +1 -1
  188. package/dist/x/differenceWith.es.js +1 -1
  189. package/dist/x/differenceWith.es.min.js +1 -1
  190. package/dist/x/differenceWith.js +1 -1
  191. package/dist/x/differenceWith.min.js +1 -1
  192. package/dist/x/differenceWith.mjs +1 -1
  193. package/dist/x/filterOut.es.js +1 -1
  194. package/dist/x/filterOut.es.min.js +1 -1
  195. package/dist/x/filterOut.js +1 -1
  196. package/dist/x/filterOut.min.js +1 -1
  197. package/dist/x/filterOut.mjs +1 -1
  198. package/dist/x/find.es.js +1 -1
  199. package/dist/x/find.es.min.js +1 -1
  200. package/dist/x/find.js +1 -1
  201. package/dist/x/find.min.js +1 -1
  202. package/dist/x/find.mjs +1 -1
  203. package/dist/x/findIndex.es.js +1 -1
  204. package/dist/x/findIndex.es.min.js +1 -1
  205. package/dist/x/findIndex.js +1 -1
  206. package/dist/x/findIndex.min.js +1 -1
  207. package/dist/x/findIndex.mjs +1 -1
  208. package/dist/x/first.es.js +1 -1
  209. package/dist/x/first.es.min.js +1 -1
  210. package/dist/x/first.js +1 -1
  211. package/dist/x/first.min.js +1 -1
  212. package/dist/x/first.mjs +1 -1
  213. package/dist/x/flatten.es.js +1 -1
  214. package/dist/x/flatten.es.min.js +1 -1
  215. package/dist/x/flatten.js +1 -1
  216. package/dist/x/flatten.min.js +1 -1
  217. package/dist/x/flatten.mjs +1 -1
  218. package/dist/x/groupBy.es.js +1 -1
  219. package/dist/x/groupBy.es.min.js +1 -1
  220. package/dist/x/groupBy.js +1 -1
  221. package/dist/x/groupBy.min.js +1 -1
  222. package/dist/x/groupBy.mjs +1 -1
  223. package/dist/x/has.es.js +1 -1
  224. package/dist/x/has.es.min.js +1 -1
  225. package/dist/x/has.js +1 -1
  226. package/dist/x/has.min.js +1 -1
  227. package/dist/x/has.mjs +1 -1
  228. package/dist/x/identity.es.js +1 -1
  229. package/dist/x/identity.es.min.js +1 -1
  230. package/dist/x/identity.js +1 -1
  231. package/dist/x/identity.min.js +1 -1
  232. package/dist/x/identity.mjs +1 -1
  233. package/dist/x/includes.es.js +1 -1
  234. package/dist/x/includes.es.min.js +1 -1
  235. package/dist/x/includes.js +1 -1
  236. package/dist/x/includes.min.js +1 -1
  237. package/dist/x/includes.mjs +1 -1
  238. package/dist/x/isDeepEqual.es.js +1 -1
  239. package/dist/x/isDeepEqual.es.min.js +1 -1
  240. package/dist/x/isDeepEqual.js +1 -1
  241. package/dist/x/isDeepEqual.min.js +1 -1
  242. package/dist/x/isDeepEqual.mjs +1 -1
  243. package/dist/x/isEmpty.es.js +1 -1
  244. package/dist/x/isEmpty.es.min.js +1 -1
  245. package/dist/x/isEmpty.js +1 -1
  246. package/dist/x/isEmpty.min.js +1 -1
  247. package/dist/x/isEmpty.mjs +1 -1
  248. package/dist/x/isEqual.es.js +1 -1
  249. package/dist/x/isEqual.es.min.js +1 -1
  250. package/dist/x/isEqual.js +1 -1
  251. package/dist/x/isEqual.min.js +1 -1
  252. package/dist/x/isEqual.mjs +1 -1
  253. package/dist/x/isFunction.es.js +1 -1
  254. package/dist/x/isFunction.es.min.js +1 -1
  255. package/dist/x/isFunction.js +1 -1
  256. package/dist/x/isFunction.min.js +1 -1
  257. package/dist/x/isFunction.mjs +1 -1
  258. package/dist/x/isIn.es.js +1 -1
  259. package/dist/x/isIn.es.min.js +1 -1
  260. package/dist/x/isIn.js +1 -1
  261. package/dist/x/isIn.min.js +1 -1
  262. package/dist/x/isIn.mjs +1 -1
  263. package/dist/x/isObject.es.js +1 -1
  264. package/dist/x/isObject.es.min.js +1 -1
  265. package/dist/x/isObject.js +1 -1
  266. package/dist/x/isObject.min.js +1 -1
  267. package/dist/x/isObject.mjs +1 -1
  268. package/dist/x/isString.es.js +1 -1
  269. package/dist/x/isString.es.min.js +1 -1
  270. package/dist/x/isString.js +1 -1
  271. package/dist/x/isString.min.js +1 -1
  272. package/dist/x/isString.mjs +1 -1
  273. package/dist/x/keys.es.js +1 -1
  274. package/dist/x/keys.es.min.js +1 -1
  275. package/dist/x/keys.js +1 -1
  276. package/dist/x/keys.min.js +1 -1
  277. package/dist/x/keys.mjs +1 -1
  278. package/dist/x/last.es.js +1 -1
  279. package/dist/x/last.es.min.js +1 -1
  280. package/dist/x/last.js +1 -1
  281. package/dist/x/last.min.js +1 -1
  282. package/dist/x/last.mjs +1 -1
  283. package/dist/x/maxBy.es.js +1 -1
  284. package/dist/x/maxBy.es.min.js +1 -1
  285. package/dist/x/maxBy.js +1 -1
  286. package/dist/x/maxBy.min.js +1 -1
  287. package/dist/x/maxBy.mjs +1 -1
  288. package/dist/x/noop.es.js +1 -1
  289. package/dist/x/noop.es.min.js +1 -1
  290. package/dist/x/noop.js +1 -1
  291. package/dist/x/noop.min.js +1 -1
  292. package/dist/x/noop.mjs +1 -1
  293. package/dist/x/pluck.es.js +41 -2
  294. package/dist/x/pluck.es.min.js +2 -2
  295. package/dist/x/pluck.js +41 -2
  296. package/dist/x/pluck.min.js +2 -2
  297. package/dist/x/pluck.mjs +41 -2
  298. package/dist/x/prepend.es.js +1 -1
  299. package/dist/x/prepend.es.min.js +1 -1
  300. package/dist/x/prepend.js +1 -1
  301. package/dist/x/prepend.min.js +1 -1
  302. package/dist/x/prepend.mjs +1 -1
  303. package/dist/x/size.es.js +1 -1
  304. package/dist/x/size.es.min.js +1 -1
  305. package/dist/x/size.js +1 -1
  306. package/dist/x/size.min.js +1 -1
  307. package/dist/x/size.mjs +1 -1
  308. package/dist/x/trace.es.js +1 -1
  309. package/dist/x/trace.es.min.js +1 -1
  310. package/dist/x/trace.js +1 -1
  311. package/dist/x/trace.min.js +1 -1
  312. package/dist/x/trace.mjs +1 -1
  313. package/dist/x/unionWith.es.js +1 -1
  314. package/dist/x/unionWith.es.min.js +1 -1
  315. package/dist/x/unionWith.js +1 -1
  316. package/dist/x/unionWith.min.js +1 -1
  317. package/dist/x/unionWith.mjs +1 -1
  318. package/dist/x/uniq.es.js +1 -1
  319. package/dist/x/uniq.es.min.js +1 -1
  320. package/dist/x/uniq.js +1 -1
  321. package/dist/x/uniq.min.js +1 -1
  322. package/dist/x/uniq.mjs +1 -1
  323. package/dist/x/unless.es.js +1 -1
  324. package/dist/x/unless.es.min.js +1 -1
  325. package/dist/x/unless.js +1 -1
  326. package/dist/x/unless.min.js +1 -1
  327. package/dist/x/unless.mjs +1 -1
  328. package/dist/x/values.es.js +1 -1
  329. package/dist/x/values.es.min.js +1 -1
  330. package/dist/x/values.js +1 -1
  331. package/dist/x/values.min.js +1 -1
  332. package/dist/x/values.mjs +1 -1
  333. package/dist/x/when.es.js +1 -1
  334. package/dist/x/when.es.min.js +1 -1
  335. package/dist/x/when.js +1 -1
  336. package/dist/x/when.min.js +1 -1
  337. package/dist/x/when.mjs +1 -1
  338. package/es.js +47 -6
  339. package/index.js +47 -6
  340. package/package.json +1 -1
  341. package/thunkify.js +66 -6
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/keys.es.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/keys.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/keys.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/last.es.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/last.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/last.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/maxBy.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/maxBy.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/noop.es.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/noop.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/noop.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -628,6 +628,30 @@ const objectMapPool = function (o, concurrency, f) {
628
628
  return result
629
629
  }
630
630
 
631
+ const areAnyValuesPromises = function (values) {
632
+ if (isArray(values)) {
633
+ const length = values.length
634
+ let index = -1
635
+ while (++index < length) {
636
+ const value = values[index]
637
+ if (isPromise(value)) {
638
+ return true
639
+ }
640
+ }
641
+ return false
642
+ }
643
+
644
+ for (const key in values) {
645
+ const value = values[key]
646
+ if (isPromise(value)) {
647
+ return true
648
+ }
649
+ }
650
+ return false
651
+ }
652
+
653
+ const funcApply2 = (func, context, args) => func.apply(context, args)
654
+
631
655
  const _curryArity = (arity, func, context, args) => function curried(...curriedArgs) {
632
656
  const argsLength = args.length,
633
657
  curriedArgsLength = curriedArgs.length,
@@ -647,7 +671,13 @@ const _curryArity = (arity, func, context, args) => function curried(...curriedA
647
671
  } else {
648
672
  nextArgs.push(arg)
649
673
  }
674
+
650
675
  if (nextArgs.length == arity) {
676
+ if (areAnyValuesPromises(nextArgs)) {
677
+ return numCurriedPlaceholders == 0
678
+ ? promiseAll(nextArgs).then(curry3(funcApply2, func, context, __))
679
+ : promiseAll(nextArgs).then(curry4(curryArity, arity, func, context, __))
680
+ }
651
681
  return numCurriedPlaceholders == 0
652
682
  ? func.apply(context, nextArgs)
653
683
  : curryArity(arity, func, context, nextArgs)
@@ -660,13 +690,22 @@ const _curryArity = (arity, func, context, args) => function curried(...curriedA
660
690
  numCurriedPlaceholders += 1
661
691
  }
662
692
  nextArgs.push(curriedArg)
693
+
663
694
  if (nextArgs.length == arity) {
695
+ if (areAnyValuesPromises(nextArgs)) {
696
+ return numCurriedPlaceholders == 0
697
+ ? promiseAll(nextArgs).then(curry3(funcApply2, func, context, __))
698
+ : promiseAll(nextArgs).then(curry4(curryArity, arity, func, context, __))
699
+ }
664
700
  return numCurriedPlaceholders == 0
665
701
  ? func.apply(context, nextArgs)
666
702
  : curryArity(arity, func, context, nextArgs)
667
703
  }
668
704
  }
669
- return curryArity(arity, func, context, nextArgs)
705
+
706
+ return areAnyValuesPromises(nextArgs)
707
+ ? promiseAll(nextArgs).then(curry4(curryArity, arity, func, context, __))
708
+ : curryArity(arity, func, context, nextArgs)
670
709
  }
671
710
 
672
711
  const curryArity = function (arity, func, context, args) {
@@ -1,7 +1,7 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
6
6
  */
7
- const isPromise=r=>null!=r&&"function"==typeof r.then,funcConcat=(r,t)=>function(...e){const n=r(...e);return isPromise(n)?n.then(t):t(n)},symbolIterator=Symbol.iterator,MappingIterator=(r,t)=>({toString:()=>"[object MappingIterator]",[symbolIterator](){return this},next(){const e=r.next();return e.done?e:{value:t(e.value),done:!1}}}),NextIteration=r=>({value:r,done:!1}),symbolAsyncIterator=Symbol.asyncIterator,MappingAsyncIterator=(r,t)=>({[symbolAsyncIterator](){return this},async next(){const e=await r.next();if(e.done)return e;const n=t(e.value);return isPromise(n)?n.then(NextIteration):{value:n,done:!1}}}),__=Symbol.for("placeholder"),curry2ResolveArg0=(r,t)=>function(e){return r(e,t)},curry2ResolveArg1=(r,t)=>function(e){return r(t,e)},curry2=function(r,t,e){return t==__?curry2ResolveArg0(r,e):curry2ResolveArg1(r,t)},curry3ResolveArg0=(r,t,e)=>function(n){return r(n,t,e)},curry3ResolveArg1=(r,t,e)=>function(n){return r(t,n,e)},curry3ResolveArg2=(r,t,e)=>function(n){return r(t,e,n)},curry3=function(r,t,e,n){return t==__?curry3ResolveArg0(r,e,n):e==__?curry3ResolveArg1(r,t,n):curry3ResolveArg2(r,t,e)},isArray=Array.isArray,isObject=r=>{if(null==r)return!1;const t=typeof r;return"object"==t||"function"==t},promiseAll=Promise.all.bind(Promise),arrayMap=function(r,t){const e=r.length,n=Array(e);let o=-1,s=!1;for(;++o<e;){const e=t(r[o],o,r);isPromise(e)&&(s=!0),n[o]=e}return s?promiseAll(n):n},callPropUnary=(r,t,e)=>r[t](e),stringMap=function(r,t){const e=arrayMap(r,t);return isPromise(e)?e.then(curry3(callPropUnary,__,"join","")):e.join("")},always=r=>function(){return r},setMap=function(r,t){const e=new Set,n=[];for(const o of r){const s=t(o,o,r);isPromise(s)?n.push(s.then(curry3(callPropUnary,e,"add",__))):e.add(s)}return 0==n.length?e:promiseAll(n).then(always(e))},curry4ResolveArg0=(r,t,e,n)=>function(o){return r(o,t,e,n)},curry4ResolveArg1=(r,t,e,n)=>function(o){return r(t,o,e,n)},curry4ResolveArg2=(r,t,e,n)=>function(o){return r(t,e,o,n)},curry4ResolveArg3=(r,t,e,n)=>function(o){return r(t,e,n,o)},curry4=function(r,t,e,n,o){return t==__?curry4ResolveArg0(r,e,n,o):e==__?curry4ResolveArg1(r,t,n,o):n==__?curry4ResolveArg2(r,t,e,o):curry4ResolveArg3(r,t,e,n)},callPropBinary=(r,t,e,n)=>r[t](e,n),mapMap=function(r,t){const e=new Map,n=[];for(const[o,s]of r){const i=t(s,o,r);isPromise(i)?n.push(i.then(curry4(callPropBinary,e,"set",o,__))):e.set(o,i)}return 0==n.length?e:promiseAll(n).then(always(e))},promiseObjectAllExecutor=r=>function(t){const e={};let n=0;for(const o in r){const s=r[o];isPromise(s)?(n+=1,s.then((r=>function(o){e[r]=o,n-=1,0==n&&t(e)})(o))):e[o]=s}0==n&&t(e)},promiseObjectAll=r=>new Promise(promiseObjectAllExecutor(r)),objectMap=function(r,t){const e={};let n=!1;for(const o in r){const s=t(r[o],o,r);isPromise(s)&&(n=!0),e[o]=s}return n?promiseObjectAll(e):e},objectSet=function(r,t,e){return r[t]=e,r},arrayMapSeriesAsync=async function(r,t,e,n){const o=r.length;for(;++n<o;){const o=t(r[n],n);e[n]=isPromise(o)?await o:o}return e},arrayMapSeries=function(r,t){const e=r.length,n=Array(e);let o=-1;for(;++o<e;){const e=t(r[o],o);if(isPromise(e))return e.then(funcConcat(curry3(objectSet,n,o,__),curry4(arrayMapSeriesAsync,r,t,__,o)));n[o]=e}return n},stringMapSeries=function(r,t){const e=arrayMapSeries(r,t);return isPromise(e)?e.then(curry3(callPropUnary,__,"join","")):e.join("")},thunkify4=(r,t,e,n,o)=>function(){return r(t,e,n,o)},_objectMapSeriesAsync=async function(r,t,e,n){for(const o in r){if(o in n)continue;let s=t(r[o]);isPromise(s)&&(s=await s),e[o]=s}return e},objectMapSeries=function(r,t){const e={},n={};for(const o in r){n[o]=!0;const s=t(r[o],o,r);if(isPromise(s))return s.then(funcConcat(curry3(objectSet,e,o,__),thunkify4(_objectMapSeriesAsync,r,t,e,n)));e[o]=s}return e},thunkify3=(r,t,e,n)=>function(){return r(t,e,n)},setAdd=function(r,t){return r.add(t),r},_setMapSeriesAsync=async function(r,t,e){let n=r.next();for(;!n.done;){let o=t(n.value);isPromise(o)&&(o=await o),e.add(o),n=r.next()}return e},setMapSeries=function(r,t){const e=new Set,n=r[symbolIterator]();let o=n.next();for(;!o.done;){const r=t(o.value);if(isPromise(r))return r.then(funcConcat(curry2(setAdd,e,__),thunkify3(_setMapSeriesAsync,n,t,e)));e.add(r),o=n.next()}return e},mapSet=function(r,t,e){return r.set(t,e)},_mapMapSeriesAsync=async function(r,t,e){let n=r.next();for(;!n.done;){let o=t(n.value[1]);isPromise(o)&&(o=await o),e.set(n.value[0],o),n=r.next()}return e},mapMapSeries=function(r,t){const e=new Map,n=r[symbolIterator]();let o=n.next();for(;!o.done;){const r=o.value[0],s=t(o.value[1]);if(isPromise(s))return s.then(funcConcat(curry3(mapSet,e,r,__),thunkify3(_mapMapSeriesAsync,n,t,e)));e.set(r,s),o=n.next()}return e},tapSync=r=>function(...t){return r(...t),t[0]},promiseRace=Promise.race.bind(Promise),arrayMapPoolAsync=async function(r,t,e,n,o,s){const i=r.length;for(;++o<i;){s.size>=e&&await promiseRace(s);const i=t(r[o]);if(isPromise(i)){const r=i.then(tapSync(()=>s.delete(r)));s.add(r),n[o]=r}else n[o]=i}return promiseAll(n)},arrayMapPool=function(r,t,e){const n=r.length,o=Array(n);let s=-1;for(;++s<n;){const n=e(r[s]);if(isPromise(n)){const i=new Set,c=n.then(tapSync(()=>i.delete(c)));return i.add(c),o[s]=c,arrayMapPoolAsync(r,e,t,o,s,i)}o[s]=n}return o},stringMapPool=function(r,t,e){const n=arrayMapPool(r,t,e);return isPromise(n)?n.then(curry3(callPropUnary,__,"join","")):n.join("")},_setMapPoolAsync=async function(r,t,e,n,o,s){let i=t.next();for(;!i.done;){s.size>=e&&await promiseRace(s);const c=n(i.value,i.value,r);if(isPromise(c)){const r=c.then(t=>{s.delete(r),o.add(t)});s.add(r)}else o.add(c);i=t.next()}return s.size>0&&await promiseAll(s),o},setMapPool=function(r,t,e){const n=new Set,o=r[symbolIterator]();let s=o.next();for(;!s.done;){const i=e(s.value,s.value,r);if(isPromise(i)){const s=new Set,c=i.then(r=>{s.delete(c),n.add(r)});return s.add(c),_setMapPoolAsync(r,o,t,e,n,s)}n.add(i),s=o.next()}return n},_mapMapPoolAsync=async function(r,t,e,n,o,s){let i=t.next();for(;!i.done;){s.size>=e&&await promiseRace(s);const c=i.value[0],a=n(i.value[1],c,r);if(isPromise(a)){o.set(c,a);const r=a.then(t=>{s.delete(r),o.set(c,t)});s.add(r)}else o.set(c,a);i=t.next()}return s.size>0&&await promiseAll(s),o},mapMapPool=function(r,t,e){const n=new Map,o=r[symbolIterator]();let s=o.next();for(;!s.done;){const i=s.value[0],c=e(s.value[1],i,r);if(isPromise(c)){const s=new Set;n.set(i,c);const a=c.then(r=>{s.delete(a),n.set(i,r)});return s.add(a),_mapMapPoolAsync(r,o,t,e,n,s)}n.set(i,c),s=o.next()}return n},_objectMapPoolAsync=async function(r,t,e,n,o,s){for(const i in r){if(i in o)continue;s.size>=t&&await promiseRace(s);const c=e(r[i],i,r);if(isPromise(c)){n[i]=c;const r=c.then(t=>{s.delete(r),n[i]=t});s.add(r)}else n[i]=c}return s.size>0&&await promiseAll(s),n},objectMapPool=function(r,t,e){const n={},o={};for(const s in r){o[s]=!0;const i=e(r[s],s,r);if(isPromise(i)){const c=new Set;n[s]=i;const a=i.then(r=>{c.delete(a),n[s]=r});return c.add(a),_objectMapPoolAsync(r,t,e,n,o,c)}n[s]=i}return n},_curryArity=(r,t,e,n)=>function(...o){const s=n.length,i=o.length,c=[];let a=-1,u=-1,l=0;for(;++a<s;){const s=n[a];if(s==__&&(u+=1)<i){const r=o[u];r==__&&(l+=1),c.push(r)}else c.push(s);if(c.length==r)return 0==l?t.apply(e,c):curryArity(r,t,e,c)}for(;++u<i;){const n=o[u];if(n==__&&(l+=1),c.push(n),c.length==r)return 0==l?t.apply(e,c):curryArity(r,t,e,c)}return curryArity(r,t,e,c)},curryArity=function(r,t,e,n){const o=n.length;if(o<r)return _curryArity(r,t,e,n);let s=-1;for(;++s<o;){if(n[s]==__)return _curryArity(r,t,e,n)}return t.apply(e,n)},spread2=r=>function([t,e]){return r(t,e)},objectMapEntries=function(r,t){const e={},n=[];for(const o in r){const s=t([o,r[o]]);isPromise(s)?n.push(s.then(spread2(curryArity(3,objectSet,this,[e])))):e[s[0]]=s[1]}return 0==n.length?e:promiseAll(n).then(always(e))},mapMapEntriesForEachCallback=(r,t,e)=>function(n,o){const s=r([o,n]);isPromise(s)?e.push(s.then(spread2(curryArity(3,mapSet,this,[t])))):t.set(s[0],s[1])},mapMapEntries=function(r,t){const e=new Map,n=[];return r.forEach(mapMapEntriesForEachCallback(t,e,n)),0==n.length?e:promiseAll(n).then(always(e))},_map=function(r,t){return isArray(r)?arrayMap(r,t):null==r?r:"function"==typeof r.then?r.then(t):"function"==typeof r.map?r.map(t):"string"==typeof r||r.constructor==String?stringMap(r,t):r.constructor==Set?setMap(r,t):r.constructor==Map?mapMap(r,t):"function"==typeof r[symbolIterator]?MappingIterator(r[symbolIterator](),t):"function"==typeof r[symbolAsyncIterator]?MappingAsyncIterator(r[symbolAsyncIterator](),t):r.constructor==Object?objectMap(r,t):t(r)},map=function(r,t){return null==t?curry2(_map,__,r):isPromise(r)?r.then(curry2(_map,__,t)):_map(r,t)},_mapEntries=(r,t)=>{if(null==r)throw new TypeError("value is not an Object or Map");if(r.constructor==Object)return objectMapEntries(r,t);if(r.constructor==Map)return mapMapEntries(r,t);throw new TypeError("value is not an Object or Map")};map.entries=function(r,t){return null==t?curry2(_mapEntries,__,r):isPromise(r)?r.then(curry2(_mapEntries,__,t)):_mapEntries(r,t)};const _mapSeries=function(r,t){if(isArray(r))return arrayMapSeries(r,t);if(null==r)throw new TypeError(`invalid collection ${r}`);if("string"==typeof r||r.constructor==String)return stringMapSeries(r,t);if(r.constructor==Set)return setMapSeries(r,t);if(r.constructor==Map)return mapMapSeries(r,t);if(r.constructor==Object)return objectMapSeries(r,t);throw new TypeError(`invalid collection ${r}`)};map.series=function(r,t){return null==t?curry2(_mapSeries,__,r):isPromise(r)?r.then(curry2(_mapSeries,__,t)):_mapSeries(r,t)};const _mapPool=function(r,t,e){if(isArray(r))return arrayMapPool(r,t,e);if(null==r)throw new TypeError(`invalid functor ${r}`);if("string"==typeof r||r.constructor==String)return stringMapPool(r,t,e);if(r.constructor==Set)return setMapPool(r,t,e);if(r.constructor==Map)return mapMapPool(r,t,e);if(r.constructor==Object)return objectMapPool(r,t,e);throw new TypeError(`invalid functor ${r}`)};map.pool=function(r,t,e){return null==e?curry3(_mapPool,__,r,t):isPromise(r)?r.then(curry3(_mapPool,__,t,e)):_mapPool(r,t,e)};const memoizeCappedUnary=function(r,t){const e=new Map,n=function(n){if(e.has(n))return e.get(n);const o=r(n);return e.set(n,o),e.size>t&&e.clear(),o};return n.cache=e,n},pathDelimiters=/[.|[|\]]+/,parsePropertyPath=function(r){const t=r.length-1,e="["==r[0],n="]"==r[t];return e&&n?r.slice(1,t).split(pathDelimiters):e?r.slice(1).split(pathDelimiters):n?r.slice(0,t).split(pathDelimiters):r.split(pathDelimiters)},memoizedCappedParsePropertyPath=memoizeCappedUnary(parsePropertyPath,500),propertyPathToArray=r=>isArray(r)?r:"string"==typeof r?memoizedCappedParsePropertyPath(r):[r],getByPath=function(r,t){const e=propertyPathToArray(t),n=e.length;let o=-1,s=r;for(;++o<n;)if(s=s[e[o]],null==s)return;return s},_get=function(r,t,e){const n=null==r?void 0:getByPath(r,t);return void 0===n?"function"==typeof e?e(r):e:n},get=function(r,t,e){return"string"==typeof r||"number"==typeof r||isArray(r)?curry3(_get,__,r,t):isPromise(r)?r.then(curry3(_get,__,t,e)):_get(r,t,e)},pluck=function(...r){const t=r.pop(),e=get(t);return 0==r.length?map(e):map(r[0],e)};export default pluck;
7
+ const isPromise=r=>null!=r&&"function"==typeof r.then,funcConcat=(r,e)=>function(...t){const n=r(...t);return isPromise(n)?n.then(e):e(n)},symbolIterator=Symbol.iterator,MappingIterator=(r,e)=>({toString:()=>"[object MappingIterator]",[symbolIterator](){return this},next(){const t=r.next();return t.done?t:{value:e(t.value),done:!1}}}),NextIteration=r=>({value:r,done:!1}),symbolAsyncIterator=Symbol.asyncIterator,MappingAsyncIterator=(r,e)=>({[symbolAsyncIterator](){return this},async next(){const t=await r.next();if(t.done)return t;const n=e(t.value);return isPromise(n)?n.then(NextIteration):{value:n,done:!1}}}),__=Symbol.for("placeholder"),curry2ResolveArg0=(r,e)=>function(t){return r(t,e)},curry2ResolveArg1=(r,e)=>function(t){return r(e,t)},curry2=function(r,e,t){return e==__?curry2ResolveArg0(r,t):curry2ResolveArg1(r,e)},curry3ResolveArg0=(r,e,t)=>function(n){return r(n,e,t)},curry3ResolveArg1=(r,e,t)=>function(n){return r(e,n,t)},curry3ResolveArg2=(r,e,t)=>function(n){return r(e,t,n)},curry3=function(r,e,t,n){return e==__?curry3ResolveArg0(r,t,n):t==__?curry3ResolveArg1(r,e,n):curry3ResolveArg2(r,e,t)},isArray=Array.isArray,isObject=r=>{if(null==r)return!1;const e=typeof r;return"object"==e||"function"==e},promiseAll=Promise.all.bind(Promise),arrayMap=function(r,e){const t=r.length,n=Array(t);let o=-1,s=!1;for(;++o<t;){const t=e(r[o],o,r);isPromise(t)&&(s=!0),n[o]=t}return s?promiseAll(n):n},callPropUnary=(r,e,t)=>r[e](t),stringMap=function(r,e){const t=arrayMap(r,e);return isPromise(t)?t.then(curry3(callPropUnary,__,"join","")):t.join("")},always=r=>function(){return r},setMap=function(r,e){const t=new Set,n=[];for(const o of r){const s=e(o,o,r);isPromise(s)?n.push(s.then(curry3(callPropUnary,t,"add",__))):t.add(s)}return 0==n.length?t:promiseAll(n).then(always(t))},curry4ResolveArg0=(r,e,t,n)=>function(o){return r(o,e,t,n)},curry4ResolveArg1=(r,e,t,n)=>function(o){return r(e,o,t,n)},curry4ResolveArg2=(r,e,t,n)=>function(o){return r(e,t,o,n)},curry4ResolveArg3=(r,e,t,n)=>function(o){return r(e,t,n,o)},curry4=function(r,e,t,n,o){return e==__?curry4ResolveArg0(r,t,n,o):t==__?curry4ResolveArg1(r,e,n,o):n==__?curry4ResolveArg2(r,e,t,o):curry4ResolveArg3(r,e,t,n)},callPropBinary=(r,e,t,n)=>r[e](t,n),mapMap=function(r,e){const t=new Map,n=[];for(const[o,s]of r){const i=e(s,o,r);isPromise(i)?n.push(i.then(curry4(callPropBinary,t,"set",o,__))):t.set(o,i)}return 0==n.length?t:promiseAll(n).then(always(t))},promiseObjectAllExecutor=r=>function(e){const t={};let n=0;for(const o in r){const s=r[o];isPromise(s)?(n+=1,s.then((r=>function(o){t[r]=o,n-=1,0==n&&e(t)})(o))):t[o]=s}0==n&&e(t)},promiseObjectAll=r=>new Promise(promiseObjectAllExecutor(r)),objectMap=function(r,e){const t={};let n=!1;for(const o in r){const s=e(r[o],o,r);isPromise(s)&&(n=!0),t[o]=s}return n?promiseObjectAll(t):t},objectSet=function(r,e,t){return r[e]=t,r},arrayMapSeriesAsync=async function(r,e,t,n){const o=r.length;for(;++n<o;){const o=e(r[n],n);t[n]=isPromise(o)?await o:o}return t},arrayMapSeries=function(r,e){const t=r.length,n=Array(t);let o=-1;for(;++o<t;){const t=e(r[o],o);if(isPromise(t))return t.then(funcConcat(curry3(objectSet,n,o,__),curry4(arrayMapSeriesAsync,r,e,__,o)));n[o]=t}return n},stringMapSeries=function(r,e){const t=arrayMapSeries(r,e);return isPromise(t)?t.then(curry3(callPropUnary,__,"join","")):t.join("")},thunkify4=(r,e,t,n,o)=>function(){return r(e,t,n,o)},_objectMapSeriesAsync=async function(r,e,t,n){for(const o in r){if(o in n)continue;let s=e(r[o]);isPromise(s)&&(s=await s),t[o]=s}return t},objectMapSeries=function(r,e){const t={},n={};for(const o in r){n[o]=!0;const s=e(r[o],o,r);if(isPromise(s))return s.then(funcConcat(curry3(objectSet,t,o,__),thunkify4(_objectMapSeriesAsync,r,e,t,n)));t[o]=s}return t},thunkify3=(r,e,t,n)=>function(){return r(e,t,n)},setAdd=function(r,e){return r.add(e),r},_setMapSeriesAsync=async function(r,e,t){let n=r.next();for(;!n.done;){let o=e(n.value);isPromise(o)&&(o=await o),t.add(o),n=r.next()}return t},setMapSeries=function(r,e){const t=new Set,n=r[symbolIterator]();let o=n.next();for(;!o.done;){const r=e(o.value);if(isPromise(r))return r.then(funcConcat(curry2(setAdd,t,__),thunkify3(_setMapSeriesAsync,n,e,t)));t.add(r),o=n.next()}return t},mapSet=function(r,e,t){return r.set(e,t)},_mapMapSeriesAsync=async function(r,e,t){let n=r.next();for(;!n.done;){let o=e(n.value[1]);isPromise(o)&&(o=await o),t.set(n.value[0],o),n=r.next()}return t},mapMapSeries=function(r,e){const t=new Map,n=r[symbolIterator]();let o=n.next();for(;!o.done;){const r=o.value[0],s=e(o.value[1]);if(isPromise(s))return s.then(funcConcat(curry3(mapSet,t,r,__),thunkify3(_mapMapSeriesAsync,n,e,t)));t.set(r,s),o=n.next()}return t},tapSync=r=>function(...e){return r(...e),e[0]},promiseRace=Promise.race.bind(Promise),arrayMapPoolAsync=async function(r,e,t,n,o,s){const i=r.length;for(;++o<i;){s.size>=t&&await promiseRace(s);const i=e(r[o]);if(isPromise(i)){const r=i.then(tapSync(()=>s.delete(r)));s.add(r),n[o]=r}else n[o]=i}return promiseAll(n)},arrayMapPool=function(r,e,t){const n=r.length,o=Array(n);let s=-1;for(;++s<n;){const n=t(r[s]);if(isPromise(n)){const i=new Set,c=n.then(tapSync(()=>i.delete(c)));return i.add(c),o[s]=c,arrayMapPoolAsync(r,t,e,o,s,i)}o[s]=n}return o},stringMapPool=function(r,e,t){const n=arrayMapPool(r,e,t);return isPromise(n)?n.then(curry3(callPropUnary,__,"join","")):n.join("")},_setMapPoolAsync=async function(r,e,t,n,o,s){let i=e.next();for(;!i.done;){s.size>=t&&await promiseRace(s);const c=n(i.value,i.value,r);if(isPromise(c)){const r=c.then(e=>{s.delete(r),o.add(e)});s.add(r)}else o.add(c);i=e.next()}return s.size>0&&await promiseAll(s),o},setMapPool=function(r,e,t){const n=new Set,o=r[symbolIterator]();let s=o.next();for(;!s.done;){const i=t(s.value,s.value,r);if(isPromise(i)){const s=new Set,c=i.then(r=>{s.delete(c),n.add(r)});return s.add(c),_setMapPoolAsync(r,o,e,t,n,s)}n.add(i),s=o.next()}return n},_mapMapPoolAsync=async function(r,e,t,n,o,s){let i=e.next();for(;!i.done;){s.size>=t&&await promiseRace(s);const c=i.value[0],a=n(i.value[1],c,r);if(isPromise(a)){o.set(c,a);const r=a.then(e=>{s.delete(r),o.set(c,e)});s.add(r)}else o.set(c,a);i=e.next()}return s.size>0&&await promiseAll(s),o},mapMapPool=function(r,e,t){const n=new Map,o=r[symbolIterator]();let s=o.next();for(;!s.done;){const i=s.value[0],c=t(s.value[1],i,r);if(isPromise(c)){const s=new Set;n.set(i,c);const a=c.then(r=>{s.delete(a),n.set(i,r)});return s.add(a),_mapMapPoolAsync(r,o,e,t,n,s)}n.set(i,c),s=o.next()}return n},_objectMapPoolAsync=async function(r,e,t,n,o,s){for(const i in r){if(i in o)continue;s.size>=e&&await promiseRace(s);const c=t(r[i],i,r);if(isPromise(c)){n[i]=c;const r=c.then(e=>{s.delete(r),n[i]=e});s.add(r)}else n[i]=c}return s.size>0&&await promiseAll(s),n},objectMapPool=function(r,e,t){const n={},o={};for(const s in r){o[s]=!0;const i=t(r[s],s,r);if(isPromise(i)){const c=new Set;n[s]=i;const a=i.then(r=>{c.delete(a),n[s]=r});return c.add(a),_objectMapPoolAsync(r,e,t,n,o,c)}n[s]=i}return n},areAnyValuesPromises=function(r){if(isArray(r)){const e=r.length;let t=-1;for(;++t<e;){const e=r[t];if(isPromise(e))return!0}return!1}for(const e in r){const t=r[e];if(isPromise(t))return!0}return!1},funcApply2=(r,e,t)=>r.apply(e,t),_curryArity=(r,e,t,n)=>function(...o){const s=n.length,i=o.length,c=[];let a=-1,u=-1,l=0;for(;++a<s;){const s=n[a];if(s==__&&(u+=1)<i){const r=o[u];r==__&&(l+=1),c.push(r)}else c.push(s);if(c.length==r)return areAnyValuesPromises(c)?0==l?promiseAll(c).then(curry3(funcApply2,e,t,__)):promiseAll(c).then(curry4(curryArity,r,e,t,__)):0==l?e.apply(t,c):curryArity(r,e,t,c)}for(;++u<i;){const n=o[u];if(n==__&&(l+=1),c.push(n),c.length==r)return areAnyValuesPromises(c)?0==l?promiseAll(c).then(curry3(funcApply2,e,t,__)):promiseAll(c).then(curry4(curryArity,r,e,t,__)):0==l?e.apply(t,c):curryArity(r,e,t,c)}return areAnyValuesPromises(c)?promiseAll(c).then(curry4(curryArity,r,e,t,__)):curryArity(r,e,t,c)},curryArity=function(r,e,t,n){const o=n.length;if(o<r)return _curryArity(r,e,t,n);let s=-1;for(;++s<o;){if(n[s]==__)return _curryArity(r,e,t,n)}return e.apply(t,n)},spread2=r=>function([e,t]){return r(e,t)},objectMapEntries=function(r,e){const t={},n=[];for(const o in r){const s=e([o,r[o]]);isPromise(s)?n.push(s.then(spread2(curryArity(3,objectSet,this,[t])))):t[s[0]]=s[1]}return 0==n.length?t:promiseAll(n).then(always(t))},mapMapEntriesForEachCallback=(r,e,t)=>function(n,o){const s=r([o,n]);isPromise(s)?t.push(s.then(spread2(curryArity(3,mapSet,this,[e])))):e.set(s[0],s[1])},mapMapEntries=function(r,e){const t=new Map,n=[];return r.forEach(mapMapEntriesForEachCallback(e,t,n)),0==n.length?t:promiseAll(n).then(always(t))},_map=function(r,e){return isArray(r)?arrayMap(r,e):null==r?r:"function"==typeof r.then?r.then(e):"function"==typeof r.map?r.map(e):"string"==typeof r||r.constructor==String?stringMap(r,e):r.constructor==Set?setMap(r,e):r.constructor==Map?mapMap(r,e):"function"==typeof r[symbolIterator]?MappingIterator(r[symbolIterator](),e):"function"==typeof r[symbolAsyncIterator]?MappingAsyncIterator(r[symbolAsyncIterator](),e):r.constructor==Object?objectMap(r,e):e(r)},map=function(r,e){return null==e?curry2(_map,__,r):isPromise(r)?r.then(curry2(_map,__,e)):_map(r,e)},_mapEntries=(r,e)=>{if(null==r)throw new TypeError("value is not an Object or Map");if(r.constructor==Object)return objectMapEntries(r,e);if(r.constructor==Map)return mapMapEntries(r,e);throw new TypeError("value is not an Object or Map")};map.entries=function(r,e){return null==e?curry2(_mapEntries,__,r):isPromise(r)?r.then(curry2(_mapEntries,__,e)):_mapEntries(r,e)};const _mapSeries=function(r,e){if(isArray(r))return arrayMapSeries(r,e);if(null==r)throw new TypeError(`invalid collection ${r}`);if("string"==typeof r||r.constructor==String)return stringMapSeries(r,e);if(r.constructor==Set)return setMapSeries(r,e);if(r.constructor==Map)return mapMapSeries(r,e);if(r.constructor==Object)return objectMapSeries(r,e);throw new TypeError(`invalid collection ${r}`)};map.series=function(r,e){return null==e?curry2(_mapSeries,__,r):isPromise(r)?r.then(curry2(_mapSeries,__,e)):_mapSeries(r,e)};const _mapPool=function(r,e,t){if(isArray(r))return arrayMapPool(r,e,t);if(null==r)throw new TypeError(`invalid functor ${r}`);if("string"==typeof r||r.constructor==String)return stringMapPool(r,e,t);if(r.constructor==Set)return setMapPool(r,e,t);if(r.constructor==Map)return mapMapPool(r,e,t);if(r.constructor==Object)return objectMapPool(r,e,t);throw new TypeError(`invalid functor ${r}`)};map.pool=function(r,e,t){return null==t?curry3(_mapPool,__,r,e):isPromise(r)?r.then(curry3(_mapPool,__,e,t)):_mapPool(r,e,t)};const memoizeCappedUnary=function(r,e){const t=new Map,n=function(n){if(t.has(n))return t.get(n);const o=r(n);return t.set(n,o),t.size>e&&t.clear(),o};return n.cache=t,n},pathDelimiters=/[.|[|\]]+/,parsePropertyPath=function(r){const e=r.length-1,t="["==r[0],n="]"==r[e];return t&&n?r.slice(1,e).split(pathDelimiters):t?r.slice(1).split(pathDelimiters):n?r.slice(0,e).split(pathDelimiters):r.split(pathDelimiters)},memoizedCappedParsePropertyPath=memoizeCappedUnary(parsePropertyPath,500),propertyPathToArray=r=>isArray(r)?r:"string"==typeof r?memoizedCappedParsePropertyPath(r):[r],getByPath=function(r,e){const t=propertyPathToArray(e),n=t.length;let o=-1,s=r;for(;++o<n;)if(s=s[t[o]],null==s)return;return s},_get=function(r,e,t){const n=null==r?void 0:getByPath(r,e);return void 0===n?"function"==typeof t?t(r):t:n},get=function(r,e,t){return"string"==typeof r||"number"==typeof r||isArray(r)?curry3(_get,__,r,e):isPromise(r)?r.then(curry3(_get,__,e,t)):_get(r,e,t)},pluck=function(...r){const e=r.pop(),t=get(e);return 0==r.length?map(t):map(r[0],t)};export default pluck;
package/dist/x/pluck.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -634,6 +634,30 @@ const objectMapPool = function (o, concurrency, f) {
634
634
  return result
635
635
  }
636
636
 
637
+ const areAnyValuesPromises = function (values) {
638
+ if (isArray(values)) {
639
+ const length = values.length
640
+ let index = -1
641
+ while (++index < length) {
642
+ const value = values[index]
643
+ if (isPromise(value)) {
644
+ return true
645
+ }
646
+ }
647
+ return false
648
+ }
649
+
650
+ for (const key in values) {
651
+ const value = values[key]
652
+ if (isPromise(value)) {
653
+ return true
654
+ }
655
+ }
656
+ return false
657
+ }
658
+
659
+ const funcApply2 = (func, context, args) => func.apply(context, args)
660
+
637
661
  const _curryArity = (arity, func, context, args) => function curried(...curriedArgs) {
638
662
  const argsLength = args.length,
639
663
  curriedArgsLength = curriedArgs.length,
@@ -653,7 +677,13 @@ const _curryArity = (arity, func, context, args) => function curried(...curriedA
653
677
  } else {
654
678
  nextArgs.push(arg)
655
679
  }
680
+
656
681
  if (nextArgs.length == arity) {
682
+ if (areAnyValuesPromises(nextArgs)) {
683
+ return numCurriedPlaceholders == 0
684
+ ? promiseAll(nextArgs).then(curry3(funcApply2, func, context, __))
685
+ : promiseAll(nextArgs).then(curry4(curryArity, arity, func, context, __))
686
+ }
657
687
  return numCurriedPlaceholders == 0
658
688
  ? func.apply(context, nextArgs)
659
689
  : curryArity(arity, func, context, nextArgs)
@@ -666,13 +696,22 @@ const _curryArity = (arity, func, context, args) => function curried(...curriedA
666
696
  numCurriedPlaceholders += 1
667
697
  }
668
698
  nextArgs.push(curriedArg)
699
+
669
700
  if (nextArgs.length == arity) {
701
+ if (areAnyValuesPromises(nextArgs)) {
702
+ return numCurriedPlaceholders == 0
703
+ ? promiseAll(nextArgs).then(curry3(funcApply2, func, context, __))
704
+ : promiseAll(nextArgs).then(curry4(curryArity, arity, func, context, __))
705
+ }
670
706
  return numCurriedPlaceholders == 0
671
707
  ? func.apply(context, nextArgs)
672
708
  : curryArity(arity, func, context, nextArgs)
673
709
  }
674
710
  }
675
- return curryArity(arity, func, context, nextArgs)
711
+
712
+ return areAnyValuesPromises(nextArgs)
713
+ ? promiseAll(nextArgs).then(curry4(curryArity, arity, func, context, __))
714
+ : curryArity(arity, func, context, nextArgs)
676
715
  }
677
716
 
678
717
  const curryArity = function (arity, func, context, args) {
@@ -1,8 +1,8 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
6
6
  */
7
7
 
8
- !function(n,t){"object"==typeof module?module.exports=t:"function"==typeof define?define(()=>t):n.pluck=t}("object"==typeof globalThis?globalThis:this,function(){"use strict";const n=n=>null!=n&&"function"==typeof n.then,t=(t,e)=>function(...r){const o=t(...r);return n(o)?o.then(e):e(o)},e=Symbol.iterator,r=(n,t)=>({toString:()=>"[object MappingIterator]",[e](){return this},next(){const e=n.next();return e.done?e:{value:t(e.value),done:!1}}}),o=n=>({value:n,done:!1}),u=Symbol.asyncIterator,c=(t,e)=>({[u](){return this},async next(){const r=await t.next();if(r.done)return r;const u=e(r.value);return n(u)?u.then(o):{value:u,done:!1}}}),i=Symbol.for("placeholder"),s=function(n,t,e){return t==i?((n,t)=>function(e){return n(e,t)})(n,e):((n,t)=>function(e){return n(t,e)})(n,t)},f=function(n,t,e,r){return t==i?((n,t,e)=>function(r){return n(r,t,e)})(n,e,r):e==i?((n,t,e)=>function(r){return n(t,r,e)})(n,t,r):((n,t,e)=>function(r){return n(t,e,r)})(n,t,e)},l=Array.isArray,a=Promise.all.bind(Promise),h=function(t,e){const r=t.length,o=Array(r);let u=-1,c=!1;for(;++u<r;){const r=e(t[u],u,t);n(r)&&(c=!0),o[u]=r}return c?a(o):o},d=(n,t,e)=>n[t](e),p=n=>function(){return n},y=function(n,t,e,r,o){return t==i?((n,t,e,r)=>function(o){return n(o,t,e,r)})(n,e,r,o):e==i?((n,t,e,r)=>function(o){return n(t,o,e,r)})(n,t,r,o):r==i?((n,t,e,r)=>function(o){return n(t,e,o,r)})(n,t,e,o):((n,t,e,r)=>function(o){return n(t,e,r,o)})(n,t,e,r)},w=(n,t,e,r)=>n[t](e,r),g=t=>new Promise((t=>function(e){const r={};let o=0;for(const u in t){const c=t[u];n(c)?(o+=1,c.then((n=>function(t){r[n]=t,o-=1,0==o&&e(r)})(u))):r[u]=c}0==o&&e(r)})(t)),v=function(n,t,e){return n[t]=e,n},x=async function(t,e,r,o){const u=t.length;for(;++o<u;){const u=e(t[o],o);r[o]=n(u)?await u:u}return r},b=function(e,r){const o=e.length,u=Array(o);let c=-1;for(;++c<o;){const o=r(e[c],c);if(n(o))return o.then(t(f(v,u,c,i),y(x,e,r,i,c)));u[c]=o}return u},S=(n,t,e,r,o)=>function(){return n(t,e,r,o)},j=async function(t,e,r,o){for(const u in t){if(u in o)continue;let c=e(t[u]);n(c)&&(c=await c),r[u]=c}return r},m=(n,t,e,r)=>function(){return n(t,e,r)},M=function(n,t){return n.add(t),n},z=async function(t,e,r){let o=t.next();for(;!o.done;){let u=e(o.value);n(u)&&(u=await u),r.add(u),o=t.next()}return r},T=function(n,t,e){return n.set(t,e)},E=async function(t,e,r){let o=t.next();for(;!o.done;){let u=e(o.value[1]);n(u)&&(u=await u),r.set(o.value[0],u),o=t.next()}return r},O=n=>function(...t){return n(...t),t[0]},A=Promise.race.bind(Promise),P=async function(t,e,r,o,u,c){const i=t.length;for(;++u<i;){c.size>=r&&await A(c);const i=e(t[u]);if(n(i)){const n=i.then(O(()=>c.delete(n)));c.add(n),o[u]=n}else o[u]=i}return a(o)},$=function(t,e,r){const o=t.length,u=Array(o);let c=-1;for(;++c<o;){const o=r(t[c]);if(n(o)){const n=new Set,i=o.then(O(()=>n.delete(i)));return n.add(i),u[c]=i,P(t,r,e,u,c,n)}u[c]=o}return u},I=async function(t,e,r,o,u,c){let i=e.next();for(;!i.done;){c.size>=r&&await A(c);const s=o(i.value,i.value,t);if(n(s)){const n=s.then(t=>{c.delete(n),u.add(t)});c.add(n)}else u.add(s);i=e.next()}return c.size>0&&await a(c),u},k=async function(t,e,r,o,u,c){let i=e.next();for(;!i.done;){c.size>=r&&await A(c);const s=i.value[0],f=o(i.value[1],s,t);if(n(f)){u.set(s,f);const n=f.then(t=>{c.delete(n),u.set(s,t)});c.add(n)}else u.set(s,f);i=e.next()}return c.size>0&&await a(c),u},q=async function(t,e,r,o,u,c){for(const i in t){if(i in u)continue;c.size>=e&&await A(c);const s=r(t[i],i,t);if(n(s)){o[i]=s;const n=s.then(t=>{c.delete(n),o[i]=t});c.add(n)}else o[i]=s}return c.size>0&&await a(c),o},B=(n,t,e,r)=>function(...o){const u=r.length,c=o.length,s=[];let f=-1,l=-1,a=0;for(;++f<u;){const u=r[f];if(u==i&&(l+=1)<c){const n=o[l];n==i&&(a+=1),s.push(n)}else s.push(u);if(s.length==n)return 0==a?t.apply(e,s):C(n,t,e,s)}for(;++l<c;){const r=o[l];if(r==i&&(a+=1),s.push(r),s.length==n)return 0==a?t.apply(e,s):C(n,t,e,s)}return C(n,t,e,s)},C=function(n,t,e,r){const o=r.length;if(o<n)return B(n,t,e,r);let u=-1;for(;++u<o;){if(r[u]==i)return B(n,t,e,r)}return t.apply(e,r)},D=n=>function([t,e]){return n(t,e)},F=(t,e,r)=>function(o,u){const c=t([u,o]);n(c)?r.push(c.then(D(C(3,T,this,[e])))):e.set(c[0],c[1])},G=function(t,o){return l(t)?h(t,o):null==t?t:"function"==typeof t.then?t.then(o):"function"==typeof t.map?t.map(o):"string"==typeof t||t.constructor==String?function(t,e){const r=h(t,e);return n(r)?r.then(f(d,i,"join","")):r.join("")}(t,o):t.constructor==Set?function(t,e){const r=new Set,o=[];for(const u of t){const c=e(u,u,t);n(c)?o.push(c.then(f(d,r,"add",i))):r.add(c)}return 0==o.length?r:a(o).then(p(r))}(t,o):t.constructor==Map?function(t,e){const r=new Map,o=[];for(const[u,c]of t){const s=e(c,u,t);n(s)?o.push(s.then(y(w,r,"set",u,i))):r.set(u,s)}return 0==o.length?r:a(o).then(p(r))}(t,o):"function"==typeof t[e]?r(t[e](),o):"function"==typeof t[u]?c(t[u](),o):t.constructor==Object?function(t,e){const r={};let o=!1;for(const u in t){const c=e(t[u],u,t);n(c)&&(o=!0),r[u]=c}return o?g(r):r}(t,o):o(t)},H=function(t,e){return null==e?s(G,i,t):n(t)?t.then(s(G,i,e)):G(t,e)},J=(t,e)=>{if(null==t)throw new TypeError("value is not an Object or Map");if(t.constructor==Object)return function(t,e){const r={},o=[];for(const u in t){const c=e([u,t[u]]);n(c)?o.push(c.then(D(C(3,v,this,[r])))):r[c[0]]=c[1]}return 0==o.length?r:a(o).then(p(r))}(t,e);if(t.constructor==Map)return function(n,t){const e=new Map,r=[];return n.forEach(F(t,e,r)),0==r.length?e:a(r).then(p(e))}(t,e);throw new TypeError("value is not an Object or Map")};H.entries=function(t,e){return null==e?s(J,i,t):n(t)?t.then(s(J,i,e)):J(t,e)};const K=function(r,o){if(l(r))return b(r,o);if(null==r)throw new TypeError(`invalid collection ${r}`);if("string"==typeof r||r.constructor==String)return function(t,e){const r=b(t,e);return n(r)?r.then(f(d,i,"join","")):r.join("")}(r,o);if(r.constructor==Set)return function(r,o){const u=new Set,c=r[e]();let f=c.next();for(;!f.done;){const e=o(f.value);if(n(e))return e.then(t(s(M,u,i),m(z,c,o,u)));u.add(e),f=c.next()}return u}(r,o);if(r.constructor==Map)return function(r,o){const u=new Map,c=r[e]();let s=c.next();for(;!s.done;){const e=s.value[0],r=o(s.value[1]);if(n(r))return r.then(t(f(T,u,e,i),m(E,c,o,u)));u.set(e,r),s=c.next()}return u}(r,o);if(r.constructor==Object)return function(e,r){const o={},u={};for(const c in e){u[c]=!0;const s=r(e[c],c,e);if(n(s))return s.then(t(f(v,o,c,i),S(j,e,r,o,u)));o[c]=s}return o}(r,o);throw new TypeError(`invalid collection ${r}`)};H.series=function(t,e){return null==e?s(K,i,t):n(t)?t.then(s(K,i,e)):K(t,e)};const L=function(t,r,o){if(l(t))return $(t,r,o);if(null==t)throw new TypeError(`invalid functor ${t}`);if("string"==typeof t||t.constructor==String)return function(t,e,r){const o=$(t,e,r);return n(o)?o.then(f(d,i,"join","")):o.join("")}(t,r,o);if(t.constructor==Set)return function(t,r,o){const u=new Set,c=t[e]();let i=c.next();for(;!i.done;){const e=o(i.value,i.value,t);if(n(e)){const n=new Set,i=e.then(t=>{n.delete(i),u.add(t)});return n.add(i),I(t,c,r,o,u,n)}u.add(e),i=c.next()}return u}(t,r,o);if(t.constructor==Map)return function(t,r,o){const u=new Map,c=t[e]();let i=c.next();for(;!i.done;){const e=i.value[0],s=o(i.value[1],e,t);if(n(s)){const n=new Set;u.set(e,s);const i=s.then(t=>{n.delete(i),u.set(e,t)});return n.add(i),k(t,c,r,o,u,n)}u.set(e,s),i=c.next()}return u}(t,r,o);if(t.constructor==Object)return function(t,e,r){const o={},u={};for(const c in t){u[c]=!0;const i=r(t[c],c,t);if(n(i)){const n=new Set;o[c]=i;const s=i.then(t=>{n.delete(s),o[c]=t});return n.add(s),q(t,e,r,o,u,n)}o[c]=i}return o}(t,r,o);throw new TypeError(`invalid functor ${t}`)};H.pool=function(t,e,r){return null==r?f(L,i,t,e):n(t)?t.then(f(L,i,e,r)):L(t,e,r)};const N=/[.|[|\]]+/,Q=function(n,t){const e=new Map,r=function(r){if(e.has(r))return e.get(r);const o=n(r);return e.set(r,o),e.size>t&&e.clear(),o};return r.cache=e,r}(function(n){const t=n.length-1,e="["==n[0],r="]"==n[t];return e&&r?n.slice(1,t).split(N):e?n.slice(1).split(N):r?n.slice(0,t).split(N):n.split(N)},500),R=function(n,t){const e=(n=>l(n)?n:"string"==typeof n?Q(n):[n])(t),r=e.length;let o=-1,u=n;for(;++o<r;)if(u=u[e[o]],null==u)return;return u},U=function(n,t,e){const r=null==n?void 0:R(n,t);return void 0===r?"function"==typeof e?e(n):e:r};return function(...t){const e=t.pop(),r="string"==typeof(o=e)||"number"==typeof o||l(o)?f(U,i,o,u):n(o)?o.then(f(U,i,u,c)):U(o,u,c);var o,u,c;return 0==t.length?H(r):H(t[0],r)}}());
8
+ !function(n,t){"object"==typeof module?module.exports=t:"function"==typeof define?define(()=>t):n.pluck=t}("object"==typeof globalThis?globalThis:this,function(){"use strict";const n=n=>null!=n&&"function"==typeof n.then,t=(t,e)=>function(...r){const o=t(...r);return n(o)?o.then(e):e(o)},e=Symbol.iterator,r=(n,t)=>({toString:()=>"[object MappingIterator]",[e](){return this},next(){const e=n.next();return e.done?e:{value:t(e.value),done:!1}}}),o=n=>({value:n,done:!1}),u=Symbol.asyncIterator,c=(t,e)=>({[u](){return this},async next(){const r=await t.next();if(r.done)return r;const u=e(r.value);return n(u)?u.then(o):{value:u,done:!1}}}),i=Symbol.for("placeholder"),s=function(n,t,e){return t==i?((n,t)=>function(e){return n(e,t)})(n,e):((n,t)=>function(e){return n(t,e)})(n,t)},f=function(n,t,e,r){return t==i?((n,t,e)=>function(r){return n(r,t,e)})(n,e,r):e==i?((n,t,e)=>function(r){return n(t,r,e)})(n,t,r):((n,t,e)=>function(r){return n(t,e,r)})(n,t,e)},l=Array.isArray,a=Promise.all.bind(Promise),h=function(t,e){const r=t.length,o=Array(r);let u=-1,c=!1;for(;++u<r;){const r=e(t[u],u,t);n(r)&&(c=!0),o[u]=r}return c?a(o):o},d=(n,t,e)=>n[t](e),p=n=>function(){return n},y=function(n,t,e,r,o){return t==i?((n,t,e,r)=>function(o){return n(o,t,e,r)})(n,e,r,o):e==i?((n,t,e,r)=>function(o){return n(t,o,e,r)})(n,t,r,o):r==i?((n,t,e,r)=>function(o){return n(t,e,o,r)})(n,t,e,o):((n,t,e,r)=>function(o){return n(t,e,r,o)})(n,t,e,r)},w=(n,t,e,r)=>n[t](e,r),g=t=>new Promise((t=>function(e){const r={};let o=0;for(const u in t){const c=t[u];n(c)?(o+=1,c.then((n=>function(t){r[n]=t,o-=1,0==o&&e(r)})(u))):r[u]=c}0==o&&e(r)})(t)),v=function(n,t,e){return n[t]=e,n},x=async function(t,e,r,o){const u=t.length;for(;++o<u;){const u=e(t[o],o);r[o]=n(u)?await u:u}return r},b=function(e,r){const o=e.length,u=Array(o);let c=-1;for(;++c<o;){const o=r(e[c],c);if(n(o))return o.then(t(f(v,u,c,i),y(x,e,r,i,c)));u[c]=o}return u},S=(n,t,e,r,o)=>function(){return n(t,e,r,o)},j=async function(t,e,r,o){for(const u in t){if(u in o)continue;let c=e(t[u]);n(c)&&(c=await c),r[u]=c}return r},m=(n,t,e,r)=>function(){return n(t,e,r)},M=function(n,t){return n.add(t),n},z=async function(t,e,r){let o=t.next();for(;!o.done;){let u=e(o.value);n(u)&&(u=await u),r.add(u),o=t.next()}return r},T=function(n,t,e){return n.set(t,e)},E=async function(t,e,r){let o=t.next();for(;!o.done;){let u=e(o.value[1]);n(u)&&(u=await u),r.set(o.value[0],u),o=t.next()}return r},O=n=>function(...t){return n(...t),t[0]},A=Promise.race.bind(Promise),P=async function(t,e,r,o,u,c){const i=t.length;for(;++u<i;){c.size>=r&&await A(c);const i=e(t[u]);if(n(i)){const n=i.then(O(()=>c.delete(n)));c.add(n),o[u]=n}else o[u]=i}return a(o)},$=function(t,e,r){const o=t.length,u=Array(o);let c=-1;for(;++c<o;){const o=r(t[c]);if(n(o)){const n=new Set,i=o.then(O(()=>n.delete(i)));return n.add(i),u[c]=i,P(t,r,e,u,c,n)}u[c]=o}return u},I=async function(t,e,r,o,u,c){let i=e.next();for(;!i.done;){c.size>=r&&await A(c);const s=o(i.value,i.value,t);if(n(s)){const n=s.then(t=>{c.delete(n),u.add(t)});c.add(n)}else u.add(s);i=e.next()}return c.size>0&&await a(c),u},k=async function(t,e,r,o,u,c){let i=e.next();for(;!i.done;){c.size>=r&&await A(c);const s=i.value[0],f=o(i.value[1],s,t);if(n(f)){u.set(s,f);const n=f.then(t=>{c.delete(n),u.set(s,t)});c.add(n)}else u.set(s,f);i=e.next()}return c.size>0&&await a(c),u},q=async function(t,e,r,o,u,c){for(const i in t){if(i in u)continue;c.size>=e&&await A(c);const s=r(t[i],i,t);if(n(s)){o[i]=s;const n=s.then(t=>{c.delete(n),o[i]=t});c.add(n)}else o[i]=s}return c.size>0&&await a(c),o},B=function(t){if(l(t)){const e=t.length;let r=-1;for(;++r<e;){const e=t[r];if(n(e))return!0}return!1}for(const e in t){const r=t[e];if(n(r))return!0}return!1},C=(n,t,e)=>n.apply(t,e),D=(n,t,e,r)=>function(...o){const u=r.length,c=o.length,s=[];let l=-1,h=-1,d=0;for(;++l<u;){const u=r[l];if(u==i&&(h+=1)<c){const n=o[h];n==i&&(d+=1),s.push(n)}else s.push(u);if(s.length==n)return B(s)?0==d?a(s).then(f(C,t,e,i)):a(s).then(y(F,n,t,e,i)):0==d?t.apply(e,s):F(n,t,e,s)}for(;++h<c;){const r=o[h];if(r==i&&(d+=1),s.push(r),s.length==n)return B(s)?0==d?a(s).then(f(C,t,e,i)):a(s).then(y(F,n,t,e,i)):0==d?t.apply(e,s):F(n,t,e,s)}return B(s)?a(s).then(y(F,n,t,e,i)):F(n,t,e,s)},F=function(n,t,e,r){const o=r.length;if(o<n)return D(n,t,e,r);let u=-1;for(;++u<o;){if(r[u]==i)return D(n,t,e,r)}return t.apply(e,r)},G=n=>function([t,e]){return n(t,e)},H=(t,e,r)=>function(o,u){const c=t([u,o]);n(c)?r.push(c.then(G(F(3,T,this,[e])))):e.set(c[0],c[1])},J=function(t,o){return l(t)?h(t,o):null==t?t:"function"==typeof t.then?t.then(o):"function"==typeof t.map?t.map(o):"string"==typeof t||t.constructor==String?function(t,e){const r=h(t,e);return n(r)?r.then(f(d,i,"join","")):r.join("")}(t,o):t.constructor==Set?function(t,e){const r=new Set,o=[];for(const u of t){const c=e(u,u,t);n(c)?o.push(c.then(f(d,r,"add",i))):r.add(c)}return 0==o.length?r:a(o).then(p(r))}(t,o):t.constructor==Map?function(t,e){const r=new Map,o=[];for(const[u,c]of t){const s=e(c,u,t);n(s)?o.push(s.then(y(w,r,"set",u,i))):r.set(u,s)}return 0==o.length?r:a(o).then(p(r))}(t,o):"function"==typeof t[e]?r(t[e](),o):"function"==typeof t[u]?c(t[u](),o):t.constructor==Object?function(t,e){const r={};let o=!1;for(const u in t){const c=e(t[u],u,t);n(c)&&(o=!0),r[u]=c}return o?g(r):r}(t,o):o(t)},K=function(t,e){return null==e?s(J,i,t):n(t)?t.then(s(J,i,e)):J(t,e)},L=(t,e)=>{if(null==t)throw new TypeError("value is not an Object or Map");if(t.constructor==Object)return function(t,e){const r={},o=[];for(const u in t){const c=e([u,t[u]]);n(c)?o.push(c.then(G(F(3,v,this,[r])))):r[c[0]]=c[1]}return 0==o.length?r:a(o).then(p(r))}(t,e);if(t.constructor==Map)return function(n,t){const e=new Map,r=[];return n.forEach(H(t,e,r)),0==r.length?e:a(r).then(p(e))}(t,e);throw new TypeError("value is not an Object or Map")};K.entries=function(t,e){return null==e?s(L,i,t):n(t)?t.then(s(L,i,e)):L(t,e)};const N=function(r,o){if(l(r))return b(r,o);if(null==r)throw new TypeError(`invalid collection ${r}`);if("string"==typeof r||r.constructor==String)return function(t,e){const r=b(t,e);return n(r)?r.then(f(d,i,"join","")):r.join("")}(r,o);if(r.constructor==Set)return function(r,o){const u=new Set,c=r[e]();let f=c.next();for(;!f.done;){const e=o(f.value);if(n(e))return e.then(t(s(M,u,i),m(z,c,o,u)));u.add(e),f=c.next()}return u}(r,o);if(r.constructor==Map)return function(r,o){const u=new Map,c=r[e]();let s=c.next();for(;!s.done;){const e=s.value[0],r=o(s.value[1]);if(n(r))return r.then(t(f(T,u,e,i),m(E,c,o,u)));u.set(e,r),s=c.next()}return u}(r,o);if(r.constructor==Object)return function(e,r){const o={},u={};for(const c in e){u[c]=!0;const s=r(e[c],c,e);if(n(s))return s.then(t(f(v,o,c,i),S(j,e,r,o,u)));o[c]=s}return o}(r,o);throw new TypeError(`invalid collection ${r}`)};K.series=function(t,e){return null==e?s(N,i,t):n(t)?t.then(s(N,i,e)):N(t,e)};const Q=function(t,r,o){if(l(t))return $(t,r,o);if(null==t)throw new TypeError(`invalid functor ${t}`);if("string"==typeof t||t.constructor==String)return function(t,e,r){const o=$(t,e,r);return n(o)?o.then(f(d,i,"join","")):o.join("")}(t,r,o);if(t.constructor==Set)return function(t,r,o){const u=new Set,c=t[e]();let i=c.next();for(;!i.done;){const e=o(i.value,i.value,t);if(n(e)){const n=new Set,i=e.then(t=>{n.delete(i),u.add(t)});return n.add(i),I(t,c,r,o,u,n)}u.add(e),i=c.next()}return u}(t,r,o);if(t.constructor==Map)return function(t,r,o){const u=new Map,c=t[e]();let i=c.next();for(;!i.done;){const e=i.value[0],s=o(i.value[1],e,t);if(n(s)){const n=new Set;u.set(e,s);const i=s.then(t=>{n.delete(i),u.set(e,t)});return n.add(i),k(t,c,r,o,u,n)}u.set(e,s),i=c.next()}return u}(t,r,o);if(t.constructor==Object)return function(t,e,r){const o={},u={};for(const c in t){u[c]=!0;const i=r(t[c],c,t);if(n(i)){const n=new Set;o[c]=i;const s=i.then(t=>{n.delete(s),o[c]=t});return n.add(s),q(t,e,r,o,u,n)}o[c]=i}return o}(t,r,o);throw new TypeError(`invalid functor ${t}`)};K.pool=function(t,e,r){return null==r?f(Q,i,t,e):n(t)?t.then(f(Q,i,e,r)):Q(t,e,r)};const R=/[.|[|\]]+/,U=function(n,t){const e=new Map,r=function(r){if(e.has(r))return e.get(r);const o=n(r);return e.set(r,o),e.size>t&&e.clear(),o};return r.cache=e,r}(function(n){const t=n.length-1,e="["==n[0],r="]"==n[t];return e&&r?n.slice(1,t).split(R):e?n.slice(1).split(R):r?n.slice(0,t).split(R):n.split(R)},500),V=function(n,t){const e=(n=>l(n)?n:"string"==typeof n?U(n):[n])(t),r=e.length;let o=-1,u=n;for(;++o<r;)if(u=u[e[o]],null==u)return;return u},W=function(n,t,e){const r=null==n?void 0:V(n,t);return void 0===r?"function"==typeof e?e(n):e:r};return function(...t){const e=t.pop(),r="string"==typeof(o=e)||"number"==typeof o||l(o)?f(W,i,o,u):n(o)?o.then(f(W,i,u,c)):W(o,u,c);var o,u,c;return 0==t.length?K(r):K(t[0],r)}}());
package/dist/x/pluck.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -628,6 +628,30 @@ const objectMapPool = function (o, concurrency, f) {
628
628
  return result
629
629
  }
630
630
 
631
+ const areAnyValuesPromises = function (values) {
632
+ if (isArray(values)) {
633
+ const length = values.length
634
+ let index = -1
635
+ while (++index < length) {
636
+ const value = values[index]
637
+ if (isPromise(value)) {
638
+ return true
639
+ }
640
+ }
641
+ return false
642
+ }
643
+
644
+ for (const key in values) {
645
+ const value = values[key]
646
+ if (isPromise(value)) {
647
+ return true
648
+ }
649
+ }
650
+ return false
651
+ }
652
+
653
+ const funcApply2 = (func, context, args) => func.apply(context, args)
654
+
631
655
  const _curryArity = (arity, func, context, args) => function curried(...curriedArgs) {
632
656
  const argsLength = args.length,
633
657
  curriedArgsLength = curriedArgs.length,
@@ -647,7 +671,13 @@ const _curryArity = (arity, func, context, args) => function curried(...curriedA
647
671
  } else {
648
672
  nextArgs.push(arg)
649
673
  }
674
+
650
675
  if (nextArgs.length == arity) {
676
+ if (areAnyValuesPromises(nextArgs)) {
677
+ return numCurriedPlaceholders == 0
678
+ ? promiseAll(nextArgs).then(curry3(funcApply2, func, context, __))
679
+ : promiseAll(nextArgs).then(curry4(curryArity, arity, func, context, __))
680
+ }
651
681
  return numCurriedPlaceholders == 0
652
682
  ? func.apply(context, nextArgs)
653
683
  : curryArity(arity, func, context, nextArgs)
@@ -660,13 +690,22 @@ const _curryArity = (arity, func, context, args) => function curried(...curriedA
660
690
  numCurriedPlaceholders += 1
661
691
  }
662
692
  nextArgs.push(curriedArg)
693
+
663
694
  if (nextArgs.length == arity) {
695
+ if (areAnyValuesPromises(nextArgs)) {
696
+ return numCurriedPlaceholders == 0
697
+ ? promiseAll(nextArgs).then(curry3(funcApply2, func, context, __))
698
+ : promiseAll(nextArgs).then(curry4(curryArity, arity, func, context, __))
699
+ }
664
700
  return numCurriedPlaceholders == 0
665
701
  ? func.apply(context, nextArgs)
666
702
  : curryArity(arity, func, context, nextArgs)
667
703
  }
668
704
  }
669
- return curryArity(arity, func, context, nextArgs)
705
+
706
+ return areAnyValuesPromises(nextArgs)
707
+ ? promiseAll(nextArgs).then(curry4(curryArity, arity, func, context, __))
708
+ : curryArity(arity, func, context, nextArgs)
670
709
  }
671
710
 
672
711
  const curryArity = function (arity, func, context, args) {
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/prepend.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/size.es.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/size.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
package/dist/x/size.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * rubico v2.8.0
2
+ * rubico v2.8.1
3
3
  * https://github.com/a-synchronous/rubico
4
4
  * (c) 2019-2026 Richard Tong
5
5
  * rubico may be freely distributed under the MIT license.