Release v0.22.2

This commit is contained in:
Mario Zechner 2025-12-15 22:09:14 +01:00
parent a7e3b8625b
commit fd5134f88c
13 changed files with 62 additions and 43 deletions

40
package-lock.json generated
View file

@ -6063,11 +6063,11 @@
}, },
"packages/agent": { "packages/agent": {
"name": "@mariozechner/pi-agent-core", "name": "@mariozechner/pi-agent-core",
"version": "0.22.1", "version": "0.22.2",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@mariozechner/pi-ai": "^0.22.1", "@mariozechner/pi-ai": "^0.22.2",
"@mariozechner/pi-tui": "^0.22.1" "@mariozechner/pi-tui": "^0.22.2"
}, },
"devDependencies": { "devDependencies": {
"@types/node": "^24.3.0", "@types/node": "^24.3.0",
@ -6097,7 +6097,7 @@
}, },
"packages/ai": { "packages/ai": {
"name": "@mariozechner/pi-ai", "name": "@mariozechner/pi-ai",
"version": "0.22.1", "version": "0.22.2",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@anthropic-ai/sdk": "0.71.2", "@anthropic-ai/sdk": "0.71.2",
@ -6139,12 +6139,12 @@
}, },
"packages/coding-agent": { "packages/coding-agent": {
"name": "@mariozechner/pi-coding-agent", "name": "@mariozechner/pi-coding-agent",
"version": "0.22.1", "version": "0.22.2",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@mariozechner/pi-agent-core": "^0.22.1", "@mariozechner/pi-agent-core": "^0.22.2",
"@mariozechner/pi-ai": "^0.22.1", "@mariozechner/pi-ai": "^0.22.2",
"@mariozechner/pi-tui": "^0.22.1", "@mariozechner/pi-tui": "^0.22.2",
"chalk": "^5.5.0", "chalk": "^5.5.0",
"diff": "^8.0.2", "diff": "^8.0.2",
"glob": "^11.0.3", "glob": "^11.0.3",
@ -6182,13 +6182,13 @@
}, },
"packages/mom": { "packages/mom": {
"name": "@mariozechner/pi-mom", "name": "@mariozechner/pi-mom",
"version": "0.22.1", "version": "0.22.2",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@anthropic-ai/sandbox-runtime": "^0.0.16", "@anthropic-ai/sandbox-runtime": "^0.0.16",
"@mariozechner/pi-agent-core": "^0.22.1", "@mariozechner/pi-agent-core": "^0.22.2",
"@mariozechner/pi-ai": "^0.22.1", "@mariozechner/pi-ai": "^0.22.2",
"@mariozechner/pi-coding-agent": "^0.22.1", "@mariozechner/pi-coding-agent": "^0.22.2",
"@sinclair/typebox": "^0.34.0", "@sinclair/typebox": "^0.34.0",
"@slack/socket-mode": "^2.0.0", "@slack/socket-mode": "^2.0.0",
"@slack/web-api": "^7.0.0", "@slack/web-api": "^7.0.0",
@ -6227,10 +6227,10 @@
}, },
"packages/pods": { "packages/pods": {
"name": "@mariozechner/pi", "name": "@mariozechner/pi",
"version": "0.22.1", "version": "0.22.2",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@mariozechner/pi-agent-core": "^0.22.1", "@mariozechner/pi-agent-core": "^0.22.2",
"chalk": "^5.5.0" "chalk": "^5.5.0"
}, },
"bin": { "bin": {
@ -6243,7 +6243,7 @@
}, },
"packages/proxy": { "packages/proxy": {
"name": "@mariozechner/pi-proxy", "name": "@mariozechner/pi-proxy",
"version": "0.22.1", "version": "0.22.2",
"dependencies": { "dependencies": {
"@hono/node-server": "^1.14.0", "@hono/node-server": "^1.14.0",
"hono": "^4.6.16" "hono": "^4.6.16"
@ -6259,7 +6259,7 @@
}, },
"packages/tui": { "packages/tui": {
"name": "@mariozechner/pi-tui", "name": "@mariozechner/pi-tui",
"version": "0.22.1", "version": "0.22.2",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@types/mime-types": "^2.1.4", "@types/mime-types": "^2.1.4",
@ -6303,12 +6303,12 @@
}, },
"packages/web-ui": { "packages/web-ui": {
"name": "@mariozechner/pi-web-ui", "name": "@mariozechner/pi-web-ui",
"version": "0.22.1", "version": "0.22.2",
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@lmstudio/sdk": "^1.5.0", "@lmstudio/sdk": "^1.5.0",
"@mariozechner/pi-ai": "^0.22.1", "@mariozechner/pi-ai": "^0.22.2",
"@mariozechner/pi-tui": "^0.22.1", "@mariozechner/pi-tui": "^0.22.2",
"docx-preview": "^0.3.7", "docx-preview": "^0.3.7",
"jszip": "^3.10.1", "jszip": "^3.10.1",
"lucide": "^0.544.0", "lucide": "^0.544.0",
@ -6329,7 +6329,7 @@
}, },
"packages/web-ui/example": { "packages/web-ui/example": {
"name": "pi-web-ui-example", "name": "pi-web-ui-example",
"version": "1.10.1", "version": "1.10.2",
"dependencies": { "dependencies": {
"@mariozechner/mini-lit": "^0.2.0", "@mariozechner/mini-lit": "^0.2.0",
"@mariozechner/pi-ai": "file:../../ai", "@mariozechner/pi-ai": "file:../../ai",

View file

@ -1,6 +1,6 @@
{ {
"name": "@mariozechner/pi-agent-core", "name": "@mariozechner/pi-agent-core",
"version": "0.22.1", "version": "0.22.2",
"description": "General-purpose agent with transport abstraction, state management, and attachment support", "description": "General-purpose agent with transport abstraction, state management, and attachment support",
"type": "module", "type": "module",
"main": "./dist/index.js", "main": "./dist/index.js",
@ -18,8 +18,8 @@
"prepublishOnly": "npm run clean && npm run build" "prepublishOnly": "npm run clean && npm run build"
}, },
"dependencies": { "dependencies": {
"@mariozechner/pi-ai": "^0.22.1", "@mariozechner/pi-ai": "^0.22.2",
"@mariozechner/pi-tui": "^0.22.1" "@mariozechner/pi-tui": "^0.22.2"
}, },
"keywords": [ "keywords": [
"ai", "ai",

View file

@ -2,6 +2,12 @@
## [Unreleased] ## [Unreleased]
## [0.22.2] - 2025-12-15
### Added
- **Interleaved thinking for Anthropic**: Added `interleavedThinking` option to `AnthropicOptions`. When enabled, Claude 4 models can think between tool calls and reason after receiving tool results. Enabled by default (no extra token cost, just unlocks the capability). Set `interleavedThinking: false` to disable.
## [0.22.1] - 2025-12-15 ## [0.22.1] - 2025-12-15
_Dedicated to Peter's shoulder ([@steipete](https://twitter.com/steipete))_ _Dedicated to Peter's shoulder ([@steipete](https://twitter.com/steipete))_

View file

@ -1,6 +1,6 @@
{ {
"name": "@mariozechner/pi-ai", "name": "@mariozechner/pi-ai",
"version": "0.22.1", "version": "0.22.2",
"description": "Unified LLM API with automatic model discovery and provider configuration", "description": "Unified LLM API with automatic model discovery and provider configuration",
"type": "module", "type": "module",
"main": "./dist/index.js", "main": "./dist/index.js",

View file

@ -83,6 +83,7 @@ function convertContentBlocks(content: (TextContent | ImageContent)[]):
export interface AnthropicOptions extends StreamOptions { export interface AnthropicOptions extends StreamOptions {
thinkingEnabled?: boolean; thinkingEnabled?: boolean;
thinkingBudgetTokens?: number; thinkingBudgetTokens?: number;
interleavedThinking?: boolean;
toolChoice?: "auto" | "any" | "none" | { type: "tool"; name: string }; toolChoice?: "auto" | "any" | "none" | { type: "tool"; name: string };
} }
@ -114,7 +115,7 @@ export const streamAnthropic: StreamFunction<"anthropic-messages"> = (
try { try {
const apiKey = options?.apiKey ?? getApiKey(model.provider) ?? ""; const apiKey = options?.apiKey ?? getApiKey(model.provider) ?? "";
const { client, isOAuthToken } = createClient(model, apiKey); const { client, isOAuthToken } = createClient(model, apiKey, options?.interleavedThinking ?? true);
const params = buildParams(model, context, isOAuthToken, options); const params = buildParams(model, context, isOAuthToken, options);
const anthropicStream = client.messages.stream({ ...params, stream: true }, { signal: options?.signal }); const anthropicStream = client.messages.stream({ ...params, stream: true }, { signal: options?.signal });
stream.push({ type: "start", partial: output }); stream.push({ type: "start", partial: output });
@ -280,12 +281,18 @@ export const streamAnthropic: StreamFunction<"anthropic-messages"> = (
function createClient( function createClient(
model: Model<"anthropic-messages">, model: Model<"anthropic-messages">,
apiKey: string, apiKey: string,
interleavedThinking: boolean,
): { client: Anthropic; isOAuthToken: boolean } { ): { client: Anthropic; isOAuthToken: boolean } {
const betaFeatures = ["fine-grained-tool-streaming-2025-05-14"];
if (interleavedThinking) {
betaFeatures.push("interleaved-thinking-2025-05-14");
}
if (apiKey.includes("sk-ant-oat")) { if (apiKey.includes("sk-ant-oat")) {
const defaultHeaders = { const defaultHeaders = {
accept: "application/json", accept: "application/json",
"anthropic-dangerous-direct-browser-access": "true", "anthropic-dangerous-direct-browser-access": "true",
"anthropic-beta": "oauth-2025-04-20,fine-grained-tool-streaming-2025-05-14,interleaved-thinking-2025-05-14", "anthropic-beta": `oauth-2025-04-20,${betaFeatures.join(",")}`,
...(model.headers || {}), ...(model.headers || {}),
}; };
@ -303,7 +310,7 @@ function createClient(
const defaultHeaders = { const defaultHeaders = {
accept: "application/json", accept: "application/json",
"anthropic-dangerous-direct-browser-access": "true", "anthropic-dangerous-direct-browser-access": "true",
"anthropic-beta": "fine-grained-tool-streaming-2025-05-14,interleaved-thinking-2025-05-14", "anthropic-beta": betaFeatures.join(","),
...(model.headers || {}), ...(model.headers || {}),
}; };

View file

@ -2,6 +2,12 @@
## [Unreleased] ## [Unreleased]
## [0.22.2] - 2025-12-15
### Changed
- Updated `@mariozechner/pi-ai` with interleaved thinking enabled by default for Anthropic Claude 4 models.
## [0.22.1] - 2025-12-15 ## [0.22.1] - 2025-12-15
_Dedicated to Peter's shoulder ([@steipete](https://twitter.com/steipete))_ _Dedicated to Peter's shoulder ([@steipete](https://twitter.com/steipete))_

View file

@ -1,6 +1,6 @@
{ {
"name": "@mariozechner/pi-coding-agent", "name": "@mariozechner/pi-coding-agent",
"version": "0.22.1", "version": "0.22.2",
"description": "Coding agent CLI with read, bash, edit, write tools and session management", "description": "Coding agent CLI with read, bash, edit, write tools and session management",
"type": "module", "type": "module",
"piConfig": { "piConfig": {
@ -39,9 +39,9 @@
"prepublishOnly": "npm run clean && npm run build" "prepublishOnly": "npm run clean && npm run build"
}, },
"dependencies": { "dependencies": {
"@mariozechner/pi-agent-core": "^0.22.1", "@mariozechner/pi-agent-core": "^0.22.2",
"@mariozechner/pi-ai": "^0.22.1", "@mariozechner/pi-ai": "^0.22.2",
"@mariozechner/pi-tui": "^0.22.1", "@mariozechner/pi-tui": "^0.22.2",
"chalk": "^5.5.0", "chalk": "^5.5.0",
"diff": "^8.0.2", "diff": "^8.0.2",
"glob": "^11.0.3", "glob": "^11.0.3",

View file

@ -1,6 +1,6 @@
{ {
"name": "@mariozechner/pi-mom", "name": "@mariozechner/pi-mom",
"version": "0.22.1", "version": "0.22.2",
"description": "Slack bot that delegates messages to the pi coding agent", "description": "Slack bot that delegates messages to the pi coding agent",
"type": "module", "type": "module",
"bin": { "bin": {
@ -21,9 +21,9 @@
}, },
"dependencies": { "dependencies": {
"@anthropic-ai/sandbox-runtime": "^0.0.16", "@anthropic-ai/sandbox-runtime": "^0.0.16",
"@mariozechner/pi-agent-core": "^0.22.1", "@mariozechner/pi-agent-core": "^0.22.2",
"@mariozechner/pi-ai": "^0.22.1", "@mariozechner/pi-ai": "^0.22.2",
"@mariozechner/pi-coding-agent": "^0.22.1", "@mariozechner/pi-coding-agent": "^0.22.2",
"@sinclair/typebox": "^0.34.0", "@sinclair/typebox": "^0.34.0",
"@slack/socket-mode": "^2.0.0", "@slack/socket-mode": "^2.0.0",
"@slack/web-api": "^7.0.0", "@slack/web-api": "^7.0.0",

View file

@ -1,6 +1,6 @@
{ {
"name": "@mariozechner/pi", "name": "@mariozechner/pi",
"version": "0.22.1", "version": "0.22.2",
"description": "CLI tool for managing vLLM deployments on GPU pods", "description": "CLI tool for managing vLLM deployments on GPU pods",
"type": "module", "type": "module",
"bin": { "bin": {
@ -34,7 +34,7 @@
"node": ">=20.0.0" "node": ">=20.0.0"
}, },
"dependencies": { "dependencies": {
"@mariozechner/pi-agent-core": "^0.22.1", "@mariozechner/pi-agent-core": "^0.22.2",
"chalk": "^5.5.0" "chalk": "^5.5.0"
}, },
"devDependencies": {} "devDependencies": {}

View file

@ -1,6 +1,6 @@
{ {
"name": "@mariozechner/pi-proxy", "name": "@mariozechner/pi-proxy",
"version": "0.22.1", "version": "0.22.2",
"type": "module", "type": "module",
"description": "CORS and authentication proxy for pi-ai", "description": "CORS and authentication proxy for pi-ai",
"main": "dist/index.js", "main": "dist/index.js",

View file

@ -1,6 +1,6 @@
{ {
"name": "@mariozechner/pi-tui", "name": "@mariozechner/pi-tui",
"version": "0.22.1", "version": "0.22.2",
"description": "Terminal User Interface library with differential rendering for efficient text-based applications", "description": "Terminal User Interface library with differential rendering for efficient text-based applications",
"type": "module", "type": "module",
"main": "dist/index.js", "main": "dist/index.js",

View file

@ -1,6 +1,6 @@
{ {
"name": "pi-web-ui-example", "name": "pi-web-ui-example",
"version": "1.10.1", "version": "1.10.2",
"private": true, "private": true,
"type": "module", "type": "module",
"scripts": { "scripts": {

View file

@ -1,6 +1,6 @@
{ {
"name": "@mariozechner/pi-web-ui", "name": "@mariozechner/pi-web-ui",
"version": "0.22.1", "version": "0.22.2",
"description": "Reusable web UI components for AI chat interfaces powered by @mariozechner/pi-ai", "description": "Reusable web UI components for AI chat interfaces powered by @mariozechner/pi-ai",
"type": "module", "type": "module",
"main": "dist/index.js", "main": "dist/index.js",
@ -18,8 +18,8 @@
}, },
"dependencies": { "dependencies": {
"@lmstudio/sdk": "^1.5.0", "@lmstudio/sdk": "^1.5.0",
"@mariozechner/pi-ai": "^0.22.1", "@mariozechner/pi-ai": "^0.22.2",
"@mariozechner/pi-tui": "^0.22.1", "@mariozechner/pi-tui": "^0.22.2",
"docx-preview": "^0.3.7", "docx-preview": "^0.3.7",
"jszip": "^3.10.1", "jszip": "^3.10.1",
"lucide": "^0.544.0", "lucide": "^0.544.0",