language-operator 0.1.81 → 0.1.82

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 (427) hide show
  1. checksums.yaml +4 -4
  2. data/.claude/agents/README.md +16 -0
  3. data/.claude/agents/changelog-writer.md +181 -0
  4. data/.claude/hooks/README.md +43 -0
  5. data/.claude/hooks/node_modules/.bin/esbuild +1 -0
  6. data/.claude/hooks/node_modules/.bin/tsc +1 -0
  7. data/.claude/hooks/node_modules/.bin/tsserver +1 -0
  8. data/.claude/hooks/node_modules/.bin/tsx +1 -0
  9. data/.claude/hooks/node_modules/.package-lock.json +136 -0
  10. data/.claude/hooks/node_modules/@esbuild/linux-x64/README.md +3 -0
  11. data/.claude/hooks/node_modules/@esbuild/linux-x64/bin/esbuild +0 -0
  12. data/.claude/hooks/node_modules/@esbuild/linux-x64/package.json +20 -0
  13. data/.claude/hooks/node_modules/@types/node/LICENSE +21 -0
  14. data/.claude/hooks/node_modules/@types/node/README.md +15 -0
  15. data/.claude/hooks/node_modules/@types/node/assert/strict.d.ts +105 -0
  16. data/.claude/hooks/node_modules/@types/node/assert.d.ts +955 -0
  17. data/.claude/hooks/node_modules/@types/node/async_hooks.d.ts +623 -0
  18. data/.claude/hooks/node_modules/@types/node/buffer.buffer.d.ts +466 -0
  19. data/.claude/hooks/node_modules/@types/node/buffer.d.ts +1810 -0
  20. data/.claude/hooks/node_modules/@types/node/child_process.d.ts +1428 -0
  21. data/.claude/hooks/node_modules/@types/node/cluster.d.ts +486 -0
  22. data/.claude/hooks/node_modules/@types/node/compatibility/iterators.d.ts +21 -0
  23. data/.claude/hooks/node_modules/@types/node/console.d.ts +151 -0
  24. data/.claude/hooks/node_modules/@types/node/constants.d.ts +20 -0
  25. data/.claude/hooks/node_modules/@types/node/crypto.d.ts +4065 -0
  26. data/.claude/hooks/node_modules/@types/node/dgram.d.ts +564 -0
  27. data/.claude/hooks/node_modules/@types/node/diagnostics_channel.d.ts +576 -0
  28. data/.claude/hooks/node_modules/@types/node/dns/promises.d.ts +503 -0
  29. data/.claude/hooks/node_modules/@types/node/dns.d.ts +922 -0
  30. data/.claude/hooks/node_modules/@types/node/domain.d.ts +166 -0
  31. data/.claude/hooks/node_modules/@types/node/events.d.ts +1054 -0
  32. data/.claude/hooks/node_modules/@types/node/fs/promises.d.ts +1316 -0
  33. data/.claude/hooks/node_modules/@types/node/fs.d.ts +4676 -0
  34. data/.claude/hooks/node_modules/@types/node/globals.d.ts +150 -0
  35. data/.claude/hooks/node_modules/@types/node/globals.typedarray.d.ts +101 -0
  36. data/.claude/hooks/node_modules/@types/node/http.d.ts +2143 -0
  37. data/.claude/hooks/node_modules/@types/node/http2.d.ts +2480 -0
  38. data/.claude/hooks/node_modules/@types/node/https.d.ts +399 -0
  39. data/.claude/hooks/node_modules/@types/node/index.d.ts +115 -0
  40. data/.claude/hooks/node_modules/@types/node/inspector/promises.d.ts +41 -0
  41. data/.claude/hooks/node_modules/@types/node/inspector.d.ts +224 -0
  42. data/.claude/hooks/node_modules/@types/node/inspector.generated.d.ts +4226 -0
  43. data/.claude/hooks/node_modules/@types/node/module.d.ts +819 -0
  44. data/.claude/hooks/node_modules/@types/node/net.d.ts +933 -0
  45. data/.claude/hooks/node_modules/@types/node/os.d.ts +507 -0
  46. data/.claude/hooks/node_modules/@types/node/package.json +155 -0
  47. data/.claude/hooks/node_modules/@types/node/path/posix.d.ts +8 -0
  48. data/.claude/hooks/node_modules/@types/node/path/win32.d.ts +8 -0
  49. data/.claude/hooks/node_modules/@types/node/path.d.ts +187 -0
  50. data/.claude/hooks/node_modules/@types/node/perf_hooks.d.ts +621 -0
  51. data/.claude/hooks/node_modules/@types/node/process.d.ts +2097 -0
  52. data/.claude/hooks/node_modules/@types/node/punycode.d.ts +117 -0
  53. data/.claude/hooks/node_modules/@types/node/querystring.d.ts +152 -0
  54. data/.claude/hooks/node_modules/@types/node/quic.d.ts +910 -0
  55. data/.claude/hooks/node_modules/@types/node/readline/promises.d.ts +161 -0
  56. data/.claude/hooks/node_modules/@types/node/readline.d.ts +541 -0
  57. data/.claude/hooks/node_modules/@types/node/repl.d.ts +415 -0
  58. data/.claude/hooks/node_modules/@types/node/sea.d.ts +162 -0
  59. data/.claude/hooks/node_modules/@types/node/sqlite.d.ts +937 -0
  60. data/.claude/hooks/node_modules/@types/node/stream/consumers.d.ts +38 -0
  61. data/.claude/hooks/node_modules/@types/node/stream/promises.d.ts +211 -0
  62. data/.claude/hooks/node_modules/@types/node/stream/web.d.ts +296 -0
  63. data/.claude/hooks/node_modules/@types/node/stream.d.ts +1760 -0
  64. data/.claude/hooks/node_modules/@types/node/string_decoder.d.ts +67 -0
  65. data/.claude/hooks/node_modules/@types/node/test/reporters.d.ts +96 -0
  66. data/.claude/hooks/node_modules/@types/node/test.d.ts +2239 -0
  67. data/.claude/hooks/node_modules/@types/node/timers/promises.d.ts +108 -0
  68. data/.claude/hooks/node_modules/@types/node/timers.d.ts +159 -0
  69. data/.claude/hooks/node_modules/@types/node/tls.d.ts +1194 -0
  70. data/.claude/hooks/node_modules/@types/node/trace_events.d.ts +197 -0
  71. data/.claude/hooks/node_modules/@types/node/ts5.6/buffer.buffer.d.ts +462 -0
  72. data/.claude/hooks/node_modules/@types/node/ts5.6/compatibility/float16array.d.ts +71 -0
  73. data/.claude/hooks/node_modules/@types/node/ts5.6/globals.typedarray.d.ts +36 -0
  74. data/.claude/hooks/node_modules/@types/node/ts5.6/index.d.ts +117 -0
  75. data/.claude/hooks/node_modules/@types/node/ts5.7/compatibility/float16array.d.ts +72 -0
  76. data/.claude/hooks/node_modules/@types/node/ts5.7/index.d.ts +117 -0
  77. data/.claude/hooks/node_modules/@types/node/tty.d.ts +250 -0
  78. data/.claude/hooks/node_modules/@types/node/url.d.ts +519 -0
  79. data/.claude/hooks/node_modules/@types/node/util/types.d.ts +558 -0
  80. data/.claude/hooks/node_modules/@types/node/util.d.ts +1653 -0
  81. data/.claude/hooks/node_modules/@types/node/v8.d.ts +979 -0
  82. data/.claude/hooks/node_modules/@types/node/vm.d.ts +1180 -0
  83. data/.claude/hooks/node_modules/@types/node/wasi.d.ts +202 -0
  84. data/.claude/hooks/node_modules/@types/node/web-globals/abortcontroller.d.ts +59 -0
  85. data/.claude/hooks/node_modules/@types/node/web-globals/blob.d.ts +23 -0
  86. data/.claude/hooks/node_modules/@types/node/web-globals/console.d.ts +9 -0
  87. data/.claude/hooks/node_modules/@types/node/web-globals/crypto.d.ts +39 -0
  88. data/.claude/hooks/node_modules/@types/node/web-globals/domexception.d.ts +68 -0
  89. data/.claude/hooks/node_modules/@types/node/web-globals/encoding.d.ts +11 -0
  90. data/.claude/hooks/node_modules/@types/node/web-globals/events.d.ts +106 -0
  91. data/.claude/hooks/node_modules/@types/node/web-globals/fetch.d.ts +54 -0
  92. data/.claude/hooks/node_modules/@types/node/web-globals/importmeta.d.ts +13 -0
  93. data/.claude/hooks/node_modules/@types/node/web-globals/messaging.d.ts +23 -0
  94. data/.claude/hooks/node_modules/@types/node/web-globals/navigator.d.ts +25 -0
  95. data/.claude/hooks/node_modules/@types/node/web-globals/performance.d.ts +45 -0
  96. data/.claude/hooks/node_modules/@types/node/web-globals/storage.d.ts +24 -0
  97. data/.claude/hooks/node_modules/@types/node/web-globals/streams.d.ts +115 -0
  98. data/.claude/hooks/node_modules/@types/node/web-globals/timers.d.ts +44 -0
  99. data/.claude/hooks/node_modules/@types/node/web-globals/url.d.ts +24 -0
  100. data/.claude/hooks/node_modules/@types/node/worker_threads.d.ts +714 -0
  101. data/.claude/hooks/node_modules/@types/node/zlib.d.ts +618 -0
  102. data/.claude/hooks/node_modules/esbuild/LICENSE.md +21 -0
  103. data/.claude/hooks/node_modules/esbuild/README.md +3 -0
  104. data/.claude/hooks/node_modules/esbuild/bin/esbuild +0 -0
  105. data/.claude/hooks/node_modules/esbuild/install.js +289 -0
  106. data/.claude/hooks/node_modules/esbuild/lib/main.d.ts +716 -0
  107. data/.claude/hooks/node_modules/esbuild/lib/main.js +2242 -0
  108. data/.claude/hooks/node_modules/esbuild/package.json +49 -0
  109. data/.claude/hooks/node_modules/get-tsconfig/LICENSE +21 -0
  110. data/.claude/hooks/node_modules/get-tsconfig/README.md +235 -0
  111. data/.claude/hooks/node_modules/get-tsconfig/dist/index.cjs +7 -0
  112. data/.claude/hooks/node_modules/get-tsconfig/dist/index.d.cts +2088 -0
  113. data/.claude/hooks/node_modules/get-tsconfig/dist/index.d.mts +2088 -0
  114. data/.claude/hooks/node_modules/get-tsconfig/dist/index.mjs +7 -0
  115. data/.claude/hooks/node_modules/get-tsconfig/package.json +46 -0
  116. data/.claude/hooks/node_modules/resolve-pkg-maps/LICENSE +21 -0
  117. data/.claude/hooks/node_modules/resolve-pkg-maps/README.md +216 -0
  118. data/.claude/hooks/node_modules/resolve-pkg-maps/dist/index.cjs +1 -0
  119. data/.claude/hooks/node_modules/resolve-pkg-maps/dist/index.d.cts +11 -0
  120. data/.claude/hooks/node_modules/resolve-pkg-maps/dist/index.d.mts +11 -0
  121. data/.claude/hooks/node_modules/resolve-pkg-maps/dist/index.mjs +1 -0
  122. data/.claude/hooks/node_modules/resolve-pkg-maps/package.json +42 -0
  123. data/.claude/hooks/node_modules/tsx/LICENSE +21 -0
  124. data/.claude/hooks/node_modules/tsx/README.md +32 -0
  125. data/.claude/hooks/node_modules/tsx/dist/cjs/api/index.cjs +1 -0
  126. data/.claude/hooks/node_modules/tsx/dist/cjs/api/index.d.cts +35 -0
  127. data/.claude/hooks/node_modules/tsx/dist/cjs/api/index.d.mts +35 -0
  128. data/.claude/hooks/node_modules/tsx/dist/cjs/api/index.mjs +1 -0
  129. data/.claude/hooks/node_modules/tsx/dist/cjs/index.cjs +1 -0
  130. data/.claude/hooks/node_modules/tsx/dist/cjs/index.mjs +1 -0
  131. data/.claude/hooks/node_modules/tsx/dist/cli.cjs +54 -0
  132. data/.claude/hooks/node_modules/tsx/dist/cli.mjs +55 -0
  133. data/.claude/hooks/node_modules/tsx/dist/client-BQVF1NaW.mjs +1 -0
  134. data/.claude/hooks/node_modules/tsx/dist/client-D6NvIMSC.cjs +1 -0
  135. data/.claude/hooks/node_modules/tsx/dist/esm/api/index.cjs +1 -0
  136. data/.claude/hooks/node_modules/tsx/dist/esm/api/index.d.cts +35 -0
  137. data/.claude/hooks/node_modules/tsx/dist/esm/api/index.d.mts +35 -0
  138. data/.claude/hooks/node_modules/tsx/dist/esm/api/index.mjs +1 -0
  139. data/.claude/hooks/node_modules/tsx/dist/esm/index.cjs +2 -0
  140. data/.claude/hooks/node_modules/tsx/dist/esm/index.mjs +2 -0
  141. data/.claude/hooks/node_modules/tsx/dist/get-pipe-path-BHW2eJdv.mjs +1 -0
  142. data/.claude/hooks/node_modules/tsx/dist/get-pipe-path-BoR10qr8.cjs +1 -0
  143. data/.claude/hooks/node_modules/tsx/dist/index-7AaEi15b.mjs +14 -0
  144. data/.claude/hooks/node_modules/tsx/dist/index-BWFBUo6r.cjs +1 -0
  145. data/.claude/hooks/node_modules/tsx/dist/index-gbaejti9.mjs +1 -0
  146. data/.claude/hooks/node_modules/tsx/dist/index-gckBtVBf.cjs +14 -0
  147. data/.claude/hooks/node_modules/tsx/dist/lexer-DQCqS3nf.mjs +3 -0
  148. data/.claude/hooks/node_modules/tsx/dist/lexer-DgIbo0BU.cjs +3 -0
  149. data/.claude/hooks/node_modules/tsx/dist/loader.cjs +1 -0
  150. data/.claude/hooks/node_modules/tsx/dist/loader.mjs +1 -0
  151. data/.claude/hooks/node_modules/tsx/dist/node-features-_8ZFwP_x.mjs +1 -0
  152. data/.claude/hooks/node_modules/tsx/dist/node-features-roYmp9jK.cjs +1 -0
  153. data/.claude/hooks/node_modules/tsx/dist/package-CeBgXWuR.mjs +1 -0
  154. data/.claude/hooks/node_modules/tsx/dist/package-Dxt5kIHw.cjs +1 -0
  155. data/.claude/hooks/node_modules/tsx/dist/patch-repl.cjs +1 -0
  156. data/.claude/hooks/node_modules/tsx/dist/patch-repl.mjs +1 -0
  157. data/.claude/hooks/node_modules/tsx/dist/preflight.cjs +1 -0
  158. data/.claude/hooks/node_modules/tsx/dist/preflight.mjs +1 -0
  159. data/.claude/hooks/node_modules/tsx/dist/register-2sWVXuRQ.cjs +1 -0
  160. data/.claude/hooks/node_modules/tsx/dist/register-B7jrtLTO.mjs +1 -0
  161. data/.claude/hooks/node_modules/tsx/dist/register-CFH5oNdT.mjs +4 -0
  162. data/.claude/hooks/node_modules/tsx/dist/register-D46fvsV_.cjs +4 -0
  163. data/.claude/hooks/node_modules/tsx/dist/repl.cjs +3 -0
  164. data/.claude/hooks/node_modules/tsx/dist/repl.mjs +3 -0
  165. data/.claude/hooks/node_modules/tsx/dist/require-D4F1Lv60.cjs +1 -0
  166. data/.claude/hooks/node_modules/tsx/dist/require-DQxpCAr4.mjs +1 -0
  167. data/.claude/hooks/node_modules/tsx/dist/suppress-warnings.cjs +1 -0
  168. data/.claude/hooks/node_modules/tsx/dist/suppress-warnings.mjs +1 -0
  169. data/.claude/hooks/node_modules/tsx/dist/temporary-directory-B83uKxJF.cjs +1 -0
  170. data/.claude/hooks/node_modules/tsx/dist/temporary-directory-CwHp0_NW.mjs +1 -0
  171. data/.claude/hooks/node_modules/tsx/dist/types-Cxp8y2TL.d.ts +5 -0
  172. data/.claude/hooks/node_modules/tsx/package.json +68 -0
  173. data/.claude/hooks/node_modules/typescript/LICENSE.txt +55 -0
  174. data/.claude/hooks/node_modules/typescript/README.md +50 -0
  175. data/.claude/hooks/node_modules/typescript/SECURITY.md +41 -0
  176. data/.claude/hooks/node_modules/typescript/ThirdPartyNoticeText.txt +193 -0
  177. data/.claude/hooks/node_modules/typescript/bin/tsc +2 -0
  178. data/.claude/hooks/node_modules/typescript/bin/tsserver +2 -0
  179. data/.claude/hooks/node_modules/typescript/lib/_tsc.js +133818 -0
  180. data/.claude/hooks/node_modules/typescript/lib/_tsserver.js +659 -0
  181. data/.claude/hooks/node_modules/typescript/lib/_typingsInstaller.js +222 -0
  182. data/.claude/hooks/node_modules/typescript/lib/cs/diagnosticMessages.generated.json +2122 -0
  183. data/.claude/hooks/node_modules/typescript/lib/de/diagnosticMessages.generated.json +2122 -0
  184. data/.claude/hooks/node_modules/typescript/lib/es/diagnosticMessages.generated.json +2122 -0
  185. data/.claude/hooks/node_modules/typescript/lib/fr/diagnosticMessages.generated.json +2122 -0
  186. data/.claude/hooks/node_modules/typescript/lib/it/diagnosticMessages.generated.json +2122 -0
  187. data/.claude/hooks/node_modules/typescript/lib/ja/diagnosticMessages.generated.json +2122 -0
  188. data/.claude/hooks/node_modules/typescript/lib/ko/diagnosticMessages.generated.json +2122 -0
  189. data/.claude/hooks/node_modules/typescript/lib/lib.d.ts +22 -0
  190. data/.claude/hooks/node_modules/typescript/lib/lib.decorators.d.ts +384 -0
  191. data/.claude/hooks/node_modules/typescript/lib/lib.decorators.legacy.d.ts +22 -0
  192. data/.claude/hooks/node_modules/typescript/lib/lib.dom.asynciterable.d.ts +41 -0
  193. data/.claude/hooks/node_modules/typescript/lib/lib.dom.d.ts +39429 -0
  194. data/.claude/hooks/node_modules/typescript/lib/lib.dom.iterable.d.ts +571 -0
  195. data/.claude/hooks/node_modules/typescript/lib/lib.es2015.collection.d.ts +147 -0
  196. data/.claude/hooks/node_modules/typescript/lib/lib.es2015.core.d.ts +597 -0
  197. data/.claude/hooks/node_modules/typescript/lib/lib.es2015.d.ts +28 -0
  198. data/.claude/hooks/node_modules/typescript/lib/lib.es2015.generator.d.ts +77 -0
  199. data/.claude/hooks/node_modules/typescript/lib/lib.es2015.iterable.d.ts +605 -0
  200. data/.claude/hooks/node_modules/typescript/lib/lib.es2015.promise.d.ts +81 -0
  201. data/.claude/hooks/node_modules/typescript/lib/lib.es2015.proxy.d.ts +128 -0
  202. data/.claude/hooks/node_modules/typescript/lib/lib.es2015.reflect.d.ts +144 -0
  203. data/.claude/hooks/node_modules/typescript/lib/lib.es2015.symbol.d.ts +46 -0
  204. data/.claude/hooks/node_modules/typescript/lib/lib.es2015.symbol.wellknown.d.ts +326 -0
  205. data/.claude/hooks/node_modules/typescript/lib/lib.es2016.array.include.d.ts +116 -0
  206. data/.claude/hooks/node_modules/typescript/lib/lib.es2016.d.ts +21 -0
  207. data/.claude/hooks/node_modules/typescript/lib/lib.es2016.full.d.ts +23 -0
  208. data/.claude/hooks/node_modules/typescript/lib/lib.es2016.intl.d.ts +31 -0
  209. data/.claude/hooks/node_modules/typescript/lib/lib.es2017.arraybuffer.d.ts +21 -0
  210. data/.claude/hooks/node_modules/typescript/lib/lib.es2017.d.ts +26 -0
  211. data/.claude/hooks/node_modules/typescript/lib/lib.es2017.date.d.ts +31 -0
  212. data/.claude/hooks/node_modules/typescript/lib/lib.es2017.full.d.ts +23 -0
  213. data/.claude/hooks/node_modules/typescript/lib/lib.es2017.intl.d.ts +44 -0
  214. data/.claude/hooks/node_modules/typescript/lib/lib.es2017.object.d.ts +49 -0
  215. data/.claude/hooks/node_modules/typescript/lib/lib.es2017.sharedmemory.d.ts +135 -0
  216. data/.claude/hooks/node_modules/typescript/lib/lib.es2017.string.d.ts +45 -0
  217. data/.claude/hooks/node_modules/typescript/lib/lib.es2017.typedarrays.d.ts +53 -0
  218. data/.claude/hooks/node_modules/typescript/lib/lib.es2018.asyncgenerator.d.ts +77 -0
  219. data/.claude/hooks/node_modules/typescript/lib/lib.es2018.asynciterable.d.ts +53 -0
  220. data/.claude/hooks/node_modules/typescript/lib/lib.es2018.d.ts +24 -0
  221. data/.claude/hooks/node_modules/typescript/lib/lib.es2018.full.d.ts +24 -0
  222. data/.claude/hooks/node_modules/typescript/lib/lib.es2018.intl.d.ts +83 -0
  223. data/.claude/hooks/node_modules/typescript/lib/lib.es2018.promise.d.ts +30 -0
  224. data/.claude/hooks/node_modules/typescript/lib/lib.es2018.regexp.d.ts +37 -0
  225. data/.claude/hooks/node_modules/typescript/lib/lib.es2019.array.d.ts +79 -0
  226. data/.claude/hooks/node_modules/typescript/lib/lib.es2019.d.ts +24 -0
  227. data/.claude/hooks/node_modules/typescript/lib/lib.es2019.full.d.ts +24 -0
  228. data/.claude/hooks/node_modules/typescript/lib/lib.es2019.intl.d.ts +23 -0
  229. data/.claude/hooks/node_modules/typescript/lib/lib.es2019.object.d.ts +33 -0
  230. data/.claude/hooks/node_modules/typescript/lib/lib.es2019.string.d.ts +37 -0
  231. data/.claude/hooks/node_modules/typescript/lib/lib.es2019.symbol.d.ts +24 -0
  232. data/.claude/hooks/node_modules/typescript/lib/lib.es2020.bigint.d.ts +765 -0
  233. data/.claude/hooks/node_modules/typescript/lib/lib.es2020.d.ts +27 -0
  234. data/.claude/hooks/node_modules/typescript/lib/lib.es2020.date.d.ts +42 -0
  235. data/.claude/hooks/node_modules/typescript/lib/lib.es2020.full.d.ts +24 -0
  236. data/.claude/hooks/node_modules/typescript/lib/lib.es2020.intl.d.ts +474 -0
  237. data/.claude/hooks/node_modules/typescript/lib/lib.es2020.number.d.ts +28 -0
  238. data/.claude/hooks/node_modules/typescript/lib/lib.es2020.promise.d.ts +47 -0
  239. data/.claude/hooks/node_modules/typescript/lib/lib.es2020.sharedmemory.d.ts +99 -0
  240. data/.claude/hooks/node_modules/typescript/lib/lib.es2020.string.d.ts +44 -0
  241. data/.claude/hooks/node_modules/typescript/lib/lib.es2020.symbol.wellknown.d.ts +41 -0
  242. data/.claude/hooks/node_modules/typescript/lib/lib.es2021.d.ts +23 -0
  243. data/.claude/hooks/node_modules/typescript/lib/lib.es2021.full.d.ts +24 -0
  244. data/.claude/hooks/node_modules/typescript/lib/lib.es2021.intl.d.ts +166 -0
  245. data/.claude/hooks/node_modules/typescript/lib/lib.es2021.promise.d.ts +48 -0
  246. data/.claude/hooks/node_modules/typescript/lib/lib.es2021.string.d.ts +33 -0
  247. data/.claude/hooks/node_modules/typescript/lib/lib.es2021.weakref.d.ts +78 -0
  248. data/.claude/hooks/node_modules/typescript/lib/lib.es2022.array.d.ts +121 -0
  249. data/.claude/hooks/node_modules/typescript/lib/lib.es2022.d.ts +25 -0
  250. data/.claude/hooks/node_modules/typescript/lib/lib.es2022.error.d.ts +75 -0
  251. data/.claude/hooks/node_modules/typescript/lib/lib.es2022.full.d.ts +24 -0
  252. data/.claude/hooks/node_modules/typescript/lib/lib.es2022.intl.d.ts +145 -0
  253. data/.claude/hooks/node_modules/typescript/lib/lib.es2022.object.d.ts +26 -0
  254. data/.claude/hooks/node_modules/typescript/lib/lib.es2022.regexp.d.ts +39 -0
  255. data/.claude/hooks/node_modules/typescript/lib/lib.es2022.string.d.ts +25 -0
  256. data/.claude/hooks/node_modules/typescript/lib/lib.es2023.array.d.ts +924 -0
  257. data/.claude/hooks/node_modules/typescript/lib/lib.es2023.collection.d.ts +21 -0
  258. data/.claude/hooks/node_modules/typescript/lib/lib.es2023.d.ts +22 -0
  259. data/.claude/hooks/node_modules/typescript/lib/lib.es2023.full.d.ts +24 -0
  260. data/.claude/hooks/node_modules/typescript/lib/lib.es2023.intl.d.ts +56 -0
  261. data/.claude/hooks/node_modules/typescript/lib/lib.es2024.arraybuffer.d.ts +65 -0
  262. data/.claude/hooks/node_modules/typescript/lib/lib.es2024.collection.d.ts +29 -0
  263. data/.claude/hooks/node_modules/typescript/lib/lib.es2024.d.ts +26 -0
  264. data/.claude/hooks/node_modules/typescript/lib/lib.es2024.full.d.ts +24 -0
  265. data/.claude/hooks/node_modules/typescript/lib/lib.es2024.object.d.ts +29 -0
  266. data/.claude/hooks/node_modules/typescript/lib/lib.es2024.promise.d.ts +35 -0
  267. data/.claude/hooks/node_modules/typescript/lib/lib.es2024.regexp.d.ts +25 -0
  268. data/.claude/hooks/node_modules/typescript/lib/lib.es2024.sharedmemory.d.ts +68 -0
  269. data/.claude/hooks/node_modules/typescript/lib/lib.es2024.string.d.ts +29 -0
  270. data/.claude/hooks/node_modules/typescript/lib/lib.es5.d.ts +4601 -0
  271. data/.claude/hooks/node_modules/typescript/lib/lib.es6.d.ts +23 -0
  272. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.array.d.ts +35 -0
  273. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.collection.d.ts +96 -0
  274. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.d.ts +29 -0
  275. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.decorators.d.ts +28 -0
  276. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.disposable.d.ts +193 -0
  277. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.error.d.ts +24 -0
  278. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.float16.d.ts +445 -0
  279. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.full.d.ts +24 -0
  280. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.intl.d.ts +21 -0
  281. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.iterator.d.ts +148 -0
  282. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.promise.d.ts +34 -0
  283. data/.claude/hooks/node_modules/typescript/lib/lib.esnext.sharedmemory.d.ts +25 -0
  284. data/.claude/hooks/node_modules/typescript/lib/lib.scripthost.d.ts +322 -0
  285. data/.claude/hooks/node_modules/typescript/lib/lib.webworker.asynciterable.d.ts +41 -0
  286. data/.claude/hooks/node_modules/typescript/lib/lib.webworker.d.ts +13150 -0
  287. data/.claude/hooks/node_modules/typescript/lib/lib.webworker.importscripts.d.ts +23 -0
  288. data/.claude/hooks/node_modules/typescript/lib/lib.webworker.iterable.d.ts +340 -0
  289. data/.claude/hooks/node_modules/typescript/lib/pl/diagnosticMessages.generated.json +2122 -0
  290. data/.claude/hooks/node_modules/typescript/lib/pt-br/diagnosticMessages.generated.json +2122 -0
  291. data/.claude/hooks/node_modules/typescript/lib/ru/diagnosticMessages.generated.json +2122 -0
  292. data/.claude/hooks/node_modules/typescript/lib/tr/diagnosticMessages.generated.json +2122 -0
  293. data/.claude/hooks/node_modules/typescript/lib/tsc.js +8 -0
  294. data/.claude/hooks/node_modules/typescript/lib/tsserver.js +8 -0
  295. data/.claude/hooks/node_modules/typescript/lib/tsserverlibrary.d.ts +17 -0
  296. data/.claude/hooks/node_modules/typescript/lib/tsserverlibrary.js +21 -0
  297. data/.claude/hooks/node_modules/typescript/lib/typesMap.json +497 -0
  298. data/.claude/hooks/node_modules/typescript/lib/typescript.d.ts +11437 -0
  299. data/.claude/hooks/node_modules/typescript/lib/typescript.js +200276 -0
  300. data/.claude/hooks/node_modules/typescript/lib/typingsInstaller.js +8 -0
  301. data/.claude/hooks/node_modules/typescript/lib/watchGuard.js +53 -0
  302. data/.claude/hooks/node_modules/typescript/lib/zh-cn/diagnosticMessages.generated.json +2122 -0
  303. data/.claude/hooks/node_modules/typescript/lib/zh-tw/diagnosticMessages.generated.json +2122 -0
  304. data/.claude/hooks/node_modules/typescript/package.json +120 -0
  305. data/.claude/hooks/node_modules/undici-types/LICENSE +21 -0
  306. data/.claude/hooks/node_modules/undici-types/README.md +6 -0
  307. data/.claude/hooks/node_modules/undici-types/agent.d.ts +32 -0
  308. data/.claude/hooks/node_modules/undici-types/api.d.ts +43 -0
  309. data/.claude/hooks/node_modules/undici-types/balanced-pool.d.ts +29 -0
  310. data/.claude/hooks/node_modules/undici-types/cache-interceptor.d.ts +172 -0
  311. data/.claude/hooks/node_modules/undici-types/cache.d.ts +36 -0
  312. data/.claude/hooks/node_modules/undici-types/client-stats.d.ts +15 -0
  313. data/.claude/hooks/node_modules/undici-types/client.d.ts +108 -0
  314. data/.claude/hooks/node_modules/undici-types/connector.d.ts +34 -0
  315. data/.claude/hooks/node_modules/undici-types/content-type.d.ts +21 -0
  316. data/.claude/hooks/node_modules/undici-types/cookies.d.ts +30 -0
  317. data/.claude/hooks/node_modules/undici-types/diagnostics-channel.d.ts +74 -0
  318. data/.claude/hooks/node_modules/undici-types/dispatcher.d.ts +276 -0
  319. data/.claude/hooks/node_modules/undici-types/env-http-proxy-agent.d.ts +22 -0
  320. data/.claude/hooks/node_modules/undici-types/errors.d.ts +161 -0
  321. data/.claude/hooks/node_modules/undici-types/eventsource.d.ts +66 -0
  322. data/.claude/hooks/node_modules/undici-types/fetch.d.ts +211 -0
  323. data/.claude/hooks/node_modules/undici-types/formdata.d.ts +108 -0
  324. data/.claude/hooks/node_modules/undici-types/global-dispatcher.d.ts +9 -0
  325. data/.claude/hooks/node_modules/undici-types/global-origin.d.ts +7 -0
  326. data/.claude/hooks/node_modules/undici-types/h2c-client.d.ts +73 -0
  327. data/.claude/hooks/node_modules/undici-types/handlers.d.ts +15 -0
  328. data/.claude/hooks/node_modules/undici-types/header.d.ts +160 -0
  329. data/.claude/hooks/node_modules/undici-types/index.d.ts +80 -0
  330. data/.claude/hooks/node_modules/undici-types/interceptors.d.ts +39 -0
  331. data/.claude/hooks/node_modules/undici-types/mock-agent.d.ts +68 -0
  332. data/.claude/hooks/node_modules/undici-types/mock-call-history.d.ts +111 -0
  333. data/.claude/hooks/node_modules/undici-types/mock-client.d.ts +27 -0
  334. data/.claude/hooks/node_modules/undici-types/mock-errors.d.ts +12 -0
  335. data/.claude/hooks/node_modules/undici-types/mock-interceptor.d.ts +94 -0
  336. data/.claude/hooks/node_modules/undici-types/mock-pool.d.ts +27 -0
  337. data/.claude/hooks/node_modules/undici-types/package.json +55 -0
  338. data/.claude/hooks/node_modules/undici-types/patch.d.ts +29 -0
  339. data/.claude/hooks/node_modules/undici-types/pool-stats.d.ts +19 -0
  340. data/.claude/hooks/node_modules/undici-types/pool.d.ts +41 -0
  341. data/.claude/hooks/node_modules/undici-types/proxy-agent.d.ts +29 -0
  342. data/.claude/hooks/node_modules/undici-types/readable.d.ts +68 -0
  343. data/.claude/hooks/node_modules/undici-types/retry-agent.d.ts +8 -0
  344. data/.claude/hooks/node_modules/undici-types/retry-handler.d.ts +125 -0
  345. data/.claude/hooks/node_modules/undici-types/snapshot-agent.d.ts +109 -0
  346. data/.claude/hooks/node_modules/undici-types/util.d.ts +18 -0
  347. data/.claude/hooks/node_modules/undici-types/utility.d.ts +7 -0
  348. data/.claude/hooks/node_modules/undici-types/webidl.d.ts +341 -0
  349. data/.claude/hooks/node_modules/undici-types/websocket.d.ts +186 -0
  350. data/.claude/hooks/package-lock.json +562 -0
  351. data/.claude/hooks/package.json +19 -0
  352. data/.claude/hooks/skill-activation-prompt.sh +11 -0
  353. data/.claude/hooks/skill-activation-prompt.ts +185 -0
  354. data/.claude/hooks/tsconfig.json +12 -0
  355. data/.claude/settings.json +33 -0
  356. data/.claude/skills/README.md +29 -0
  357. data/.claude/skills/ruby-gem-development/SKILL.md +293 -0
  358. data/.claude/skills/skill-rules.json +117 -0
  359. data/.claude/skills/thor-cli-development/SKILL.md +431 -0
  360. data/CHANGELOG.md +7 -0
  361. data/Gemfile.lock +3 -1
  362. data/completions/{_aictl → _langop} +37 -37
  363. data/completions/{aictl.bash → langop.bash} +16 -16
  364. data/completions/langop.fish +114 -0
  365. data/components/agent/Gemfile +1 -1
  366. data/components/tool/Gemfile +1 -1
  367. data/docs/README.md +10 -10
  368. data/docs/agent-internals.md +1 -1
  369. data/docs/cheat-sheet.md +76 -76
  370. data/docs/cli-reference.md +71 -71
  371. data/docs/how-agents-work.md +1 -1
  372. data/docs/installation.md +30 -30
  373. data/docs/quickstart.md +30 -30
  374. data/docs/using-tools.md +11 -11
  375. data/docs/webhooks.md +6 -6
  376. data/examples/ux_helpers_demo.rb +4 -4
  377. data/lib/language_operator/agent/task_executor.rb +0 -37
  378. data/lib/language_operator/agent/web_server.rb +311 -323
  379. data/lib/language_operator/cli/commands/agent/base.rb +16 -15
  380. data/lib/language_operator/cli/commands/agent/code_operations.rb +6 -6
  381. data/lib/language_operator/cli/commands/agent/helpers/synthesis_watcher.rb +1 -1
  382. data/lib/language_operator/cli/commands/agent/lifecycle.rb +2 -2
  383. data/lib/language_operator/cli/commands/agent/logs.rb +2 -2
  384. data/lib/language_operator/cli/commands/agent/workspace.rb +8 -8
  385. data/lib/language_operator/cli/commands/cluster.rb +172 -158
  386. data/lib/language_operator/cli/commands/install.rb +878 -81
  387. data/lib/language_operator/cli/commands/model/base.rb +7 -6
  388. data/lib/language_operator/cli/commands/organization.rb +61 -0
  389. data/lib/language_operator/cli/commands/persona.rb +10 -8
  390. data/lib/language_operator/cli/commands/status.rb +83 -13
  391. data/lib/language_operator/cli/commands/system/exec.rb +10 -10
  392. data/lib/language_operator/cli/commands/system/schema.rb +6 -6
  393. data/lib/language_operator/cli/commands/system/synthesis_template.rb +6 -6
  394. data/lib/language_operator/cli/commands/system/synthesize.rb +14 -14
  395. data/lib/language_operator/cli/commands/system/validate_template.rb +4 -4
  396. data/lib/language_operator/cli/commands/tool/base.rb +1 -1
  397. data/lib/language_operator/cli/commands/tool/install.rb +2 -2
  398. data/lib/language_operator/cli/commands/tool/search.rb +3 -3
  399. data/lib/language_operator/cli/commands/ui.rb +173 -0
  400. data/lib/language_operator/cli/commands/use.rb +80 -9
  401. data/lib/language_operator/cli/errors/suggestions.rb +21 -21
  402. data/lib/language_operator/cli/formatters/progress_formatter.rb +2 -1
  403. data/lib/language_operator/cli/formatters/table_formatter.rb +21 -1
  404. data/lib/language_operator/cli/helpers/cluster_validator.rb +2 -2
  405. data/lib/language_operator/cli/helpers/health_checker.rb +263 -0
  406. data/lib/language_operator/cli/helpers/kubeconfig_validator.rb +3 -3
  407. data/lib/language_operator/cli/helpers/ux_helper.rb +4 -3
  408. data/lib/language_operator/cli/main.rb +30 -21
  409. data/lib/language_operator/cli/wizards/model_wizard.rb +7 -5
  410. data/lib/language_operator/config/cluster_config.rb +3 -3
  411. data/lib/language_operator/constants/kubernetes_labels.rb +1 -1
  412. data/lib/language_operator/kubernetes/client.rb +53 -109
  413. data/lib/language_operator/kubernetes/resource_builder.rb +46 -14
  414. data/lib/language_operator/templates/schema/agent_dsl_openapi.yaml +1 -1
  415. data/lib/language_operator/templates/schema/agent_dsl_schema.json +1 -1
  416. data/lib/language_operator/utils/org_context.rb +100 -0
  417. data/lib/language_operator/version.rb +1 -1
  418. data/synth/001/Makefile +1 -1
  419. data/synth/002/Makefile +1 -1
  420. data/synth/003/Makefile +1 -1
  421. data/synth/004/Makefile +1 -1
  422. metadata +384 -11
  423. data/completions/aictl.fish +0 -114
  424. data/lib/language_operator/agent/event_config.rb +0 -172
  425. data/lib/language_operator/cli/commands/quickstart.rb +0 -22
  426. data/lib/language_operator/cli/wizards/quickstart_wizard.rb +0 -561
  427. /data/bin/{aictl → langop} +0 -0
@@ -0,0 +1,714 @@
1
+ /**
2
+ * The `node:worker_threads` module enables the use of threads that execute
3
+ * JavaScript in parallel. To access it:
4
+ *
5
+ * ```js
6
+ * import worker from 'node:worker_threads';
7
+ * ```
8
+ *
9
+ * Workers (threads) are useful for performing CPU-intensive JavaScript operations.
10
+ * They do not help much with I/O-intensive work. The Node.js built-in
11
+ * asynchronous I/O operations are more efficient than Workers can be.
12
+ *
13
+ * Unlike `child_process` or `cluster`, `worker_threads` can share memory. They do
14
+ * so by transferring `ArrayBuffer` instances or sharing `SharedArrayBuffer` instances.
15
+ *
16
+ * ```js
17
+ * import {
18
+ * Worker,
19
+ * isMainThread,
20
+ * parentPort,
21
+ * workerData,
22
+ * } from 'node:worker_threads';
23
+ *
24
+ * if (!isMainThread) {
25
+ * const { parse } = await import('some-js-parsing-library');
26
+ * const script = workerData;
27
+ * parentPort.postMessage(parse(script));
28
+ * }
29
+ *
30
+ * export default function parseJSAsync(script) {
31
+ * return new Promise((resolve, reject) => {
32
+ * const worker = new Worker(new URL(import.meta.url), {
33
+ * workerData: script,
34
+ * });
35
+ * worker.on('message', resolve);
36
+ * worker.on('error', reject);
37
+ * worker.on('exit', (code) => {
38
+ * if (code !== 0)
39
+ * reject(new Error(`Worker stopped with exit code ${code}`));
40
+ * });
41
+ * });
42
+ * };
43
+ * ```
44
+ *
45
+ * The above example spawns a Worker thread for each `parseJSAsync()` call. In
46
+ * practice, use a pool of Workers for these kinds of tasks. Otherwise, the
47
+ * overhead of creating Workers would likely exceed their benefit.
48
+ *
49
+ * When implementing a worker pool, use the `AsyncResource` API to inform
50
+ * diagnostic tools (e.g. to provide asynchronous stack traces) about the
51
+ * correlation between tasks and their outcomes. See `"Using AsyncResource for a Worker thread pool"` in the `async_hooks` documentation for an example implementation.
52
+ *
53
+ * Worker threads inherit non-process-specific options by default. Refer to `Worker constructor options` to know how to customize worker thread options,
54
+ * specifically `argv` and `execArgv` options.
55
+ * @see [source](https://github.com/nodejs/node/blob/v25.x/lib/worker_threads.js)
56
+ */
57
+ declare module "node:worker_threads" {
58
+ import {
59
+ EventEmitter,
60
+ InternalEventEmitter,
61
+ InternalEventTargetEventProperties,
62
+ NodeEventTarget,
63
+ } from "node:events";
64
+ import { FileHandle } from "node:fs/promises";
65
+ import { Performance } from "node:perf_hooks";
66
+ import { Readable, Writable } from "node:stream";
67
+ import { ReadableStream, TransformStream, WritableStream } from "node:stream/web";
68
+ import { URL } from "node:url";
69
+ import { CPUProfileHandle, HeapInfo, HeapProfileHandle } from "node:v8";
70
+ import { Context } from "node:vm";
71
+ import { MessageEvent } from "undici-types";
72
+ const isInternalThread: boolean;
73
+ const isMainThread: boolean;
74
+ const parentPort: null | MessagePort;
75
+ const resourceLimits: ResourceLimits;
76
+ const SHARE_ENV: unique symbol;
77
+ const threadId: number;
78
+ const threadName: string | null;
79
+ const workerData: any;
80
+ interface WorkerPerformance extends Pick<Performance, "eventLoopUtilization"> {}
81
+ /** @deprecated Use `import { Transferable } from "node:worker_threads"` instead. */
82
+ // TODO: remove in a future major @types/node version.
83
+ type TransferListItem = Transferable;
84
+ interface WorkerOptions {
85
+ /**
86
+ * List of arguments which would be stringified and appended to
87
+ * `process.argv` in the worker. This is mostly similar to the `workerData`
88
+ * but the values will be available on the global `process.argv` as if they
89
+ * were passed as CLI options to the script.
90
+ */
91
+ argv?: any[] | undefined;
92
+ env?: NodeJS.Dict<string> | typeof SHARE_ENV | undefined;
93
+ eval?: boolean | undefined;
94
+ workerData?: any;
95
+ stdin?: boolean | undefined;
96
+ stdout?: boolean | undefined;
97
+ stderr?: boolean | undefined;
98
+ execArgv?: string[] | undefined;
99
+ resourceLimits?: ResourceLimits | undefined;
100
+ /**
101
+ * Additional data to send in the first worker message.
102
+ */
103
+ transferList?: Transferable[] | undefined;
104
+ /**
105
+ * @default true
106
+ */
107
+ trackUnmanagedFds?: boolean | undefined;
108
+ /**
109
+ * An optional `name` to be appended to the worker title
110
+ * for debugging/identification purposes, making the final title as
111
+ * `[worker ${id}] ${name}`.
112
+ */
113
+ name?: string | undefined;
114
+ }
115
+ interface ResourceLimits {
116
+ /**
117
+ * The maximum size of a heap space for recently created objects.
118
+ */
119
+ maxYoungGenerationSizeMb?: number | undefined;
120
+ /**
121
+ * The maximum size of the main heap in MB.
122
+ */
123
+ maxOldGenerationSizeMb?: number | undefined;
124
+ /**
125
+ * The size of a pre-allocated memory range used for generated code.
126
+ */
127
+ codeRangeSizeMb?: number | undefined;
128
+ /**
129
+ * The default maximum stack size for the thread. Small values may lead to unusable Worker instances.
130
+ * @default 4
131
+ */
132
+ stackSizeMb?: number | undefined;
133
+ }
134
+ interface WorkerEventMap {
135
+ "error": [err: unknown];
136
+ "exit": [exitCode: number];
137
+ "message": [value: any];
138
+ "messageerror": [error: Error];
139
+ "online": [];
140
+ }
141
+ /**
142
+ * The `Worker` class represents an independent JavaScript execution thread.
143
+ * Most Node.js APIs are available inside of it.
144
+ *
145
+ * Notable differences inside a Worker environment are:
146
+ *
147
+ * * The `process.stdin`, `process.stdout`, and `process.stderr` streams may be redirected by the parent thread.
148
+ * * The `import { isMainThread } from 'node:worker_threads'` variable is set to `false`.
149
+ * * The `import { parentPort } from 'node:worker_threads'` message port is available.
150
+ * * `process.exit()` does not stop the whole program, just the single thread,
151
+ * and `process.abort()` is not available.
152
+ * * `process.chdir()` and `process` methods that set group or user ids
153
+ * are not available.
154
+ * * `process.env` is a copy of the parent thread's environment variables,
155
+ * unless otherwise specified. Changes to one copy are not visible in other
156
+ * threads, and are not visible to native add-ons (unless `worker.SHARE_ENV` is passed as the `env` option to the `Worker` constructor). On Windows, unlike the main thread, a copy of the
157
+ * environment variables operates in a case-sensitive manner.
158
+ * * `process.title` cannot be modified.
159
+ * * Signals are not delivered through `process.on('...')`.
160
+ * * Execution may stop at any point as a result of `worker.terminate()` being invoked.
161
+ * * IPC channels from parent processes are not accessible.
162
+ * * The `trace_events` module is not supported.
163
+ * * Native add-ons can only be loaded from multiple threads if they fulfill `certain conditions`.
164
+ *
165
+ * Creating `Worker` instances inside of other `Worker`s is possible.
166
+ *
167
+ * Like [Web Workers](https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API) and the `node:cluster module`, two-way communication
168
+ * can be achieved through inter-thread message passing. Internally, a `Worker` has
169
+ * a built-in pair of `MessagePort` s that are already associated with each
170
+ * other when the `Worker` is created. While the `MessagePort` object on the parent
171
+ * side is not directly exposed, its functionalities are exposed through `worker.postMessage()` and the `worker.on('message')` event
172
+ * on the `Worker` object for the parent thread.
173
+ *
174
+ * To create custom messaging channels (which is encouraged over using the default
175
+ * global channel because it facilitates separation of concerns), users can create
176
+ * a `MessageChannel` object on either thread and pass one of the`MessagePort`s on that `MessageChannel` to the other thread through a
177
+ * pre-existing channel, such as the global one.
178
+ *
179
+ * See `port.postMessage()` for more information on how messages are passed,
180
+ * and what kind of JavaScript values can be successfully transported through
181
+ * the thread barrier.
182
+ *
183
+ * ```js
184
+ * import assert from 'node:assert';
185
+ * import {
186
+ * Worker, MessageChannel, MessagePort, isMainThread, parentPort,
187
+ * } from 'node:worker_threads';
188
+ * if (isMainThread) {
189
+ * const worker = new Worker(__filename);
190
+ * const subChannel = new MessageChannel();
191
+ * worker.postMessage({ hereIsYourPort: subChannel.port1 }, [subChannel.port1]);
192
+ * subChannel.port2.on('message', (value) => {
193
+ * console.log('received:', value);
194
+ * });
195
+ * } else {
196
+ * parentPort.once('message', (value) => {
197
+ * assert(value.hereIsYourPort instanceof MessagePort);
198
+ * value.hereIsYourPort.postMessage('the worker is sending this');
199
+ * value.hereIsYourPort.close();
200
+ * });
201
+ * }
202
+ * ```
203
+ * @since v10.5.0
204
+ */
205
+ class Worker implements EventEmitter {
206
+ /**
207
+ * If `stdin: true` was passed to the `Worker` constructor, this is a
208
+ * writable stream. The data written to this stream will be made available in
209
+ * the worker thread as `process.stdin`.
210
+ * @since v10.5.0
211
+ */
212
+ readonly stdin: Writable | null;
213
+ /**
214
+ * This is a readable stream which contains data written to `process.stdout` inside the worker thread. If `stdout: true` was not passed to the `Worker` constructor, then data is piped to the
215
+ * parent thread's `process.stdout` stream.
216
+ * @since v10.5.0
217
+ */
218
+ readonly stdout: Readable;
219
+ /**
220
+ * This is a readable stream which contains data written to `process.stderr` inside the worker thread. If `stderr: true` was not passed to the `Worker` constructor, then data is piped to the
221
+ * parent thread's `process.stderr` stream.
222
+ * @since v10.5.0
223
+ */
224
+ readonly stderr: Readable;
225
+ /**
226
+ * An integer identifier for the referenced thread. Inside the worker thread,
227
+ * it is available as `import { threadId } from 'node:worker_threads'`.
228
+ * This value is unique for each `Worker` instance inside a single process.
229
+ * @since v10.5.0
230
+ */
231
+ readonly threadId: number;
232
+ /**
233
+ * A string identifier for the referenced thread or null if the thread is not running.
234
+ * Inside the worker thread, it is available as `require('node:worker_threads').threadName`.
235
+ * @since v24.6.0
236
+ */
237
+ readonly threadName: string | null;
238
+ /**
239
+ * Provides the set of JS engine resource constraints for this Worker thread.
240
+ * If the `resourceLimits` option was passed to the `Worker` constructor,
241
+ * this matches its values.
242
+ *
243
+ * If the worker has stopped, the return value is an empty object.
244
+ * @since v13.2.0, v12.16.0
245
+ */
246
+ readonly resourceLimits?: ResourceLimits | undefined;
247
+ /**
248
+ * An object that can be used to query performance information from a worker
249
+ * instance. Similar to `perf_hooks.performance`.
250
+ * @since v15.1.0, v14.17.0, v12.22.0
251
+ */
252
+ readonly performance: WorkerPerformance;
253
+ /**
254
+ * @param filename The path to the Worker’s main script or module.
255
+ * Must be either an absolute path or a relative path (i.e. relative to the current working directory) starting with ./ or ../,
256
+ * or a WHATWG URL object using file: protocol. If options.eval is true, this is a string containing JavaScript code rather than a path.
257
+ */
258
+ constructor(filename: string | URL, options?: WorkerOptions);
259
+ /**
260
+ * Send a message to the worker that is received via `require('node:worker_threads').parentPort.on('message')`.
261
+ * See `port.postMessage()` for more details.
262
+ * @since v10.5.0
263
+ */
264
+ postMessage(value: any, transferList?: readonly Transferable[]): void;
265
+ /**
266
+ * Opposite of `unref()`, calling `ref()` on a previously `unref()`ed worker does _not_ let the program exit if it's the only active handle left (the default
267
+ * behavior). If the worker is `ref()`ed, calling `ref()` again has
268
+ * no effect.
269
+ * @since v10.5.0
270
+ */
271
+ ref(): void;
272
+ /**
273
+ * Calling `unref()` on a worker allows the thread to exit if this is the only
274
+ * active handle in the event system. If the worker is already `unref()`ed calling `unref()` again has no effect.
275
+ * @since v10.5.0
276
+ */
277
+ unref(): void;
278
+ /**
279
+ * Stop all JavaScript execution in the worker thread as soon as possible.
280
+ * Returns a Promise for the exit code that is fulfilled when the `'exit' event` is emitted.
281
+ * @since v10.5.0
282
+ */
283
+ terminate(): Promise<number>;
284
+ /**
285
+ * This method returns a `Promise` that will resolve to an object identical to `process.threadCpuUsage()`,
286
+ * or reject with an `ERR_WORKER_NOT_RUNNING` error if the worker is no longer running.
287
+ * This methods allows the statistics to be observed from outside the actual thread.
288
+ * @since v24.6.0
289
+ */
290
+ cpuUsage(prev?: NodeJS.CpuUsage): Promise<NodeJS.CpuUsage>;
291
+ /**
292
+ * Returns a readable stream for a V8 snapshot of the current state of the Worker.
293
+ * See `v8.getHeapSnapshot()` for more details.
294
+ *
295
+ * If the Worker thread is no longer running, which may occur before the `'exit' event` is emitted, the returned `Promise` is rejected
296
+ * immediately with an `ERR_WORKER_NOT_RUNNING` error.
297
+ * @since v13.9.0, v12.17.0
298
+ * @return A promise for a Readable Stream containing a V8 heap snapshot
299
+ */
300
+ getHeapSnapshot(): Promise<Readable>;
301
+ /**
302
+ * This method returns a `Promise` that will resolve to an object identical to `v8.getHeapStatistics()`,
303
+ * or reject with an `ERR_WORKER_NOT_RUNNING` error if the worker is no longer running.
304
+ * This methods allows the statistics to be observed from outside the actual thread.
305
+ * @since v24.0.0
306
+ */
307
+ getHeapStatistics(): Promise<HeapInfo>;
308
+ /**
309
+ * Starting a CPU profile then return a Promise that fulfills with an error
310
+ * or an `CPUProfileHandle` object. This API supports `await using` syntax.
311
+ *
312
+ * ```js
313
+ * const { Worker } = require('node:worker_threads');
314
+ *
315
+ * const worker = new Worker(`
316
+ * const { parentPort } = require('worker_threads');
317
+ * parentPort.on('message', () => {});
318
+ * `, { eval: true });
319
+ *
320
+ * worker.on('online', async () => {
321
+ * const handle = await worker.startCpuProfile();
322
+ * const profile = await handle.stop();
323
+ * console.log(profile);
324
+ * worker.terminate();
325
+ * });
326
+ * ```
327
+ *
328
+ * `await using` example.
329
+ *
330
+ * ```js
331
+ * const { Worker } = require('node:worker_threads');
332
+ *
333
+ * const w = new Worker(`
334
+ * const { parentPort } = require('node:worker_threads');
335
+ * parentPort.on('message', () => {});
336
+ * `, { eval: true });
337
+ *
338
+ * w.on('online', async () => {
339
+ * // Stop profile automatically when return and profile will be discarded
340
+ * await using handle = await w.startCpuProfile();
341
+ * });
342
+ * ```
343
+ * @since v24.8.0
344
+ */
345
+ startCpuProfile(): Promise<CPUProfileHandle>;
346
+ /**
347
+ * Starting a Heap profile then return a Promise that fulfills with an error
348
+ * or an `HeapProfileHandle` object. This API supports `await using` syntax.
349
+ *
350
+ * ```js
351
+ * const { Worker } = require('node:worker_threads');
352
+ *
353
+ * const worker = new Worker(`
354
+ * const { parentPort } = require('worker_threads');
355
+ * parentPort.on('message', () => {});
356
+ * `, { eval: true });
357
+ *
358
+ * worker.on('online', async () => {
359
+ * const handle = await worker.startHeapProfile();
360
+ * const profile = await handle.stop();
361
+ * console.log(profile);
362
+ * worker.terminate();
363
+ * });
364
+ * ```
365
+ *
366
+ * `await using` example.
367
+ *
368
+ * ```js
369
+ * const { Worker } = require('node:worker_threads');
370
+ *
371
+ * const w = new Worker(`
372
+ * const { parentPort } = require('node:worker_threads');
373
+ * parentPort.on('message', () => {});
374
+ * `, { eval: true });
375
+ *
376
+ * w.on('online', async () => {
377
+ * // Stop profile automatically when return and profile will be discarded
378
+ * await using handle = await w.startHeapProfile();
379
+ * });
380
+ * ```
381
+ */
382
+ startHeapProfile(): Promise<HeapProfileHandle>;
383
+ /**
384
+ * Calls `worker.terminate()` when the dispose scope is exited.
385
+ *
386
+ * ```js
387
+ * async function example() {
388
+ * await using worker = new Worker('for (;;) {}', { eval: true });
389
+ * // Worker is automatically terminate when the scope is exited.
390
+ * }
391
+ * ```
392
+ * @since v24.2.0
393
+ */
394
+ [Symbol.asyncDispose](): Promise<void>;
395
+ }
396
+ interface Worker extends InternalEventEmitter<WorkerEventMap> {}
397
+ /**
398
+ * Mark an object as not transferable. If `object` occurs in the transfer list of
399
+ * a `port.postMessage()` call, it is ignored.
400
+ *
401
+ * In particular, this makes sense for objects that can be cloned, rather than
402
+ * transferred, and which are used by other objects on the sending side.
403
+ * For example, Node.js marks the `ArrayBuffer`s it uses for its `Buffer pool` with this.
404
+ *
405
+ * This operation cannot be undone.
406
+ *
407
+ * ```js
408
+ * import { MessageChannel, markAsUntransferable } from 'node:worker_threads';
409
+ *
410
+ * const pooledBuffer = new ArrayBuffer(8);
411
+ * const typedArray1 = new Uint8Array(pooledBuffer);
412
+ * const typedArray2 = new Float64Array(pooledBuffer);
413
+ *
414
+ * markAsUntransferable(pooledBuffer);
415
+ *
416
+ * const { port1 } = new MessageChannel();
417
+ * port1.postMessage(typedArray1, [ typedArray1.buffer ]);
418
+ *
419
+ * // The following line prints the contents of typedArray1 -- it still owns
420
+ * // its memory and has been cloned, not transferred. Without
421
+ * // `markAsUntransferable()`, this would print an empty Uint8Array.
422
+ * // typedArray2 is intact as well.
423
+ * console.log(typedArray1);
424
+ * console.log(typedArray2);
425
+ * ```
426
+ *
427
+ * There is no equivalent to this API in browsers.
428
+ * @since v14.5.0, v12.19.0
429
+ */
430
+ function markAsUntransferable(object: object): void;
431
+ /**
432
+ * Check if an object is marked as not transferable with
433
+ * {@link markAsUntransferable}.
434
+ * @since v21.0.0
435
+ */
436
+ function isMarkedAsUntransferable(object: object): boolean;
437
+ /**
438
+ * Mark an object as not cloneable. If `object` is used as `message` in
439
+ * a `port.postMessage()` call, an error is thrown. This is a no-op if `object` is a
440
+ * primitive value.
441
+ *
442
+ * This has no effect on `ArrayBuffer`, or any `Buffer` like objects.
443
+ *
444
+ * This operation cannot be undone.
445
+ *
446
+ * ```js
447
+ * const { markAsUncloneable } = require('node:worker_threads');
448
+ *
449
+ * const anyObject = { foo: 'bar' };
450
+ * markAsUncloneable(anyObject);
451
+ * const { port1 } = new MessageChannel();
452
+ * try {
453
+ * // This will throw an error, because anyObject is not cloneable.
454
+ * port1.postMessage(anyObject)
455
+ * } catch (error) {
456
+ * // error.name === 'DataCloneError'
457
+ * }
458
+ * ```
459
+ *
460
+ * There is no equivalent to this API in browsers.
461
+ * @since v22.10.0
462
+ */
463
+ function markAsUncloneable(object: object): void;
464
+ /**
465
+ * Transfer a `MessagePort` to a different `vm` Context. The original `port` object is rendered unusable, and the returned `MessagePort` instance
466
+ * takes its place.
467
+ *
468
+ * The returned `MessagePort` is an object in the target context and
469
+ * inherits from its global `Object` class. Objects passed to the [`port.onmessage()`](https://developer.mozilla.org/en-US/docs/Web/API/MessagePort/onmessage) listener are also created in the
470
+ * target context
471
+ * and inherit from its global `Object` class.
472
+ *
473
+ * However, the created `MessagePort` no longer inherits from [`EventTarget`](https://developer.mozilla.org/en-US/docs/Web/API/EventTarget), and only
474
+ * [`port.onmessage()`](https://developer.mozilla.org/en-US/docs/Web/API/MessagePort/onmessage) can be used to receive
475
+ * events using it.
476
+ * @since v11.13.0
477
+ * @param port The message port to transfer.
478
+ * @param contextifiedSandbox A `contextified` object as returned by the `vm.createContext()` method.
479
+ */
480
+ function moveMessagePortToContext(port: MessagePort, contextifiedSandbox: Context): MessagePort;
481
+ /**
482
+ * Receive a single message from a given `MessagePort`. If no message is available,`undefined` is returned, otherwise an object with a single `message` property
483
+ * that contains the message payload, corresponding to the oldest message in the `MessagePort`'s queue.
484
+ *
485
+ * ```js
486
+ * import { MessageChannel, receiveMessageOnPort } from 'node:worker_threads';
487
+ * const { port1, port2 } = new MessageChannel();
488
+ * port1.postMessage({ hello: 'world' });
489
+ *
490
+ * console.log(receiveMessageOnPort(port2));
491
+ * // Prints: { message: { hello: 'world' } }
492
+ * console.log(receiveMessageOnPort(port2));
493
+ * // Prints: undefined
494
+ * ```
495
+ *
496
+ * When this function is used, no `'message'` event is emitted and the `onmessage` listener is not invoked.
497
+ * @since v12.3.0
498
+ */
499
+ function receiveMessageOnPort(port: MessagePort):
500
+ | {
501
+ message: any;
502
+ }
503
+ | undefined;
504
+ type Serializable = string | object | number | boolean | bigint;
505
+ /**
506
+ * Within a worker thread, `worker.getEnvironmentData()` returns a clone
507
+ * of data passed to the spawning thread's `worker.setEnvironmentData()`.
508
+ * Every new `Worker` receives its own copy of the environment data
509
+ * automatically.
510
+ *
511
+ * ```js
512
+ * import {
513
+ * Worker,
514
+ * isMainThread,
515
+ * setEnvironmentData,
516
+ * getEnvironmentData,
517
+ * } from 'node:worker_threads';
518
+ *
519
+ * if (isMainThread) {
520
+ * setEnvironmentData('Hello', 'World!');
521
+ * const worker = new Worker(__filename);
522
+ * } else {
523
+ * console.log(getEnvironmentData('Hello')); // Prints 'World!'.
524
+ * }
525
+ * ```
526
+ * @since v15.12.0, v14.18.0
527
+ * @param key Any arbitrary, cloneable JavaScript value that can be used as a {Map} key.
528
+ */
529
+ function getEnvironmentData(key: Serializable): Serializable;
530
+ /**
531
+ * The `worker.setEnvironmentData()` API sets the content of `worker.getEnvironmentData()` in the current thread and all new `Worker` instances spawned from the current context.
532
+ * @since v15.12.0, v14.18.0
533
+ * @param key Any arbitrary, cloneable JavaScript value that can be used as a {Map} key.
534
+ * @param value Any arbitrary, cloneable JavaScript value that will be cloned and passed automatically to all new `Worker` instances. If `value` is passed as `undefined`, any previously set value
535
+ * for the `key` will be deleted.
536
+ */
537
+ function setEnvironmentData(key: Serializable, value?: Serializable): void;
538
+ /**
539
+ * Sends a value to another worker, identified by its thread ID.
540
+ * @param threadId The target thread ID. If the thread ID is invalid, a `ERR_WORKER_MESSAGING_FAILED` error will be thrown.
541
+ * If the target thread ID is the current thread ID, a `ERR_WORKER_MESSAGING_SAME_THREAD` error will be thrown.
542
+ * @param value The value to send.
543
+ * @param transferList If one or more `MessagePort`-like objects are passed in value, a `transferList` is required for those items
544
+ * or `ERR_MISSING_MESSAGE_PORT_IN_TRANSFER_LIST` is thrown. See `port.postMessage()` for more information.
545
+ * @param timeout Time to wait for the message to be delivered in milliseconds. By default it's `undefined`, which means wait forever.
546
+ * If the operation times out, a `ERR_WORKER_MESSAGING_TIMEOUT` error is thrown.
547
+ * @since v22.5.0
548
+ */
549
+ function postMessageToThread(threadId: number, value: any, timeout?: number): Promise<void>;
550
+ function postMessageToThread(
551
+ threadId: number,
552
+ value: any,
553
+ transferList: readonly Transferable[],
554
+ timeout?: number,
555
+ ): Promise<void>;
556
+ // #region web types
557
+ type LockMode = "exclusive" | "shared";
558
+ type Transferable =
559
+ | ArrayBuffer
560
+ | MessagePort
561
+ | AbortSignal
562
+ | FileHandle
563
+ | ReadableStream
564
+ | WritableStream
565
+ | TransformStream;
566
+ interface LockGrantedCallback<T> {
567
+ (lock: Lock | null): T;
568
+ }
569
+ interface LockInfo {
570
+ clientId: string;
571
+ mode: LockMode;
572
+ name: string;
573
+ }
574
+ interface LockManagerSnapshot {
575
+ held: LockInfo[];
576
+ pending: LockInfo[];
577
+ }
578
+ interface LockOptions {
579
+ ifAvailable?: boolean;
580
+ mode?: LockMode;
581
+ signal?: AbortSignal;
582
+ steal?: boolean;
583
+ }
584
+ interface StructuredSerializeOptions {
585
+ transfer?: Transferable[];
586
+ }
587
+ interface BroadcastChannelEventMap {
588
+ "message": MessageEvent;
589
+ "messageerror": MessageEvent;
590
+ }
591
+ interface BroadcastChannel
592
+ extends EventTarget, InternalEventTargetEventProperties<BroadcastChannelEventMap>, NodeJS.RefCounted
593
+ {
594
+ readonly name: string;
595
+ close(): void;
596
+ postMessage(message: any): void;
597
+ addEventListener<K extends keyof BroadcastChannelEventMap>(
598
+ type: K,
599
+ listener: (ev: BroadcastChannelEventMap[K]) => void,
600
+ options?: AddEventListenerOptions | boolean,
601
+ ): void;
602
+ addEventListener(
603
+ type: string,
604
+ listener: EventListener | EventListenerObject,
605
+ options?: AddEventListenerOptions | boolean,
606
+ ): void;
607
+ removeEventListener<K extends keyof BroadcastChannelEventMap>(
608
+ type: K,
609
+ listener: (ev: BroadcastChannelEventMap[K]) => void,
610
+ options?: EventListenerOptions | boolean,
611
+ ): void;
612
+ removeEventListener(
613
+ type: string,
614
+ listener: EventListener | EventListenerObject,
615
+ options?: EventListenerOptions | boolean,
616
+ ): void;
617
+ }
618
+ var BroadcastChannel: {
619
+ prototype: BroadcastChannel;
620
+ new(name: string): BroadcastChannel;
621
+ };
622
+ interface Lock {
623
+ readonly mode: LockMode;
624
+ readonly name: string;
625
+ }
626
+ // var Lock: {
627
+ // prototype: Lock;
628
+ // new(): Lock;
629
+ // };
630
+ interface LockManager {
631
+ query(): Promise<LockManagerSnapshot>;
632
+ request<T>(name: string, callback: LockGrantedCallback<T>): Promise<Awaited<T>>;
633
+ request<T>(name: string, options: LockOptions, callback: LockGrantedCallback<T>): Promise<Awaited<T>>;
634
+ }
635
+ // var LockManager: {
636
+ // prototype: LockManager;
637
+ // new(): LockManager;
638
+ // };
639
+ interface MessageChannel {
640
+ readonly port1: MessagePort;
641
+ readonly port2: MessagePort;
642
+ }
643
+ var MessageChannel: {
644
+ prototype: MessageChannel;
645
+ new(): MessageChannel;
646
+ };
647
+ interface MessagePortEventMap {
648
+ "close": Event;
649
+ "message": MessageEvent;
650
+ "messageerror": MessageEvent;
651
+ }
652
+ interface MessagePort extends NodeEventTarget, InternalEventTargetEventProperties<MessagePortEventMap> {
653
+ close(): void;
654
+ postMessage(message: any, transfer: Transferable[]): void;
655
+ postMessage(message: any, options?: StructuredSerializeOptions): void;
656
+ start(): void;
657
+ addEventListener<K extends keyof MessagePortEventMap>(
658
+ type: K,
659
+ listener: (ev: MessagePortEventMap[K]) => void,
660
+ options?: AddEventListenerOptions | boolean,
661
+ ): void;
662
+ addEventListener(
663
+ type: string,
664
+ listener: EventListener | EventListenerObject,
665
+ options?: AddEventListenerOptions | boolean,
666
+ ): void;
667
+ removeEventListener<K extends keyof MessagePortEventMap>(
668
+ type: K,
669
+ listener: (ev: MessagePortEventMap[K]) => void,
670
+ options?: EventListenerOptions | boolean,
671
+ ): void;
672
+ removeEventListener(
673
+ type: string,
674
+ listener: EventListener | EventListenerObject,
675
+ options?: EventListenerOptions | boolean,
676
+ ): void;
677
+ // #region NodeEventTarget
678
+ addListener(event: "close", listener: (ev: Event) => void): this;
679
+ addListener(event: "message", listener: (value: any) => void): this;
680
+ addListener(event: "messageerror", listener: (error: Error) => void): this;
681
+ addListener(event: string, listener: (arg: any) => void): this;
682
+ emit(event: "close", ev: Event): boolean;
683
+ emit(event: "message", value: any): boolean;
684
+ emit(event: "messageerror", error: Error): boolean;
685
+ emit(event: string, arg: any): boolean;
686
+ off(event: "close", listener: (ev: Event) => void, options?: EventListenerOptions): this;
687
+ off(event: "message", listener: (value: any) => void, options?: EventListenerOptions): this;
688
+ off(event: "messageerror", listener: (error: Error) => void, options?: EventListenerOptions): this;
689
+ off(event: string, listener: (arg: any) => void, options?: EventListenerOptions): this;
690
+ on(event: "close", listener: (ev: Event) => void): this;
691
+ on(event: "message", listener: (value: any) => void): this;
692
+ on(event: "messageerror", listener: (error: Error) => void): this;
693
+ on(event: string, listener: (arg: any) => void): this;
694
+ once(event: "close", listener: (ev: Event) => void): this;
695
+ once(event: "message", listener: (value: any) => void): this;
696
+ once(event: "messageerror", listener: (error: Error) => void): this;
697
+ once(event: string, listener: (arg: any) => void): this;
698
+ removeListener(event: "close", listener: (ev: Event) => void, options?: EventListenerOptions): this;
699
+ removeListener(event: "message", listener: (value: any) => void, options?: EventListenerOptions): this;
700
+ removeListener(event: "messageerror", listener: (error: Error) => void, options?: EventListenerOptions): this;
701
+ removeListener(event: string, listener: (arg: any) => void, options?: EventListenerOptions): this;
702
+ // #endregion
703
+ }
704
+ var MessagePort: {
705
+ prototype: MessagePort;
706
+ new(): MessagePort;
707
+ };
708
+ var locks: LockManager;
709
+ export import structuredClone = globalThis.structuredClone;
710
+ // #endregion
711
+ }
712
+ declare module "worker_threads" {
713
+ export * from "node:worker_threads";
714
+ }