claude-flow 2.7.0-alpha.10 → 2.7.0-alpha.11
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.
- package/.claude/settings.reasoningbank-example.json +124 -0
- package/.claude/settings.reasoningbank-minimal.json +40 -0
- package/.claude/skills/agentdb-memory-patterns/SKILL.md +166 -0
- package/.claude/skills/agentdb-vector-search/SKILL.md +126 -0
- package/.claude/skills/flow-nexus-neural/SKILL.md +738 -0
- package/.claude/skills/flow-nexus-platform/SKILL.md +1157 -0
- package/.claude/skills/flow-nexus-swarm/SKILL.md +610 -0
- package/.claude/skills/github-code-review/SKILL.md +1140 -0
- package/.claude/skills/github-multi-repo/SKILL.md +874 -0
- package/.claude/skills/github-project-management/SKILL.md +1277 -0
- package/.claude/skills/github-release-management/SKILL.md +1081 -0
- package/.claude/skills/github-workflow-automation/SKILL.md +1065 -0
- package/.claude/skills/hive-mind-advanced/SKILL.md +712 -0
- package/.claude/skills/hooks-automation/SKILL.md +1201 -0
- package/.claude/skills/pair-programming/SKILL.md +1202 -0
- package/.claude/skills/performance-analysis/SKILL.md +563 -0
- package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -0
- package/.claude/skills/skill-builder/SKILL.md +910 -0
- package/.claude/skills/sparc-methodology/SKILL.md +1115 -0
- package/.claude/skills/stream-chain/SKILL.md +563 -0
- package/.claude/skills/swarm-advanced/SKILL.md +973 -0
- package/.claude/skills/swarm-orchestration/SKILL.md +179 -0
- package/.claude/skills/verification-quality/SKILL.md +649 -0
- package/.claude/test-reasoningbank-hooks.sh +99 -0
- package/CHANGELOG.md +304 -0
- package/README.md +231 -191
- package/bin/claude-flow +1 -1
- package/docs/COMMANDS_TO_SKILLS_MIGRATION.md +382 -0
- package/docs/FINAL_INIT_STRUCTURE.md +320 -0
- package/docs/reasoningbank/CLAUDE-CODE-INTEGRATION.md +563 -0
- package/docs/reasoningbank/EXAMPLES.md +611 -0
- package/docs/reasoningbank/README.md +1139 -0
- package/docs/reasoningbank/agentic-flow-integration.md +800 -0
- package/docs/reasoningbank/architecture.md +680 -0
- package/docs/reasoningbank/google-research.md +1017 -0
- package/docs/reasoningbank/models/.claude-flow/metrics/agent-metrics.json +1 -0
- package/docs/reasoningbank/models/.claude-flow/metrics/performance.json +87 -0
- package/docs/reasoningbank/models/.claude-flow/metrics/task-metrics.json +10 -0
- package/docs/reasoningbank/models/HOW-TO-TRAIN.md +537 -0
- package/docs/reasoningbank/models/HOW-TO-USE.md +655 -0
- package/docs/reasoningbank/models/INDEX.md +276 -0
- package/docs/reasoningbank/models/README.md +345 -0
- package/docs/reasoningbank/models/_docs/COMPATIBILITY.md +448 -0
- package/docs/reasoningbank/models/_docs/COMPLETION-SUMMARY.md +478 -0
- package/docs/reasoningbank/models/_docs/README.md +80 -0
- package/docs/reasoningbank/models/_docs/SCHEMA-UPDATE-SUMMARY.md +376 -0
- package/docs/reasoningbank/models/_docs/VERIFICATION-COMPLETE.md +370 -0
- package/docs/reasoningbank/models/_scripts/README.md +270 -0
- package/docs/reasoningbank/models/_scripts/benchmark-all.cjs +407 -0
- package/docs/reasoningbank/models/_scripts/fix-schema-compatibility.cjs +300 -0
- package/docs/reasoningbank/models/_scripts/schema-validator.cjs +360 -0
- package/docs/reasoningbank/models/_scripts/training-coordinator.cjs +85 -0
- package/docs/reasoningbank/models/_scripts/validation-suite.cjs +239 -0
- package/docs/reasoningbank/models/benchmark-output.log +41 -0
- package/docs/reasoningbank/models/code-reasoning/.claude-flow/metrics/agent-metrics.json +1 -0
- package/docs/reasoningbank/models/code-reasoning/.claude-flow/metrics/performance.json +87 -0
- package/docs/reasoningbank/models/code-reasoning/.claude-flow/metrics/task-metrics.json +18 -0
- package/docs/reasoningbank/models/code-reasoning/.swarm/SCHEMA-FIX-REPORT.md +69 -0
- package/docs/reasoningbank/models/code-reasoning/.swarm/memory.db +0 -0
- package/docs/reasoningbank/models/code-reasoning/.swarm/memory.db.backup +0 -0
- package/docs/reasoningbank/models/code-reasoning/README.md +451 -0
- package/docs/reasoningbank/models/code-reasoning/TRAINING-SUMMARY.md +416 -0
- package/docs/reasoningbank/models/code-reasoning/train-code.js +2059 -0
- package/docs/reasoningbank/models/code-reasoning/training.log +18 -0
- package/docs/reasoningbank/models/code-reasoning/validation-report.md +349 -0
- package/docs/reasoningbank/models/domain-expert/.claude-flow/metrics/agent-metrics.json +1 -0
- package/docs/reasoningbank/models/domain-expert/.claude-flow/metrics/performance.json +87 -0
- package/docs/reasoningbank/models/domain-expert/.claude-flow/metrics/task-metrics.json +18 -0
- package/docs/reasoningbank/models/domain-expert/COMPLETION-REPORT.md +451 -0
- package/docs/reasoningbank/models/domain-expert/INDEX.md +182 -0
- package/docs/reasoningbank/models/domain-expert/README.md +215 -0
- package/docs/reasoningbank/models/domain-expert/SCHEMA-FIX-REPORT.md +65 -0
- package/docs/reasoningbank/models/domain-expert/SUMMARY.md +286 -0
- package/docs/reasoningbank/models/domain-expert/USAGE.md +394 -0
- package/docs/reasoningbank/models/domain-expert/demo-queries.sh +42 -0
- package/docs/reasoningbank/models/domain-expert/memory.db +0 -0
- package/docs/reasoningbank/models/domain-expert/train-domain.js +1324 -0
- package/docs/reasoningbank/models/domain-expert/validate.js +218 -0
- package/docs/reasoningbank/models/domain-expert/validation-report.md +89 -0
- package/docs/reasoningbank/models/google-research/README.md +455 -0
- package/docs/reasoningbank/models/google-research/SCHEMA-FIX-REPORT.md +65 -0
- package/docs/reasoningbank/models/google-research/memory.db +0 -0
- package/docs/reasoningbank/models/google-research/memory.db.backup +0 -0
- package/docs/reasoningbank/models/google-research/train-google.js +697 -0
- package/docs/reasoningbank/models/google-research/validation-report.md +99 -0
- package/docs/reasoningbank/models/google-research/validation-suite.js +323 -0
- package/docs/reasoningbank/models/problem-solving/.claude-flow/metrics/agent-metrics.json +1 -0
- package/docs/reasoningbank/models/problem-solving/.claude-flow/metrics/performance.json +87 -0
- package/docs/reasoningbank/models/problem-solving/.claude-flow/metrics/task-metrics.json +10 -0
- package/docs/reasoningbank/models/problem-solving/.swarm/memory.db +0 -0
- package/docs/reasoningbank/models/problem-solving/README.md +629 -0
- package/docs/reasoningbank/models/problem-solving/SCHEMA-FIX-REPORT.md +66 -0
- package/docs/reasoningbank/models/problem-solving/TRAINING_SUMMARY.md +524 -0
- package/docs/reasoningbank/models/problem-solving/memory.db +0 -0
- package/docs/reasoningbank/models/problem-solving/memory.db.backup +0 -0
- package/docs/reasoningbank/models/problem-solving/train-problem.js +1319 -0
- package/docs/reasoningbank/models/problem-solving/validation-report.md +300 -0
- package/docs/reasoningbank/models/safla/.claude-flow/metrics/agent-metrics.json +1 -0
- package/docs/reasoningbank/models/safla/.claude-flow/metrics/performance.json +87 -0
- package/docs/reasoningbank/models/safla/.claude-flow/metrics/task-metrics.json +10 -0
- package/docs/reasoningbank/models/safla/CHEATSHEET.md +277 -0
- package/docs/reasoningbank/models/safla/COMPLETION_REPORT.txt +108 -0
- package/docs/reasoningbank/models/safla/MANIFEST.txt +104 -0
- package/docs/reasoningbank/models/safla/QUICKSTART.md +349 -0
- package/docs/reasoningbank/models/safla/README.md +457 -0
- package/docs/reasoningbank/models/safla/SCHEMA-FIX-REPORT.md +68 -0
- package/docs/reasoningbank/models/safla/TRAINING_SUMMARY.md +383 -0
- package/docs/reasoningbank/models/safla/memory/memory-store.json +11 -0
- package/docs/reasoningbank/models/safla/memory.db +0 -0
- package/docs/reasoningbank/models/safla/memory.db.backup +0 -0
- package/docs/reasoningbank/models/safla/node_modules/.package-lock.json +456 -0
- package/docs/reasoningbank/models/safla/node_modules/base64-js/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/base64-js/README.md +34 -0
- package/docs/reasoningbank/models/safla/node_modules/base64-js/base64js.min.js +1 -0
- package/docs/reasoningbank/models/safla/node_modules/base64-js/index.d.ts +3 -0
- package/docs/reasoningbank/models/safla/node_modules/base64-js/index.js +150 -0
- package/docs/reasoningbank/models/safla/node_modules/base64-js/package.json +47 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/README.md +99 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/binding.gyp +38 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/build/Release/better_sqlite3.node +0 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/common.gypi +68 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/copy.js +31 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/defines.gypi +41 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/download.sh +122 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/patches/1208.patch +15 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/sqlite3/sqlite3.c +261480 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/sqlite3/sqlite3.h +13715 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/sqlite3/sqlite3ext.h +719 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/sqlite3.gyp +80 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/deps/test_extension.c +21 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/database.js +90 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/index.js +3 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/aggregate.js +43 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/backup.js +67 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/function.js +31 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/inspect.js +7 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/pragma.js +12 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/serialize.js +16 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/table.js +189 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/transaction.js +78 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/methods/wrappers.js +54 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/sqlite-error.js +20 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/lib/util.js +12 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/package.json +54 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/src/better_sqlite3.cpp +2186 -0
- package/docs/reasoningbank/models/safla/node_modules/better-sqlite3/src/better_sqlite3.hpp +1036 -0
- package/docs/reasoningbank/models/safla/node_modules/bindings/LICENSE.md +22 -0
- package/docs/reasoningbank/models/safla/node_modules/bindings/README.md +98 -0
- package/docs/reasoningbank/models/safla/node_modules/bindings/bindings.js +221 -0
- package/docs/reasoningbank/models/safla/node_modules/bindings/package.json +28 -0
- package/docs/reasoningbank/models/safla/node_modules/bl/.travis.yml +17 -0
- package/docs/reasoningbank/models/safla/node_modules/bl/BufferList.js +396 -0
- package/docs/reasoningbank/models/safla/node_modules/bl/LICENSE.md +13 -0
- package/docs/reasoningbank/models/safla/node_modules/bl/README.md +247 -0
- package/docs/reasoningbank/models/safla/node_modules/bl/bl.js +84 -0
- package/docs/reasoningbank/models/safla/node_modules/bl/package.json +37 -0
- package/docs/reasoningbank/models/safla/node_modules/bl/test/convert.js +21 -0
- package/docs/reasoningbank/models/safla/node_modules/bl/test/indexOf.js +492 -0
- package/docs/reasoningbank/models/safla/node_modules/bl/test/isBufferList.js +32 -0
- package/docs/reasoningbank/models/safla/node_modules/bl/test/test.js +869 -0
- package/docs/reasoningbank/models/safla/node_modules/buffer/AUTHORS.md +70 -0
- package/docs/reasoningbank/models/safla/node_modules/buffer/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/buffer/README.md +410 -0
- package/docs/reasoningbank/models/safla/node_modules/buffer/index.d.ts +186 -0
- package/docs/reasoningbank/models/safla/node_modules/buffer/index.js +1817 -0
- package/docs/reasoningbank/models/safla/node_modules/buffer/package.json +96 -0
- package/docs/reasoningbank/models/safla/node_modules/chownr/LICENSE +15 -0
- package/docs/reasoningbank/models/safla/node_modules/chownr/README.md +3 -0
- package/docs/reasoningbank/models/safla/node_modules/chownr/chownr.js +167 -0
- package/docs/reasoningbank/models/safla/node_modules/chownr/package.json +29 -0
- package/docs/reasoningbank/models/safla/node_modules/decompress-response/index.d.ts +22 -0
- package/docs/reasoningbank/models/safla/node_modules/decompress-response/index.js +58 -0
- package/docs/reasoningbank/models/safla/node_modules/decompress-response/license +9 -0
- package/docs/reasoningbank/models/safla/node_modules/decompress-response/package.json +56 -0
- package/docs/reasoningbank/models/safla/node_modules/decompress-response/readme.md +48 -0
- package/docs/reasoningbank/models/safla/node_modules/deep-extend/CHANGELOG.md +46 -0
- package/docs/reasoningbank/models/safla/node_modules/deep-extend/LICENSE +20 -0
- package/docs/reasoningbank/models/safla/node_modules/deep-extend/README.md +91 -0
- package/docs/reasoningbank/models/safla/node_modules/deep-extend/index.js +1 -0
- package/docs/reasoningbank/models/safla/node_modules/deep-extend/lib/deep-extend.js +150 -0
- package/docs/reasoningbank/models/safla/node_modules/deep-extend/package.json +62 -0
- package/docs/reasoningbank/models/safla/node_modules/detect-libc/LICENSE +201 -0
- package/docs/reasoningbank/models/safla/node_modules/detect-libc/README.md +163 -0
- package/docs/reasoningbank/models/safla/node_modules/detect-libc/index.d.ts +14 -0
- package/docs/reasoningbank/models/safla/node_modules/detect-libc/lib/detect-libc.js +313 -0
- package/docs/reasoningbank/models/safla/node_modules/detect-libc/lib/elf.js +39 -0
- package/docs/reasoningbank/models/safla/node_modules/detect-libc/lib/filesystem.js +51 -0
- package/docs/reasoningbank/models/safla/node_modules/detect-libc/lib/process.js +24 -0
- package/docs/reasoningbank/models/safla/node_modules/detect-libc/package.json +44 -0
- package/docs/reasoningbank/models/safla/node_modules/end-of-stream/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/end-of-stream/README.md +54 -0
- package/docs/reasoningbank/models/safla/node_modules/end-of-stream/index.js +96 -0
- package/docs/reasoningbank/models/safla/node_modules/end-of-stream/package.json +37 -0
- package/docs/reasoningbank/models/safla/node_modules/expand-template/.travis.yml +6 -0
- package/docs/reasoningbank/models/safla/node_modules/expand-template/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/expand-template/README.md +43 -0
- package/docs/reasoningbank/models/safla/node_modules/expand-template/index.js +26 -0
- package/docs/reasoningbank/models/safla/node_modules/expand-template/package.json +29 -0
- package/docs/reasoningbank/models/safla/node_modules/expand-template/test.js +67 -0
- package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/.travis.yml +30 -0
- package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/History.md +21 -0
- package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/LICENSE +20 -0
- package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/README.md +74 -0
- package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/index.d.ts +2 -0
- package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/index.js +66 -0
- package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/package.json +32 -0
- package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/test/test.js +24 -0
- package/docs/reasoningbank/models/safla/node_modules/file-uri-to-path/test/tests.json +13 -0
- package/docs/reasoningbank/models/safla/node_modules/fs-constants/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/fs-constants/README.md +26 -0
- package/docs/reasoningbank/models/safla/node_modules/fs-constants/browser.js +1 -0
- package/docs/reasoningbank/models/safla/node_modules/fs-constants/index.js +1 -0
- package/docs/reasoningbank/models/safla/node_modules/fs-constants/package.json +19 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/.travis.yml +4 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/LICENSE +18 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/example/package.json +8 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/example/url.js +3 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/index.js +17 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/package.json +30 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/readme.markdown +53 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/a.json +8 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/b.json +5 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/c.json +5 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/d.json +7 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/e.json +5 -0
- package/docs/reasoningbank/models/safla/node_modules/github-from-package/test/url.js +19 -0
- package/docs/reasoningbank/models/safla/node_modules/ieee754/LICENSE +11 -0
- package/docs/reasoningbank/models/safla/node_modules/ieee754/README.md +51 -0
- package/docs/reasoningbank/models/safla/node_modules/ieee754/index.d.ts +10 -0
- package/docs/reasoningbank/models/safla/node_modules/ieee754/index.js +85 -0
- package/docs/reasoningbank/models/safla/node_modules/ieee754/package.json +52 -0
- package/docs/reasoningbank/models/safla/node_modules/inherits/LICENSE +16 -0
- package/docs/reasoningbank/models/safla/node_modules/inherits/README.md +42 -0
- package/docs/reasoningbank/models/safla/node_modules/inherits/inherits.js +9 -0
- package/docs/reasoningbank/models/safla/node_modules/inherits/inherits_browser.js +27 -0
- package/docs/reasoningbank/models/safla/node_modules/inherits/package.json +29 -0
- package/docs/reasoningbank/models/safla/node_modules/ini/LICENSE +15 -0
- package/docs/reasoningbank/models/safla/node_modules/ini/README.md +102 -0
- package/docs/reasoningbank/models/safla/node_modules/ini/ini.js +206 -0
- package/docs/reasoningbank/models/safla/node_modules/ini/package.json +33 -0
- package/docs/reasoningbank/models/safla/node_modules/mimic-response/index.d.ts +17 -0
- package/docs/reasoningbank/models/safla/node_modules/mimic-response/index.js +77 -0
- package/docs/reasoningbank/models/safla/node_modules/mimic-response/license +9 -0
- package/docs/reasoningbank/models/safla/node_modules/mimic-response/package.json +42 -0
- package/docs/reasoningbank/models/safla/node_modules/mimic-response/readme.md +78 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/.eslintrc +29 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/.github/FUNDING.yml +12 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/.nycrc +14 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/CHANGELOG.md +298 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/LICENSE +18 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/README.md +121 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/example/parse.js +4 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/index.js +263 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/package.json +75 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/all_bool.js +34 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/bool.js +177 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/dash.js +43 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/default_bool.js +37 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/dotted.js +24 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/kv_short.js +32 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/long.js +33 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/num.js +38 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/parse.js +209 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/parse_modified.js +11 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/proto.js +64 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/short.js +69 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/stop_early.js +17 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/unknown.js +104 -0
- package/docs/reasoningbank/models/safla/node_modules/minimist/test/whitespace.js +10 -0
- package/docs/reasoningbank/models/safla/node_modules/mkdirp-classic/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/mkdirp-classic/README.md +18 -0
- package/docs/reasoningbank/models/safla/node_modules/mkdirp-classic/index.js +98 -0
- package/docs/reasoningbank/models/safla/node_modules/mkdirp-classic/package.json +18 -0
- package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/.github/workflows/run-npm-tests.yml +31 -0
- package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/README.md +52 -0
- package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/index.js +214 -0
- package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/index.md +0 -0
- package/docs/reasoningbank/models/safla/node_modules/napi-build-utils/package.json +42 -0
- package/docs/reasoningbank/models/safla/node_modules/node-abi/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/node-abi/README.md +54 -0
- package/docs/reasoningbank/models/safla/node_modules/node-abi/abi_registry.json +408 -0
- package/docs/reasoningbank/models/safla/node_modules/node-abi/index.js +179 -0
- package/docs/reasoningbank/models/safla/node_modules/node-abi/package.json +45 -0
- package/docs/reasoningbank/models/safla/node_modules/once/LICENSE +15 -0
- package/docs/reasoningbank/models/safla/node_modules/once/README.md +79 -0
- package/docs/reasoningbank/models/safla/node_modules/once/once.js +42 -0
- package/docs/reasoningbank/models/safla/node_modules/once/package.json +33 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/CHANGELOG.md +131 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/CONTRIBUTING.md +6 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/README.md +163 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/asset.js +44 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/bin.js +78 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/download.js +142 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/error.js +14 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/help.txt +16 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/index.js +1 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/log.js +33 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/package.json +67 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/proxy.js +35 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/rc.js +64 -0
- package/docs/reasoningbank/models/safla/node_modules/prebuild-install/util.js +143 -0
- package/docs/reasoningbank/models/safla/node_modules/pump/.github/FUNDING.yml +2 -0
- package/docs/reasoningbank/models/safla/node_modules/pump/.travis.yml +5 -0
- package/docs/reasoningbank/models/safla/node_modules/pump/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/pump/README.md +74 -0
- package/docs/reasoningbank/models/safla/node_modules/pump/SECURITY.md +5 -0
- package/docs/reasoningbank/models/safla/node_modules/pump/index.js +86 -0
- package/docs/reasoningbank/models/safla/node_modules/pump/package.json +24 -0
- package/docs/reasoningbank/models/safla/node_modules/pump/test-browser.js +66 -0
- package/docs/reasoningbank/models/safla/node_modules/pump/test-node.js +53 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/LICENSE.APACHE2 +15 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/LICENSE.BSD +26 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/LICENSE.MIT +24 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/README.md +227 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/browser.js +7 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/cli.js +4 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/index.js +53 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/lib/utils.js +104 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/package.json +29 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/test/ini.js +16 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/test/nested-env-vars.js +50 -0
- package/docs/reasoningbank/models/safla/node_modules/rc/test/test.js +59 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/CONTRIBUTING.md +38 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/GOVERNANCE.md +136 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/LICENSE +47 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/README.md +106 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/errors-browser.js +127 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/errors.js +116 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/experimentalWarning.js +17 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/_stream_duplex.js +126 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/_stream_passthrough.js +37 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/_stream_readable.js +1027 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/_stream_transform.js +190 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/_stream_writable.js +641 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/async_iterator.js +180 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/buffer_list.js +183 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/destroy.js +96 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +86 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/from-browser.js +3 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/from.js +52 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/pipeline.js +86 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/state.js +22 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/stream-browser.js +1 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/lib/internal/streams/stream.js +1 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/package.json +68 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/readable-browser.js +9 -0
- package/docs/reasoningbank/models/safla/node_modules/readable-stream/readable.js +16 -0
- package/docs/reasoningbank/models/safla/node_modules/safe-buffer/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/safe-buffer/README.md +584 -0
- package/docs/reasoningbank/models/safla/node_modules/safe-buffer/index.d.ts +187 -0
- package/docs/reasoningbank/models/safla/node_modules/safe-buffer/index.js +65 -0
- package/docs/reasoningbank/models/safla/node_modules/safe-buffer/package.json +51 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/LICENSE +15 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/README.md +664 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/bin/semver.js +191 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/classes/comparator.js +143 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/classes/index.js +7 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/classes/range.js +557 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/classes/semver.js +333 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/clean.js +8 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/cmp.js +54 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/coerce.js +62 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/compare-build.js +9 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/compare-loose.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/compare.js +7 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/diff.js +60 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/eq.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/gt.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/gte.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/inc.js +21 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/lt.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/lte.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/major.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/minor.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/neq.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/parse.js +18 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/patch.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/prerelease.js +8 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/rcompare.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/rsort.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/satisfies.js +12 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/sort.js +5 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/functions/valid.js +8 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/index.js +91 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/internal/constants.js +37 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/internal/debug.js +11 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/internal/identifiers.js +29 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/internal/lrucache.js +42 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/internal/parse-options.js +17 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/internal/re.js +223 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/package.json +78 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/preload.js +4 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/range.bnf +16 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/ranges/gtr.js +6 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/ranges/intersects.js +9 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/ranges/ltr.js +6 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/ranges/max-satisfying.js +27 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/ranges/min-satisfying.js +26 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/ranges/min-version.js +63 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/ranges/outside.js +82 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/ranges/simplify.js +49 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/ranges/subset.js +249 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/ranges/to-comparators.js +10 -0
- package/docs/reasoningbank/models/safla/node_modules/semver/ranges/valid.js +13 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-concat/.travis.yml +3 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-concat/LICENSE +20 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-concat/README.md +44 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-concat/index.js +15 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-concat/package.json +47 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-concat/test/basic.js +41 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-get/.github/dependabot.yml +15 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-get/.github/workflows/ci.yml +23 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-get/LICENSE +20 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-get/README.md +333 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-get/index.js +108 -0
- package/docs/reasoningbank/models/safla/node_modules/simple-get/package.json +67 -0
- package/docs/reasoningbank/models/safla/node_modules/string_decoder/LICENSE +48 -0
- package/docs/reasoningbank/models/safla/node_modules/string_decoder/README.md +47 -0
- package/docs/reasoningbank/models/safla/node_modules/string_decoder/lib/string_decoder.js +296 -0
- package/docs/reasoningbank/models/safla/node_modules/string_decoder/package.json +34 -0
- package/docs/reasoningbank/models/safla/node_modules/strip-json-comments/index.js +70 -0
- package/docs/reasoningbank/models/safla/node_modules/strip-json-comments/license +21 -0
- package/docs/reasoningbank/models/safla/node_modules/strip-json-comments/package.json +42 -0
- package/docs/reasoningbank/models/safla/node_modules/strip-json-comments/readme.md +64 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/.travis.yml +6 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/README.md +165 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/index.js +363 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/package.json +41 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/a/hello.txt +1 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/b/a/test.txt +1 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/d/file1 +0 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/d/file2 +0 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/d/sub-dir/file5 +0 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/d/sub-files/file3 +0 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/d/sub-files/file4 +0 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/e/directory/.ignore +0 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/e/file +0 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/fixtures/invalid.tar +0 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-fs/test/index.js +346 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-stream/LICENSE +21 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-stream/README.md +168 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-stream/extract.js +257 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-stream/headers.js +295 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-stream/index.js +2 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-stream/pack.js +255 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-stream/package.json +58 -0
- package/docs/reasoningbank/models/safla/node_modules/tar-stream/sandbox.js +11 -0
- package/docs/reasoningbank/models/safla/node_modules/tunnel-agent/LICENSE +55 -0
- package/docs/reasoningbank/models/safla/node_modules/tunnel-agent/README.md +4 -0
- package/docs/reasoningbank/models/safla/node_modules/tunnel-agent/index.js +244 -0
- package/docs/reasoningbank/models/safla/node_modules/tunnel-agent/package.json +22 -0
- package/docs/reasoningbank/models/safla/node_modules/util-deprecate/History.md +16 -0
- package/docs/reasoningbank/models/safla/node_modules/util-deprecate/LICENSE +24 -0
- package/docs/reasoningbank/models/safla/node_modules/util-deprecate/README.md +53 -0
- package/docs/reasoningbank/models/safla/node_modules/util-deprecate/browser.js +67 -0
- package/docs/reasoningbank/models/safla/node_modules/util-deprecate/node.js +6 -0
- package/docs/reasoningbank/models/safla/node_modules/util-deprecate/package.json +27 -0
- package/docs/reasoningbank/models/safla/node_modules/wrappy/LICENSE +15 -0
- package/docs/reasoningbank/models/safla/node_modules/wrappy/README.md +36 -0
- package/docs/reasoningbank/models/safla/node_modules/wrappy/package.json +29 -0
- package/docs/reasoningbank/models/safla/node_modules/wrappy/wrappy.js +33 -0
- package/docs/reasoningbank/models/safla/package-lock.json +463 -0
- package/docs/reasoningbank/models/safla/package.json +14 -0
- package/docs/reasoningbank/models/safla/train-safla.js +524 -0
- package/docs/reasoningbank/models/safla/training.log +64 -0
- package/docs/reasoningbank/models/safla/validate-safla.js +449 -0
- package/docs/reasoningbank/models/safla/validation-report.md +115 -0
- package/docs/reasoningbank/models/safla/validation-results.json +189 -0
- package/docs/reasoningbank/tutorial-advanced.md +869 -0
- package/docs/reasoningbank/tutorial-basic.md +626 -0
- package/docs/skills/skills-tutorial.md +2910 -0
- package/package.json +4 -3
- package/src/cli/simple-commands/init/index.js +15 -0
- package/src/cli/simple-commands/init/skills-copier.js +197 -0
- package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +0 -54
- package/.claude/commands/analysis/bottleneck-detect.md +0 -162
- package/.claude/commands/analysis/performance-bottlenecks.md +0 -59
- package/.claude/commands/analysis/performance-report.md +0 -25
- package/.claude/commands/flow-nexus/app-store.md +0 -124
- package/.claude/commands/flow-nexus/challenges.md +0 -120
- package/.claude/commands/flow-nexus/login-registration.md +0 -65
- package/.claude/commands/flow-nexus/neural-network.md +0 -134
- package/.claude/commands/flow-nexus/payments.md +0 -116
- package/.claude/commands/flow-nexus/sandbox.md +0 -83
- package/.claude/commands/flow-nexus/swarm.md +0 -87
- package/.claude/commands/flow-nexus/user-tools.md +0 -152
- package/.claude/commands/flow-nexus/workflow.md +0 -115
- package/.claude/commands/github/code-review-swarm.md +0 -514
- package/.claude/commands/github/github-modes.md +0 -147
- package/.claude/commands/github/issue-tracker.md +0 -292
- package/.claude/commands/github/multi-repo-swarm.md +0 -519
- package/.claude/commands/github/pr-manager.md +0 -170
- package/.claude/commands/github/project-board-sync.md +0 -471
- package/.claude/commands/github/release-manager.md +0 -338
- package/.claude/commands/github/release-swarm.md +0 -544
- package/.claude/commands/github/repo-architect.md +0 -367
- package/.claude/commands/github/swarm-issue.md +0 -482
- package/.claude/commands/github/swarm-pr.md +0 -285
- package/.claude/commands/github/sync-coordinator.md +0 -301
- package/.claude/commands/github/workflow-automation.md +0 -442
- package/.claude/commands/hive-mind/hive-mind-resume.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-sessions.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-stop.md +0 -8
- package/.claude/commands/hive-mind/hive-mind-wizard.md +0 -8
- package/.claude/commands/hive-mind/hive-mind.md +0 -27
- package/.claude/commands/hooks/overview.md +0 -132
- package/.claude/commands/memory/usage.md +0 -46
- package/.claude/commands/pair/commands.md +0 -546
- package/.claude/commands/pair/config.md +0 -510
- package/.claude/commands/pair/examples.md +0 -512
- package/.claude/commands/pair/modes.md +0 -348
- package/.claude/commands/pair/session.md +0 -407
- package/.claude/commands/pair/start.md +0 -209
- package/.claude/commands/sparc/orchestrator.md +0 -132
- package/.claude/commands/sparc/sparc-modes.md +0 -174
- package/.claude/commands/stream-chain/pipeline.md +0 -121
- package/.claude/commands/stream-chain/run.md +0 -70
- package/.claude/commands/swarm/analysis.md +0 -95
- package/.claude/commands/swarm/development.md +0 -96
- package/.claude/commands/swarm/examples.md +0 -168
- package/.claude/commands/swarm/maintenance.md +0 -102
- package/.claude/commands/swarm/optimization.md +0 -117
- package/.claude/commands/swarm/research.md +0 -136
- package/.claude/commands/swarm/swarm-analysis.md +0 -8
- package/.claude/commands/swarm/swarm-spawn.md +0 -19
- package/.claude/commands/swarm/swarm-strategies.md +0 -8
- package/.claude/commands/swarm/testing.md +0 -131
- package/.claude/commands/truth/start.md +0 -143
- package/.claude/commands/verify/check.md +0 -50
- package/.claude/commands/verify/start.md +0 -128
- /package/{.claude/agents → docs}/reasoning/README.md +0 -0
- /package/{.claude/agents → docs}/reasoning/example-reasoning-agent-template.md +0 -0
|
@@ -0,0 +1,396 @@
|
|
|
1
|
+
'use strict'
|
|
2
|
+
|
|
3
|
+
const { Buffer } = require('buffer')
|
|
4
|
+
const symbol = Symbol.for('BufferList')
|
|
5
|
+
|
|
6
|
+
function BufferList (buf) {
|
|
7
|
+
if (!(this instanceof BufferList)) {
|
|
8
|
+
return new BufferList(buf)
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
BufferList._init.call(this, buf)
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
BufferList._init = function _init (buf) {
|
|
15
|
+
Object.defineProperty(this, symbol, { value: true })
|
|
16
|
+
|
|
17
|
+
this._bufs = []
|
|
18
|
+
this.length = 0
|
|
19
|
+
|
|
20
|
+
if (buf) {
|
|
21
|
+
this.append(buf)
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
BufferList.prototype._new = function _new (buf) {
|
|
26
|
+
return new BufferList(buf)
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
BufferList.prototype._offset = function _offset (offset) {
|
|
30
|
+
if (offset === 0) {
|
|
31
|
+
return [0, 0]
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
let tot = 0
|
|
35
|
+
|
|
36
|
+
for (let i = 0; i < this._bufs.length; i++) {
|
|
37
|
+
const _t = tot + this._bufs[i].length
|
|
38
|
+
if (offset < _t || i === this._bufs.length - 1) {
|
|
39
|
+
return [i, offset - tot]
|
|
40
|
+
}
|
|
41
|
+
tot = _t
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
BufferList.prototype._reverseOffset = function (blOffset) {
|
|
46
|
+
const bufferId = blOffset[0]
|
|
47
|
+
let offset = blOffset[1]
|
|
48
|
+
|
|
49
|
+
for (let i = 0; i < bufferId; i++) {
|
|
50
|
+
offset += this._bufs[i].length
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
return offset
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
BufferList.prototype.get = function get (index) {
|
|
57
|
+
if (index > this.length || index < 0) {
|
|
58
|
+
return undefined
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
const offset = this._offset(index)
|
|
62
|
+
|
|
63
|
+
return this._bufs[offset[0]][offset[1]]
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
BufferList.prototype.slice = function slice (start, end) {
|
|
67
|
+
if (typeof start === 'number' && start < 0) {
|
|
68
|
+
start += this.length
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
if (typeof end === 'number' && end < 0) {
|
|
72
|
+
end += this.length
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
return this.copy(null, 0, start, end)
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
BufferList.prototype.copy = function copy (dst, dstStart, srcStart, srcEnd) {
|
|
79
|
+
if (typeof srcStart !== 'number' || srcStart < 0) {
|
|
80
|
+
srcStart = 0
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
if (typeof srcEnd !== 'number' || srcEnd > this.length) {
|
|
84
|
+
srcEnd = this.length
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
if (srcStart >= this.length) {
|
|
88
|
+
return dst || Buffer.alloc(0)
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
if (srcEnd <= 0) {
|
|
92
|
+
return dst || Buffer.alloc(0)
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
const copy = !!dst
|
|
96
|
+
const off = this._offset(srcStart)
|
|
97
|
+
const len = srcEnd - srcStart
|
|
98
|
+
let bytes = len
|
|
99
|
+
let bufoff = (copy && dstStart) || 0
|
|
100
|
+
let start = off[1]
|
|
101
|
+
|
|
102
|
+
// copy/slice everything
|
|
103
|
+
if (srcStart === 0 && srcEnd === this.length) {
|
|
104
|
+
if (!copy) {
|
|
105
|
+
// slice, but full concat if multiple buffers
|
|
106
|
+
return this._bufs.length === 1
|
|
107
|
+
? this._bufs[0]
|
|
108
|
+
: Buffer.concat(this._bufs, this.length)
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
// copy, need to copy individual buffers
|
|
112
|
+
for (let i = 0; i < this._bufs.length; i++) {
|
|
113
|
+
this._bufs[i].copy(dst, bufoff)
|
|
114
|
+
bufoff += this._bufs[i].length
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
return dst
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
// easy, cheap case where it's a subset of one of the buffers
|
|
121
|
+
if (bytes <= this._bufs[off[0]].length - start) {
|
|
122
|
+
return copy
|
|
123
|
+
? this._bufs[off[0]].copy(dst, dstStart, start, start + bytes)
|
|
124
|
+
: this._bufs[off[0]].slice(start, start + bytes)
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
if (!copy) {
|
|
128
|
+
// a slice, we need something to copy in to
|
|
129
|
+
dst = Buffer.allocUnsafe(len)
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
for (let i = off[0]; i < this._bufs.length; i++) {
|
|
133
|
+
const l = this._bufs[i].length - start
|
|
134
|
+
|
|
135
|
+
if (bytes > l) {
|
|
136
|
+
this._bufs[i].copy(dst, bufoff, start)
|
|
137
|
+
bufoff += l
|
|
138
|
+
} else {
|
|
139
|
+
this._bufs[i].copy(dst, bufoff, start, start + bytes)
|
|
140
|
+
bufoff += l
|
|
141
|
+
break
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
bytes -= l
|
|
145
|
+
|
|
146
|
+
if (start) {
|
|
147
|
+
start = 0
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
// safeguard so that we don't return uninitialized memory
|
|
152
|
+
if (dst.length > bufoff) return dst.slice(0, bufoff)
|
|
153
|
+
|
|
154
|
+
return dst
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
BufferList.prototype.shallowSlice = function shallowSlice (start, end) {
|
|
158
|
+
start = start || 0
|
|
159
|
+
end = typeof end !== 'number' ? this.length : end
|
|
160
|
+
|
|
161
|
+
if (start < 0) {
|
|
162
|
+
start += this.length
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
if (end < 0) {
|
|
166
|
+
end += this.length
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
if (start === end) {
|
|
170
|
+
return this._new()
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
const startOffset = this._offset(start)
|
|
174
|
+
const endOffset = this._offset(end)
|
|
175
|
+
const buffers = this._bufs.slice(startOffset[0], endOffset[0] + 1)
|
|
176
|
+
|
|
177
|
+
if (endOffset[1] === 0) {
|
|
178
|
+
buffers.pop()
|
|
179
|
+
} else {
|
|
180
|
+
buffers[buffers.length - 1] = buffers[buffers.length - 1].slice(0, endOffset[1])
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
if (startOffset[1] !== 0) {
|
|
184
|
+
buffers[0] = buffers[0].slice(startOffset[1])
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
return this._new(buffers)
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
BufferList.prototype.toString = function toString (encoding, start, end) {
|
|
191
|
+
return this.slice(start, end).toString(encoding)
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
BufferList.prototype.consume = function consume (bytes) {
|
|
195
|
+
// first, normalize the argument, in accordance with how Buffer does it
|
|
196
|
+
bytes = Math.trunc(bytes)
|
|
197
|
+
// do nothing if not a positive number
|
|
198
|
+
if (Number.isNaN(bytes) || bytes <= 0) return this
|
|
199
|
+
|
|
200
|
+
while (this._bufs.length) {
|
|
201
|
+
if (bytes >= this._bufs[0].length) {
|
|
202
|
+
bytes -= this._bufs[0].length
|
|
203
|
+
this.length -= this._bufs[0].length
|
|
204
|
+
this._bufs.shift()
|
|
205
|
+
} else {
|
|
206
|
+
this._bufs[0] = this._bufs[0].slice(bytes)
|
|
207
|
+
this.length -= bytes
|
|
208
|
+
break
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
return this
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
BufferList.prototype.duplicate = function duplicate () {
|
|
216
|
+
const copy = this._new()
|
|
217
|
+
|
|
218
|
+
for (let i = 0; i < this._bufs.length; i++) {
|
|
219
|
+
copy.append(this._bufs[i])
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
return copy
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
BufferList.prototype.append = function append (buf) {
|
|
226
|
+
if (buf == null) {
|
|
227
|
+
return this
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
if (buf.buffer) {
|
|
231
|
+
// append a view of the underlying ArrayBuffer
|
|
232
|
+
this._appendBuffer(Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength))
|
|
233
|
+
} else if (Array.isArray(buf)) {
|
|
234
|
+
for (let i = 0; i < buf.length; i++) {
|
|
235
|
+
this.append(buf[i])
|
|
236
|
+
}
|
|
237
|
+
} else if (this._isBufferList(buf)) {
|
|
238
|
+
// unwrap argument into individual BufferLists
|
|
239
|
+
for (let i = 0; i < buf._bufs.length; i++) {
|
|
240
|
+
this.append(buf._bufs[i])
|
|
241
|
+
}
|
|
242
|
+
} else {
|
|
243
|
+
// coerce number arguments to strings, since Buffer(number) does
|
|
244
|
+
// uninitialized memory allocation
|
|
245
|
+
if (typeof buf === 'number') {
|
|
246
|
+
buf = buf.toString()
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
this._appendBuffer(Buffer.from(buf))
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
return this
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
BufferList.prototype._appendBuffer = function appendBuffer (buf) {
|
|
256
|
+
this._bufs.push(buf)
|
|
257
|
+
this.length += buf.length
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
BufferList.prototype.indexOf = function (search, offset, encoding) {
|
|
261
|
+
if (encoding === undefined && typeof offset === 'string') {
|
|
262
|
+
encoding = offset
|
|
263
|
+
offset = undefined
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
if (typeof search === 'function' || Array.isArray(search)) {
|
|
267
|
+
throw new TypeError('The "value" argument must be one of type string, Buffer, BufferList, or Uint8Array.')
|
|
268
|
+
} else if (typeof search === 'number') {
|
|
269
|
+
search = Buffer.from([search])
|
|
270
|
+
} else if (typeof search === 'string') {
|
|
271
|
+
search = Buffer.from(search, encoding)
|
|
272
|
+
} else if (this._isBufferList(search)) {
|
|
273
|
+
search = search.slice()
|
|
274
|
+
} else if (Array.isArray(search.buffer)) {
|
|
275
|
+
search = Buffer.from(search.buffer, search.byteOffset, search.byteLength)
|
|
276
|
+
} else if (!Buffer.isBuffer(search)) {
|
|
277
|
+
search = Buffer.from(search)
|
|
278
|
+
}
|
|
279
|
+
|
|
280
|
+
offset = Number(offset || 0)
|
|
281
|
+
|
|
282
|
+
if (isNaN(offset)) {
|
|
283
|
+
offset = 0
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
if (offset < 0) {
|
|
287
|
+
offset = this.length + offset
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
if (offset < 0) {
|
|
291
|
+
offset = 0
|
|
292
|
+
}
|
|
293
|
+
|
|
294
|
+
if (search.length === 0) {
|
|
295
|
+
return offset > this.length ? this.length : offset
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
const blOffset = this._offset(offset)
|
|
299
|
+
let blIndex = blOffset[0] // index of which internal buffer we're working on
|
|
300
|
+
let buffOffset = blOffset[1] // offset of the internal buffer we're working on
|
|
301
|
+
|
|
302
|
+
// scan over each buffer
|
|
303
|
+
for (; blIndex < this._bufs.length; blIndex++) {
|
|
304
|
+
const buff = this._bufs[blIndex]
|
|
305
|
+
|
|
306
|
+
while (buffOffset < buff.length) {
|
|
307
|
+
const availableWindow = buff.length - buffOffset
|
|
308
|
+
|
|
309
|
+
if (availableWindow >= search.length) {
|
|
310
|
+
const nativeSearchResult = buff.indexOf(search, buffOffset)
|
|
311
|
+
|
|
312
|
+
if (nativeSearchResult !== -1) {
|
|
313
|
+
return this._reverseOffset([blIndex, nativeSearchResult])
|
|
314
|
+
}
|
|
315
|
+
|
|
316
|
+
buffOffset = buff.length - search.length + 1 // end of native search window
|
|
317
|
+
} else {
|
|
318
|
+
const revOffset = this._reverseOffset([blIndex, buffOffset])
|
|
319
|
+
|
|
320
|
+
if (this._match(revOffset, search)) {
|
|
321
|
+
return revOffset
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
buffOffset++
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
buffOffset = 0
|
|
329
|
+
}
|
|
330
|
+
|
|
331
|
+
return -1
|
|
332
|
+
}
|
|
333
|
+
|
|
334
|
+
BufferList.prototype._match = function (offset, search) {
|
|
335
|
+
if (this.length - offset < search.length) {
|
|
336
|
+
return false
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
for (let searchOffset = 0; searchOffset < search.length; searchOffset++) {
|
|
340
|
+
if (this.get(offset + searchOffset) !== search[searchOffset]) {
|
|
341
|
+
return false
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
return true
|
|
345
|
+
}
|
|
346
|
+
|
|
347
|
+
;(function () {
|
|
348
|
+
const methods = {
|
|
349
|
+
readDoubleBE: 8,
|
|
350
|
+
readDoubleLE: 8,
|
|
351
|
+
readFloatBE: 4,
|
|
352
|
+
readFloatLE: 4,
|
|
353
|
+
readInt32BE: 4,
|
|
354
|
+
readInt32LE: 4,
|
|
355
|
+
readUInt32BE: 4,
|
|
356
|
+
readUInt32LE: 4,
|
|
357
|
+
readInt16BE: 2,
|
|
358
|
+
readInt16LE: 2,
|
|
359
|
+
readUInt16BE: 2,
|
|
360
|
+
readUInt16LE: 2,
|
|
361
|
+
readInt8: 1,
|
|
362
|
+
readUInt8: 1,
|
|
363
|
+
readIntBE: null,
|
|
364
|
+
readIntLE: null,
|
|
365
|
+
readUIntBE: null,
|
|
366
|
+
readUIntLE: null
|
|
367
|
+
}
|
|
368
|
+
|
|
369
|
+
for (const m in methods) {
|
|
370
|
+
(function (m) {
|
|
371
|
+
if (methods[m] === null) {
|
|
372
|
+
BufferList.prototype[m] = function (offset, byteLength) {
|
|
373
|
+
return this.slice(offset, offset + byteLength)[m](0, byteLength)
|
|
374
|
+
}
|
|
375
|
+
} else {
|
|
376
|
+
BufferList.prototype[m] = function (offset = 0) {
|
|
377
|
+
return this.slice(offset, offset + methods[m])[m](0)
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
}(m))
|
|
381
|
+
}
|
|
382
|
+
}())
|
|
383
|
+
|
|
384
|
+
// Used internally by the class and also as an indicator of this object being
|
|
385
|
+
// a `BufferList`. It's not possible to use `instanceof BufferList` in a browser
|
|
386
|
+
// environment because there could be multiple different copies of the
|
|
387
|
+
// BufferList class and some `BufferList`s might be `BufferList`s.
|
|
388
|
+
BufferList.prototype._isBufferList = function _isBufferList (b) {
|
|
389
|
+
return b instanceof BufferList || BufferList.isBufferList(b)
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
BufferList.isBufferList = function isBufferList (b) {
|
|
393
|
+
return b != null && b[symbol]
|
|
394
|
+
}
|
|
395
|
+
|
|
396
|
+
module.exports = BufferList
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
The MIT License (MIT)
|
|
2
|
+
=====================
|
|
3
|
+
|
|
4
|
+
Copyright (c) 2013-2019 bl contributors
|
|
5
|
+
----------------------------------
|
|
6
|
+
|
|
7
|
+
*bl contributors listed at <https://github.com/rvagg/bl#contributors>*
|
|
8
|
+
|
|
9
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
10
|
+
|
|
11
|
+
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
12
|
+
|
|
13
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
@@ -0,0 +1,247 @@
|
|
|
1
|
+
# bl *(BufferList)*
|
|
2
|
+
|
|
3
|
+
[](https://travis-ci.com/rvagg/bl/)
|
|
4
|
+
|
|
5
|
+
**A Node.js Buffer list collector, reader and streamer thingy.**
|
|
6
|
+
|
|
7
|
+
[](https://nodei.co/npm/bl/)
|
|
8
|
+
|
|
9
|
+
**bl** is a storage object for collections of Node Buffers, exposing them with the main Buffer readable API. Also works as a duplex stream so you can collect buffers from a stream that emits them and emit buffers to a stream that consumes them!
|
|
10
|
+
|
|
11
|
+
The original buffers are kept intact and copies are only done as necessary. Any reads that require the use of a single original buffer will return a slice of that buffer only (which references the same memory as the original buffer). Reads that span buffers perform concatenation as required and return the results transparently.
|
|
12
|
+
|
|
13
|
+
```js
|
|
14
|
+
const { BufferList } = require('bl')
|
|
15
|
+
|
|
16
|
+
const bl = new BufferList()
|
|
17
|
+
bl.append(Buffer.from('abcd'))
|
|
18
|
+
bl.append(Buffer.from('efg'))
|
|
19
|
+
bl.append('hi') // bl will also accept & convert Strings
|
|
20
|
+
bl.append(Buffer.from('j'))
|
|
21
|
+
bl.append(Buffer.from([ 0x3, 0x4 ]))
|
|
22
|
+
|
|
23
|
+
console.log(bl.length) // 12
|
|
24
|
+
|
|
25
|
+
console.log(bl.slice(0, 10).toString('ascii')) // 'abcdefghij'
|
|
26
|
+
console.log(bl.slice(3, 10).toString('ascii')) // 'defghij'
|
|
27
|
+
console.log(bl.slice(3, 6).toString('ascii')) // 'def'
|
|
28
|
+
console.log(bl.slice(3, 8).toString('ascii')) // 'defgh'
|
|
29
|
+
console.log(bl.slice(5, 10).toString('ascii')) // 'fghij'
|
|
30
|
+
|
|
31
|
+
console.log(bl.indexOf('def')) // 3
|
|
32
|
+
console.log(bl.indexOf('asdf')) // -1
|
|
33
|
+
|
|
34
|
+
// or just use toString!
|
|
35
|
+
console.log(bl.toString()) // 'abcdefghij\u0003\u0004'
|
|
36
|
+
console.log(bl.toString('ascii', 3, 8)) // 'defgh'
|
|
37
|
+
console.log(bl.toString('ascii', 5, 10)) // 'fghij'
|
|
38
|
+
|
|
39
|
+
// other standard Buffer readables
|
|
40
|
+
console.log(bl.readUInt16BE(10)) // 0x0304
|
|
41
|
+
console.log(bl.readUInt16LE(10)) // 0x0403
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
Give it a callback in the constructor and use it just like **[concat-stream](https://github.com/maxogden/node-concat-stream)**:
|
|
45
|
+
|
|
46
|
+
```js
|
|
47
|
+
const { BufferListStream } = require('bl')
|
|
48
|
+
const fs = require('fs')
|
|
49
|
+
|
|
50
|
+
fs.createReadStream('README.md')
|
|
51
|
+
.pipe(BufferListStream((err, data) => { // note 'new' isn't strictly required
|
|
52
|
+
// `data` is a complete Buffer object containing the full data
|
|
53
|
+
console.log(data.toString())
|
|
54
|
+
}))
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
Note that when you use the *callback* method like this, the resulting `data` parameter is a concatenation of all `Buffer` objects in the list. If you want to avoid the overhead of this concatenation (in cases of extreme performance consciousness), then avoid the *callback* method and just listen to `'end'` instead, like a standard Stream.
|
|
58
|
+
|
|
59
|
+
Or to fetch a URL using [hyperquest](https://github.com/substack/hyperquest) (should work with [request](http://github.com/mikeal/request) and even plain Node http too!):
|
|
60
|
+
|
|
61
|
+
```js
|
|
62
|
+
const hyperquest = require('hyperquest')
|
|
63
|
+
const { BufferListStream } = require('bl')
|
|
64
|
+
|
|
65
|
+
const url = 'https://raw.github.com/rvagg/bl/master/README.md'
|
|
66
|
+
|
|
67
|
+
hyperquest(url).pipe(BufferListStream((err, data) => {
|
|
68
|
+
console.log(data.toString())
|
|
69
|
+
}))
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
Or, use it as a readable stream to recompose a list of Buffers to an output source:
|
|
73
|
+
|
|
74
|
+
```js
|
|
75
|
+
const { BufferListStream } = require('bl')
|
|
76
|
+
const fs = require('fs')
|
|
77
|
+
|
|
78
|
+
var bl = new BufferListStream()
|
|
79
|
+
bl.append(Buffer.from('abcd'))
|
|
80
|
+
bl.append(Buffer.from('efg'))
|
|
81
|
+
bl.append(Buffer.from('hi'))
|
|
82
|
+
bl.append(Buffer.from('j'))
|
|
83
|
+
|
|
84
|
+
bl.pipe(fs.createWriteStream('gibberish.txt'))
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
## API
|
|
88
|
+
|
|
89
|
+
* <a href="#ctor"><code><b>new BufferList([ buf ])</b></code></a>
|
|
90
|
+
* <a href="#isBufferList"><code><b>BufferList.isBufferList(obj)</b></code></a>
|
|
91
|
+
* <a href="#length"><code>bl.<b>length</b></code></a>
|
|
92
|
+
* <a href="#append"><code>bl.<b>append(buffer)</b></code></a>
|
|
93
|
+
* <a href="#get"><code>bl.<b>get(index)</b></code></a>
|
|
94
|
+
* <a href="#indexOf"><code>bl.<b>indexOf(value[, byteOffset][, encoding])</b></code></a>
|
|
95
|
+
* <a href="#slice"><code>bl.<b>slice([ start[, end ] ])</b></code></a>
|
|
96
|
+
* <a href="#shallowSlice"><code>bl.<b>shallowSlice([ start[, end ] ])</b></code></a>
|
|
97
|
+
* <a href="#copy"><code>bl.<b>copy(dest, [ destStart, [ srcStart [, srcEnd ] ] ])</b></code></a>
|
|
98
|
+
* <a href="#duplicate"><code>bl.<b>duplicate()</b></code></a>
|
|
99
|
+
* <a href="#consume"><code>bl.<b>consume(bytes)</b></code></a>
|
|
100
|
+
* <a href="#toString"><code>bl.<b>toString([encoding, [ start, [ end ]]])</b></code></a>
|
|
101
|
+
* <a href="#readXX"><code>bl.<b>readDoubleBE()</b></code>, <code>bl.<b>readDoubleLE()</b></code>, <code>bl.<b>readFloatBE()</b></code>, <code>bl.<b>readFloatLE()</b></code>, <code>bl.<b>readInt32BE()</b></code>, <code>bl.<b>readInt32LE()</b></code>, <code>bl.<b>readUInt32BE()</b></code>, <code>bl.<b>readUInt32LE()</b></code>, <code>bl.<b>readInt16BE()</b></code>, <code>bl.<b>readInt16LE()</b></code>, <code>bl.<b>readUInt16BE()</b></code>, <code>bl.<b>readUInt16LE()</b></code>, <code>bl.<b>readInt8()</b></code>, <code>bl.<b>readUInt8()</b></code></a>
|
|
102
|
+
* <a href="#ctorStream"><code><b>new BufferListStream([ callback ])</b></code></a>
|
|
103
|
+
|
|
104
|
+
--------------------------------------------------------
|
|
105
|
+
<a name="ctor"></a>
|
|
106
|
+
### new BufferList([ Buffer | Buffer array | BufferList | BufferList array | String ])
|
|
107
|
+
No arguments are _required_ for the constructor, but you can initialise the list by passing in a single `Buffer` object or an array of `Buffer` objects.
|
|
108
|
+
|
|
109
|
+
`new` is not strictly required, if you don't instantiate a new object, it will be done automatically for you so you can create a new instance simply with:
|
|
110
|
+
|
|
111
|
+
```js
|
|
112
|
+
const { BufferList } = require('bl')
|
|
113
|
+
const bl = BufferList()
|
|
114
|
+
|
|
115
|
+
// equivalent to:
|
|
116
|
+
|
|
117
|
+
const { BufferList } = require('bl')
|
|
118
|
+
const bl = new BufferList()
|
|
119
|
+
```
|
|
120
|
+
|
|
121
|
+
--------------------------------------------------------
|
|
122
|
+
<a name="isBufferList"></a>
|
|
123
|
+
### BufferList.isBufferList(obj)
|
|
124
|
+
Determines if the passed object is a `BufferList`. It will return `true` if the passed object is an instance of `BufferList` **or** `BufferListStream` and `false` otherwise.
|
|
125
|
+
|
|
126
|
+
N.B. this won't return `true` for `BufferList` or `BufferListStream` instances created by versions of this library before this static method was added.
|
|
127
|
+
|
|
128
|
+
--------------------------------------------------------
|
|
129
|
+
<a name="length"></a>
|
|
130
|
+
### bl.length
|
|
131
|
+
Get the length of the list in bytes. This is the sum of the lengths of all of the buffers contained in the list, minus any initial offset for a semi-consumed buffer at the beginning. Should accurately represent the total number of bytes that can be read from the list.
|
|
132
|
+
|
|
133
|
+
--------------------------------------------------------
|
|
134
|
+
<a name="append"></a>
|
|
135
|
+
### bl.append(Buffer | Buffer array | BufferList | BufferList array | String)
|
|
136
|
+
`append(buffer)` adds an additional buffer or BufferList to the internal list. `this` is returned so it can be chained.
|
|
137
|
+
|
|
138
|
+
--------------------------------------------------------
|
|
139
|
+
<a name="get"></a>
|
|
140
|
+
### bl.get(index)
|
|
141
|
+
`get()` will return the byte at the specified index.
|
|
142
|
+
|
|
143
|
+
--------------------------------------------------------
|
|
144
|
+
<a name="indexOf"></a>
|
|
145
|
+
### bl.indexOf(value[, byteOffset][, encoding])
|
|
146
|
+
`get()` will return the byte at the specified index.
|
|
147
|
+
`indexOf()` method returns the first index at which a given element can be found in the BufferList, or -1 if it is not present.
|
|
148
|
+
|
|
149
|
+
--------------------------------------------------------
|
|
150
|
+
<a name="slice"></a>
|
|
151
|
+
### bl.slice([ start, [ end ] ])
|
|
152
|
+
`slice()` returns a new `Buffer` object containing the bytes within the range specified. Both `start` and `end` are optional and will default to the beginning and end of the list respectively.
|
|
153
|
+
|
|
154
|
+
If the requested range spans a single internal buffer then a slice of that buffer will be returned which shares the original memory range of that Buffer. If the range spans multiple buffers then copy operations will likely occur to give you a uniform Buffer.
|
|
155
|
+
|
|
156
|
+
--------------------------------------------------------
|
|
157
|
+
<a name="shallowSlice"></a>
|
|
158
|
+
### bl.shallowSlice([ start, [ end ] ])
|
|
159
|
+
`shallowSlice()` returns a new `BufferList` object containing the bytes within the range specified. Both `start` and `end` are optional and will default to the beginning and end of the list respectively.
|
|
160
|
+
|
|
161
|
+
No copies will be performed. All buffers in the result share memory with the original list.
|
|
162
|
+
|
|
163
|
+
--------------------------------------------------------
|
|
164
|
+
<a name="copy"></a>
|
|
165
|
+
### bl.copy(dest, [ destStart, [ srcStart [, srcEnd ] ] ])
|
|
166
|
+
`copy()` copies the content of the list in the `dest` buffer, starting from `destStart` and containing the bytes within the range specified with `srcStart` to `srcEnd`. `destStart`, `start` and `end` are optional and will default to the beginning of the `dest` buffer, and the beginning and end of the list respectively.
|
|
167
|
+
|
|
168
|
+
--------------------------------------------------------
|
|
169
|
+
<a name="duplicate"></a>
|
|
170
|
+
### bl.duplicate()
|
|
171
|
+
`duplicate()` performs a **shallow-copy** of the list. The internal Buffers remains the same, so if you change the underlying Buffers, the change will be reflected in both the original and the duplicate. This method is needed if you want to call `consume()` or `pipe()` and still keep the original list.Example:
|
|
172
|
+
|
|
173
|
+
```js
|
|
174
|
+
var bl = new BufferListStream()
|
|
175
|
+
|
|
176
|
+
bl.append('hello')
|
|
177
|
+
bl.append(' world')
|
|
178
|
+
bl.append('\n')
|
|
179
|
+
|
|
180
|
+
bl.duplicate().pipe(process.stdout, { end: false })
|
|
181
|
+
|
|
182
|
+
console.log(bl.toString())
|
|
183
|
+
```
|
|
184
|
+
|
|
185
|
+
--------------------------------------------------------
|
|
186
|
+
<a name="consume"></a>
|
|
187
|
+
### bl.consume(bytes)
|
|
188
|
+
`consume()` will shift bytes *off the start of the list*. The number of bytes consumed don't need to line up with the sizes of the internal Buffers—initial offsets will be calculated accordingly in order to give you a consistent view of the data.
|
|
189
|
+
|
|
190
|
+
--------------------------------------------------------
|
|
191
|
+
<a name="toString"></a>
|
|
192
|
+
### bl.toString([encoding, [ start, [ end ]]])
|
|
193
|
+
`toString()` will return a string representation of the buffer. The optional `start` and `end` arguments are passed on to `slice()`, while the `encoding` is passed on to `toString()` of the resulting Buffer. See the [Buffer#toString()](http://nodejs.org/docs/latest/api/buffer.html#buffer_buf_tostring_encoding_start_end) documentation for more information.
|
|
194
|
+
|
|
195
|
+
--------------------------------------------------------
|
|
196
|
+
<a name="readXX"></a>
|
|
197
|
+
### bl.readDoubleBE(), bl.readDoubleLE(), bl.readFloatBE(), bl.readFloatLE(), bl.readInt32BE(), bl.readInt32LE(), bl.readUInt32BE(), bl.readUInt32LE(), bl.readInt16BE(), bl.readInt16LE(), bl.readUInt16BE(), bl.readUInt16LE(), bl.readInt8(), bl.readUInt8()
|
|
198
|
+
|
|
199
|
+
All of the standard byte-reading methods of the `Buffer` interface are implemented and will operate across internal Buffer boundaries transparently.
|
|
200
|
+
|
|
201
|
+
See the <b><code>[Buffer](http://nodejs.org/docs/latest/api/buffer.html)</code></b> documentation for how these work.
|
|
202
|
+
|
|
203
|
+
--------------------------------------------------------
|
|
204
|
+
<a name="ctorStream"></a>
|
|
205
|
+
### new BufferListStream([ callback | Buffer | Buffer array | BufferList | BufferList array | String ])
|
|
206
|
+
**BufferListStream** is a Node **[Duplex Stream](http://nodejs.org/docs/latest/api/stream.html#stream_class_stream_duplex)**, so it can be read from and written to like a standard Node stream. You can also `pipe()` to and from a **BufferListStream** instance.
|
|
207
|
+
|
|
208
|
+
The constructor takes an optional callback, if supplied, the callback will be called with an error argument followed by a reference to the **bl** instance, when `bl.end()` is called (i.e. from a piped stream). This is a convenient method of collecting the entire contents of a stream, particularly when the stream is *chunky*, such as a network stream.
|
|
209
|
+
|
|
210
|
+
Normally, no arguments are required for the constructor, but you can initialise the list by passing in a single `Buffer` object or an array of `Buffer` object.
|
|
211
|
+
|
|
212
|
+
`new` is not strictly required, if you don't instantiate a new object, it will be done automatically for you so you can create a new instance simply with:
|
|
213
|
+
|
|
214
|
+
```js
|
|
215
|
+
const { BufferListStream } = require('bl')
|
|
216
|
+
const bl = BufferListStream()
|
|
217
|
+
|
|
218
|
+
// equivalent to:
|
|
219
|
+
|
|
220
|
+
const { BufferListStream } = require('bl')
|
|
221
|
+
const bl = new BufferListStream()
|
|
222
|
+
```
|
|
223
|
+
|
|
224
|
+
N.B. For backwards compatibility reasons, `BufferListStream` is the **default** export when you `require('bl')`:
|
|
225
|
+
|
|
226
|
+
```js
|
|
227
|
+
const { BufferListStream } = require('bl')
|
|
228
|
+
// equivalent to:
|
|
229
|
+
const BufferListStream = require('bl')
|
|
230
|
+
```
|
|
231
|
+
|
|
232
|
+
--------------------------------------------------------
|
|
233
|
+
|
|
234
|
+
## Contributors
|
|
235
|
+
|
|
236
|
+
**bl** is brought to you by the following hackers:
|
|
237
|
+
|
|
238
|
+
* [Rod Vagg](https://github.com/rvagg)
|
|
239
|
+
* [Matteo Collina](https://github.com/mcollina)
|
|
240
|
+
* [Jarett Cruger](https://github.com/jcrugzz)
|
|
241
|
+
|
|
242
|
+
<a name="license"></a>
|
|
243
|
+
## License & copyright
|
|
244
|
+
|
|
245
|
+
Copyright (c) 2013-2019 bl contributors (listed above).
|
|
246
|
+
|
|
247
|
+
bl is licensed under the MIT license. All rights not explicitly granted in the MIT license are reserved. See the included LICENSE.md file for more details.
|