@codex-infinity/pi-infinity 0.64.1 → 0.64.2

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.
Files changed (70) hide show
  1. package/CHANGELOG.md +73 -0
  2. package/README.md +6 -2
  3. package/dist/core/agent-session-runtime.d.ts +134 -0
  4. package/dist/core/agent-session-runtime.d.ts.map +1 -0
  5. package/dist/core/agent-session-runtime.js +262 -0
  6. package/dist/core/agent-session-runtime.js.map +1 -0
  7. package/dist/core/agent-session.d.ts +5 -42
  8. package/dist/core/agent-session.d.ts.map +1 -1
  9. package/dist/core/agent-session.js +13 -207
  10. package/dist/core/agent-session.js.map +1 -1
  11. package/dist/core/export-html/tool-renderer.d.ts +2 -0
  12. package/dist/core/export-html/tool-renderer.d.ts.map +1 -1
  13. package/dist/core/export-html/tool-renderer.js +2 -2
  14. package/dist/core/export-html/tool-renderer.js.map +1 -1
  15. package/dist/core/extensions/index.d.ts +1 -1
  16. package/dist/core/extensions/index.d.ts.map +1 -1
  17. package/dist/core/extensions/index.js.map +1 -1
  18. package/dist/core/extensions/types.d.ts +7 -16
  19. package/dist/core/extensions/types.d.ts.map +1 -1
  20. package/dist/core/extensions/types.js.map +1 -1
  21. package/dist/core/footer-data-provider.d.ts +5 -1
  22. package/dist/core/footer-data-provider.d.ts.map +1 -1
  23. package/dist/core/footer-data-provider.js +69 -8
  24. package/dist/core/footer-data-provider.js.map +1 -1
  25. package/dist/core/index.d.ts +2 -1
  26. package/dist/core/index.d.ts.map +1 -1
  27. package/dist/core/index.js +1 -0
  28. package/dist/core/index.js.map +1 -1
  29. package/dist/core/sdk.d.ts +4 -1
  30. package/dist/core/sdk.d.ts.map +1 -1
  31. package/dist/core/sdk.js +3 -0
  32. package/dist/core/sdk.js.map +1 -1
  33. package/dist/index.d.ts +2 -2
  34. package/dist/index.d.ts.map +1 -1
  35. package/dist/index.js +2 -2
  36. package/dist/index.js.map +1 -1
  37. package/dist/main.d.ts.map +1 -1
  38. package/dist/main.js +41 -9
  39. package/dist/main.js.map +1 -1
  40. package/dist/modes/interactive/components/footer.d.ts +1 -0
  41. package/dist/modes/interactive/components/footer.d.ts.map +1 -1
  42. package/dist/modes/interactive/components/footer.js +4 -1
  43. package/dist/modes/interactive/components/footer.js.map +1 -1
  44. package/dist/modes/interactive/interactive-mode.d.ts +8 -4
  45. package/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  46. package/dist/modes/interactive/interactive-mode.js +89 -86
  47. package/dist/modes/interactive/interactive-mode.js.map +1 -1
  48. package/dist/modes/interactive/theme/theme.d.ts.map +1 -1
  49. package/dist/modes/interactive/theme/theme.js +6 -11
  50. package/dist/modes/interactive/theme/theme.js.map +1 -1
  51. package/dist/modes/print-mode.d.ts +2 -2
  52. package/dist/modes/print-mode.d.ts.map +1 -1
  53. package/dist/modes/print-mode.js +37 -36
  54. package/dist/modes/print-mode.js.map +1 -1
  55. package/dist/modes/rpc/rpc-mode.d.ts +2 -2
  56. package/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
  57. package/dist/modes/rpc/rpc-mode.js +69 -49
  58. package/dist/modes/rpc/rpc-mode.js.map +1 -1
  59. package/docs/extensions.md +43 -19
  60. package/docs/sdk.md +148 -63
  61. package/docs/tree.md +1 -1
  62. package/examples/extensions/hidden-thinking-label.ts +0 -4
  63. package/examples/extensions/rpc-demo.ts +3 -9
  64. package/examples/extensions/status-line.ts +0 -8
  65. package/examples/extensions/todo.ts +0 -2
  66. package/examples/extensions/tools.ts +0 -5
  67. package/examples/extensions/widget-placement.ts +4 -12
  68. package/examples/sdk/13-session-runtime.ts +49 -0
  69. package/examples/sdk/README.md +2 -1
  70. package/package.json +4 -4
package/docs/tree.md CHANGED
@@ -13,7 +13,7 @@ Sessions are stored as trees where each entry has an `id` and `parentId`. The "l
13
13
  | View | Flat list of user messages | Full tree structure |
14
14
  | Action | Extracts path to **new session file** | Changes leaf in **same session** |
15
15
  | Summary | Never | Optional (user prompted) |
16
- | Events | `session_before_fork` / `session_fork` | `session_before_tree` / `session_tree` |
16
+ | Events | `session_before_fork` / `session_start` (`reason: "fork"`) | `session_before_tree` / `session_tree` |
17
17
 
18
18
  ## Tree UI
19
19
 
@@ -33,10 +33,6 @@ export default function (pi: ExtensionAPI) {
33
33
  applyLabel(ctx);
34
34
  });
35
35
 
36
- pi.on("session_switch", async (_event, ctx) => {
37
- applyLabel(ctx);
38
- });
39
-
40
36
  pi.registerCommand("thinking-label", {
41
37
  description: "Set the hidden thinking label. Use without args to reset.",
42
38
  handler: async (args, ctx) => {
@@ -13,7 +13,7 @@
13
13
  * - notify() - after each dialog completes
14
14
  * - setStatus() - on turn_start/turn_end
15
15
  * - setWidget() - on session_start
16
- * - setTitle() - on session_start and session_switch
16
+ * - setTitle() - on session_start
17
17
  * - setEditorText() - via /rpc-prefill command
18
18
  */
19
19
 
@@ -24,18 +24,12 @@ export default function (pi: ExtensionAPI) {
24
24
 
25
25
  // -- setTitle, setWidget, setStatus on session lifecycle --
26
26
 
27
- pi.on("session_start", async (_event, ctx) => {
28
- ctx.ui.setTitle("pi RPC Demo");
27
+ pi.on("session_start", async (event, ctx) => {
28
+ ctx.ui.setTitle(event.reason === "new" ? "pi RPC Demo (new session)" : "pi RPC Demo");
29
29
  ctx.ui.setWidget("rpc-demo", ["--- RPC Extension UI Demo ---", "Loaded and ready."]);
30
30
  ctx.ui.setStatus("rpc-demo", `Turns: ${turnCount}`);
31
31
  });
32
32
 
33
- pi.on("session_switch", async (_event, ctx) => {
34
- turnCount = 0;
35
- ctx.ui.setTitle("pi RPC Demo (new session)");
36
- ctx.ui.setStatus("rpc-demo", `Turns: ${turnCount}`);
37
- });
38
-
39
33
  // -- setStatus on turn lifecycle --
40
34
 
41
35
  pi.on("turn_start", async (_event, ctx) => {
@@ -29,12 +29,4 @@ export default function (pi: ExtensionAPI) {
29
29
  const text = theme.fg("dim", ` Turn ${turnCount} complete`);
30
30
  ctx.ui.setStatus("status-demo", check + text);
31
31
  });
32
-
33
- pi.on("session_switch", async (event, ctx) => {
34
- if (event.reason === "new") {
35
- turnCount = 0;
36
- const theme = ctx.ui.theme;
37
- ctx.ui.setStatus("status-demo", theme.fg("dim", "Ready"));
38
- }
39
- });
40
32
  }
@@ -130,8 +130,6 @@ export default function (pi: ExtensionAPI) {
130
130
 
131
131
  // Reconstruct state on session events
132
132
  pi.on("session_start", async (_event, ctx) => reconstructState(ctx));
133
- pi.on("session_switch", async (_event, ctx) => reconstructState(ctx));
134
- pi.on("session_fork", async (_event, ctx) => reconstructState(ctx));
135
133
  pi.on("session_tree", async (_event, ctx) => reconstructState(ctx));
136
134
 
137
135
  // Register the todo tool for the LLM
@@ -138,9 +138,4 @@ export default function toolsExtension(pi: ExtensionAPI) {
138
138
  pi.on("session_tree", async (_event, ctx) => {
139
139
  restoreFromBranch(ctx);
140
140
  });
141
-
142
- // Restore state after forking
143
- pi.on("session_fork", async (_event, ctx) => {
144
- restoreFromBranch(ctx);
145
- });
146
141
  }
@@ -1,17 +1,9 @@
1
- import type { ExtensionAPI, ExtensionContext } from "@mariozechner/pi-coding-agent";
2
-
3
- const applyWidgets = (ctx: ExtensionContext) => {
4
- if (!ctx.hasUI) return;
5
- ctx.ui.setWidget("widget-above", ["Above editor widget"]);
6
- ctx.ui.setWidget("widget-below", ["Below editor widget"], { placement: "belowEditor" });
7
- };
1
+ import type { ExtensionAPI } from "@mariozechner/pi-coding-agent";
8
2
 
9
3
  export default function widgetPlacementExtension(pi: ExtensionAPI) {
10
4
  pi.on("session_start", (_event, ctx) => {
11
- applyWidgets(ctx);
12
- });
13
-
14
- pi.on("session_switch", (_event, ctx) => {
15
- applyWidgets(ctx);
5
+ if (!ctx.hasUI) return;
6
+ ctx.ui.setWidget("widget-above", ["Above editor widget"]);
7
+ ctx.ui.setWidget("widget-below", ["Below editor widget"], { placement: "belowEditor" });
16
8
  });
17
9
  }
@@ -0,0 +1,49 @@
1
+ /**
2
+ * Session Runtime Host
3
+ *
4
+ * Use the runtime host when you need to replace the active AgentSession,
5
+ * for example for new-session, resume, fork, or import flows.
6
+ *
7
+ * The important pattern is: after the host replaces the runtime, rebind any
8
+ * session-local subscriptions and extension bindings to `runtimeHost.session`.
9
+ */
10
+
11
+ import { AgentSessionRuntimeHost, createAgentSessionRuntime, SessionManager } from "@mariozechner/pi-coding-agent";
12
+
13
+ const bootstrap = {};
14
+ const runtime = await createAgentSessionRuntime(bootstrap, {
15
+ cwd: process.cwd(),
16
+ sessionManager: SessionManager.create(process.cwd()),
17
+ });
18
+ const runtimeHost = new AgentSessionRuntimeHost(bootstrap, runtime);
19
+
20
+ let unsubscribe: (() => void) | undefined;
21
+
22
+ async function bindSession() {
23
+ unsubscribe?.();
24
+ const session = runtimeHost.session;
25
+ await session.bindExtensions({});
26
+ unsubscribe = session.subscribe((event) => {
27
+ if (event.type === "queue_update") {
28
+ console.log("Queued:", event.steering.length + event.followUp.length);
29
+ }
30
+ });
31
+ return session;
32
+ }
33
+
34
+ let session = await bindSession();
35
+ const originalSessionFile = session.sessionFile;
36
+ console.log("Initial session:", originalSessionFile);
37
+
38
+ await runtimeHost.newSession();
39
+ session = await bindSession();
40
+ console.log("After newSession():", session.sessionFile);
41
+
42
+ if (originalSessionFile) {
43
+ await runtimeHost.switchSession(originalSessionFile);
44
+ session = await bindSession();
45
+ console.log("After switchSession():", session.sessionFile);
46
+ }
47
+
48
+ unsubscribe?.();
49
+ await runtimeHost.dispose();
@@ -1,6 +1,6 @@
1
1
  # SDK Examples
2
2
 
3
- Programmatic usage of pi-coding-agent via `createAgentSession()`.
3
+ Programmatic usage of pi-coding-agent via `createAgentSession()` and `createAgentSessionRuntime()`.
4
4
 
5
5
  ## Examples
6
6
 
@@ -18,6 +18,7 @@ Programmatic usage of pi-coding-agent via `createAgentSession()`.
18
18
  | `10-settings.ts` | Override compaction, retry, terminal settings |
19
19
  | `11-sessions.ts` | In-memory, persistent, continue, list sessions |
20
20
  | `12-full-control.ts` | Replace everything, no discovery |
21
+ | `13-session-runtime.ts` | Manage runtime-backed session replacement |
21
22
 
22
23
  ## Running
23
24
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@codex-infinity/pi-infinity",
3
- "version": "0.64.1",
3
+ "version": "0.64.2",
4
4
  "description": "Coding agent CLI with read, bash, edit, write tools and session management",
5
5
  "type": "module",
6
6
  "piConfig": {
@@ -40,9 +40,9 @@
40
40
  },
41
41
  "dependencies": {
42
42
  "@mariozechner/jiti": "^2.6.2",
43
- "@mariozechner/pi-agent-core": "^0.64.1",
44
- "@mariozechner/pi-ai": "^0.64.1",
45
- "@mariozechner/pi-tui": "^0.64.1",
43
+ "@mariozechner/pi-agent-core": "^0.64.2",
44
+ "@mariozechner/pi-ai": "^0.64.2",
45
+ "@mariozechner/pi-tui": "^0.64.2",
46
46
  "@silvia-odwyer/photon-node": "^0.3.4",
47
47
  "ajv": "^8.17.1",
48
48
  "chalk": "^5.5.0",