@anthropic-ai/claude-code 0.2.9
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/LICENSE.md +3 -0
- package/README.md +55 -0
- package/cli.mjs +1398 -0
- package/package.json +31 -0
- package/vendor/ripgrep/COPYING +3 -0
- package/vendor/ripgrep/arm64-darwin/rg +0 -0
- package/vendor/ripgrep/arm64-linux/rg +0 -0
- package/vendor/ripgrep/x64-darwin/rg +0 -0
- package/vendor/ripgrep/x64-linux/rg +0 -0
- package/vendor/ripgrep/x64-win32/rg.exe +0 -0
- package/vendor/sdk/CHANGELOG.md +1421 -0
- package/vendor/sdk/LICENSE +8 -0
- package/vendor/sdk/README.md +536 -0
- package/vendor/sdk/_shims/MultipartBody.d.ts +9 -0
- package/vendor/sdk/_shims/MultipartBody.d.ts.map +1 -0
- package/vendor/sdk/_shims/MultipartBody.js +16 -0
- package/vendor/sdk/_shims/MultipartBody.js.map +1 -0
- package/vendor/sdk/_shims/MultipartBody.mjs +12 -0
- package/vendor/sdk/_shims/MultipartBody.mjs.map +1 -0
- package/vendor/sdk/_shims/README.md +46 -0
- package/vendor/sdk/_shims/auto/runtime-bun.d.ts +5 -0
- package/vendor/sdk/_shims/auto/runtime-bun.d.ts.map +1 -0
- package/vendor/sdk/_shims/auto/runtime-bun.js +21 -0
- package/vendor/sdk/_shims/auto/runtime-bun.js.map +1 -0
- package/vendor/sdk/_shims/auto/runtime-bun.mjs +2 -0
- package/vendor/sdk/_shims/auto/runtime-bun.mjs.map +1 -0
- package/vendor/sdk/_shims/auto/runtime-node.d.ts +5 -0
- package/vendor/sdk/_shims/auto/runtime-node.d.ts.map +1 -0
- package/vendor/sdk/_shims/auto/runtime-node.js +21 -0
- package/vendor/sdk/_shims/auto/runtime-node.js.map +1 -0
- package/vendor/sdk/_shims/auto/runtime-node.mjs +2 -0
- package/vendor/sdk/_shims/auto/runtime-node.mjs.map +1 -0
- package/vendor/sdk/_shims/auto/runtime.d.ts +5 -0
- package/vendor/sdk/_shims/auto/runtime.d.ts.map +1 -0
- package/vendor/sdk/_shims/auto/runtime.js +21 -0
- package/vendor/sdk/_shims/auto/runtime.js.map +1 -0
- package/vendor/sdk/_shims/auto/runtime.mjs +2 -0
- package/vendor/sdk/_shims/auto/runtime.mjs.map +1 -0
- package/vendor/sdk/_shims/auto/types-node.d.ts +5 -0
- package/vendor/sdk/_shims/auto/types-node.d.ts.map +1 -0
- package/vendor/sdk/_shims/auto/types-node.js +21 -0
- package/vendor/sdk/_shims/auto/types-node.js.map +1 -0
- package/vendor/sdk/_shims/auto/types-node.mjs +2 -0
- package/vendor/sdk/_shims/auto/types-node.mjs.map +1 -0
- package/vendor/sdk/_shims/auto/types.d.ts +101 -0
- package/vendor/sdk/_shims/auto/types.js +3 -0
- package/vendor/sdk/_shims/auto/types.mjs +3 -0
- package/vendor/sdk/_shims/bun-runtime.d.ts +6 -0
- package/vendor/sdk/_shims/bun-runtime.d.ts.map +1 -0
- package/vendor/sdk/_shims/bun-runtime.js +14 -0
- package/vendor/sdk/_shims/bun-runtime.js.map +1 -0
- package/vendor/sdk/_shims/bun-runtime.mjs +10 -0
- package/vendor/sdk/_shims/bun-runtime.mjs.map +1 -0
- package/vendor/sdk/_shims/index.d.ts +81 -0
- package/vendor/sdk/_shims/index.js +13 -0
- package/vendor/sdk/_shims/index.mjs +7 -0
- package/vendor/sdk/_shims/manual-types.d.ts +12 -0
- package/vendor/sdk/_shims/manual-types.js +3 -0
- package/vendor/sdk/_shims/manual-types.mjs +3 -0
- package/vendor/sdk/_shims/node-runtime.d.ts +3 -0
- package/vendor/sdk/_shims/node-runtime.d.ts.map +1 -0
- package/vendor/sdk/_shims/node-runtime.js +89 -0
- package/vendor/sdk/_shims/node-runtime.js.map +1 -0
- package/vendor/sdk/_shims/node-runtime.mjs +56 -0
- package/vendor/sdk/_shims/node-runtime.mjs.map +1 -0
- package/vendor/sdk/_shims/node-types.d.ts +42 -0
- package/vendor/sdk/_shims/node-types.js +3 -0
- package/vendor/sdk/_shims/node-types.mjs +3 -0
- package/vendor/sdk/_shims/registry.d.ts +37 -0
- package/vendor/sdk/_shims/registry.d.ts.map +1 -0
- package/vendor/sdk/_shims/registry.js +41 -0
- package/vendor/sdk/_shims/registry.js.map +1 -0
- package/vendor/sdk/_shims/registry.mjs +37 -0
- package/vendor/sdk/_shims/registry.mjs.map +1 -0
- package/vendor/sdk/_shims/web-runtime.d.ts +5 -0
- package/vendor/sdk/_shims/web-runtime.d.ts.map +1 -0
- package/vendor/sdk/_shims/web-runtime.js +78 -0
- package/vendor/sdk/_shims/web-runtime.js.map +1 -0
- package/vendor/sdk/_shims/web-runtime.mjs +71 -0
- package/vendor/sdk/_shims/web-runtime.mjs.map +1 -0
- package/vendor/sdk/_shims/web-types.d.ts +83 -0
- package/vendor/sdk/_shims/web-types.js +3 -0
- package/vendor/sdk/_shims/web-types.mjs +3 -0
- package/vendor/sdk/_vendor/partial-json-parser/parser.d.ts +3 -0
- package/vendor/sdk/_vendor/partial-json-parser/parser.d.ts.map +1 -0
- package/vendor/sdk/_vendor/partial-json-parser/parser.js +226 -0
- package/vendor/sdk/_vendor/partial-json-parser/parser.js.map +1 -0
- package/vendor/sdk/_vendor/partial-json-parser/parser.mjs +223 -0
- package/vendor/sdk/_vendor/partial-json-parser/parser.mjs.map +1 -0
- package/vendor/sdk/core.d.ts +248 -0
- package/vendor/sdk/core.d.ts.map +1 -0
- package/vendor/sdk/core.js +935 -0
- package/vendor/sdk/core.js.map +1 -0
- package/vendor/sdk/core.mjs +903 -0
- package/vendor/sdk/core.mjs.map +1 -0
- package/vendor/sdk/error.d.ts +48 -0
- package/vendor/sdk/error.d.ts.map +1 -0
- package/vendor/sdk/error.js +114 -0
- package/vendor/sdk/error.js.map +1 -0
- package/vendor/sdk/error.mjs +98 -0
- package/vendor/sdk/error.mjs.map +1 -0
- package/vendor/sdk/index.d.mts +152 -0
- package/vendor/sdk/index.d.ts +152 -0
- package/vendor/sdk/index.d.ts.map +1 -0
- package/vendor/sdk/index.js +179 -0
- package/vendor/sdk/index.js.map +1 -0
- package/vendor/sdk/index.mjs +136 -0
- package/vendor/sdk/index.mjs.map +1 -0
- package/vendor/sdk/internal/decoders/jsonl.d.ts +12 -0
- package/vendor/sdk/internal/decoders/jsonl.d.ts.map +1 -0
- package/vendor/sdk/internal/decoders/jsonl.js +35 -0
- package/vendor/sdk/internal/decoders/jsonl.js.map +1 -0
- package/vendor/sdk/internal/decoders/jsonl.mjs +31 -0
- package/vendor/sdk/internal/decoders/jsonl.mjs.map +1 -0
- package/vendor/sdk/internal/decoders/line.d.ts +20 -0
- package/vendor/sdk/internal/decoders/line.d.ts.map +1 -0
- package/vendor/sdk/internal/decoders/line.js +123 -0
- package/vendor/sdk/internal/decoders/line.js.map +1 -0
- package/vendor/sdk/internal/decoders/line.mjs +119 -0
- package/vendor/sdk/internal/decoders/line.mjs.map +1 -0
- package/vendor/sdk/internal/stream-utils.d.ts +8 -0
- package/vendor/sdk/internal/stream-utils.d.ts.map +1 -0
- package/vendor/sdk/internal/stream-utils.js +39 -0
- package/vendor/sdk/internal/stream-utils.js.map +1 -0
- package/vendor/sdk/internal/stream-utils.mjs +35 -0
- package/vendor/sdk/internal/stream-utils.mjs.map +1 -0
- package/vendor/sdk/lib/BetaMessageStream.d.ts +114 -0
- package/vendor/sdk/lib/BetaMessageStream.d.ts.map +1 -0
- package/vendor/sdk/lib/BetaMessageStream.js +547 -0
- package/vendor/sdk/lib/BetaMessageStream.js.map +1 -0
- package/vendor/sdk/lib/BetaMessageStream.mjs +543 -0
- package/vendor/sdk/lib/BetaMessageStream.mjs.map +1 -0
- package/vendor/sdk/lib/MessageStream.d.ts +114 -0
- package/vendor/sdk/lib/MessageStream.d.ts.map +1 -0
- package/vendor/sdk/lib/MessageStream.js +547 -0
- package/vendor/sdk/lib/MessageStream.js.map +1 -0
- package/vendor/sdk/lib/MessageStream.mjs +543 -0
- package/vendor/sdk/lib/MessageStream.mjs.map +1 -0
- package/vendor/sdk/node_modules/@types/node/LICENSE +21 -0
- package/vendor/sdk/node_modules/@types/node/README.md +15 -0
- package/vendor/sdk/node_modules/@types/node/assert/strict.d.ts +8 -0
- package/vendor/sdk/node_modules/@types/node/assert.d.ts +985 -0
- package/vendor/sdk/node_modules/@types/node/async_hooks.d.ts +522 -0
- package/vendor/sdk/node_modules/@types/node/buffer.buffer.d.ts +385 -0
- package/vendor/sdk/node_modules/@types/node/buffer.d.ts +1903 -0
- package/vendor/sdk/node_modules/@types/node/child_process.d.ts +1549 -0
- package/vendor/sdk/node_modules/@types/node/cluster.d.ts +578 -0
- package/vendor/sdk/node_modules/@types/node/compatibility/disposable.d.ts +14 -0
- package/vendor/sdk/node_modules/@types/node/compatibility/index.d.ts +9 -0
- package/vendor/sdk/node_modules/@types/node/compatibility/indexable.d.ts +20 -0
- package/vendor/sdk/node_modules/@types/node/compatibility/iterators.d.ts +20 -0
- package/vendor/sdk/node_modules/@types/node/console.d.ts +452 -0
- package/vendor/sdk/node_modules/@types/node/constants.d.ts +19 -0
- package/vendor/sdk/node_modules/@types/node/crypto.d.ts +4453 -0
- package/vendor/sdk/node_modules/@types/node/dgram.d.ts +596 -0
- package/vendor/sdk/node_modules/@types/node/diagnostics_channel.d.ts +546 -0
- package/vendor/sdk/node_modules/@types/node/dns/promises.d.ts +475 -0
- package/vendor/sdk/node_modules/@types/node/dns.d.ts +853 -0
- package/vendor/sdk/node_modules/@types/node/dom-events.d.ts +124 -0
- package/vendor/sdk/node_modules/@types/node/domain.d.ts +170 -0
- package/vendor/sdk/node_modules/@types/node/events.d.ts +819 -0
- package/vendor/sdk/node_modules/@types/node/fs/promises.d.ts +1205 -0
- package/vendor/sdk/node_modules/@types/node/fs.d.ts +4237 -0
- package/vendor/sdk/node_modules/@types/node/globals.d.ts +442 -0
- package/vendor/sdk/node_modules/@types/node/globals.typedarray.d.ts +21 -0
- package/vendor/sdk/node_modules/@types/node/http.d.ts +1839 -0
- package/vendor/sdk/node_modules/@types/node/http2.d.ts +2517 -0
- package/vendor/sdk/node_modules/@types/node/https.d.ts +544 -0
- package/vendor/sdk/node_modules/@types/node/index.d.ts +90 -0
- package/vendor/sdk/node_modules/@types/node/inspector.d.ts +2775 -0
- package/vendor/sdk/node_modules/@types/node/module.d.ts +291 -0
- package/vendor/sdk/node_modules/@types/node/net.d.ts +924 -0
- package/vendor/sdk/node_modules/@types/node/os.d.ts +473 -0
- package/vendor/sdk/node_modules/@types/node/package.json +225 -0
- package/vendor/sdk/node_modules/@types/node/path.d.ts +191 -0
- package/vendor/sdk/node_modules/@types/node/perf_hooks.d.ts +753 -0
- package/vendor/sdk/node_modules/@types/node/process.d.ts +1553 -0
- package/vendor/sdk/node_modules/@types/node/punycode.d.ts +117 -0
- package/vendor/sdk/node_modules/@types/node/querystring.d.ts +141 -0
- package/vendor/sdk/node_modules/@types/node/readline/promises.d.ts +154 -0
- package/vendor/sdk/node_modules/@types/node/readline.d.ts +715 -0
- package/vendor/sdk/node_modules/@types/node/repl.d.ts +430 -0
- package/vendor/sdk/node_modules/@types/node/stream/consumers.d.ts +12 -0
- package/vendor/sdk/node_modules/@types/node/stream/promises.d.ts +90 -0
- package/vendor/sdk/node_modules/@types/node/stream/web.d.ts +523 -0
- package/vendor/sdk/node_modules/@types/node/stream.d.ts +1731 -0
- package/vendor/sdk/node_modules/@types/node/string_decoder.d.ts +67 -0
- package/vendor/sdk/node_modules/@types/node/test.d.ts +1245 -0
- package/vendor/sdk/node_modules/@types/node/timers/promises.d.ts +93 -0
- package/vendor/sdk/node_modules/@types/node/timers.d.ts +126 -0
- package/vendor/sdk/node_modules/@types/node/tls.d.ts +1203 -0
- package/vendor/sdk/node_modules/@types/node/trace_events.d.ts +171 -0
- package/vendor/sdk/node_modules/@types/node/ts5.6/buffer.buffer.d.ts +385 -0
- package/vendor/sdk/node_modules/@types/node/ts5.6/globals.typedarray.d.ts +19 -0
- package/vendor/sdk/node_modules/@types/node/ts5.6/index.d.ts +90 -0
- package/vendor/sdk/node_modules/@types/node/tty.d.ts +206 -0
- package/vendor/sdk/node_modules/@types/node/url.d.ts +957 -0
- package/vendor/sdk/node_modules/@types/node/util.d.ts +2083 -0
- package/vendor/sdk/node_modules/@types/node/v8.d.ts +753 -0
- package/vendor/sdk/node_modules/@types/node/vm.d.ts +666 -0
- package/vendor/sdk/node_modules/@types/node/wasi.d.ts +160 -0
- package/vendor/sdk/node_modules/@types/node/worker_threads.d.ts +695 -0
- package/vendor/sdk/node_modules/@types/node/zlib.d.ts +517 -0
- package/vendor/sdk/node_modules/undici-types/README.md +6 -0
- package/vendor/sdk/node_modules/undici-types/agent.d.ts +31 -0
- package/vendor/sdk/node_modules/undici-types/api.d.ts +43 -0
- package/vendor/sdk/node_modules/undici-types/balanced-pool.d.ts +18 -0
- package/vendor/sdk/node_modules/undici-types/cache.d.ts +36 -0
- package/vendor/sdk/node_modules/undici-types/client.d.ts +97 -0
- package/vendor/sdk/node_modules/undici-types/connector.d.ts +34 -0
- package/vendor/sdk/node_modules/undici-types/content-type.d.ts +21 -0
- package/vendor/sdk/node_modules/undici-types/cookies.d.ts +28 -0
- package/vendor/sdk/node_modules/undici-types/diagnostics-channel.d.ts +67 -0
- package/vendor/sdk/node_modules/undici-types/dispatcher.d.ts +241 -0
- package/vendor/sdk/node_modules/undici-types/errors.d.ts +128 -0
- package/vendor/sdk/node_modules/undici-types/fetch.d.ts +209 -0
- package/vendor/sdk/node_modules/undici-types/file.d.ts +39 -0
- package/vendor/sdk/node_modules/undici-types/filereader.d.ts +54 -0
- package/vendor/sdk/node_modules/undici-types/formdata.d.ts +108 -0
- package/vendor/sdk/node_modules/undici-types/global-dispatcher.d.ts +9 -0
- package/vendor/sdk/node_modules/undici-types/global-origin.d.ts +7 -0
- package/vendor/sdk/node_modules/undici-types/handlers.d.ts +9 -0
- package/vendor/sdk/node_modules/undici-types/header.d.ts +4 -0
- package/vendor/sdk/node_modules/undici-types/index.d.ts +63 -0
- package/vendor/sdk/node_modules/undici-types/interceptors.d.ts +5 -0
- package/vendor/sdk/node_modules/undici-types/mock-agent.d.ts +50 -0
- package/vendor/sdk/node_modules/undici-types/mock-client.d.ts +25 -0
- package/vendor/sdk/node_modules/undici-types/mock-errors.d.ts +12 -0
- package/vendor/sdk/node_modules/undici-types/mock-interceptor.d.ts +93 -0
- package/vendor/sdk/node_modules/undici-types/mock-pool.d.ts +25 -0
- package/vendor/sdk/node_modules/undici-types/package.json +55 -0
- package/vendor/sdk/node_modules/undici-types/patch.d.ts +71 -0
- package/vendor/sdk/node_modules/undici-types/pool-stats.d.ts +19 -0
- package/vendor/sdk/node_modules/undici-types/pool.d.ts +28 -0
- package/vendor/sdk/node_modules/undici-types/proxy-agent.d.ts +30 -0
- package/vendor/sdk/node_modules/undici-types/readable.d.ts +61 -0
- package/vendor/sdk/node_modules/undici-types/webidl.d.ts +220 -0
- package/vendor/sdk/node_modules/undici-types/websocket.d.ts +131 -0
- package/vendor/sdk/package.json +124 -0
- package/vendor/sdk/pagination.d.ts +27 -0
- package/vendor/sdk/pagination.d.ts.map +1 -0
- package/vendor/sdk/pagination.js +60 -0
- package/vendor/sdk/pagination.js.map +1 -0
- package/vendor/sdk/pagination.mjs +56 -0
- package/vendor/sdk/pagination.mjs.map +1 -0
- package/vendor/sdk/resource.d.ts +6 -0
- package/vendor/sdk/resource.d.ts.map +1 -0
- package/vendor/sdk/resource.js +11 -0
- package/vendor/sdk/resource.js.map +1 -0
- package/vendor/sdk/resource.mjs +7 -0
- package/vendor/sdk/resource.mjs.map +1 -0
- package/vendor/sdk/resources/beta/beta.d.ts +57 -0
- package/vendor/sdk/resources/beta/beta.d.ts.map +1 -0
- package/vendor/sdk/resources/beta/beta.js +44 -0
- package/vendor/sdk/resources/beta/beta.js.map +1 -0
- package/vendor/sdk/resources/beta/beta.mjs +17 -0
- package/vendor/sdk/resources/beta/beta.mjs.map +1 -0
- package/vendor/sdk/resources/beta/index.d.ts +4 -0
- package/vendor/sdk/resources/beta/index.d.ts.map +1 -0
- package/vendor/sdk/resources/beta/index.js +12 -0
- package/vendor/sdk/resources/beta/index.js.map +1 -0
- package/vendor/sdk/resources/beta/index.mjs +5 -0
- package/vendor/sdk/resources/beta/index.mjs.map +1 -0
- package/vendor/sdk/resources/beta/messages/batches.d.ts +289 -0
- package/vendor/sdk/resources/beta/messages/batches.d.ts.map +1 -0
- package/vendor/sdk/resources/beta/messages/batches.js +112 -0
- package/vendor/sdk/resources/beta/messages/batches.js.map +1 -0
- package/vendor/sdk/resources/beta/messages/batches.mjs +107 -0
- package/vendor/sdk/resources/beta/messages/batches.mjs.map +1 -0
- package/vendor/sdk/resources/beta/messages/index.d.ts +3 -0
- package/vendor/sdk/resources/beta/messages/index.d.ts.map +1 -0
- package/vendor/sdk/resources/beta/messages/index.js +10 -0
- package/vendor/sdk/resources/beta/messages/index.js.map +1 -0
- package/vendor/sdk/resources/beta/messages/index.mjs +4 -0
- package/vendor/sdk/resources/beta/messages/index.mjs.map +1 -0
- package/vendor/sdk/resources/beta/messages/messages.d.ts +1038 -0
- package/vendor/sdk/resources/beta/messages/messages.d.ts.map +1 -0
- package/vendor/sdk/resources/beta/messages/messages.js +93 -0
- package/vendor/sdk/resources/beta/messages/messages.js.map +1 -0
- package/vendor/sdk/resources/beta/messages/messages.mjs +66 -0
- package/vendor/sdk/resources/beta/messages/messages.mjs.map +1 -0
- package/vendor/sdk/resources/beta/models.d.ts +49 -0
- package/vendor/sdk/resources/beta/models.d.ts.map +1 -0
- package/vendor/sdk/resources/beta/models.js +30 -0
- package/vendor/sdk/resources/beta/models.js.map +1 -0
- package/vendor/sdk/resources/beta/models.mjs +25 -0
- package/vendor/sdk/resources/beta/models.mjs.map +1 -0
- package/vendor/sdk/resources/completions.d.ts +166 -0
- package/vendor/sdk/resources/completions.d.ts.map +1 -0
- package/vendor/sdk/resources/completions.js +17 -0
- package/vendor/sdk/resources/completions.js.map +1 -0
- package/vendor/sdk/resources/completions.mjs +13 -0
- package/vendor/sdk/resources/completions.mjs.map +1 -0
- package/vendor/sdk/resources/index.d.ts +6 -0
- package/vendor/sdk/resources/index.d.ts.map +1 -0
- package/vendor/sdk/resources/index.js +29 -0
- package/vendor/sdk/resources/index.js.map +1 -0
- package/vendor/sdk/resources/index.mjs +7 -0
- package/vendor/sdk/resources/index.mjs.map +1 -0
- package/vendor/sdk/resources/messages/batches.d.ts +253 -0
- package/vendor/sdk/resources/messages/batches.d.ts.map +1 -0
- package/vendor/sdk/resources/messages/batches.js +102 -0
- package/vendor/sdk/resources/messages/batches.js.map +1 -0
- package/vendor/sdk/resources/messages/batches.mjs +97 -0
- package/vendor/sdk/resources/messages/batches.mjs.map +1 -0
- package/vendor/sdk/resources/messages/index.d.ts +3 -0
- package/vendor/sdk/resources/messages/index.d.ts.map +1 -0
- package/vendor/sdk/resources/messages/index.js +10 -0
- package/vendor/sdk/resources/messages/index.js.map +1 -0
- package/vendor/sdk/resources/messages/index.mjs +4 -0
- package/vendor/sdk/resources/messages/index.mjs.map +1 -0
- package/vendor/sdk/resources/messages/messages.d.ts +1028 -0
- package/vendor/sdk/resources/messages/messages.d.ts.map +1 -0
- package/vendor/sdk/resources/messages/messages.js +82 -0
- package/vendor/sdk/resources/messages/messages.js.map +1 -0
- package/vendor/sdk/resources/messages/messages.mjs +54 -0
- package/vendor/sdk/resources/messages/messages.mjs.map +1 -0
- package/vendor/sdk/resources/models.d.ts +49 -0
- package/vendor/sdk/resources/models.d.ts.map +1 -0
- package/vendor/sdk/resources/models.js +30 -0
- package/vendor/sdk/resources/models.js.map +1 -0
- package/vendor/sdk/resources/models.mjs +25 -0
- package/vendor/sdk/resources/models.mjs.map +1 -0
- package/vendor/sdk/resources/shared.d.ts +42 -0
- package/vendor/sdk/resources/shared.d.ts.map +1 -0
- package/vendor/sdk/resources/shared.js +4 -0
- package/vendor/sdk/resources/shared.js.map +1 -0
- package/vendor/sdk/resources/shared.mjs +3 -0
- package/vendor/sdk/resources/shared.mjs.map +1 -0
- package/vendor/sdk/resources/top-level.d.ts +2 -0
- package/vendor/sdk/resources/top-level.d.ts.map +1 -0
- package/vendor/sdk/resources/top-level.js +4 -0
- package/vendor/sdk/resources/top-level.js.map +1 -0
- package/vendor/sdk/resources/top-level.mjs +3 -0
- package/vendor/sdk/resources/top-level.mjs.map +1 -0
- package/vendor/sdk/shims/node.d.ts +30 -0
- package/vendor/sdk/shims/node.d.ts.map +1 -0
- package/vendor/sdk/shims/node.js +31 -0
- package/vendor/sdk/shims/node.js.map +1 -0
- package/vendor/sdk/shims/node.mjs +5 -0
- package/vendor/sdk/shims/node.mjs.map +1 -0
- package/vendor/sdk/shims/web.d.ts +26 -0
- package/vendor/sdk/shims/web.d.ts.map +1 -0
- package/vendor/sdk/shims/web.js +31 -0
- package/vendor/sdk/shims/web.js.map +1 -0
- package/vendor/sdk/shims/web.mjs +5 -0
- package/vendor/sdk/shims/web.mjs.map +1 -0
- package/vendor/sdk/src/_shims/MultipartBody.ts +9 -0
- package/vendor/sdk/src/_shims/README.md +46 -0
- package/vendor/sdk/src/_shims/auto/runtime-bun.ts +4 -0
- package/vendor/sdk/src/_shims/auto/runtime-node.ts +4 -0
- package/vendor/sdk/src/_shims/auto/runtime.ts +4 -0
- package/vendor/sdk/src/_shims/auto/types-node.ts +4 -0
- package/vendor/sdk/src/_shims/auto/types.d.ts +101 -0
- package/vendor/sdk/src/_shims/auto/types.js +3 -0
- package/vendor/sdk/src/_shims/auto/types.mjs +3 -0
- package/vendor/sdk/src/_shims/bun-runtime.ts +14 -0
- package/vendor/sdk/src/_shims/index.d.ts +81 -0
- package/vendor/sdk/src/_shims/index.js +13 -0
- package/vendor/sdk/src/_shims/index.mjs +7 -0
- package/vendor/sdk/src/_shims/manual-types.d.ts +12 -0
- package/vendor/sdk/src/_shims/manual-types.js +3 -0
- package/vendor/sdk/src/_shims/manual-types.mjs +3 -0
- package/vendor/sdk/src/_shims/node-runtime.ts +81 -0
- package/vendor/sdk/src/_shims/node-types.d.ts +42 -0
- package/vendor/sdk/src/_shims/node-types.js +3 -0
- package/vendor/sdk/src/_shims/node-types.mjs +3 -0
- package/vendor/sdk/src/_shims/registry.ts +67 -0
- package/vendor/sdk/src/_shims/web-runtime.ts +103 -0
- package/vendor/sdk/src/_shims/web-types.d.ts +83 -0
- package/vendor/sdk/src/_shims/web-types.js +3 -0
- package/vendor/sdk/src/_shims/web-types.mjs +3 -0
- package/vendor/sdk/src/_vendor/partial-json-parser/README.md +3 -0
- package/vendor/sdk/src/_vendor/partial-json-parser/parser.ts +264 -0
- package/vendor/sdk/src/core.ts +1250 -0
- package/vendor/sdk/src/error.ts +133 -0
- package/vendor/sdk/src/index.ts +465 -0
- package/vendor/sdk/src/internal/decoders/jsonl.ts +41 -0
- package/vendor/sdk/src/internal/decoders/line.ts +145 -0
- package/vendor/sdk/src/internal/stream-utils.ts +32 -0
- package/vendor/sdk/src/lib/.keep +4 -0
- package/vendor/sdk/src/lib/BetaMessageStream.ts +661 -0
- package/vendor/sdk/src/lib/MessageStream.ts +662 -0
- package/vendor/sdk/src/pagination.ts +92 -0
- package/vendor/sdk/src/resource.ts +11 -0
- package/vendor/sdk/src/resources/beta/beta.ts +249 -0
- package/vendor/sdk/src/resources/beta/index.ts +83 -0
- package/vendor/sdk/src/resources/beta/messages/batches.ts +486 -0
- package/vendor/sdk/src/resources/beta/messages/index.ts +87 -0
- package/vendor/sdk/src/resources/beta/messages/messages.ts +1444 -0
- package/vendor/sdk/src/resources/beta/models.ts +78 -0
- package/vendor/sdk/src/resources/completions.ts +210 -0
- package/vendor/sdk/src/resources/index.ts +95 -0
- package/vendor/sdk/src/resources/messages/batches.ts +352 -0
- package/vendor/sdk/src/resources/messages/index.ts +85 -0
- package/vendor/sdk/src/resources/messages/messages.ts +1412 -0
- package/vendor/sdk/src/resources/models.ts +75 -0
- package/vendor/sdk/src/resources/shared.ts +72 -0
- package/vendor/sdk/src/resources/top-level.ts +3 -0
- package/vendor/sdk/src/shims/node.ts +50 -0
- package/vendor/sdk/src/shims/web.ts +50 -0
- package/vendor/sdk/src/streaming.ts +372 -0
- package/vendor/sdk/src/tsconfig.json +11 -0
- package/vendor/sdk/src/uploads.ts +255 -0
- package/vendor/sdk/src/version.ts +1 -0
- package/vendor/sdk/streaming.d.ts +36 -0
- package/vendor/sdk/streaming.d.ts.map +1 -0
- package/vendor/sdk/streaming.js +316 -0
- package/vendor/sdk/streaming.js.map +1 -0
- package/vendor/sdk/streaming.mjs +310 -0
- package/vendor/sdk/streaming.mjs.map +1 -0
- package/vendor/sdk/uploads.d.ts +75 -0
- package/vendor/sdk/uploads.d.ts.map +1 -0
- package/vendor/sdk/uploads.js +171 -0
- package/vendor/sdk/uploads.js.map +1 -0
- package/vendor/sdk/uploads.mjs +158 -0
- package/vendor/sdk/uploads.mjs.map +1 -0
- package/vendor/sdk/version.d.ts +2 -0
- package/vendor/sdk/version.d.ts.map +1 -0
- package/vendor/sdk/version.js +5 -0
- package/vendor/sdk/version.js.map +1 -0
- package/vendor/sdk/version.mjs +2 -0
- package/vendor/sdk/version.mjs.map +1 -0
- package/yoga.wasm +0 -0
|
@@ -0,0 +1,661 @@
|
|
|
1
|
+
import * as Core from "../core.js";
|
|
2
|
+
import { AnthropicError, APIUserAbortError } from "../error.js";
|
|
3
|
+
import {
|
|
4
|
+
type BetaContentBlock,
|
|
5
|
+
Messages as BetaMessages,
|
|
6
|
+
type BetaMessage,
|
|
7
|
+
type BetaRawMessageStreamEvent as BetaMessageStreamEvent,
|
|
8
|
+
type BetaMessageParam,
|
|
9
|
+
type MessageCreateParams as BetaMessageCreateParams,
|
|
10
|
+
type MessageCreateParamsBase as BetaMessageCreateParamsBase,
|
|
11
|
+
type BetaTextBlock,
|
|
12
|
+
type BetaTextCitation,
|
|
13
|
+
} from "../resources/beta/messages/messages.js";
|
|
14
|
+
import { type ReadableStream, type Response } from "../_shims/index.js";
|
|
15
|
+
import { Stream } from "../streaming.js";
|
|
16
|
+
import { partialParse } from "../_vendor/partial-json-parser/parser.js";
|
|
17
|
+
|
|
18
|
+
export interface MessageStreamEvents {
|
|
19
|
+
connect: () => void;
|
|
20
|
+
streamEvent: (event: BetaMessageStreamEvent, snapshot: BetaMessage) => void;
|
|
21
|
+
text: (textDelta: string, textSnapshot: string) => void;
|
|
22
|
+
citation: (citation: BetaTextCitation, citationsSnapshot: BetaTextCitation[]) => void;
|
|
23
|
+
inputJson: (partialJson: string, jsonSnapshot: unknown) => void;
|
|
24
|
+
thinking: (thinkingDelta: string, thinkingSnapshot: string) => void;
|
|
25
|
+
message: (message: BetaMessage) => void;
|
|
26
|
+
contentBlock: (content: BetaContentBlock) => void;
|
|
27
|
+
finalMessage: (message: BetaMessage) => void;
|
|
28
|
+
error: (error: AnthropicError) => void;
|
|
29
|
+
abort: (error: APIUserAbortError) => void;
|
|
30
|
+
end: () => void;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
type MessageStreamEventListeners<Event extends keyof MessageStreamEvents> = {
|
|
34
|
+
listener: MessageStreamEvents[Event];
|
|
35
|
+
once?: boolean;
|
|
36
|
+
}[];
|
|
37
|
+
|
|
38
|
+
const JSON_BUF_PROPERTY = '__json_buf';
|
|
39
|
+
|
|
40
|
+
export class BetaMessageStream implements AsyncIterable<BetaMessageStreamEvent> {
|
|
41
|
+
messages: BetaMessageParam[] = [];
|
|
42
|
+
receivedMessages: BetaMessage[] = [];
|
|
43
|
+
#currentMessageSnapshot: BetaMessage | undefined;
|
|
44
|
+
|
|
45
|
+
controller: AbortController = new AbortController();
|
|
46
|
+
|
|
47
|
+
#connectedPromise: Promise<Response | null>;
|
|
48
|
+
#resolveConnectedPromise: (response: Response | null) => void = () => {};
|
|
49
|
+
#rejectConnectedPromise: (error: AnthropicError) => void = () => {};
|
|
50
|
+
|
|
51
|
+
#endPromise: Promise<void>;
|
|
52
|
+
#resolveEndPromise: () => void = () => {};
|
|
53
|
+
#rejectEndPromise: (error: AnthropicError) => void = () => {};
|
|
54
|
+
|
|
55
|
+
#listeners: { [Event in keyof MessageStreamEvents]?: MessageStreamEventListeners<Event> } = {};
|
|
56
|
+
|
|
57
|
+
#ended = false;
|
|
58
|
+
#errored = false;
|
|
59
|
+
#aborted = false;
|
|
60
|
+
#catchingPromiseCreated = false;
|
|
61
|
+
#response: Response | null | undefined;
|
|
62
|
+
#request_id: string | null | undefined;
|
|
63
|
+
|
|
64
|
+
constructor() {
|
|
65
|
+
this.#connectedPromise = new Promise<Response | null>((resolve, reject) => {
|
|
66
|
+
this.#resolveConnectedPromise = resolve;
|
|
67
|
+
this.#rejectConnectedPromise = reject;
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
this.#endPromise = new Promise<void>((resolve, reject) => {
|
|
71
|
+
this.#resolveEndPromise = resolve;
|
|
72
|
+
this.#rejectEndPromise = reject;
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
// Don't let these promises cause unhandled rejection errors.
|
|
76
|
+
// we will manually cause an unhandled rejection error later
|
|
77
|
+
// if the user hasn't registered any error listener or called
|
|
78
|
+
// any promise-returning method.
|
|
79
|
+
this.#connectedPromise.catch(() => {});
|
|
80
|
+
this.#endPromise.catch(() => {});
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
get response(): Response | null | undefined {
|
|
84
|
+
return this.#response;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
get request_id(): string | null | undefined {
|
|
88
|
+
return this.#request_id;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* Returns the `MessageStream` data, the raw `Response` instance and the ID of the request,
|
|
93
|
+
* returned vie the `request-id` header which is useful for debugging requests and resporting
|
|
94
|
+
* issues to Anthropic.
|
|
95
|
+
*
|
|
96
|
+
* This is the same as the `APIPromise.withResponse()` method.
|
|
97
|
+
*
|
|
98
|
+
* This method will raise an error if you created the stream using `MessageStream.fromReadableStream`
|
|
99
|
+
* as no `Response` is available.
|
|
100
|
+
*/
|
|
101
|
+
async withResponse(): Promise<{
|
|
102
|
+
data: BetaMessageStream;
|
|
103
|
+
response: Response;
|
|
104
|
+
request_id: string | null | undefined;
|
|
105
|
+
}> {
|
|
106
|
+
const response = await this.#connectedPromise;
|
|
107
|
+
if (!response) {
|
|
108
|
+
throw new Error('Could not resolve a `Response` object');
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
return {
|
|
112
|
+
data: this,
|
|
113
|
+
response,
|
|
114
|
+
request_id: response.headers.get('request-id'),
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
/**
|
|
119
|
+
* Intended for use on the frontend, consuming a stream produced with
|
|
120
|
+
* `.toReadableStream()` on the backend.
|
|
121
|
+
*
|
|
122
|
+
* Note that messages sent to the model do not appear in `.on('message')`
|
|
123
|
+
* in this context.
|
|
124
|
+
*/
|
|
125
|
+
static fromReadableStream(stream: ReadableStream): BetaMessageStream {
|
|
126
|
+
const runner = new BetaMessageStream();
|
|
127
|
+
runner._run(() => runner._fromReadableStream(stream));
|
|
128
|
+
return runner;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
static createMessage(
|
|
132
|
+
messages: BetaMessages,
|
|
133
|
+
params: BetaMessageCreateParamsBase,
|
|
134
|
+
options?: Core.RequestOptions,
|
|
135
|
+
): BetaMessageStream {
|
|
136
|
+
const runner = new BetaMessageStream();
|
|
137
|
+
for (const message of params.messages) {
|
|
138
|
+
runner._addMessageParam(message);
|
|
139
|
+
}
|
|
140
|
+
runner._run(() =>
|
|
141
|
+
runner._createMessage(
|
|
142
|
+
messages,
|
|
143
|
+
{ ...params, stream: true },
|
|
144
|
+
{ ...options, headers: { ...options?.headers, 'X-Stainless-Helper-Method': 'stream' } },
|
|
145
|
+
),
|
|
146
|
+
);
|
|
147
|
+
return runner;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
protected _run(executor: () => Promise<any>) {
|
|
151
|
+
executor().then(() => {
|
|
152
|
+
this._emitFinal();
|
|
153
|
+
this._emit('end');
|
|
154
|
+
}, this.#handleError);
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
protected _addMessageParam(message: BetaMessageParam) {
|
|
158
|
+
this.messages.push(message);
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
protected _addMessage(message: BetaMessage, emit = true) {
|
|
162
|
+
this.receivedMessages.push(message);
|
|
163
|
+
if (emit) {
|
|
164
|
+
this._emit('message', message);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
protected async _createMessage(
|
|
169
|
+
messages: BetaMessages,
|
|
170
|
+
params: BetaMessageCreateParams,
|
|
171
|
+
options?: Core.RequestOptions,
|
|
172
|
+
): Promise<void> {
|
|
173
|
+
const signal = options?.signal;
|
|
174
|
+
if (signal) {
|
|
175
|
+
if (signal.aborted) this.controller.abort();
|
|
176
|
+
signal.addEventListener('abort', () => this.controller.abort());
|
|
177
|
+
}
|
|
178
|
+
this.#beginRequest();
|
|
179
|
+
const { response, data: stream } = await messages
|
|
180
|
+
.create({ ...params, stream: true }, { ...options, signal: this.controller.signal })
|
|
181
|
+
.withResponse();
|
|
182
|
+
this._connected(response);
|
|
183
|
+
for await (const event of stream) {
|
|
184
|
+
this.#addStreamEvent(event);
|
|
185
|
+
}
|
|
186
|
+
if (stream.controller.signal?.aborted) {
|
|
187
|
+
throw new APIUserAbortError();
|
|
188
|
+
}
|
|
189
|
+
this.#endRequest();
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
protected _connected(response: Response | null) {
|
|
193
|
+
if (this.ended) return;
|
|
194
|
+
this.#response = response;
|
|
195
|
+
this.#request_id = response?.headers.get('request-id');
|
|
196
|
+
this.#resolveConnectedPromise(response);
|
|
197
|
+
this._emit('connect');
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
get ended(): boolean {
|
|
201
|
+
return this.#ended;
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
get errored(): boolean {
|
|
205
|
+
return this.#errored;
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
get aborted(): boolean {
|
|
209
|
+
return this.#aborted;
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
abort() {
|
|
213
|
+
this.controller.abort();
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
/**
|
|
217
|
+
* Adds the listener function to the end of the listeners array for the event.
|
|
218
|
+
* No checks are made to see if the listener has already been added. Multiple calls passing
|
|
219
|
+
* the same combination of event and listener will result in the listener being added, and
|
|
220
|
+
* called, multiple times.
|
|
221
|
+
* @returns this MessageStream, so that calls can be chained
|
|
222
|
+
*/
|
|
223
|
+
on<Event extends keyof MessageStreamEvents>(event: Event, listener: MessageStreamEvents[Event]): this {
|
|
224
|
+
const listeners: MessageStreamEventListeners<Event> =
|
|
225
|
+
this.#listeners[event] || (this.#listeners[event] = []);
|
|
226
|
+
listeners.push({ listener });
|
|
227
|
+
return this;
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
/**
|
|
231
|
+
* Removes the specified listener from the listener array for the event.
|
|
232
|
+
* off() will remove, at most, one instance of a listener from the listener array. If any single
|
|
233
|
+
* listener has been added multiple times to the listener array for the specified event, then
|
|
234
|
+
* off() must be called multiple times to remove each instance.
|
|
235
|
+
* @returns this MessageStream, so that calls can be chained
|
|
236
|
+
*/
|
|
237
|
+
off<Event extends keyof MessageStreamEvents>(event: Event, listener: MessageStreamEvents[Event]): this {
|
|
238
|
+
const listeners = this.#listeners[event];
|
|
239
|
+
if (!listeners) return this;
|
|
240
|
+
const index = listeners.findIndex((l) => l.listener === listener);
|
|
241
|
+
if (index >= 0) listeners.splice(index, 1);
|
|
242
|
+
return this;
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
/**
|
|
246
|
+
* Adds a one-time listener function for the event. The next time the event is triggered,
|
|
247
|
+
* this listener is removed and then invoked.
|
|
248
|
+
* @returns this MessageStream, so that calls can be chained
|
|
249
|
+
*/
|
|
250
|
+
once<Event extends keyof MessageStreamEvents>(event: Event, listener: MessageStreamEvents[Event]): this {
|
|
251
|
+
const listeners: MessageStreamEventListeners<Event> =
|
|
252
|
+
this.#listeners[event] || (this.#listeners[event] = []);
|
|
253
|
+
listeners.push({ listener, once: true });
|
|
254
|
+
return this;
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
/**
|
|
258
|
+
* This is similar to `.once()`, but returns a Promise that resolves the next time
|
|
259
|
+
* the event is triggered, instead of calling a listener callback.
|
|
260
|
+
* @returns a Promise that resolves the next time given event is triggered,
|
|
261
|
+
* or rejects if an error is emitted. (If you request the 'error' event,
|
|
262
|
+
* returns a promise that resolves with the error).
|
|
263
|
+
*
|
|
264
|
+
* Example:
|
|
265
|
+
*
|
|
266
|
+
* const message = await stream.emitted('message') // rejects if the stream errors
|
|
267
|
+
*/
|
|
268
|
+
emitted<Event extends keyof MessageStreamEvents>(
|
|
269
|
+
event: Event,
|
|
270
|
+
): Promise<
|
|
271
|
+
Parameters<MessageStreamEvents[Event]> extends [infer Param] ? Param
|
|
272
|
+
: Parameters<MessageStreamEvents[Event]> extends [] ? void
|
|
273
|
+
: Parameters<MessageStreamEvents[Event]>
|
|
274
|
+
> {
|
|
275
|
+
return new Promise((resolve, reject) => {
|
|
276
|
+
this.#catchingPromiseCreated = true;
|
|
277
|
+
if (event !== 'error') this.once('error', reject);
|
|
278
|
+
this.once(event, resolve as any);
|
|
279
|
+
});
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
async done(): Promise<void> {
|
|
283
|
+
this.#catchingPromiseCreated = true;
|
|
284
|
+
await this.#endPromise;
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
get currentMessage(): BetaMessage | undefined {
|
|
288
|
+
return this.#currentMessageSnapshot;
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
#getFinalMessage(): BetaMessage {
|
|
292
|
+
if (this.receivedMessages.length === 0) {
|
|
293
|
+
throw new AnthropicError('stream ended without producing a Message with role=assistant');
|
|
294
|
+
}
|
|
295
|
+
return this.receivedMessages.at(-1)!;
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
/**
|
|
299
|
+
* @returns a promise that resolves with the the final assistant Message response,
|
|
300
|
+
* or rejects if an error occurred or the stream ended prematurely without producing a Message.
|
|
301
|
+
*/
|
|
302
|
+
async finalMessage(): Promise<BetaMessage> {
|
|
303
|
+
await this.done();
|
|
304
|
+
return this.#getFinalMessage();
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
#getFinalText(): string {
|
|
308
|
+
if (this.receivedMessages.length === 0) {
|
|
309
|
+
throw new AnthropicError('stream ended without producing a Message with role=assistant');
|
|
310
|
+
}
|
|
311
|
+
const textBlocks = this.receivedMessages
|
|
312
|
+
.at(-1)!
|
|
313
|
+
.content.filter((block): block is BetaTextBlock => block.type === 'text')
|
|
314
|
+
.map((block) => block.text);
|
|
315
|
+
if (textBlocks.length === 0) {
|
|
316
|
+
throw new AnthropicError('stream ended without producing a content block with type=text');
|
|
317
|
+
}
|
|
318
|
+
return textBlocks.join(' ');
|
|
319
|
+
}
|
|
320
|
+
|
|
321
|
+
/**
|
|
322
|
+
* @returns a promise that resolves with the the final assistant Message's text response, concatenated
|
|
323
|
+
* together if there are more than one text blocks.
|
|
324
|
+
* Rejects if an error occurred or the stream ended prematurely without producing a Message.
|
|
325
|
+
*/
|
|
326
|
+
async finalText(): Promise<string> {
|
|
327
|
+
await this.done();
|
|
328
|
+
return this.#getFinalText();
|
|
329
|
+
}
|
|
330
|
+
|
|
331
|
+
#handleError = (error: unknown) => {
|
|
332
|
+
this.#errored = true;
|
|
333
|
+
if (error instanceof Error && error.name === 'AbortError') {
|
|
334
|
+
error = new APIUserAbortError();
|
|
335
|
+
}
|
|
336
|
+
if (error instanceof APIUserAbortError) {
|
|
337
|
+
this.#aborted = true;
|
|
338
|
+
return this._emit('abort', error);
|
|
339
|
+
}
|
|
340
|
+
if (error instanceof AnthropicError) {
|
|
341
|
+
return this._emit('error', error);
|
|
342
|
+
}
|
|
343
|
+
if (error instanceof Error) {
|
|
344
|
+
const anthropicError: AnthropicError = new AnthropicError(error.message);
|
|
345
|
+
// @ts-ignore
|
|
346
|
+
anthropicError.cause = error;
|
|
347
|
+
return this._emit('error', anthropicError);
|
|
348
|
+
}
|
|
349
|
+
return this._emit('error', new AnthropicError(String(error)));
|
|
350
|
+
};
|
|
351
|
+
|
|
352
|
+
protected _emit<Event extends keyof MessageStreamEvents>(
|
|
353
|
+
event: Event,
|
|
354
|
+
...args: Parameters<MessageStreamEvents[Event]>
|
|
355
|
+
) {
|
|
356
|
+
// make sure we don't emit any MessageStreamEvents after end
|
|
357
|
+
if (this.#ended) return;
|
|
358
|
+
|
|
359
|
+
if (event === 'end') {
|
|
360
|
+
this.#ended = true;
|
|
361
|
+
this.#resolveEndPromise();
|
|
362
|
+
}
|
|
363
|
+
|
|
364
|
+
const listeners: MessageStreamEventListeners<Event> | undefined = this.#listeners[event];
|
|
365
|
+
if (listeners) {
|
|
366
|
+
this.#listeners[event] = listeners.filter((l) => !l.once) as any;
|
|
367
|
+
listeners.forEach(({ listener }: any) => listener(...args));
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
if (event === 'abort') {
|
|
371
|
+
const error = args[0] as APIUserAbortError;
|
|
372
|
+
if (!this.#catchingPromiseCreated && !listeners?.length) {
|
|
373
|
+
Promise.reject(error);
|
|
374
|
+
}
|
|
375
|
+
this.#rejectConnectedPromise(error);
|
|
376
|
+
this.#rejectEndPromise(error);
|
|
377
|
+
this._emit('end');
|
|
378
|
+
return;
|
|
379
|
+
}
|
|
380
|
+
|
|
381
|
+
if (event === 'error') {
|
|
382
|
+
// NOTE: _emit('error', error) should only be called from #handleError().
|
|
383
|
+
|
|
384
|
+
const error = args[0] as AnthropicError;
|
|
385
|
+
if (!this.#catchingPromiseCreated && !listeners?.length) {
|
|
386
|
+
// Trigger an unhandled rejection if the user hasn't registered any error handlers.
|
|
387
|
+
// If you are seeing stack traces here, make sure to handle errors via either:
|
|
388
|
+
// - runner.on('error', () => ...)
|
|
389
|
+
// - await runner.done()
|
|
390
|
+
// - await runner.final...()
|
|
391
|
+
// - etc.
|
|
392
|
+
Promise.reject(error);
|
|
393
|
+
}
|
|
394
|
+
this.#rejectConnectedPromise(error);
|
|
395
|
+
this.#rejectEndPromise(error);
|
|
396
|
+
this._emit('end');
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
|
|
400
|
+
protected _emitFinal() {
|
|
401
|
+
const finalMessage = this.receivedMessages.at(-1);
|
|
402
|
+
if (finalMessage) {
|
|
403
|
+
this._emit('finalMessage', this.#getFinalMessage());
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
|
|
407
|
+
#beginRequest() {
|
|
408
|
+
if (this.ended) return;
|
|
409
|
+
this.#currentMessageSnapshot = undefined;
|
|
410
|
+
}
|
|
411
|
+
#addStreamEvent(event: BetaMessageStreamEvent) {
|
|
412
|
+
if (this.ended) return;
|
|
413
|
+
const messageSnapshot = this.#accumulateMessage(event);
|
|
414
|
+
this._emit('streamEvent', event, messageSnapshot);
|
|
415
|
+
|
|
416
|
+
switch (event.type) {
|
|
417
|
+
case 'content_block_delta': {
|
|
418
|
+
const content = messageSnapshot.content.at(-1)!;
|
|
419
|
+
switch (event.delta.type) {
|
|
420
|
+
case 'text_delta': {
|
|
421
|
+
if (content.type === 'text') {
|
|
422
|
+
this._emit('text', event.delta.text, content.text || '');
|
|
423
|
+
}
|
|
424
|
+
break;
|
|
425
|
+
}
|
|
426
|
+
case 'citations_delta': {
|
|
427
|
+
if (content.type === 'text') {
|
|
428
|
+
this._emit('citation', event.delta.citation, content.citations ?? []);
|
|
429
|
+
}
|
|
430
|
+
break;
|
|
431
|
+
}
|
|
432
|
+
case 'input_json_delta': {
|
|
433
|
+
if (content.type === 'tool_use' && content.input) {
|
|
434
|
+
this._emit('inputJson', event.delta.partial_json, content.input);
|
|
435
|
+
}
|
|
436
|
+
break;
|
|
437
|
+
}
|
|
438
|
+
case 'thinking_delta': {
|
|
439
|
+
if (content.type === 'thinking') {
|
|
440
|
+
this._emit('thinking', event.delta.thinking, content.thinking);
|
|
441
|
+
}
|
|
442
|
+
break;
|
|
443
|
+
}
|
|
444
|
+
case 'signature_delta': {
|
|
445
|
+
// we don't emit anything special in this case.
|
|
446
|
+
break;
|
|
447
|
+
}
|
|
448
|
+
default:
|
|
449
|
+
checkNever(event.delta);
|
|
450
|
+
}
|
|
451
|
+
break;
|
|
452
|
+
}
|
|
453
|
+
case 'message_stop': {
|
|
454
|
+
this._addMessageParam(messageSnapshot);
|
|
455
|
+
this._addMessage(messageSnapshot, true);
|
|
456
|
+
break;
|
|
457
|
+
}
|
|
458
|
+
case 'content_block_stop': {
|
|
459
|
+
this._emit('contentBlock', messageSnapshot.content.at(-1)!);
|
|
460
|
+
break;
|
|
461
|
+
}
|
|
462
|
+
case 'message_start': {
|
|
463
|
+
this.#currentMessageSnapshot = messageSnapshot;
|
|
464
|
+
break;
|
|
465
|
+
}
|
|
466
|
+
case 'content_block_start':
|
|
467
|
+
case 'message_delta':
|
|
468
|
+
break;
|
|
469
|
+
}
|
|
470
|
+
}
|
|
471
|
+
#endRequest(): BetaMessage {
|
|
472
|
+
if (this.ended) {
|
|
473
|
+
throw new AnthropicError(`stream has ended, this shouldn't happen`);
|
|
474
|
+
}
|
|
475
|
+
const snapshot = this.#currentMessageSnapshot;
|
|
476
|
+
if (!snapshot) {
|
|
477
|
+
throw new AnthropicError(`request ended without sending any chunks`);
|
|
478
|
+
}
|
|
479
|
+
this.#currentMessageSnapshot = undefined;
|
|
480
|
+
return snapshot;
|
|
481
|
+
}
|
|
482
|
+
|
|
483
|
+
protected async _fromReadableStream(
|
|
484
|
+
readableStream: ReadableStream,
|
|
485
|
+
options?: Core.RequestOptions,
|
|
486
|
+
): Promise<void> {
|
|
487
|
+
const signal = options?.signal;
|
|
488
|
+
if (signal) {
|
|
489
|
+
if (signal.aborted) this.controller.abort();
|
|
490
|
+
signal.addEventListener('abort', () => this.controller.abort());
|
|
491
|
+
}
|
|
492
|
+
this.#beginRequest();
|
|
493
|
+
this._connected(null);
|
|
494
|
+
const stream = Stream.fromReadableStream<BetaMessageStreamEvent>(readableStream, this.controller);
|
|
495
|
+
for await (const event of stream) {
|
|
496
|
+
this.#addStreamEvent(event);
|
|
497
|
+
}
|
|
498
|
+
if (stream.controller.signal?.aborted) {
|
|
499
|
+
throw new APIUserAbortError();
|
|
500
|
+
}
|
|
501
|
+
this.#endRequest();
|
|
502
|
+
}
|
|
503
|
+
|
|
504
|
+
/**
|
|
505
|
+
* Mutates this.#currentMessage with the current event. Handling the accumulation of multiple messages
|
|
506
|
+
* will be needed to be handled by the caller, this method will throw if you try to accumulate for multiple
|
|
507
|
+
* messages.
|
|
508
|
+
*/
|
|
509
|
+
#accumulateMessage(event: BetaMessageStreamEvent): BetaMessage {
|
|
510
|
+
let snapshot = this.#currentMessageSnapshot;
|
|
511
|
+
|
|
512
|
+
if (event.type === 'message_start') {
|
|
513
|
+
if (snapshot) {
|
|
514
|
+
throw new AnthropicError(`Unexpected event order, got ${event.type} before receiving "message_stop"`);
|
|
515
|
+
}
|
|
516
|
+
return event.message;
|
|
517
|
+
}
|
|
518
|
+
|
|
519
|
+
if (!snapshot) {
|
|
520
|
+
throw new AnthropicError(`Unexpected event order, got ${event.type} before "message_start"`);
|
|
521
|
+
}
|
|
522
|
+
|
|
523
|
+
switch (event.type) {
|
|
524
|
+
case 'message_stop':
|
|
525
|
+
return snapshot;
|
|
526
|
+
case 'message_delta':
|
|
527
|
+
snapshot.stop_reason = event.delta.stop_reason;
|
|
528
|
+
snapshot.stop_sequence = event.delta.stop_sequence;
|
|
529
|
+
snapshot.usage.output_tokens = event.usage.output_tokens;
|
|
530
|
+
return snapshot;
|
|
531
|
+
case 'content_block_start':
|
|
532
|
+
snapshot.content.push(event.content_block);
|
|
533
|
+
return snapshot;
|
|
534
|
+
case 'content_block_delta': {
|
|
535
|
+
const snapshotContent = snapshot.content.at(event.index);
|
|
536
|
+
|
|
537
|
+
switch (event.delta.type) {
|
|
538
|
+
case 'text_delta': {
|
|
539
|
+
if (snapshotContent?.type === 'text') {
|
|
540
|
+
snapshotContent.text += event.delta.text;
|
|
541
|
+
}
|
|
542
|
+
break;
|
|
543
|
+
}
|
|
544
|
+
case 'citations_delta': {
|
|
545
|
+
if (snapshotContent?.type === 'text') {
|
|
546
|
+
snapshotContent.citations ??= [];
|
|
547
|
+
snapshotContent.citations.push(event.delta.citation);
|
|
548
|
+
}
|
|
549
|
+
break;
|
|
550
|
+
}
|
|
551
|
+
case 'input_json_delta': {
|
|
552
|
+
if (snapshotContent?.type === 'tool_use') {
|
|
553
|
+
// we need to keep track of the raw JSON string as well so that we can
|
|
554
|
+
// re-parse it for each delta, for now we just store it as an untyped
|
|
555
|
+
// non-enumerable property on the snapshot
|
|
556
|
+
let jsonBuf = (snapshotContent as any)[JSON_BUF_PROPERTY] || '';
|
|
557
|
+
jsonBuf += event.delta.partial_json;
|
|
558
|
+
|
|
559
|
+
Object.defineProperty(snapshotContent, JSON_BUF_PROPERTY, {
|
|
560
|
+
value: jsonBuf,
|
|
561
|
+
enumerable: false,
|
|
562
|
+
writable: true,
|
|
563
|
+
});
|
|
564
|
+
|
|
565
|
+
if (jsonBuf) {
|
|
566
|
+
snapshotContent.input = partialParse(jsonBuf);
|
|
567
|
+
}
|
|
568
|
+
}
|
|
569
|
+
break;
|
|
570
|
+
}
|
|
571
|
+
case 'thinking_delta': {
|
|
572
|
+
if (snapshotContent?.type === 'thinking') {
|
|
573
|
+
snapshotContent.thinking += event.delta.thinking;
|
|
574
|
+
}
|
|
575
|
+
break;
|
|
576
|
+
}
|
|
577
|
+
case 'signature_delta': {
|
|
578
|
+
if (snapshotContent?.type === 'thinking') {
|
|
579
|
+
snapshotContent.signature += event.delta.signature;
|
|
580
|
+
}
|
|
581
|
+
break;
|
|
582
|
+
}
|
|
583
|
+
default:
|
|
584
|
+
checkNever(event.delta);
|
|
585
|
+
}
|
|
586
|
+
return snapshot;
|
|
587
|
+
}
|
|
588
|
+
case 'content_block_stop':
|
|
589
|
+
return snapshot;
|
|
590
|
+
}
|
|
591
|
+
}
|
|
592
|
+
|
|
593
|
+
[Symbol.asyncIterator](): AsyncIterator<BetaMessageStreamEvent> {
|
|
594
|
+
const pushQueue: BetaMessageStreamEvent[] = [];
|
|
595
|
+
const readQueue: {
|
|
596
|
+
resolve: (chunk: BetaMessageStreamEvent | undefined) => void;
|
|
597
|
+
reject: (error: unknown) => void;
|
|
598
|
+
}[] = [];
|
|
599
|
+
let done = false;
|
|
600
|
+
|
|
601
|
+
this.on('streamEvent', (event) => {
|
|
602
|
+
const reader = readQueue.shift();
|
|
603
|
+
if (reader) {
|
|
604
|
+
reader.resolve(event);
|
|
605
|
+
} else {
|
|
606
|
+
pushQueue.push(event);
|
|
607
|
+
}
|
|
608
|
+
});
|
|
609
|
+
|
|
610
|
+
this.on('end', () => {
|
|
611
|
+
done = true;
|
|
612
|
+
for (const reader of readQueue) {
|
|
613
|
+
reader.resolve(undefined);
|
|
614
|
+
}
|
|
615
|
+
readQueue.length = 0;
|
|
616
|
+
});
|
|
617
|
+
|
|
618
|
+
this.on('abort', (err) => {
|
|
619
|
+
done = true;
|
|
620
|
+
for (const reader of readQueue) {
|
|
621
|
+
reader.reject(err);
|
|
622
|
+
}
|
|
623
|
+
readQueue.length = 0;
|
|
624
|
+
});
|
|
625
|
+
|
|
626
|
+
this.on('error', (err) => {
|
|
627
|
+
done = true;
|
|
628
|
+
for (const reader of readQueue) {
|
|
629
|
+
reader.reject(err);
|
|
630
|
+
}
|
|
631
|
+
readQueue.length = 0;
|
|
632
|
+
});
|
|
633
|
+
|
|
634
|
+
return {
|
|
635
|
+
next: async (): Promise<IteratorResult<BetaMessageStreamEvent>> => {
|
|
636
|
+
if (!pushQueue.length) {
|
|
637
|
+
if (done) {
|
|
638
|
+
return { value: undefined, done: true };
|
|
639
|
+
}
|
|
640
|
+
return new Promise<BetaMessageStreamEvent | undefined>((resolve, reject) =>
|
|
641
|
+
readQueue.push({ resolve, reject }),
|
|
642
|
+
).then((chunk) => (chunk ? { value: chunk, done: false } : { value: undefined, done: true }));
|
|
643
|
+
}
|
|
644
|
+
const chunk = pushQueue.shift()!;
|
|
645
|
+
return { value: chunk, done: false };
|
|
646
|
+
},
|
|
647
|
+
return: async () => {
|
|
648
|
+
this.abort();
|
|
649
|
+
return { value: undefined, done: true };
|
|
650
|
+
},
|
|
651
|
+
};
|
|
652
|
+
}
|
|
653
|
+
|
|
654
|
+
toReadableStream(): ReadableStream {
|
|
655
|
+
const stream = new Stream(this[Symbol.asyncIterator].bind(this), this.controller);
|
|
656
|
+
return stream.toReadableStream();
|
|
657
|
+
}
|
|
658
|
+
}
|
|
659
|
+
|
|
660
|
+
// used to ensure exhaustive case matching without throwing a runtime error
|
|
661
|
+
function checkNever(x: never) {}
|