claude-flow 2.7.0-alpha.10 → 2.7.0-alpha.12

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 (543) hide show
  1. package/.claude/settings.reasoningbank-example.json +124 -0
  2. package/.claude/settings.reasoningbank-minimal.json +40 -0
  3. package/.claude/skills/agentdb-memory-patterns/SKILL.md +166 -0
  4. package/.claude/skills/agentdb-vector-search/SKILL.md +126 -0
  5. package/.claude/skills/flow-nexus-neural/SKILL.md +738 -0
  6. package/.claude/skills/flow-nexus-platform/SKILL.md +1157 -0
  7. package/.claude/skills/flow-nexus-swarm/SKILL.md +610 -0
  8. package/.claude/skills/github-code-review/SKILL.md +1140 -0
  9. package/.claude/skills/github-multi-repo/SKILL.md +874 -0
  10. package/.claude/skills/github-project-management/SKILL.md +1277 -0
  11. package/.claude/skills/github-release-management/SKILL.md +1081 -0
  12. package/.claude/skills/github-workflow-automation/SKILL.md +1065 -0
  13. package/.claude/skills/hive-mind-advanced/SKILL.md +712 -0
  14. package/.claude/skills/hooks-automation/SKILL.md +1201 -0
  15. package/.claude/skills/pair-programming/SKILL.md +1202 -0
  16. package/.claude/skills/performance-analysis/SKILL.md +563 -0
  17. package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -0
  18. package/.claude/skills/skill-builder/SKILL.md +910 -0
  19. package/.claude/skills/sparc-methodology/SKILL.md +1115 -0
  20. package/.claude/skills/stream-chain/SKILL.md +563 -0
  21. package/.claude/skills/swarm-advanced/SKILL.md +973 -0
  22. package/.claude/skills/swarm-orchestration/SKILL.md +179 -0
  23. package/.claude/skills/verification-quality/SKILL.md +649 -0
  24. package/.claude/statusline-command.sh +175 -0
  25. package/.claude/test-reasoningbank-hooks.sh +99 -0
  26. package/CHANGELOG.md +330 -0
  27. package/README.md +231 -191
  28. package/bin/claude-flow +1 -1
  29. package/docker-test/.claude-flow/metrics/performance.json +3 -3
  30. package/docker-test/.claude-flow/metrics/task-metrics.json +3 -3
  31. package/docker-test/Dockerfile.alpha11-test +26 -0
  32. package/docker-test/Dockerfile.local-test +42 -0
  33. package/docker-test/test-alpha11.sh +244 -0
  34. package/docker-test/test-local-fix.sh +235 -0
  35. package/docs/COMMANDS_TO_SKILLS_MIGRATION.md +382 -0
  36. package/docs/FINAL_INIT_STRUCTURE.md +320 -0
  37. package/docs/reasoningbank/CLAUDE-CODE-INTEGRATION.md +563 -0
  38. package/docs/reasoningbank/EXAMPLES.md +611 -0
  39. package/docs/reasoningbank/README.md +1139 -0
  40. package/docs/reasoningbank/agentic-flow-integration.md +800 -0
  41. package/docs/reasoningbank/architecture.md +680 -0
  42. package/docs/reasoningbank/google-research.md +1017 -0
  43. package/docs/reasoningbank/models/.claude-flow/metrics/agent-metrics.json +1 -0
  44. package/docs/reasoningbank/models/.claude-flow/metrics/performance.json +87 -0
  45. package/docs/reasoningbank/models/.claude-flow/metrics/task-metrics.json +10 -0
  46. package/docs/reasoningbank/models/HOW-TO-TRAIN.md +537 -0
  47. package/docs/reasoningbank/models/HOW-TO-USE.md +655 -0
  48. package/docs/reasoningbank/models/INDEX.md +276 -0
  49. package/docs/reasoningbank/models/README.md +345 -0
  50. package/docs/reasoningbank/models/_docs/COMPATIBILITY.md +448 -0
  51. package/docs/reasoningbank/models/_docs/COMPLETION-SUMMARY.md +478 -0
  52. package/docs/reasoningbank/models/_docs/README.md +80 -0
  53. package/docs/reasoningbank/models/_docs/SCHEMA-UPDATE-SUMMARY.md +376 -0
  54. package/docs/reasoningbank/models/_docs/VERIFICATION-COMPLETE.md +370 -0
  55. package/docs/reasoningbank/models/_scripts/README.md +270 -0
  56. package/docs/reasoningbank/models/_scripts/benchmark-all.cjs +407 -0
  57. package/docs/reasoningbank/models/_scripts/fix-schema-compatibility.cjs +300 -0
  58. package/docs/reasoningbank/models/_scripts/schema-validator.cjs +360 -0
  59. package/docs/reasoningbank/models/_scripts/training-coordinator.cjs +85 -0
  60. package/docs/reasoningbank/models/_scripts/validation-suite.cjs +239 -0
  61. package/docs/reasoningbank/models/benchmark-output.log +41 -0
  62. package/docs/reasoningbank/models/code-reasoning/.claude-flow/metrics/agent-metrics.json +1 -0
  63. package/docs/reasoningbank/models/code-reasoning/.claude-flow/metrics/performance.json +87 -0
  64. package/docs/reasoningbank/models/code-reasoning/.claude-flow/metrics/task-metrics.json +18 -0
  65. package/docs/reasoningbank/models/code-reasoning/.swarm/SCHEMA-FIX-REPORT.md +69 -0
  66. package/docs/reasoningbank/models/code-reasoning/.swarm/memory.db +0 -0
  67. package/docs/reasoningbank/models/code-reasoning/.swarm/memory.db.backup +0 -0
  68. package/docs/reasoningbank/models/code-reasoning/README.md +451 -0
  69. package/docs/reasoningbank/models/code-reasoning/TRAINING-SUMMARY.md +416 -0
  70. package/docs/reasoningbank/models/code-reasoning/train-code.js +2059 -0
  71. package/docs/reasoningbank/models/code-reasoning/training.log +18 -0
  72. package/docs/reasoningbank/models/code-reasoning/validation-report.md +349 -0
  73. package/docs/reasoningbank/models/domain-expert/.claude-flow/metrics/agent-metrics.json +1 -0
  74. package/docs/reasoningbank/models/domain-expert/.claude-flow/metrics/performance.json +87 -0
  75. package/docs/reasoningbank/models/domain-expert/.claude-flow/metrics/task-metrics.json +18 -0
  76. package/docs/reasoningbank/models/domain-expert/COMPLETION-REPORT.md +451 -0
  77. package/docs/reasoningbank/models/domain-expert/INDEX.md +182 -0
  78. package/docs/reasoningbank/models/domain-expert/README.md +215 -0
  79. package/docs/reasoningbank/models/domain-expert/SCHEMA-FIX-REPORT.md +65 -0
  80. package/docs/reasoningbank/models/domain-expert/SUMMARY.md +286 -0
  81. package/docs/reasoningbank/models/domain-expert/USAGE.md +394 -0
  82. package/docs/reasoningbank/models/domain-expert/demo-queries.sh +42 -0
  83. package/docs/reasoningbank/models/domain-expert/memory.db +0 -0
  84. package/docs/reasoningbank/models/domain-expert/train-domain.js +1324 -0
  85. package/docs/reasoningbank/models/domain-expert/validate.js +218 -0
  86. package/docs/reasoningbank/models/domain-expert/validation-report.md +89 -0
  87. package/docs/reasoningbank/models/google-research/README.md +455 -0
  88. package/docs/reasoningbank/models/google-research/SCHEMA-FIX-REPORT.md +65 -0
  89. package/docs/reasoningbank/models/google-research/memory.db +0 -0
  90. package/docs/reasoningbank/models/google-research/memory.db.backup +0 -0
  91. package/docs/reasoningbank/models/google-research/train-google.js +697 -0
  92. package/docs/reasoningbank/models/google-research/validation-report.md +99 -0
  93. package/docs/reasoningbank/models/google-research/validation-suite.js +323 -0
  94. package/docs/reasoningbank/models/problem-solving/.claude-flow/metrics/agent-metrics.json +1 -0
  95. package/docs/reasoningbank/models/problem-solving/.claude-flow/metrics/performance.json +87 -0
  96. package/docs/reasoningbank/models/problem-solving/.claude-flow/metrics/task-metrics.json +10 -0
  97. package/docs/reasoningbank/models/problem-solving/.swarm/memory.db +0 -0
  98. package/docs/reasoningbank/models/problem-solving/README.md +629 -0
  99. package/docs/reasoningbank/models/problem-solving/SCHEMA-FIX-REPORT.md +66 -0
  100. package/docs/reasoningbank/models/problem-solving/TRAINING_SUMMARY.md +524 -0
  101. package/docs/reasoningbank/models/problem-solving/memory.db +0 -0
  102. package/docs/reasoningbank/models/problem-solving/memory.db.backup +0 -0
  103. package/docs/reasoningbank/models/problem-solving/train-problem.js +1319 -0
  104. package/docs/reasoningbank/models/problem-solving/validation-report.md +300 -0
  105. package/docs/reasoningbank/models/safla/.claude-flow/metrics/agent-metrics.json +1 -0
  106. package/docs/reasoningbank/models/safla/.claude-flow/metrics/performance.json +87 -0
  107. package/docs/reasoningbank/models/safla/.claude-flow/metrics/task-metrics.json +10 -0
  108. package/docs/reasoningbank/models/safla/CHEATSHEET.md +277 -0
  109. package/docs/reasoningbank/models/safla/COMPLETION_REPORT.txt +108 -0
  110. package/docs/reasoningbank/models/safla/MANIFEST.txt +104 -0
  111. package/docs/reasoningbank/models/safla/QUICKSTART.md +349 -0
  112. package/docs/reasoningbank/models/safla/README.md +457 -0
  113. package/docs/reasoningbank/models/safla/SCHEMA-FIX-REPORT.md +68 -0
  114. package/docs/reasoningbank/models/safla/TRAINING_SUMMARY.md +383 -0
  115. package/docs/reasoningbank/models/safla/memory/memory-store.json +11 -0
  116. package/docs/reasoningbank/models/safla/memory.db +0 -0
  117. package/docs/reasoningbank/models/safla/memory.db.backup +0 -0
  118. package/docs/reasoningbank/models/safla/node_modules/.package-lock.json +456 -0
  119. package/docs/reasoningbank/models/safla/node_modules/base64-js/LICENSE +21 -0
  120. package/docs/reasoningbank/models/safla/node_modules/base64-js/README.md +34 -0
  121. package/docs/reasoningbank/models/safla/node_modules/base64-js/base64js.min.js +1 -0
  122. package/docs/reasoningbank/models/safla/node_modules/base64-js/index.d.ts +3 -0
  123. package/docs/reasoningbank/models/safla/node_modules/base64-js/index.js +150 -0
  124. package/docs/reasoningbank/models/safla/node_modules/base64-js/package.json +47 -0
  125. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/LICENSE +21 -0
  126. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/README.md +99 -0
  127. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/binding.gyp +38 -0
  128. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/build/Release/better_sqlite3.node +0 -0
  129. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/common.gypi +68 -0
  130. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/copy.js +31 -0
  131. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/defines.gypi +41 -0
  132. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/download.sh +122 -0
  133. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/patches/1208.patch +15 -0
  134. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/sqlite3/sqlite3.c +261480 -0
  135. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/sqlite3/sqlite3.h +13715 -0
  136. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/sqlite3/sqlite3ext.h +719 -0
  137. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/sqlite3.gyp +80 -0
  138. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/test_extension.c +21 -0
  139. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/database.js +90 -0
  140. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/index.js +3 -0
  141. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/aggregate.js +43 -0
  142. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/backup.js +67 -0
  143. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/function.js +31 -0
  144. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/inspect.js +7 -0
  145. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/pragma.js +12 -0
  146. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/serialize.js +16 -0
  147. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/table.js +189 -0
  148. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/transaction.js +78 -0
  149. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/wrappers.js +54 -0
  150. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/sqlite-error.js +20 -0
  151. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/util.js +12 -0
  152. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/package.json +54 -0
  153. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/src/better_sqlite3.cpp +2186 -0
  154. package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/src/better_sqlite3.hpp +1036 -0
  155. package/docs/reasoningbank/models/safla/node_modules/bindings/LICENSE.md +22 -0
  156. package/docs/reasoningbank/models/safla/node_modules/bindings/README.md +98 -0
  157. package/docs/reasoningbank/models/safla/node_modules/bindings/bindings.js +221 -0
  158. package/docs/reasoningbank/models/safla/node_modules/bindings/package.json +28 -0
  159. package/docs/reasoningbank/models/safla/node_modules/bl/.travis.yml +17 -0
  160. package/docs/reasoningbank/models/safla/node_modules/bl/BufferList.js +396 -0
  161. package/docs/reasoningbank/models/safla/node_modules/bl/LICENSE.md +13 -0
  162. package/docs/reasoningbank/models/safla/node_modules/bl/README.md +247 -0
  163. package/docs/reasoningbank/models/safla/node_modules/bl/bl.js +84 -0
  164. package/docs/reasoningbank/models/safla/node_modules/bl/package.json +37 -0
  165. package/docs/reasoningbank/models/safla/node_modules/bl/test/convert.js +21 -0
  166. package/docs/reasoningbank/models/safla/node_modules/bl/test/indexOf.js +492 -0
  167. package/docs/reasoningbank/models/safla/node_modules/bl/test/isBufferList.js +32 -0
  168. package/docs/reasoningbank/models/safla/node_modules/bl/test/test.js +869 -0
  169. package/docs/reasoningbank/models/safla/node_modules/buffer/AUTHORS.md +70 -0
  170. package/docs/reasoningbank/models/safla/node_modules/buffer/LICENSE +21 -0
  171. package/docs/reasoningbank/models/safla/node_modules/buffer/README.md +410 -0
  172. package/docs/reasoningbank/models/safla/node_modules/buffer/index.d.ts +186 -0
  173. package/docs/reasoningbank/models/safla/node_modules/buffer/index.js +1817 -0
  174. package/docs/reasoningbank/models/safla/node_modules/buffer/package.json +96 -0
  175. package/docs/reasoningbank/models/safla/node_modules/chownr/LICENSE +15 -0
  176. package/docs/reasoningbank/models/safla/node_modules/chownr/README.md +3 -0
  177. package/docs/reasoningbank/models/safla/node_modules/chownr/chownr.js +167 -0
  178. package/docs/reasoningbank/models/safla/node_modules/chownr/package.json +29 -0
  179. package/docs/reasoningbank/models/safla/node_modules/decompress-response/index.d.ts +22 -0
  180. package/docs/reasoningbank/models/safla/node_modules/decompress-response/index.js +58 -0
  181. package/docs/reasoningbank/models/safla/node_modules/decompress-response/license +9 -0
  182. package/docs/reasoningbank/models/safla/node_modules/decompress-response/package.json +56 -0
  183. package/docs/reasoningbank/models/safla/node_modules/decompress-response/readme.md +48 -0
  184. package/docs/reasoningbank/models/safla/node_modules/deep-extend/CHANGELOG.md +46 -0
  185. package/docs/reasoningbank/models/safla/node_modules/deep-extend/LICENSE +20 -0
  186. package/docs/reasoningbank/models/safla/node_modules/deep-extend/README.md +91 -0
  187. package/docs/reasoningbank/models/safla/node_modules/deep-extend/index.js +1 -0
  188. package/docs/reasoningbank/models/safla/node_modules/deep-extend/lib/deep-extend.js +150 -0
  189. package/docs/reasoningbank/models/safla/node_modules/deep-extend/package.json +62 -0
  190. package/docs/reasoningbank/models/safla/node_modules/detect-libc/LICENSE +201 -0
  191. package/docs/reasoningbank/models/safla/node_modules/detect-libc/README.md +163 -0
  192. package/docs/reasoningbank/models/safla/node_modules/detect-libc/index.d.ts +14 -0
  193. package/docs/reasoningbank/models/safla/node_modules/detect-libc/lib/detect-libc.js +313 -0
  194. package/docs/reasoningbank/models/safla/node_modules/detect-libc/lib/elf.js +39 -0
  195. package/docs/reasoningbank/models/safla/node_modules/detect-libc/lib/filesystem.js +51 -0
  196. package/docs/reasoningbank/models/safla/node_modules/detect-libc/lib/process.js +24 -0
  197. package/docs/reasoningbank/models/safla/node_modules/detect-libc/package.json +44 -0
  198. package/docs/reasoningbank/models/safla/node_modules/end-of-stream/LICENSE +21 -0
  199. package/docs/reasoningbank/models/safla/node_modules/end-of-stream/README.md +54 -0
  200. package/docs/reasoningbank/models/safla/node_modules/end-of-stream/index.js +96 -0
  201. package/docs/reasoningbank/models/safla/node_modules/end-of-stream/package.json +37 -0
  202. package/docs/reasoningbank/models/safla/node_modules/expand-template/.travis.yml +6 -0
  203. package/docs/reasoningbank/models/safla/node_modules/expand-template/LICENSE +21 -0
  204. package/docs/reasoningbank/models/safla/node_modules/expand-template/README.md +43 -0
  205. package/docs/reasoningbank/models/safla/node_modules/expand-template/index.js +26 -0
  206. package/docs/reasoningbank/models/safla/node_modules/expand-template/package.json +29 -0
  207. package/docs/reasoningbank/models/safla/node_modules/expand-template/test.js +67 -0
  208. package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/.travis.yml +30 -0
  209. package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/History.md +21 -0
  210. package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/LICENSE +20 -0
  211. package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/README.md +74 -0
  212. package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/index.d.ts +2 -0
  213. package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/index.js +66 -0
  214. package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/package.json +32 -0
  215. package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/test/test.js +24 -0
  216. package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/test/tests.json +13 -0
  217. package/docs/reasoningbank/models/safla/node_modules/fs-constants/LICENSE +21 -0
  218. package/docs/reasoningbank/models/safla/node_modules/fs-constants/README.md +26 -0
  219. package/docs/reasoningbank/models/safla/node_modules/fs-constants/browser.js +1 -0
  220. package/docs/reasoningbank/models/safla/node_modules/fs-constants/index.js +1 -0
  221. package/docs/reasoningbank/models/safla/node_modules/fs-constants/package.json +19 -0
  222. package/docs/reasoningbank/models/safla/node_modules/github-from-package/.travis.yml +4 -0
  223. package/docs/reasoningbank/models/safla/node_modules/github-from-package/LICENSE +18 -0
  224. package/docs/reasoningbank/models/safla/node_modules/github-from-package/example/package.json +8 -0
  225. package/docs/reasoningbank/models/safla/node_modules/github-from-package/example/url.js +3 -0
  226. package/docs/reasoningbank/models/safla/node_modules/github-from-package/index.js +17 -0
  227. package/docs/reasoningbank/models/safla/node_modules/github-from-package/package.json +30 -0
  228. package/docs/reasoningbank/models/safla/node_modules/github-from-package/readme.markdown +53 -0
  229. package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/a.json +8 -0
  230. package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/b.json +5 -0
  231. package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/c.json +5 -0
  232. package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/d.json +7 -0
  233. package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/e.json +5 -0
  234. package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/url.js +19 -0
  235. package/docs/reasoningbank/models/safla/node_modules/ieee754/LICENSE +11 -0
  236. package/docs/reasoningbank/models/safla/node_modules/ieee754/README.md +51 -0
  237. package/docs/reasoningbank/models/safla/node_modules/ieee754/index.d.ts +10 -0
  238. package/docs/reasoningbank/models/safla/node_modules/ieee754/index.js +85 -0
  239. package/docs/reasoningbank/models/safla/node_modules/ieee754/package.json +52 -0
  240. package/docs/reasoningbank/models/safla/node_modules/inherits/LICENSE +16 -0
  241. package/docs/reasoningbank/models/safla/node_modules/inherits/README.md +42 -0
  242. package/docs/reasoningbank/models/safla/node_modules/inherits/inherits.js +9 -0
  243. package/docs/reasoningbank/models/safla/node_modules/inherits/inherits_browser.js +27 -0
  244. package/docs/reasoningbank/models/safla/node_modules/inherits/package.json +29 -0
  245. package/docs/reasoningbank/models/safla/node_modules/ini/LICENSE +15 -0
  246. package/docs/reasoningbank/models/safla/node_modules/ini/README.md +102 -0
  247. package/docs/reasoningbank/models/safla/node_modules/ini/ini.js +206 -0
  248. package/docs/reasoningbank/models/safla/node_modules/ini/package.json +33 -0
  249. package/docs/reasoningbank/models/safla/node_modules/mimic-response/index.d.ts +17 -0
  250. package/docs/reasoningbank/models/safla/node_modules/mimic-response/index.js +77 -0
  251. package/docs/reasoningbank/models/safla/node_modules/mimic-response/license +9 -0
  252. package/docs/reasoningbank/models/safla/node_modules/mimic-response/package.json +42 -0
  253. package/docs/reasoningbank/models/safla/node_modules/mimic-response/readme.md +78 -0
  254. package/docs/reasoningbank/models/safla/node_modules/minimist/.eslintrc +29 -0
  255. package/docs/reasoningbank/models/safla/node_modules/minimist/.github/FUNDING.yml +12 -0
  256. package/docs/reasoningbank/models/safla/node_modules/minimist/.nycrc +14 -0
  257. package/docs/reasoningbank/models/safla/node_modules/minimist/CHANGELOG.md +298 -0
  258. package/docs/reasoningbank/models/safla/node_modules/minimist/LICENSE +18 -0
  259. package/docs/reasoningbank/models/safla/node_modules/minimist/README.md +121 -0
  260. package/docs/reasoningbank/models/safla/node_modules/minimist/example/parse.js +4 -0
  261. package/docs/reasoningbank/models/safla/node_modules/minimist/index.js +263 -0
  262. package/docs/reasoningbank/models/safla/node_modules/minimist/package.json +75 -0
  263. package/docs/reasoningbank/models/safla/node_modules/minimist/test/all_bool.js +34 -0
  264. package/docs/reasoningbank/models/safla/node_modules/minimist/test/bool.js +177 -0
  265. package/docs/reasoningbank/models/safla/node_modules/minimist/test/dash.js +43 -0
  266. package/docs/reasoningbank/models/safla/node_modules/minimist/test/default_bool.js +37 -0
  267. package/docs/reasoningbank/models/safla/node_modules/minimist/test/dotted.js +24 -0
  268. package/docs/reasoningbank/models/safla/node_modules/minimist/test/kv_short.js +32 -0
  269. package/docs/reasoningbank/models/safla/node_modules/minimist/test/long.js +33 -0
  270. package/docs/reasoningbank/models/safla/node_modules/minimist/test/num.js +38 -0
  271. package/docs/reasoningbank/models/safla/node_modules/minimist/test/parse.js +209 -0
  272. package/docs/reasoningbank/models/safla/node_modules/minimist/test/parse_modified.js +11 -0
  273. package/docs/reasoningbank/models/safla/node_modules/minimist/test/proto.js +64 -0
  274. package/docs/reasoningbank/models/safla/node_modules/minimist/test/short.js +69 -0
  275. package/docs/reasoningbank/models/safla/node_modules/minimist/test/stop_early.js +17 -0
  276. package/docs/reasoningbank/models/safla/node_modules/minimist/test/unknown.js +104 -0
  277. package/docs/reasoningbank/models/safla/node_modules/minimist/test/whitespace.js +10 -0
  278. package/docs/reasoningbank/models/safla/node_modules/mkdirp-classic/LICENSE +21 -0
  279. package/docs/reasoningbank/models/safla/node_modules/mkdirp-classic/README.md +18 -0
  280. package/docs/reasoningbank/models/safla/node_modules/mkdirp-classic/index.js +98 -0
  281. package/docs/reasoningbank/models/safla/node_modules/mkdirp-classic/package.json +18 -0
  282. package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/.github/workflows/run-npm-tests.yml +31 -0
  283. package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/LICENSE +21 -0
  284. package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/README.md +52 -0
  285. package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/index.js +214 -0
  286. package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/index.md +0 -0
  287. package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/package.json +42 -0
  288. package/docs/reasoningbank/models/safla/node_modules/node-abi/LICENSE +21 -0
  289. package/docs/reasoningbank/models/safla/node_modules/node-abi/README.md +54 -0
  290. package/docs/reasoningbank/models/safla/node_modules/node-abi/abi_registry.json +408 -0
  291. package/docs/reasoningbank/models/safla/node_modules/node-abi/index.js +179 -0
  292. package/docs/reasoningbank/models/safla/node_modules/node-abi/package.json +45 -0
  293. package/docs/reasoningbank/models/safla/node_modules/once/LICENSE +15 -0
  294. package/docs/reasoningbank/models/safla/node_modules/once/README.md +79 -0
  295. package/docs/reasoningbank/models/safla/node_modules/once/once.js +42 -0
  296. package/docs/reasoningbank/models/safla/node_modules/once/package.json +33 -0
  297. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/CHANGELOG.md +131 -0
  298. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/CONTRIBUTING.md +6 -0
  299. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/LICENSE +21 -0
  300. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/README.md +163 -0
  301. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/asset.js +44 -0
  302. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/bin.js +78 -0
  303. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/download.js +142 -0
  304. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/error.js +14 -0
  305. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/help.txt +16 -0
  306. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/index.js +1 -0
  307. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/log.js +33 -0
  308. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/package.json +67 -0
  309. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/proxy.js +35 -0
  310. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/rc.js +64 -0
  311. package/docs/reasoningbank/models/safla/node_modules/prebuild-install/util.js +143 -0
  312. package/docs/reasoningbank/models/safla/node_modules/pump/.github/FUNDING.yml +2 -0
  313. package/docs/reasoningbank/models/safla/node_modules/pump/.travis.yml +5 -0
  314. package/docs/reasoningbank/models/safla/node_modules/pump/LICENSE +21 -0
  315. package/docs/reasoningbank/models/safla/node_modules/pump/README.md +74 -0
  316. package/docs/reasoningbank/models/safla/node_modules/pump/SECURITY.md +5 -0
  317. package/docs/reasoningbank/models/safla/node_modules/pump/index.js +86 -0
  318. package/docs/reasoningbank/models/safla/node_modules/pump/package.json +24 -0
  319. package/docs/reasoningbank/models/safla/node_modules/pump/test-browser.js +66 -0
  320. package/docs/reasoningbank/models/safla/node_modules/pump/test-node.js +53 -0
  321. package/docs/reasoningbank/models/safla/node_modules/rc/LICENSE.APACHE2 +15 -0
  322. package/docs/reasoningbank/models/safla/node_modules/rc/LICENSE.BSD +26 -0
  323. package/docs/reasoningbank/models/safla/node_modules/rc/LICENSE.MIT +24 -0
  324. package/docs/reasoningbank/models/safla/node_modules/rc/README.md +227 -0
  325. package/docs/reasoningbank/models/safla/node_modules/rc/browser.js +7 -0
  326. package/docs/reasoningbank/models/safla/node_modules/rc/cli.js +4 -0
  327. package/docs/reasoningbank/models/safla/node_modules/rc/index.js +53 -0
  328. package/docs/reasoningbank/models/safla/node_modules/rc/lib/utils.js +104 -0
  329. package/docs/reasoningbank/models/safla/node_modules/rc/package.json +29 -0
  330. package/docs/reasoningbank/models/safla/node_modules/rc/test/ini.js +16 -0
  331. package/docs/reasoningbank/models/safla/node_modules/rc/test/nested-env-vars.js +50 -0
  332. package/docs/reasoningbank/models/safla/node_modules/rc/test/test.js +59 -0
  333. package/docs/reasoningbank/models/safla/node_modules/readable-stream/CONTRIBUTING.md +38 -0
  334. package/docs/reasoningbank/models/safla/node_modules/readable-stream/GOVERNANCE.md +136 -0
  335. package/docs/reasoningbank/models/safla/node_modules/readable-stream/LICENSE +47 -0
  336. package/docs/reasoningbank/models/safla/node_modules/readable-stream/README.md +106 -0
  337. package/docs/reasoningbank/models/safla/node_modules/readable-stream/errors-browser.js +127 -0
  338. package/docs/reasoningbank/models/safla/node_modules/readable-stream/errors.js +116 -0
  339. package/docs/reasoningbank/models/safla/node_modules/readable-stream/experimentalWarning.js +17 -0
  340. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/_stream_duplex.js +126 -0
  341. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/_stream_passthrough.js +37 -0
  342. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/_stream_readable.js +1027 -0
  343. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/_stream_transform.js +190 -0
  344. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/_stream_writable.js +641 -0
  345. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/async_iterator.js +180 -0
  346. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/buffer_list.js +183 -0
  347. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/destroy.js +96 -0
  348. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +86 -0
  349. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/from-browser.js +3 -0
  350. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/from.js +52 -0
  351. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/pipeline.js +86 -0
  352. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/state.js +22 -0
  353. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/stream-browser.js +1 -0
  354. package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/stream.js +1 -0
  355. package/docs/reasoningbank/models/safla/node_modules/readable-stream/package.json +68 -0
  356. package/docs/reasoningbank/models/safla/node_modules/readable-stream/readable-browser.js +9 -0
  357. package/docs/reasoningbank/models/safla/node_modules/readable-stream/readable.js +16 -0
  358. package/docs/reasoningbank/models/safla/node_modules/safe-buffer/LICENSE +21 -0
  359. package/docs/reasoningbank/models/safla/node_modules/safe-buffer/README.md +584 -0
  360. package/docs/reasoningbank/models/safla/node_modules/safe-buffer/index.d.ts +187 -0
  361. package/docs/reasoningbank/models/safla/node_modules/safe-buffer/index.js +65 -0
  362. package/docs/reasoningbank/models/safla/node_modules/safe-buffer/package.json +51 -0
  363. package/docs/reasoningbank/models/safla/node_modules/semver/LICENSE +15 -0
  364. package/docs/reasoningbank/models/safla/node_modules/semver/README.md +664 -0
  365. package/docs/reasoningbank/models/safla/node_modules/semver/bin/semver.js +191 -0
  366. package/docs/reasoningbank/models/safla/node_modules/semver/classes/comparator.js +143 -0
  367. package/docs/reasoningbank/models/safla/node_modules/semver/classes/index.js +7 -0
  368. package/docs/reasoningbank/models/safla/node_modules/semver/classes/range.js +557 -0
  369. package/docs/reasoningbank/models/safla/node_modules/semver/classes/semver.js +333 -0
  370. package/docs/reasoningbank/models/safla/node_modules/semver/functions/clean.js +8 -0
  371. package/docs/reasoningbank/models/safla/node_modules/semver/functions/cmp.js +54 -0
  372. package/docs/reasoningbank/models/safla/node_modules/semver/functions/coerce.js +62 -0
  373. package/docs/reasoningbank/models/safla/node_modules/semver/functions/compare-build.js +9 -0
  374. package/docs/reasoningbank/models/safla/node_modules/semver/functions/compare-loose.js +5 -0
  375. package/docs/reasoningbank/models/safla/node_modules/semver/functions/compare.js +7 -0
  376. package/docs/reasoningbank/models/safla/node_modules/semver/functions/diff.js +60 -0
  377. package/docs/reasoningbank/models/safla/node_modules/semver/functions/eq.js +5 -0
  378. package/docs/reasoningbank/models/safla/node_modules/semver/functions/gt.js +5 -0
  379. package/docs/reasoningbank/models/safla/node_modules/semver/functions/gte.js +5 -0
  380. package/docs/reasoningbank/models/safla/node_modules/semver/functions/inc.js +21 -0
  381. package/docs/reasoningbank/models/safla/node_modules/semver/functions/lt.js +5 -0
  382. package/docs/reasoningbank/models/safla/node_modules/semver/functions/lte.js +5 -0
  383. package/docs/reasoningbank/models/safla/node_modules/semver/functions/major.js +5 -0
  384. package/docs/reasoningbank/models/safla/node_modules/semver/functions/minor.js +5 -0
  385. package/docs/reasoningbank/models/safla/node_modules/semver/functions/neq.js +5 -0
  386. package/docs/reasoningbank/models/safla/node_modules/semver/functions/parse.js +18 -0
  387. package/docs/reasoningbank/models/safla/node_modules/semver/functions/patch.js +5 -0
  388. package/docs/reasoningbank/models/safla/node_modules/semver/functions/prerelease.js +8 -0
  389. package/docs/reasoningbank/models/safla/node_modules/semver/functions/rcompare.js +5 -0
  390. package/docs/reasoningbank/models/safla/node_modules/semver/functions/rsort.js +5 -0
  391. package/docs/reasoningbank/models/safla/node_modules/semver/functions/satisfies.js +12 -0
  392. package/docs/reasoningbank/models/safla/node_modules/semver/functions/sort.js +5 -0
  393. package/docs/reasoningbank/models/safla/node_modules/semver/functions/valid.js +8 -0
  394. package/docs/reasoningbank/models/safla/node_modules/semver/index.js +91 -0
  395. package/docs/reasoningbank/models/safla/node_modules/semver/internal/constants.js +37 -0
  396. package/docs/reasoningbank/models/safla/node_modules/semver/internal/debug.js +11 -0
  397. package/docs/reasoningbank/models/safla/node_modules/semver/internal/identifiers.js +29 -0
  398. package/docs/reasoningbank/models/safla/node_modules/semver/internal/lrucache.js +42 -0
  399. package/docs/reasoningbank/models/safla/node_modules/semver/internal/parse-options.js +17 -0
  400. package/docs/reasoningbank/models/safla/node_modules/semver/internal/re.js +223 -0
  401. package/docs/reasoningbank/models/safla/node_modules/semver/package.json +78 -0
  402. package/docs/reasoningbank/models/safla/node_modules/semver/preload.js +4 -0
  403. package/docs/reasoningbank/models/safla/node_modules/semver/range.bnf +16 -0
  404. package/docs/reasoningbank/models/safla/node_modules/semver/ranges/gtr.js +6 -0
  405. package/docs/reasoningbank/models/safla/node_modules/semver/ranges/intersects.js +9 -0
  406. package/docs/reasoningbank/models/safla/node_modules/semver/ranges/ltr.js +6 -0
  407. package/docs/reasoningbank/models/safla/node_modules/semver/ranges/max-satisfying.js +27 -0
  408. package/docs/reasoningbank/models/safla/node_modules/semver/ranges/min-satisfying.js +26 -0
  409. package/docs/reasoningbank/models/safla/node_modules/semver/ranges/min-version.js +63 -0
  410. package/docs/reasoningbank/models/safla/node_modules/semver/ranges/outside.js +82 -0
  411. package/docs/reasoningbank/models/safla/node_modules/semver/ranges/simplify.js +49 -0
  412. package/docs/reasoningbank/models/safla/node_modules/semver/ranges/subset.js +249 -0
  413. package/docs/reasoningbank/models/safla/node_modules/semver/ranges/to-comparators.js +10 -0
  414. package/docs/reasoningbank/models/safla/node_modules/semver/ranges/valid.js +13 -0
  415. package/docs/reasoningbank/models/safla/node_modules/simple-concat/.travis.yml +3 -0
  416. package/docs/reasoningbank/models/safla/node_modules/simple-concat/LICENSE +20 -0
  417. package/docs/reasoningbank/models/safla/node_modules/simple-concat/README.md +44 -0
  418. package/docs/reasoningbank/models/safla/node_modules/simple-concat/index.js +15 -0
  419. package/docs/reasoningbank/models/safla/node_modules/simple-concat/package.json +47 -0
  420. package/docs/reasoningbank/models/safla/node_modules/simple-concat/test/basic.js +41 -0
  421. package/docs/reasoningbank/models/safla/node_modules/simple-get/.github/dependabot.yml +15 -0
  422. package/docs/reasoningbank/models/safla/node_modules/simple-get/.github/workflows/ci.yml +23 -0
  423. package/docs/reasoningbank/models/safla/node_modules/simple-get/LICENSE +20 -0
  424. package/docs/reasoningbank/models/safla/node_modules/simple-get/README.md +333 -0
  425. package/docs/reasoningbank/models/safla/node_modules/simple-get/index.js +108 -0
  426. package/docs/reasoningbank/models/safla/node_modules/simple-get/package.json +67 -0
  427. package/docs/reasoningbank/models/safla/node_modules/string_decoder/LICENSE +48 -0
  428. package/docs/reasoningbank/models/safla/node_modules/string_decoder/README.md +47 -0
  429. package/docs/reasoningbank/models/safla/node_modules/string_decoder/lib/string_decoder.js +296 -0
  430. package/docs/reasoningbank/models/safla/node_modules/string_decoder/package.json +34 -0
  431. package/docs/reasoningbank/models/safla/node_modules/strip-json-comments/index.js +70 -0
  432. package/docs/reasoningbank/models/safla/node_modules/strip-json-comments/license +21 -0
  433. package/docs/reasoningbank/models/safla/node_modules/strip-json-comments/package.json +42 -0
  434. package/docs/reasoningbank/models/safla/node_modules/strip-json-comments/readme.md +64 -0
  435. package/docs/reasoningbank/models/safla/node_modules/tar-fs/.travis.yml +6 -0
  436. package/docs/reasoningbank/models/safla/node_modules/tar-fs/LICENSE +21 -0
  437. package/docs/reasoningbank/models/safla/node_modules/tar-fs/README.md +165 -0
  438. package/docs/reasoningbank/models/safla/node_modules/tar-fs/index.js +363 -0
  439. package/docs/reasoningbank/models/safla/node_modules/tar-fs/package.json +41 -0
  440. package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/a/hello.txt +1 -0
  441. package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/b/a/test.txt +1 -0
  442. package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/d/file1 +0 -0
  443. package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/d/file2 +0 -0
  444. package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/d/sub-dir/file5 +0 -0
  445. package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/d/sub-files/file3 +0 -0
  446. package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/d/sub-files/file4 +0 -0
  447. package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/e/directory/.ignore +0 -0
  448. package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/e/file +0 -0
  449. package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/invalid.tar +0 -0
  450. package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/index.js +346 -0
  451. package/docs/reasoningbank/models/safla/node_modules/tar-stream/LICENSE +21 -0
  452. package/docs/reasoningbank/models/safla/node_modules/tar-stream/README.md +168 -0
  453. package/docs/reasoningbank/models/safla/node_modules/tar-stream/extract.js +257 -0
  454. package/docs/reasoningbank/models/safla/node_modules/tar-stream/headers.js +295 -0
  455. package/docs/reasoningbank/models/safla/node_modules/tar-stream/index.js +2 -0
  456. package/docs/reasoningbank/models/safla/node_modules/tar-stream/pack.js +255 -0
  457. package/docs/reasoningbank/models/safla/node_modules/tar-stream/package.json +58 -0
  458. package/docs/reasoningbank/models/safla/node_modules/tar-stream/sandbox.js +11 -0
  459. package/docs/reasoningbank/models/safla/node_modules/tunnel-agent/LICENSE +55 -0
  460. package/docs/reasoningbank/models/safla/node_modules/tunnel-agent/README.md +4 -0
  461. package/docs/reasoningbank/models/safla/node_modules/tunnel-agent/index.js +244 -0
  462. package/docs/reasoningbank/models/safla/node_modules/tunnel-agent/package.json +22 -0
  463. package/docs/reasoningbank/models/safla/node_modules/util-deprecate/History.md +16 -0
  464. package/docs/reasoningbank/models/safla/node_modules/util-deprecate/LICENSE +24 -0
  465. package/docs/reasoningbank/models/safla/node_modules/util-deprecate/README.md +53 -0
  466. package/docs/reasoningbank/models/safla/node_modules/util-deprecate/browser.js +67 -0
  467. package/docs/reasoningbank/models/safla/node_modules/util-deprecate/node.js +6 -0
  468. package/docs/reasoningbank/models/safla/node_modules/util-deprecate/package.json +27 -0
  469. package/docs/reasoningbank/models/safla/node_modules/wrappy/LICENSE +15 -0
  470. package/docs/reasoningbank/models/safla/node_modules/wrappy/README.md +36 -0
  471. package/docs/reasoningbank/models/safla/node_modules/wrappy/package.json +29 -0
  472. package/docs/reasoningbank/models/safla/node_modules/wrappy/wrappy.js +33 -0
  473. package/docs/reasoningbank/models/safla/package-lock.json +463 -0
  474. package/docs/reasoningbank/models/safla/package.json +14 -0
  475. package/docs/reasoningbank/models/safla/train-safla.js +524 -0
  476. package/docs/reasoningbank/models/safla/training.log +64 -0
  477. package/docs/reasoningbank/models/safla/validate-safla.js +449 -0
  478. package/docs/reasoningbank/models/safla/validation-report.md +115 -0
  479. package/docs/reasoningbank/models/safla/validation-results.json +189 -0
  480. package/docs/reasoningbank/tutorial-advanced.md +869 -0
  481. package/docs/reasoningbank/tutorial-basic.md +626 -0
  482. package/docs/skills/skills-tutorial.md +2910 -0
  483. package/package.json +4 -3
  484. package/src/cli/simple-commands/init/index.js +22 -4
  485. package/src/cli/simple-commands/init/skills-copier.js +215 -0
  486. package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +0 -54
  487. package/.claude/commands/analysis/bottleneck-detect.md +0 -162
  488. package/.claude/commands/analysis/performance-bottlenecks.md +0 -59
  489. package/.claude/commands/analysis/performance-report.md +0 -25
  490. package/.claude/commands/flow-nexus/app-store.md +0 -124
  491. package/.claude/commands/flow-nexus/challenges.md +0 -120
  492. package/.claude/commands/flow-nexus/login-registration.md +0 -65
  493. package/.claude/commands/flow-nexus/neural-network.md +0 -134
  494. package/.claude/commands/flow-nexus/payments.md +0 -116
  495. package/.claude/commands/flow-nexus/sandbox.md +0 -83
  496. package/.claude/commands/flow-nexus/swarm.md +0 -87
  497. package/.claude/commands/flow-nexus/user-tools.md +0 -152
  498. package/.claude/commands/flow-nexus/workflow.md +0 -115
  499. package/.claude/commands/github/code-review-swarm.md +0 -514
  500. package/.claude/commands/github/github-modes.md +0 -147
  501. package/.claude/commands/github/issue-tracker.md +0 -292
  502. package/.claude/commands/github/multi-repo-swarm.md +0 -519
  503. package/.claude/commands/github/pr-manager.md +0 -170
  504. package/.claude/commands/github/project-board-sync.md +0 -471
  505. package/.claude/commands/github/release-manager.md +0 -338
  506. package/.claude/commands/github/release-swarm.md +0 -544
  507. package/.claude/commands/github/repo-architect.md +0 -367
  508. package/.claude/commands/github/swarm-issue.md +0 -482
  509. package/.claude/commands/github/swarm-pr.md +0 -285
  510. package/.claude/commands/github/sync-coordinator.md +0 -301
  511. package/.claude/commands/github/workflow-automation.md +0 -442
  512. package/.claude/commands/hive-mind/hive-mind-resume.md +0 -8
  513. package/.claude/commands/hive-mind/hive-mind-sessions.md +0 -8
  514. package/.claude/commands/hive-mind/hive-mind-stop.md +0 -8
  515. package/.claude/commands/hive-mind/hive-mind-wizard.md +0 -8
  516. package/.claude/commands/hive-mind/hive-mind.md +0 -27
  517. package/.claude/commands/hooks/overview.md +0 -132
  518. package/.claude/commands/memory/usage.md +0 -46
  519. package/.claude/commands/pair/commands.md +0 -546
  520. package/.claude/commands/pair/config.md +0 -510
  521. package/.claude/commands/pair/examples.md +0 -512
  522. package/.claude/commands/pair/modes.md +0 -348
  523. package/.claude/commands/pair/session.md +0 -407
  524. package/.claude/commands/pair/start.md +0 -209
  525. package/.claude/commands/sparc/orchestrator.md +0 -132
  526. package/.claude/commands/sparc/sparc-modes.md +0 -174
  527. package/.claude/commands/stream-chain/pipeline.md +0 -121
  528. package/.claude/commands/stream-chain/run.md +0 -70
  529. package/.claude/commands/swarm/analysis.md +0 -95
  530. package/.claude/commands/swarm/development.md +0 -96
  531. package/.claude/commands/swarm/examples.md +0 -168
  532. package/.claude/commands/swarm/maintenance.md +0 -102
  533. package/.claude/commands/swarm/optimization.md +0 -117
  534. package/.claude/commands/swarm/research.md +0 -136
  535. package/.claude/commands/swarm/swarm-analysis.md +0 -8
  536. package/.claude/commands/swarm/swarm-spawn.md +0 -19
  537. package/.claude/commands/swarm/swarm-strategies.md +0 -8
  538. package/.claude/commands/swarm/testing.md +0 -131
  539. package/.claude/commands/truth/start.md +0 -143
  540. package/.claude/commands/verify/check.md +0 -50
  541. package/.claude/commands/verify/start.md +0 -128
  542. /package/{.claude/agents → docs}/reasoning/README.md +0 -0
  543. /package/{.claude/agents → docs}/reasoning/example-reasoning-agent-template.md +0 -0
@@ -0,0 +1,1027 @@
1
+ // Copyright Joyent, Inc. and other Node contributors.
2
+ //
3
+ // Permission is hereby granted, free of charge, to any person obtaining a
4
+ // copy of this software and associated documentation files (the
5
+ // "Software"), to deal in the Software without restriction, including
6
+ // without limitation the rights to use, copy, modify, merge, publish,
7
+ // distribute, sublicense, and/or sell copies of the Software, and to permit
8
+ // persons to whom the Software is furnished to do so, subject to the
9
+ // following conditions:
10
+ //
11
+ // The above copyright notice and this permission notice shall be included
12
+ // in all copies or substantial portions of the Software.
13
+ //
14
+ // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
15
+ // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
17
+ // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
18
+ // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
19
+ // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
20
+ // USE OR OTHER DEALINGS IN THE SOFTWARE.
21
+
22
+ 'use strict';
23
+
24
+ module.exports = Readable;
25
+
26
+ /*<replacement>*/
27
+ var Duplex;
28
+ /*</replacement>*/
29
+
30
+ Readable.ReadableState = ReadableState;
31
+
32
+ /*<replacement>*/
33
+ var EE = require('events').EventEmitter;
34
+ var EElistenerCount = function EElistenerCount(emitter, type) {
35
+ return emitter.listeners(type).length;
36
+ };
37
+ /*</replacement>*/
38
+
39
+ /*<replacement>*/
40
+ var Stream = require('./internal/streams/stream');
41
+ /*</replacement>*/
42
+
43
+ var Buffer = require('buffer').Buffer;
44
+ var OurUint8Array = (typeof global !== 'undefined' ? global : typeof window !== 'undefined' ? window : typeof self !== 'undefined' ? self : {}).Uint8Array || function () {};
45
+ function _uint8ArrayToBuffer(chunk) {
46
+ return Buffer.from(chunk);
47
+ }
48
+ function _isUint8Array(obj) {
49
+ return Buffer.isBuffer(obj) || obj instanceof OurUint8Array;
50
+ }
51
+
52
+ /*<replacement>*/
53
+ var debugUtil = require('util');
54
+ var debug;
55
+ if (debugUtil && debugUtil.debuglog) {
56
+ debug = debugUtil.debuglog('stream');
57
+ } else {
58
+ debug = function debug() {};
59
+ }
60
+ /*</replacement>*/
61
+
62
+ var BufferList = require('./internal/streams/buffer_list');
63
+ var destroyImpl = require('./internal/streams/destroy');
64
+ var _require = require('./internal/streams/state'),
65
+ getHighWaterMark = _require.getHighWaterMark;
66
+ var _require$codes = require('../errors').codes,
67
+ ERR_INVALID_ARG_TYPE = _require$codes.ERR_INVALID_ARG_TYPE,
68
+ ERR_STREAM_PUSH_AFTER_EOF = _require$codes.ERR_STREAM_PUSH_AFTER_EOF,
69
+ ERR_METHOD_NOT_IMPLEMENTED = _require$codes.ERR_METHOD_NOT_IMPLEMENTED,
70
+ ERR_STREAM_UNSHIFT_AFTER_END_EVENT = _require$codes.ERR_STREAM_UNSHIFT_AFTER_END_EVENT;
71
+
72
+ // Lazy loaded to improve the startup performance.
73
+ var StringDecoder;
74
+ var createReadableStreamAsyncIterator;
75
+ var from;
76
+ require('inherits')(Readable, Stream);
77
+ var errorOrDestroy = destroyImpl.errorOrDestroy;
78
+ var kProxyEvents = ['error', 'close', 'destroy', 'pause', 'resume'];
79
+ function prependListener(emitter, event, fn) {
80
+ // Sadly this is not cacheable as some libraries bundle their own
81
+ // event emitter implementation with them.
82
+ if (typeof emitter.prependListener === 'function') return emitter.prependListener(event, fn);
83
+
84
+ // This is a hack to make sure that our error handler is attached before any
85
+ // userland ones. NEVER DO THIS. This is here only because this code needs
86
+ // to continue to work with older versions of Node.js that do not include
87
+ // the prependListener() method. The goal is to eventually remove this hack.
88
+ if (!emitter._events || !emitter._events[event]) emitter.on(event, fn);else if (Array.isArray(emitter._events[event])) emitter._events[event].unshift(fn);else emitter._events[event] = [fn, emitter._events[event]];
89
+ }
90
+ function ReadableState(options, stream, isDuplex) {
91
+ Duplex = Duplex || require('./_stream_duplex');
92
+ options = options || {};
93
+
94
+ // Duplex streams are both readable and writable, but share
95
+ // the same options object.
96
+ // However, some cases require setting options to different
97
+ // values for the readable and the writable sides of the duplex stream.
98
+ // These options can be provided separately as readableXXX and writableXXX.
99
+ if (typeof isDuplex !== 'boolean') isDuplex = stream instanceof Duplex;
100
+
101
+ // object stream flag. Used to make read(n) ignore n and to
102
+ // make all the buffer merging and length checks go away
103
+ this.objectMode = !!options.objectMode;
104
+ if (isDuplex) this.objectMode = this.objectMode || !!options.readableObjectMode;
105
+
106
+ // the point at which it stops calling _read() to fill the buffer
107
+ // Note: 0 is a valid value, means "don't call _read preemptively ever"
108
+ this.highWaterMark = getHighWaterMark(this, options, 'readableHighWaterMark', isDuplex);
109
+
110
+ // A linked list is used to store data chunks instead of an array because the
111
+ // linked list can remove elements from the beginning faster than
112
+ // array.shift()
113
+ this.buffer = new BufferList();
114
+ this.length = 0;
115
+ this.pipes = null;
116
+ this.pipesCount = 0;
117
+ this.flowing = null;
118
+ this.ended = false;
119
+ this.endEmitted = false;
120
+ this.reading = false;
121
+
122
+ // a flag to be able to tell if the event 'readable'/'data' is emitted
123
+ // immediately, or on a later tick. We set this to true at first, because
124
+ // any actions that shouldn't happen until "later" should generally also
125
+ // not happen before the first read call.
126
+ this.sync = true;
127
+
128
+ // whenever we return null, then we set a flag to say
129
+ // that we're awaiting a 'readable' event emission.
130
+ this.needReadable = false;
131
+ this.emittedReadable = false;
132
+ this.readableListening = false;
133
+ this.resumeScheduled = false;
134
+ this.paused = true;
135
+
136
+ // Should close be emitted on destroy. Defaults to true.
137
+ this.emitClose = options.emitClose !== false;
138
+
139
+ // Should .destroy() be called after 'end' (and potentially 'finish')
140
+ this.autoDestroy = !!options.autoDestroy;
141
+
142
+ // has it been destroyed
143
+ this.destroyed = false;
144
+
145
+ // Crypto is kind of old and crusty. Historically, its default string
146
+ // encoding is 'binary' so we have to make this configurable.
147
+ // Everything else in the universe uses 'utf8', though.
148
+ this.defaultEncoding = options.defaultEncoding || 'utf8';
149
+
150
+ // the number of writers that are awaiting a drain event in .pipe()s
151
+ this.awaitDrain = 0;
152
+
153
+ // if true, a maybeReadMore has been scheduled
154
+ this.readingMore = false;
155
+ this.decoder = null;
156
+ this.encoding = null;
157
+ if (options.encoding) {
158
+ if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;
159
+ this.decoder = new StringDecoder(options.encoding);
160
+ this.encoding = options.encoding;
161
+ }
162
+ }
163
+ function Readable(options) {
164
+ Duplex = Duplex || require('./_stream_duplex');
165
+ if (!(this instanceof Readable)) return new Readable(options);
166
+
167
+ // Checking for a Stream.Duplex instance is faster here instead of inside
168
+ // the ReadableState constructor, at least with V8 6.5
169
+ var isDuplex = this instanceof Duplex;
170
+ this._readableState = new ReadableState(options, this, isDuplex);
171
+
172
+ // legacy
173
+ this.readable = true;
174
+ if (options) {
175
+ if (typeof options.read === 'function') this._read = options.read;
176
+ if (typeof options.destroy === 'function') this._destroy = options.destroy;
177
+ }
178
+ Stream.call(this);
179
+ }
180
+ Object.defineProperty(Readable.prototype, 'destroyed', {
181
+ // making it explicit this property is not enumerable
182
+ // because otherwise some prototype manipulation in
183
+ // userland will fail
184
+ enumerable: false,
185
+ get: function get() {
186
+ if (this._readableState === undefined) {
187
+ return false;
188
+ }
189
+ return this._readableState.destroyed;
190
+ },
191
+ set: function set(value) {
192
+ // we ignore the value if the stream
193
+ // has not been initialized yet
194
+ if (!this._readableState) {
195
+ return;
196
+ }
197
+
198
+ // backward compatibility, the user is explicitly
199
+ // managing destroyed
200
+ this._readableState.destroyed = value;
201
+ }
202
+ });
203
+ Readable.prototype.destroy = destroyImpl.destroy;
204
+ Readable.prototype._undestroy = destroyImpl.undestroy;
205
+ Readable.prototype._destroy = function (err, cb) {
206
+ cb(err);
207
+ };
208
+
209
+ // Manually shove something into the read() buffer.
210
+ // This returns true if the highWaterMark has not been hit yet,
211
+ // similar to how Writable.write() returns true if you should
212
+ // write() some more.
213
+ Readable.prototype.push = function (chunk, encoding) {
214
+ var state = this._readableState;
215
+ var skipChunkCheck;
216
+ if (!state.objectMode) {
217
+ if (typeof chunk === 'string') {
218
+ encoding = encoding || state.defaultEncoding;
219
+ if (encoding !== state.encoding) {
220
+ chunk = Buffer.from(chunk, encoding);
221
+ encoding = '';
222
+ }
223
+ skipChunkCheck = true;
224
+ }
225
+ } else {
226
+ skipChunkCheck = true;
227
+ }
228
+ return readableAddChunk(this, chunk, encoding, false, skipChunkCheck);
229
+ };
230
+
231
+ // Unshift should *always* be something directly out of read()
232
+ Readable.prototype.unshift = function (chunk) {
233
+ return readableAddChunk(this, chunk, null, true, false);
234
+ };
235
+ function readableAddChunk(stream, chunk, encoding, addToFront, skipChunkCheck) {
236
+ debug('readableAddChunk', chunk);
237
+ var state = stream._readableState;
238
+ if (chunk === null) {
239
+ state.reading = false;
240
+ onEofChunk(stream, state);
241
+ } else {
242
+ var er;
243
+ if (!skipChunkCheck) er = chunkInvalid(state, chunk);
244
+ if (er) {
245
+ errorOrDestroy(stream, er);
246
+ } else if (state.objectMode || chunk && chunk.length > 0) {
247
+ if (typeof chunk !== 'string' && !state.objectMode && Object.getPrototypeOf(chunk) !== Buffer.prototype) {
248
+ chunk = _uint8ArrayToBuffer(chunk);
249
+ }
250
+ if (addToFront) {
251
+ if (state.endEmitted) errorOrDestroy(stream, new ERR_STREAM_UNSHIFT_AFTER_END_EVENT());else addChunk(stream, state, chunk, true);
252
+ } else if (state.ended) {
253
+ errorOrDestroy(stream, new ERR_STREAM_PUSH_AFTER_EOF());
254
+ } else if (state.destroyed) {
255
+ return false;
256
+ } else {
257
+ state.reading = false;
258
+ if (state.decoder && !encoding) {
259
+ chunk = state.decoder.write(chunk);
260
+ if (state.objectMode || chunk.length !== 0) addChunk(stream, state, chunk, false);else maybeReadMore(stream, state);
261
+ } else {
262
+ addChunk(stream, state, chunk, false);
263
+ }
264
+ }
265
+ } else if (!addToFront) {
266
+ state.reading = false;
267
+ maybeReadMore(stream, state);
268
+ }
269
+ }
270
+
271
+ // We can push more data if we are below the highWaterMark.
272
+ // Also, if we have no data yet, we can stand some more bytes.
273
+ // This is to work around cases where hwm=0, such as the repl.
274
+ return !state.ended && (state.length < state.highWaterMark || state.length === 0);
275
+ }
276
+ function addChunk(stream, state, chunk, addToFront) {
277
+ if (state.flowing && state.length === 0 && !state.sync) {
278
+ state.awaitDrain = 0;
279
+ stream.emit('data', chunk);
280
+ } else {
281
+ // update the buffer info.
282
+ state.length += state.objectMode ? 1 : chunk.length;
283
+ if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);
284
+ if (state.needReadable) emitReadable(stream);
285
+ }
286
+ maybeReadMore(stream, state);
287
+ }
288
+ function chunkInvalid(state, chunk) {
289
+ var er;
290
+ if (!_isUint8Array(chunk) && typeof chunk !== 'string' && chunk !== undefined && !state.objectMode) {
291
+ er = new ERR_INVALID_ARG_TYPE('chunk', ['string', 'Buffer', 'Uint8Array'], chunk);
292
+ }
293
+ return er;
294
+ }
295
+ Readable.prototype.isPaused = function () {
296
+ return this._readableState.flowing === false;
297
+ };
298
+
299
+ // backwards compatibility.
300
+ Readable.prototype.setEncoding = function (enc) {
301
+ if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;
302
+ var decoder = new StringDecoder(enc);
303
+ this._readableState.decoder = decoder;
304
+ // If setEncoding(null), decoder.encoding equals utf8
305
+ this._readableState.encoding = this._readableState.decoder.encoding;
306
+
307
+ // Iterate over current buffer to convert already stored Buffers:
308
+ var p = this._readableState.buffer.head;
309
+ var content = '';
310
+ while (p !== null) {
311
+ content += decoder.write(p.data);
312
+ p = p.next;
313
+ }
314
+ this._readableState.buffer.clear();
315
+ if (content !== '') this._readableState.buffer.push(content);
316
+ this._readableState.length = content.length;
317
+ return this;
318
+ };
319
+
320
+ // Don't raise the hwm > 1GB
321
+ var MAX_HWM = 0x40000000;
322
+ function computeNewHighWaterMark(n) {
323
+ if (n >= MAX_HWM) {
324
+ // TODO(ronag): Throw ERR_VALUE_OUT_OF_RANGE.
325
+ n = MAX_HWM;
326
+ } else {
327
+ // Get the next highest power of 2 to prevent increasing hwm excessively in
328
+ // tiny amounts
329
+ n--;
330
+ n |= n >>> 1;
331
+ n |= n >>> 2;
332
+ n |= n >>> 4;
333
+ n |= n >>> 8;
334
+ n |= n >>> 16;
335
+ n++;
336
+ }
337
+ return n;
338
+ }
339
+
340
+ // This function is designed to be inlinable, so please take care when making
341
+ // changes to the function body.
342
+ function howMuchToRead(n, state) {
343
+ if (n <= 0 || state.length === 0 && state.ended) return 0;
344
+ if (state.objectMode) return 1;
345
+ if (n !== n) {
346
+ // Only flow one buffer at a time
347
+ if (state.flowing && state.length) return state.buffer.head.data.length;else return state.length;
348
+ }
349
+ // If we're asking for more than the current hwm, then raise the hwm.
350
+ if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);
351
+ if (n <= state.length) return n;
352
+ // Don't have enough
353
+ if (!state.ended) {
354
+ state.needReadable = true;
355
+ return 0;
356
+ }
357
+ return state.length;
358
+ }
359
+
360
+ // you can override either this method, or the async _read(n) below.
361
+ Readable.prototype.read = function (n) {
362
+ debug('read', n);
363
+ n = parseInt(n, 10);
364
+ var state = this._readableState;
365
+ var nOrig = n;
366
+ if (n !== 0) state.emittedReadable = false;
367
+
368
+ // if we're doing read(0) to trigger a readable event, but we
369
+ // already have a bunch of data in the buffer, then just trigger
370
+ // the 'readable' event and move on.
371
+ if (n === 0 && state.needReadable && ((state.highWaterMark !== 0 ? state.length >= state.highWaterMark : state.length > 0) || state.ended)) {
372
+ debug('read: emitReadable', state.length, state.ended);
373
+ if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);
374
+ return null;
375
+ }
376
+ n = howMuchToRead(n, state);
377
+
378
+ // if we've ended, and we're now clear, then finish it up.
379
+ if (n === 0 && state.ended) {
380
+ if (state.length === 0) endReadable(this);
381
+ return null;
382
+ }
383
+
384
+ // All the actual chunk generation logic needs to be
385
+ // *below* the call to _read. The reason is that in certain
386
+ // synthetic stream cases, such as passthrough streams, _read
387
+ // may be a completely synchronous operation which may change
388
+ // the state of the read buffer, providing enough data when
389
+ // before there was *not* enough.
390
+ //
391
+ // So, the steps are:
392
+ // 1. Figure out what the state of things will be after we do
393
+ // a read from the buffer.
394
+ //
395
+ // 2. If that resulting state will trigger a _read, then call _read.
396
+ // Note that this may be asynchronous, or synchronous. Yes, it is
397
+ // deeply ugly to write APIs this way, but that still doesn't mean
398
+ // that the Readable class should behave improperly, as streams are
399
+ // designed to be sync/async agnostic.
400
+ // Take note if the _read call is sync or async (ie, if the read call
401
+ // has returned yet), so that we know whether or not it's safe to emit
402
+ // 'readable' etc.
403
+ //
404
+ // 3. Actually pull the requested chunks out of the buffer and return.
405
+
406
+ // if we need a readable event, then we need to do some reading.
407
+ var doRead = state.needReadable;
408
+ debug('need readable', doRead);
409
+
410
+ // if we currently have less than the highWaterMark, then also read some
411
+ if (state.length === 0 || state.length - n < state.highWaterMark) {
412
+ doRead = true;
413
+ debug('length less than watermark', doRead);
414
+ }
415
+
416
+ // however, if we've ended, then there's no point, and if we're already
417
+ // reading, then it's unnecessary.
418
+ if (state.ended || state.reading) {
419
+ doRead = false;
420
+ debug('reading or ended', doRead);
421
+ } else if (doRead) {
422
+ debug('do read');
423
+ state.reading = true;
424
+ state.sync = true;
425
+ // if the length is currently zero, then we *need* a readable event.
426
+ if (state.length === 0) state.needReadable = true;
427
+ // call internal read method
428
+ this._read(state.highWaterMark);
429
+ state.sync = false;
430
+ // If _read pushed data synchronously, then `reading` will be false,
431
+ // and we need to re-evaluate how much data we can return to the user.
432
+ if (!state.reading) n = howMuchToRead(nOrig, state);
433
+ }
434
+ var ret;
435
+ if (n > 0) ret = fromList(n, state);else ret = null;
436
+ if (ret === null) {
437
+ state.needReadable = state.length <= state.highWaterMark;
438
+ n = 0;
439
+ } else {
440
+ state.length -= n;
441
+ state.awaitDrain = 0;
442
+ }
443
+ if (state.length === 0) {
444
+ // If we have nothing in the buffer, then we want to know
445
+ // as soon as we *do* get something into the buffer.
446
+ if (!state.ended) state.needReadable = true;
447
+
448
+ // If we tried to read() past the EOF, then emit end on the next tick.
449
+ if (nOrig !== n && state.ended) endReadable(this);
450
+ }
451
+ if (ret !== null) this.emit('data', ret);
452
+ return ret;
453
+ };
454
+ function onEofChunk(stream, state) {
455
+ debug('onEofChunk');
456
+ if (state.ended) return;
457
+ if (state.decoder) {
458
+ var chunk = state.decoder.end();
459
+ if (chunk && chunk.length) {
460
+ state.buffer.push(chunk);
461
+ state.length += state.objectMode ? 1 : chunk.length;
462
+ }
463
+ }
464
+ state.ended = true;
465
+ if (state.sync) {
466
+ // if we are sync, wait until next tick to emit the data.
467
+ // Otherwise we risk emitting data in the flow()
468
+ // the readable code triggers during a read() call
469
+ emitReadable(stream);
470
+ } else {
471
+ // emit 'readable' now to make sure it gets picked up.
472
+ state.needReadable = false;
473
+ if (!state.emittedReadable) {
474
+ state.emittedReadable = true;
475
+ emitReadable_(stream);
476
+ }
477
+ }
478
+ }
479
+
480
+ // Don't emit readable right away in sync mode, because this can trigger
481
+ // another read() call => stack overflow. This way, it might trigger
482
+ // a nextTick recursion warning, but that's not so bad.
483
+ function emitReadable(stream) {
484
+ var state = stream._readableState;
485
+ debug('emitReadable', state.needReadable, state.emittedReadable);
486
+ state.needReadable = false;
487
+ if (!state.emittedReadable) {
488
+ debug('emitReadable', state.flowing);
489
+ state.emittedReadable = true;
490
+ process.nextTick(emitReadable_, stream);
491
+ }
492
+ }
493
+ function emitReadable_(stream) {
494
+ var state = stream._readableState;
495
+ debug('emitReadable_', state.destroyed, state.length, state.ended);
496
+ if (!state.destroyed && (state.length || state.ended)) {
497
+ stream.emit('readable');
498
+ state.emittedReadable = false;
499
+ }
500
+
501
+ // The stream needs another readable event if
502
+ // 1. It is not flowing, as the flow mechanism will take
503
+ // care of it.
504
+ // 2. It is not ended.
505
+ // 3. It is below the highWaterMark, so we can schedule
506
+ // another readable later.
507
+ state.needReadable = !state.flowing && !state.ended && state.length <= state.highWaterMark;
508
+ flow(stream);
509
+ }
510
+
511
+ // at this point, the user has presumably seen the 'readable' event,
512
+ // and called read() to consume some data. that may have triggered
513
+ // in turn another _read(n) call, in which case reading = true if
514
+ // it's in progress.
515
+ // However, if we're not ended, or reading, and the length < hwm,
516
+ // then go ahead and try to read some more preemptively.
517
+ function maybeReadMore(stream, state) {
518
+ if (!state.readingMore) {
519
+ state.readingMore = true;
520
+ process.nextTick(maybeReadMore_, stream, state);
521
+ }
522
+ }
523
+ function maybeReadMore_(stream, state) {
524
+ // Attempt to read more data if we should.
525
+ //
526
+ // The conditions for reading more data are (one of):
527
+ // - Not enough data buffered (state.length < state.highWaterMark). The loop
528
+ // is responsible for filling the buffer with enough data if such data
529
+ // is available. If highWaterMark is 0 and we are not in the flowing mode
530
+ // we should _not_ attempt to buffer any extra data. We'll get more data
531
+ // when the stream consumer calls read() instead.
532
+ // - No data in the buffer, and the stream is in flowing mode. In this mode
533
+ // the loop below is responsible for ensuring read() is called. Failing to
534
+ // call read here would abort the flow and there's no other mechanism for
535
+ // continuing the flow if the stream consumer has just subscribed to the
536
+ // 'data' event.
537
+ //
538
+ // In addition to the above conditions to keep reading data, the following
539
+ // conditions prevent the data from being read:
540
+ // - The stream has ended (state.ended).
541
+ // - There is already a pending 'read' operation (state.reading). This is a
542
+ // case where the the stream has called the implementation defined _read()
543
+ // method, but they are processing the call asynchronously and have _not_
544
+ // called push() with new data. In this case we skip performing more
545
+ // read()s. The execution ends in this method again after the _read() ends
546
+ // up calling push() with more data.
547
+ while (!state.reading && !state.ended && (state.length < state.highWaterMark || state.flowing && state.length === 0)) {
548
+ var len = state.length;
549
+ debug('maybeReadMore read 0');
550
+ stream.read(0);
551
+ if (len === state.length)
552
+ // didn't get any data, stop spinning.
553
+ break;
554
+ }
555
+ state.readingMore = false;
556
+ }
557
+
558
+ // abstract method. to be overridden in specific implementation classes.
559
+ // call cb(er, data) where data is <= n in length.
560
+ // for virtual (non-string, non-buffer) streams, "length" is somewhat
561
+ // arbitrary, and perhaps not very meaningful.
562
+ Readable.prototype._read = function (n) {
563
+ errorOrDestroy(this, new ERR_METHOD_NOT_IMPLEMENTED('_read()'));
564
+ };
565
+ Readable.prototype.pipe = function (dest, pipeOpts) {
566
+ var src = this;
567
+ var state = this._readableState;
568
+ switch (state.pipesCount) {
569
+ case 0:
570
+ state.pipes = dest;
571
+ break;
572
+ case 1:
573
+ state.pipes = [state.pipes, dest];
574
+ break;
575
+ default:
576
+ state.pipes.push(dest);
577
+ break;
578
+ }
579
+ state.pipesCount += 1;
580
+ debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);
581
+ var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;
582
+ var endFn = doEnd ? onend : unpipe;
583
+ if (state.endEmitted) process.nextTick(endFn);else src.once('end', endFn);
584
+ dest.on('unpipe', onunpipe);
585
+ function onunpipe(readable, unpipeInfo) {
586
+ debug('onunpipe');
587
+ if (readable === src) {
588
+ if (unpipeInfo && unpipeInfo.hasUnpiped === false) {
589
+ unpipeInfo.hasUnpiped = true;
590
+ cleanup();
591
+ }
592
+ }
593
+ }
594
+ function onend() {
595
+ debug('onend');
596
+ dest.end();
597
+ }
598
+
599
+ // when the dest drains, it reduces the awaitDrain counter
600
+ // on the source. This would be more elegant with a .once()
601
+ // handler in flow(), but adding and removing repeatedly is
602
+ // too slow.
603
+ var ondrain = pipeOnDrain(src);
604
+ dest.on('drain', ondrain);
605
+ var cleanedUp = false;
606
+ function cleanup() {
607
+ debug('cleanup');
608
+ // cleanup event handlers once the pipe is broken
609
+ dest.removeListener('close', onclose);
610
+ dest.removeListener('finish', onfinish);
611
+ dest.removeListener('drain', ondrain);
612
+ dest.removeListener('error', onerror);
613
+ dest.removeListener('unpipe', onunpipe);
614
+ src.removeListener('end', onend);
615
+ src.removeListener('end', unpipe);
616
+ src.removeListener('data', ondata);
617
+ cleanedUp = true;
618
+
619
+ // if the reader is waiting for a drain event from this
620
+ // specific writer, then it would cause it to never start
621
+ // flowing again.
622
+ // So, if this is awaiting a drain, then we just call it now.
623
+ // If we don't know, then assume that we are waiting for one.
624
+ if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();
625
+ }
626
+ src.on('data', ondata);
627
+ function ondata(chunk) {
628
+ debug('ondata');
629
+ var ret = dest.write(chunk);
630
+ debug('dest.write', ret);
631
+ if (ret === false) {
632
+ // If the user unpiped during `dest.write()`, it is possible
633
+ // to get stuck in a permanently paused state if that write
634
+ // also returned false.
635
+ // => Check whether `dest` is still a piping destination.
636
+ if ((state.pipesCount === 1 && state.pipes === dest || state.pipesCount > 1 && indexOf(state.pipes, dest) !== -1) && !cleanedUp) {
637
+ debug('false write response, pause', state.awaitDrain);
638
+ state.awaitDrain++;
639
+ }
640
+ src.pause();
641
+ }
642
+ }
643
+
644
+ // if the dest has an error, then stop piping into it.
645
+ // however, don't suppress the throwing behavior for this.
646
+ function onerror(er) {
647
+ debug('onerror', er);
648
+ unpipe();
649
+ dest.removeListener('error', onerror);
650
+ if (EElistenerCount(dest, 'error') === 0) errorOrDestroy(dest, er);
651
+ }
652
+
653
+ // Make sure our error handler is attached before userland ones.
654
+ prependListener(dest, 'error', onerror);
655
+
656
+ // Both close and finish should trigger unpipe, but only once.
657
+ function onclose() {
658
+ dest.removeListener('finish', onfinish);
659
+ unpipe();
660
+ }
661
+ dest.once('close', onclose);
662
+ function onfinish() {
663
+ debug('onfinish');
664
+ dest.removeListener('close', onclose);
665
+ unpipe();
666
+ }
667
+ dest.once('finish', onfinish);
668
+ function unpipe() {
669
+ debug('unpipe');
670
+ src.unpipe(dest);
671
+ }
672
+
673
+ // tell the dest that it's being piped to
674
+ dest.emit('pipe', src);
675
+
676
+ // start the flow if it hasn't been started already.
677
+ if (!state.flowing) {
678
+ debug('pipe resume');
679
+ src.resume();
680
+ }
681
+ return dest;
682
+ };
683
+ function pipeOnDrain(src) {
684
+ return function pipeOnDrainFunctionResult() {
685
+ var state = src._readableState;
686
+ debug('pipeOnDrain', state.awaitDrain);
687
+ if (state.awaitDrain) state.awaitDrain--;
688
+ if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {
689
+ state.flowing = true;
690
+ flow(src);
691
+ }
692
+ };
693
+ }
694
+ Readable.prototype.unpipe = function (dest) {
695
+ var state = this._readableState;
696
+ var unpipeInfo = {
697
+ hasUnpiped: false
698
+ };
699
+
700
+ // if we're not piping anywhere, then do nothing.
701
+ if (state.pipesCount === 0) return this;
702
+
703
+ // just one destination. most common case.
704
+ if (state.pipesCount === 1) {
705
+ // passed in one, but it's not the right one.
706
+ if (dest && dest !== state.pipes) return this;
707
+ if (!dest) dest = state.pipes;
708
+
709
+ // got a match.
710
+ state.pipes = null;
711
+ state.pipesCount = 0;
712
+ state.flowing = false;
713
+ if (dest) dest.emit('unpipe', this, unpipeInfo);
714
+ return this;
715
+ }
716
+
717
+ // slow case. multiple pipe destinations.
718
+
719
+ if (!dest) {
720
+ // remove all.
721
+ var dests = state.pipes;
722
+ var len = state.pipesCount;
723
+ state.pipes = null;
724
+ state.pipesCount = 0;
725
+ state.flowing = false;
726
+ for (var i = 0; i < len; i++) dests[i].emit('unpipe', this, {
727
+ hasUnpiped: false
728
+ });
729
+ return this;
730
+ }
731
+
732
+ // try to find the right one.
733
+ var index = indexOf(state.pipes, dest);
734
+ if (index === -1) return this;
735
+ state.pipes.splice(index, 1);
736
+ state.pipesCount -= 1;
737
+ if (state.pipesCount === 1) state.pipes = state.pipes[0];
738
+ dest.emit('unpipe', this, unpipeInfo);
739
+ return this;
740
+ };
741
+
742
+ // set up data events if they are asked for
743
+ // Ensure readable listeners eventually get something
744
+ Readable.prototype.on = function (ev, fn) {
745
+ var res = Stream.prototype.on.call(this, ev, fn);
746
+ var state = this._readableState;
747
+ if (ev === 'data') {
748
+ // update readableListening so that resume() may be a no-op
749
+ // a few lines down. This is needed to support once('readable').
750
+ state.readableListening = this.listenerCount('readable') > 0;
751
+
752
+ // Try start flowing on next tick if stream isn't explicitly paused
753
+ if (state.flowing !== false) this.resume();
754
+ } else if (ev === 'readable') {
755
+ if (!state.endEmitted && !state.readableListening) {
756
+ state.readableListening = state.needReadable = true;
757
+ state.flowing = false;
758
+ state.emittedReadable = false;
759
+ debug('on readable', state.length, state.reading);
760
+ if (state.length) {
761
+ emitReadable(this);
762
+ } else if (!state.reading) {
763
+ process.nextTick(nReadingNextTick, this);
764
+ }
765
+ }
766
+ }
767
+ return res;
768
+ };
769
+ Readable.prototype.addListener = Readable.prototype.on;
770
+ Readable.prototype.removeListener = function (ev, fn) {
771
+ var res = Stream.prototype.removeListener.call(this, ev, fn);
772
+ if (ev === 'readable') {
773
+ // We need to check if there is someone still listening to
774
+ // readable and reset the state. However this needs to happen
775
+ // after readable has been emitted but before I/O (nextTick) to
776
+ // support once('readable', fn) cycles. This means that calling
777
+ // resume within the same tick will have no
778
+ // effect.
779
+ process.nextTick(updateReadableListening, this);
780
+ }
781
+ return res;
782
+ };
783
+ Readable.prototype.removeAllListeners = function (ev) {
784
+ var res = Stream.prototype.removeAllListeners.apply(this, arguments);
785
+ if (ev === 'readable' || ev === undefined) {
786
+ // We need to check if there is someone still listening to
787
+ // readable and reset the state. However this needs to happen
788
+ // after readable has been emitted but before I/O (nextTick) to
789
+ // support once('readable', fn) cycles. This means that calling
790
+ // resume within the same tick will have no
791
+ // effect.
792
+ process.nextTick(updateReadableListening, this);
793
+ }
794
+ return res;
795
+ };
796
+ function updateReadableListening(self) {
797
+ var state = self._readableState;
798
+ state.readableListening = self.listenerCount('readable') > 0;
799
+ if (state.resumeScheduled && !state.paused) {
800
+ // flowing needs to be set to true now, otherwise
801
+ // the upcoming resume will not flow.
802
+ state.flowing = true;
803
+
804
+ // crude way to check if we should resume
805
+ } else if (self.listenerCount('data') > 0) {
806
+ self.resume();
807
+ }
808
+ }
809
+ function nReadingNextTick(self) {
810
+ debug('readable nexttick read 0');
811
+ self.read(0);
812
+ }
813
+
814
+ // pause() and resume() are remnants of the legacy readable stream API
815
+ // If the user uses them, then switch into old mode.
816
+ Readable.prototype.resume = function () {
817
+ var state = this._readableState;
818
+ if (!state.flowing) {
819
+ debug('resume');
820
+ // we flow only if there is no one listening
821
+ // for readable, but we still have to call
822
+ // resume()
823
+ state.flowing = !state.readableListening;
824
+ resume(this, state);
825
+ }
826
+ state.paused = false;
827
+ return this;
828
+ };
829
+ function resume(stream, state) {
830
+ if (!state.resumeScheduled) {
831
+ state.resumeScheduled = true;
832
+ process.nextTick(resume_, stream, state);
833
+ }
834
+ }
835
+ function resume_(stream, state) {
836
+ debug('resume', state.reading);
837
+ if (!state.reading) {
838
+ stream.read(0);
839
+ }
840
+ state.resumeScheduled = false;
841
+ stream.emit('resume');
842
+ flow(stream);
843
+ if (state.flowing && !state.reading) stream.read(0);
844
+ }
845
+ Readable.prototype.pause = function () {
846
+ debug('call pause flowing=%j', this._readableState.flowing);
847
+ if (this._readableState.flowing !== false) {
848
+ debug('pause');
849
+ this._readableState.flowing = false;
850
+ this.emit('pause');
851
+ }
852
+ this._readableState.paused = true;
853
+ return this;
854
+ };
855
+ function flow(stream) {
856
+ var state = stream._readableState;
857
+ debug('flow', state.flowing);
858
+ while (state.flowing && stream.read() !== null);
859
+ }
860
+
861
+ // wrap an old-style stream as the async data source.
862
+ // This is *not* part of the readable stream interface.
863
+ // It is an ugly unfortunate mess of history.
864
+ Readable.prototype.wrap = function (stream) {
865
+ var _this = this;
866
+ var state = this._readableState;
867
+ var paused = false;
868
+ stream.on('end', function () {
869
+ debug('wrapped end');
870
+ if (state.decoder && !state.ended) {
871
+ var chunk = state.decoder.end();
872
+ if (chunk && chunk.length) _this.push(chunk);
873
+ }
874
+ _this.push(null);
875
+ });
876
+ stream.on('data', function (chunk) {
877
+ debug('wrapped data');
878
+ if (state.decoder) chunk = state.decoder.write(chunk);
879
+
880
+ // don't skip over falsy values in objectMode
881
+ if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;
882
+ var ret = _this.push(chunk);
883
+ if (!ret) {
884
+ paused = true;
885
+ stream.pause();
886
+ }
887
+ });
888
+
889
+ // proxy all the other methods.
890
+ // important when wrapping filters and duplexes.
891
+ for (var i in stream) {
892
+ if (this[i] === undefined && typeof stream[i] === 'function') {
893
+ this[i] = function methodWrap(method) {
894
+ return function methodWrapReturnFunction() {
895
+ return stream[method].apply(stream, arguments);
896
+ };
897
+ }(i);
898
+ }
899
+ }
900
+
901
+ // proxy certain important events.
902
+ for (var n = 0; n < kProxyEvents.length; n++) {
903
+ stream.on(kProxyEvents[n], this.emit.bind(this, kProxyEvents[n]));
904
+ }
905
+
906
+ // when we try to consume some more bytes, simply unpause the
907
+ // underlying stream.
908
+ this._read = function (n) {
909
+ debug('wrapped _read', n);
910
+ if (paused) {
911
+ paused = false;
912
+ stream.resume();
913
+ }
914
+ };
915
+ return this;
916
+ };
917
+ if (typeof Symbol === 'function') {
918
+ Readable.prototype[Symbol.asyncIterator] = function () {
919
+ if (createReadableStreamAsyncIterator === undefined) {
920
+ createReadableStreamAsyncIterator = require('./internal/streams/async_iterator');
921
+ }
922
+ return createReadableStreamAsyncIterator(this);
923
+ };
924
+ }
925
+ Object.defineProperty(Readable.prototype, 'readableHighWaterMark', {
926
+ // making it explicit this property is not enumerable
927
+ // because otherwise some prototype manipulation in
928
+ // userland will fail
929
+ enumerable: false,
930
+ get: function get() {
931
+ return this._readableState.highWaterMark;
932
+ }
933
+ });
934
+ Object.defineProperty(Readable.prototype, 'readableBuffer', {
935
+ // making it explicit this property is not enumerable
936
+ // because otherwise some prototype manipulation in
937
+ // userland will fail
938
+ enumerable: false,
939
+ get: function get() {
940
+ return this._readableState && this._readableState.buffer;
941
+ }
942
+ });
943
+ Object.defineProperty(Readable.prototype, 'readableFlowing', {
944
+ // making it explicit this property is not enumerable
945
+ // because otherwise some prototype manipulation in
946
+ // userland will fail
947
+ enumerable: false,
948
+ get: function get() {
949
+ return this._readableState.flowing;
950
+ },
951
+ set: function set(state) {
952
+ if (this._readableState) {
953
+ this._readableState.flowing = state;
954
+ }
955
+ }
956
+ });
957
+
958
+ // exposed for testing purposes only.
959
+ Readable._fromList = fromList;
960
+ Object.defineProperty(Readable.prototype, 'readableLength', {
961
+ // making it explicit this property is not enumerable
962
+ // because otherwise some prototype manipulation in
963
+ // userland will fail
964
+ enumerable: false,
965
+ get: function get() {
966
+ return this._readableState.length;
967
+ }
968
+ });
969
+
970
+ // Pluck off n bytes from an array of buffers.
971
+ // Length is the combined lengths of all the buffers in the list.
972
+ // This function is designed to be inlinable, so please take care when making
973
+ // changes to the function body.
974
+ function fromList(n, state) {
975
+ // nothing buffered
976
+ if (state.length === 0) return null;
977
+ var ret;
978
+ if (state.objectMode) ret = state.buffer.shift();else if (!n || n >= state.length) {
979
+ // read it all, truncate the list
980
+ if (state.decoder) ret = state.buffer.join('');else if (state.buffer.length === 1) ret = state.buffer.first();else ret = state.buffer.concat(state.length);
981
+ state.buffer.clear();
982
+ } else {
983
+ // read part of list
984
+ ret = state.buffer.consume(n, state.decoder);
985
+ }
986
+ return ret;
987
+ }
988
+ function endReadable(stream) {
989
+ var state = stream._readableState;
990
+ debug('endReadable', state.endEmitted);
991
+ if (!state.endEmitted) {
992
+ state.ended = true;
993
+ process.nextTick(endReadableNT, state, stream);
994
+ }
995
+ }
996
+ function endReadableNT(state, stream) {
997
+ debug('endReadableNT', state.endEmitted, state.length);
998
+
999
+ // Check that we didn't get one last unshift.
1000
+ if (!state.endEmitted && state.length === 0) {
1001
+ state.endEmitted = true;
1002
+ stream.readable = false;
1003
+ stream.emit('end');
1004
+ if (state.autoDestroy) {
1005
+ // In case of duplex streams we need a way to detect
1006
+ // if the writable side is ready for autoDestroy as well
1007
+ var wState = stream._writableState;
1008
+ if (!wState || wState.autoDestroy && wState.finished) {
1009
+ stream.destroy();
1010
+ }
1011
+ }
1012
+ }
1013
+ }
1014
+ if (typeof Symbol === 'function') {
1015
+ Readable.from = function (iterable, opts) {
1016
+ if (from === undefined) {
1017
+ from = require('./internal/streams/from');
1018
+ }
1019
+ return from(Readable, iterable, opts);
1020
+ };
1021
+ }
1022
+ function indexOf(xs, x) {
1023
+ for (var i = 0, l = xs.length; i < l; i++) {
1024
+ if (xs[i] === x) return i;
1025
+ }
1026
+ return -1;
1027
+ }