From dba267468126651a075ba1eb8376f08a65ae8781 Mon Sep 17 00:00:00 2001 From: Mario Zechner Date: Fri, 12 Dec 2025 10:53:53 +0100 Subject: [PATCH] Release v0.18.6 --- package-lock.json | 40 ++++++++++++++-------------- packages/agent/package.json | 6 ++--- packages/ai/package.json | 2 +- packages/coding-agent/package.json | 8 +++--- packages/mom/CHANGELOG.md | 7 ++++- packages/mom/package.json | 8 +++--- packages/mom/src/agent.ts | 2 +- packages/mom/src/context.ts | 13 ++++++--- packages/pods/package.json | 4 +-- packages/proxy/package.json | 2 +- packages/tui/package.json | 2 +- packages/web-ui/example/package.json | 2 +- packages/web-ui/package.json | 6 ++--- 13 files changed, 57 insertions(+), 45 deletions(-) diff --git a/package-lock.json b/package-lock.json index 677ba069..606825d4 100644 --- a/package-lock.json +++ b/package-lock.json @@ -6538,11 +6538,11 @@ }, "packages/agent": { "name": "@mariozechner/pi-agent-core", - "version": "0.18.5", + "version": "0.18.6", "license": "MIT", "dependencies": { - "@mariozechner/pi-ai": "^0.18.5", - "@mariozechner/pi-tui": "^0.18.5" + "@mariozechner/pi-ai": "^0.18.6", + "@mariozechner/pi-tui": "^0.18.6" }, "devDependencies": { "@types/node": "^24.3.0", @@ -6572,7 +6572,7 @@ }, "packages/ai": { "name": "@mariozechner/pi-ai", - "version": "0.18.5", + "version": "0.18.6", "license": "MIT", "dependencies": { "@anthropic-ai/sdk": "0.71.2", @@ -6614,12 +6614,12 @@ }, "packages/coding-agent": { "name": "@mariozechner/pi-coding-agent", - "version": "0.18.5", + "version": "0.18.6", "license": "MIT", "dependencies": { - "@mariozechner/pi-agent-core": "^0.18.5", - "@mariozechner/pi-ai": "^0.18.5", - "@mariozechner/pi-tui": "^0.18.5", + "@mariozechner/pi-agent-core": "^0.18.6", + "@mariozechner/pi-ai": "^0.18.6", + "@mariozechner/pi-tui": "^0.18.6", "chalk": "^5.5.0", "diff": "^8.0.2", "glob": "^11.0.3", @@ -6657,13 +6657,13 @@ }, "packages/mom": { "name": "@mariozechner/pi-mom", - "version": "0.18.5", + "version": "0.18.6", "license": "MIT", "dependencies": { "@anthropic-ai/sandbox-runtime": "^0.0.16", - "@mariozechner/pi-agent-core": "^0.18.5", - "@mariozechner/pi-ai": "^0.18.5", - "@mariozechner/pi-coding-agent": "^0.18.5", + "@mariozechner/pi-agent-core": "^0.18.6", + "@mariozechner/pi-ai": "^0.18.6", + "@mariozechner/pi-coding-agent": "^0.18.6", "@sinclair/typebox": "^0.34.0", "@slack/socket-mode": "^2.0.0", "@slack/web-api": "^7.0.0", @@ -6701,10 +6701,10 @@ }, "packages/pods": { "name": "@mariozechner/pi", - "version": "0.18.5", + "version": "0.18.6", "license": "MIT", "dependencies": { - "@mariozechner/pi-agent-core": "^0.18.5", + "@mariozechner/pi-agent-core": "^0.18.6", "chalk": "^5.5.0" }, "bin": { @@ -6717,7 +6717,7 @@ }, "packages/proxy": { "name": "@mariozechner/pi-proxy", - "version": "0.18.5", + "version": "0.18.6", "dependencies": { "@hono/node-server": "^1.14.0", "hono": "^4.6.16" @@ -6733,7 +6733,7 @@ }, "packages/tui": { "name": "@mariozechner/pi-tui", - "version": "0.18.5", + "version": "0.18.6", "license": "MIT", "dependencies": { "@types/mime-types": "^2.1.4", @@ -6777,12 +6777,12 @@ }, "packages/web-ui": { "name": "@mariozechner/pi-web-ui", - "version": "0.18.5", + "version": "0.18.6", "license": "MIT", "dependencies": { "@lmstudio/sdk": "^1.5.0", - "@mariozechner/pi-ai": "^0.18.5", - "@mariozechner/pi-tui": "^0.18.5", + "@mariozechner/pi-ai": "^0.18.6", + "@mariozechner/pi-tui": "^0.18.6", "docx-preview": "^0.3.7", "jszip": "^3.10.1", "lucide": "^0.544.0", @@ -6803,7 +6803,7 @@ }, "packages/web-ui/example": { "name": "pi-web-ui-example", - "version": "1.6.5", + "version": "1.6.6", "dependencies": { "@mariozechner/mini-lit": "^0.2.0", "@mariozechner/pi-ai": "file:../../ai", diff --git a/packages/agent/package.json b/packages/agent/package.json index 09e9caf6..0e5b5034 100644 --- a/packages/agent/package.json +++ b/packages/agent/package.json @@ -1,6 +1,6 @@ { "name": "@mariozechner/pi-agent-core", - "version": "0.18.5", + "version": "0.18.6", "description": "General-purpose agent with transport abstraction, state management, and attachment support", "type": "module", "main": "./dist/index.js", @@ -18,8 +18,8 @@ "prepublishOnly": "npm run clean && npm run build" }, "dependencies": { - "@mariozechner/pi-ai": "^0.18.5", - "@mariozechner/pi-tui": "^0.18.5" + "@mariozechner/pi-ai": "^0.18.6", + "@mariozechner/pi-tui": "^0.18.6" }, "keywords": [ "ai", diff --git a/packages/ai/package.json b/packages/ai/package.json index 2f3a605f..177ecdcd 100644 --- a/packages/ai/package.json +++ b/packages/ai/package.json @@ -1,6 +1,6 @@ { "name": "@mariozechner/pi-ai", - "version": "0.18.5", + "version": "0.18.6", "description": "Unified LLM API with automatic model discovery and provider configuration", "type": "module", "main": "./dist/index.js", diff --git a/packages/coding-agent/package.json b/packages/coding-agent/package.json index 67e6c4d2..2c47985a 100644 --- a/packages/coding-agent/package.json +++ b/packages/coding-agent/package.json @@ -1,6 +1,6 @@ { "name": "@mariozechner/pi-coding-agent", - "version": "0.18.5", + "version": "0.18.6", "description": "Coding agent CLI with read, bash, edit, write tools and session management", "type": "module", "piConfig": { @@ -39,9 +39,9 @@ "prepublishOnly": "npm run clean && npm run build" }, "dependencies": { - "@mariozechner/pi-agent-core": "^0.18.5", - "@mariozechner/pi-ai": "^0.18.5", - "@mariozechner/pi-tui": "^0.18.5", + "@mariozechner/pi-agent-core": "^0.18.6", + "@mariozechner/pi-ai": "^0.18.6", + "@mariozechner/pi-tui": "^0.18.6", "chalk": "^5.5.0", "diff": "^8.0.2", "glob": "^11.0.3", diff --git a/packages/mom/CHANGELOG.md b/packages/mom/CHANGELOG.md index 2ecb2711..00134ce9 100644 --- a/packages/mom/CHANGELOG.md +++ b/packages/mom/CHANGELOG.md @@ -1,6 +1,11 @@ # Changelog -## [Unreleased] +## [0.18.6] - 2025-12-12 + +### Fixed + +- Duplicate message in context when message has attachments (sync from log didn't strip attachment section before comparing) +- Use `` delimiter for attachments in messages (easier to parse/strip) ## [0.18.5] - 2025-12-12 diff --git a/packages/mom/package.json b/packages/mom/package.json index b15592af..05a3924c 100644 --- a/packages/mom/package.json +++ b/packages/mom/package.json @@ -1,6 +1,6 @@ { "name": "@mariozechner/pi-mom", - "version": "0.18.5", + "version": "0.18.6", "description": "Slack bot that delegates messages to the pi coding agent", "type": "module", "bin": { @@ -21,9 +21,9 @@ }, "dependencies": { "@anthropic-ai/sandbox-runtime": "^0.0.16", - "@mariozechner/pi-agent-core": "^0.18.5", - "@mariozechner/pi-ai": "^0.18.5", - "@mariozechner/pi-coding-agent": "^0.18.5", + "@mariozechner/pi-agent-core": "^0.18.6", + "@mariozechner/pi-ai": "^0.18.6", + "@mariozechner/pi-coding-agent": "^0.18.6", "@sinclair/typebox": "^0.34.0", "@slack/socket-mode": "^2.0.0", "@slack/web-api": "^7.0.0", diff --git a/packages/mom/src/agent.ts b/packages/mom/src/agent.ts index 79ccdb06..fb294668 100644 --- a/packages/mom/src/agent.ts +++ b/packages/mom/src/agent.ts @@ -588,7 +588,7 @@ function createRunner(sandboxConfig: SandboxConfig, channelId: string, channelDi // Add attachment paths if any (convert to absolute paths in execution environment) if (ctx.message.attachments && ctx.message.attachments.length > 0) { const attachmentPaths = ctx.message.attachments.map((a) => `${workspacePath}/${a.local}`).join("\n"); - userMessage += `\n\nAttachments:\n${attachmentPaths}`; + userMessage += `\n\n\n${attachmentPaths}\n`; } // Debug: write context to last_prompt.jsonl diff --git a/packages/mom/src/context.ts b/packages/mom/src/context.ts index d2f4d62f..542bce4f 100644 --- a/packages/mom/src/context.ts +++ b/packages/mom/src/context.ts @@ -604,7 +604,7 @@ export function syncLogToContext(channelDir: string, excludeAfterTs?: string): n } // For deduplication, we need to track what's already in context - // Read context and extract user message content + // Read context and extract user message content (strip attachments section for comparison) const existingMessages = new Set(); if (existsSync(contextFile)) { const contextContent = readFileSync(contextFile, "utf-8"); @@ -613,9 +613,16 @@ export function syncLogToContext(channelDir: string, excludeAfterTs?: string): n try { const entry = JSON.parse(line); if (entry.type === "message" && entry.message?.role === "user") { - const content = + let content = typeof entry.message.content === "string" ? entry.message.content : entry.message.content?.[0]?.text; - if (content) existingMessages.add(content); + // Strip attachments section for comparison (live messages have it, log messages don't) + if (content) { + const attachmentsIdx = content.indexOf("\n\n\n"); + if (attachmentsIdx !== -1) { + content = content.substring(0, attachmentsIdx); + } + existingMessages.add(content); + } } } catch {} } diff --git a/packages/pods/package.json b/packages/pods/package.json index bb592284..f7b959cd 100644 --- a/packages/pods/package.json +++ b/packages/pods/package.json @@ -1,6 +1,6 @@ { "name": "@mariozechner/pi", - "version": "0.18.5", + "version": "0.18.6", "description": "CLI tool for managing vLLM deployments on GPU pods", "type": "module", "bin": { @@ -34,7 +34,7 @@ "node": ">=20.0.0" }, "dependencies": { - "@mariozechner/pi-agent-core": "^0.18.5", + "@mariozechner/pi-agent-core": "^0.18.6", "chalk": "^5.5.0" }, "devDependencies": {} diff --git a/packages/proxy/package.json b/packages/proxy/package.json index 242b0fe3..43dfa68a 100644 --- a/packages/proxy/package.json +++ b/packages/proxy/package.json @@ -1,6 +1,6 @@ { "name": "@mariozechner/pi-proxy", - "version": "0.18.5", + "version": "0.18.6", "type": "module", "description": "CORS and authentication proxy for pi-ai", "main": "dist/index.js", diff --git a/packages/tui/package.json b/packages/tui/package.json index 744122c9..61eef27e 100644 --- a/packages/tui/package.json +++ b/packages/tui/package.json @@ -1,6 +1,6 @@ { "name": "@mariozechner/pi-tui", - "version": "0.18.5", + "version": "0.18.6", "description": "Terminal User Interface library with differential rendering for efficient text-based applications", "type": "module", "main": "dist/index.js", diff --git a/packages/web-ui/example/package.json b/packages/web-ui/example/package.json index 26aa328f..64b3ed22 100644 --- a/packages/web-ui/example/package.json +++ b/packages/web-ui/example/package.json @@ -1,6 +1,6 @@ { "name": "pi-web-ui-example", - "version": "1.6.5", + "version": "1.6.6", "private": true, "type": "module", "scripts": { diff --git a/packages/web-ui/package.json b/packages/web-ui/package.json index 5470ddf8..4a44ef5d 100644 --- a/packages/web-ui/package.json +++ b/packages/web-ui/package.json @@ -1,6 +1,6 @@ { "name": "@mariozechner/pi-web-ui", - "version": "0.18.5", + "version": "0.18.6", "description": "Reusable web UI components for AI chat interfaces powered by @mariozechner/pi-ai", "type": "module", "main": "dist/index.js", @@ -18,8 +18,8 @@ }, "dependencies": { "@lmstudio/sdk": "^1.5.0", - "@mariozechner/pi-ai": "^0.18.5", - "@mariozechner/pi-tui": "^0.18.5", + "@mariozechner/pi-ai": "^0.18.6", + "@mariozechner/pi-tui": "^0.18.6", "docx-preview": "^0.3.7", "jszip": "^3.10.1", "lucide": "^0.544.0",