@pencil-agent/nano-pencil 1.11.22 → 1.11.23

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.
@@ -16,6 +16,7 @@ const BUNDLED_SIMPLIFY_EXTENSION = join(__dirname, "extensions", "optional", "si
16
16
  const BUNDLED_LINK_WORLD_EXTENSION = join(__dirname, "extensions", "defaults", "link-world", "index.js");
17
17
  const BUNDLED_SECURITY_AUDIT_EXTENSION = join(__dirname, "extensions", "defaults", "security-audit", "index.js");
18
18
  const BUNDLED_SOUL_EXTENSION = join(__dirname, "extensions", "defaults", "soul", "index.js");
19
+ const BUNDLED_PRESENCE_EXTENSION = join(__dirname, "extensions", "defaults", "presence", "index.js");
19
20
  const BUNDLED_INTERVIEW_EXTENSION = join(__dirname, "extensions", "defaults", "interview", "index.js");
20
21
  const BUNDLED_LOOP_EXTENSION = join(__dirname, "extensions", "defaults", "loop", "index.js");
21
22
  const BUNDLED_TEAM_EXTENSION = join(__dirname, "extensions", "defaults", "team", "index.js");
@@ -119,6 +120,14 @@ export function getBuiltinExtensionPaths() {
119
120
  if (existsSync(soulTs))
120
121
  paths.push(soulTs);
121
122
  }
123
+ if (existsSync(BUNDLED_PRESENCE_EXTENSION)) {
124
+ paths.push(BUNDLED_PRESENCE_EXTENSION);
125
+ }
126
+ else {
127
+ const presenceTs = join(__dirname, "extensions", "defaults", "presence", "index.ts");
128
+ if (existsSync(presenceTs))
129
+ paths.push(presenceTs);
130
+ }
122
131
  // === Interview 扩展(需求澄清)===
123
132
  // Placed after Soul to ensure Interview probe sees both Mem + Soul style/systemPrompt injections.
124
133
  if (existsSync(BUNDLED_INTERVIEW_EXTENSION)) {
@@ -10,6 +10,7 @@ export declare const COMPACTION_SUMMARY_PREFIX = "The conversation history befor
10
10
  export declare const COMPACTION_SUMMARY_SUFFIX = "\n</summary>";
11
11
  export declare const BRANCH_SUMMARY_PREFIX = "The following is a summary of a branch that this conversation came back from:\n\n<summary>\n";
12
12
  export declare const BRANCH_SUMMARY_SUFFIX = "</summary>";
13
+ export declare const CUSTOM_MESSAGE_TYPES_EXCLUDED_FROM_CONTEXT: Set<string>;
13
14
  /**
14
15
  * Message type for bash executions via the ! command.
15
16
  */
@@ -9,6 +9,7 @@ export const BRANCH_SUMMARY_PREFIX = `The following is a summary of a branch tha
9
9
  <summary>
10
10
  `;
11
11
  export const BRANCH_SUMMARY_SUFFIX = `</summary>`;
12
+ export const CUSTOM_MESSAGE_TYPES_EXCLUDED_FROM_CONTEXT = new Set(["presence"]);
12
13
  /**
13
14
  * Convert a BashExecutionMessage to user message text for LLM context.
14
15
  */
@@ -81,6 +82,9 @@ export function convertToLlm(messages) {
81
82
  timestamp: m.timestamp,
82
83
  };
83
84
  case "custom": {
85
+ if (CUSTOM_MESSAGE_TYPES_EXCLUDED_FROM_CONTEXT.has(m.customType)) {
86
+ return undefined;
87
+ }
84
88
  const content = typeof m.content === "string" ? [{ type: "text", text: m.content }] : m.content;
85
89
  return {
86
90
  role: "user",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pencil-agent/nano-pencil",
3
- "version": "1.11.22",
3
+ "version": "1.11.23",
4
4
  "description": "CLI writing agent with read, bash, edit, write tools and session management. Based on pi; supports DashScope Coding Plan. Soul enabled by default for AI personality evolution.",
5
5
  "type": "module",
6
6
  "bin": {
@@ -25,7 +25,7 @@
25
25
  "build": "npm run build:deps && tsc && npm run copy:theme:json && npm run copy:extensions && npm run bundle:packages",
26
26
  "build:deps": "npm run build --prefix packages/agent-core && npm run build --prefix packages/ai && npm run build --prefix packages/tui",
27
27
  "copy:theme:json": "node -e \"const fs=require('fs');const p=require('path');const d='dist/modes/interactive/theme';if(!fs.existsSync(d))fs.mkdirSync(d,{recursive:true});fs.readdirSync('modes/interactive/theme').forEach(f=>{if(f.endsWith('.json'))fs.copyFileSync(p.join('modes/interactive/theme',f),p.join(d,f))})\"",
28
- "copy:extensions": "node -e \"\nconst fs=require('fs');\nconst p=require('path');\nfunction c(s,d){\n if(fs.existsSync(d))fs.rmSync(d,{recursive:true,force:true});\n if(!fs.existsSync(d))fs.mkdirSync(d,{recursive:true});\n fs.readdirSync(s).forEach(f=>{\n const sp=p.join(s,f),dp=p.join(d,f);\n fs.statSync(sp).isDirectory()?c(sp,dp):fs.copyFileSync(sp,dp)\n })\n}\n// Copy defaults extensions\n\nc('extensions/defaults/security-audit','dist/extensions/defaults/security-audit');\nc('extensions/defaults/soul','dist/extensions/defaults/soul');\nc('extensions/defaults/interview','dist/extensions/defaults/interview');\nc('extensions/defaults/loop','dist/extensions/defaults/loop');\nc('extensions/defaults/team','dist/extensions/defaults/team');\nc('extensions/defaults/mcp','dist/extensions/defaults/mcp');\n// Copy optional extensions\nc('extensions/optional/simplify','dist/extensions/optional/simplify');\nc('extensions/optional/export-html','dist/extensions/optional/export-html');\nconsole.log('Extensions copied to dist/');\n\"",
28
+ "copy:extensions": "node -e \"\nconst fs=require('fs');\nconst p=require('path');\nfunction c(s,d){\n if(fs.existsSync(d))fs.rmSync(d,{recursive:true,force:true});\n if(!fs.existsSync(d))fs.mkdirSync(d,{recursive:true});\n fs.readdirSync(s).forEach(f=>{\n const sp=p.join(s,f),dp=p.join(d,f);\n fs.statSync(sp).isDirectory()?c(sp,dp):fs.copyFileSync(sp,dp)\n })\n}\n// Copy defaults extensions\n\nc('extensions/defaults/security-audit','dist/extensions/defaults/security-audit');\nc('extensions/defaults/soul','dist/extensions/defaults/soul');\nc('extensions/defaults/presence','dist/extensions/defaults/presence');\nc('extensions/defaults/interview','dist/extensions/defaults/interview');\nc('extensions/defaults/loop','dist/extensions/defaults/loop');\nc('extensions/defaults/team','dist/extensions/defaults/team');\nc('extensions/defaults/mcp','dist/extensions/defaults/mcp');\n// Copy optional extensions\nc('extensions/optional/simplify','dist/extensions/optional/simplify');\nc('extensions/optional/export-html','dist/extensions/optional/export-html');\nconsole.log('Extensions copied to dist/');\n\"",
29
29
  "bundle:packages": "node scripts/bundle-deps.js",
30
30
  "watch": "tsc --watch",
31
31
  "start": "npx cross-env NODE_ENV=production node --no-deprecation dist/cli.js",