@xynogen/pix-commands 0.1.3 → 0.1.5
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/README.md +7 -3
- package/package.json +2 -2
- package/src/extension.ts +0 -2
- package/src/index.ts +0 -1
- package/src/diff.ts +0 -38
package/README.md
CHANGED
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
# pix-commands
|
|
2
2
|
|
|
3
|
-
Pi extension — `/
|
|
3
|
+
Pi extension — `/clear` slash command.
|
|
4
4
|
|
|
5
5
|
## What it does
|
|
6
6
|
|
|
7
|
-
Registers
|
|
7
|
+
Registers the `/clear` slash command. `/clear` deletes `~/.cache/pi` — useful for flushing stale model-data or BenchLM cache — and prompts you to run `/reload` to apply the change. No extra dependencies beyond Pi.
|
|
8
|
+
|
|
9
|
+
> Diff review moved to the `diff` skill in [`@xynogen/pix-skills`](https://github.com/xynogen/pix-mono/tree/main/packages/pix-skills), which pre-populates `git status` + staged/unstaged diffs via the `` !`cmd` `` directive.
|
|
8
10
|
|
|
9
11
|
## Install
|
|
10
12
|
|
|
@@ -12,7 +14,7 @@ Registers two slash commands. `/diff` asks the agent to inspect `git status` and
|
|
|
12
14
|
pi install npm:@xynogen/pix-commands
|
|
13
15
|
```
|
|
14
16
|
|
|
15
|
-
> Also included in [`@xynogen/pix-core`](https://
|
|
17
|
+
> Also included in [`@xynogen/pix-core`](https://www.npmjs.com/package/@xynogen/pix-core):
|
|
16
18
|
>
|
|
17
19
|
> ```bash
|
|
18
20
|
> pi install npm:@xynogen/pix-core
|
|
@@ -20,6 +22,8 @@ pi install npm:@xynogen/pix-commands
|
|
|
20
22
|
|
|
21
23
|
## Full distro
|
|
22
24
|
|
|
25
|
+
Source: [github.com/xynogen/pix-mono](https://github.com/xynogen/pix-mono)
|
|
26
|
+
|
|
23
27
|
To install the complete pix suite (all packages + Pi itself):
|
|
24
28
|
|
|
25
29
|
```bash
|
package/package.json
CHANGED
package/src/extension.ts
CHANGED
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import type { ExtensionAPI } from "@earendil-works/pi-coding-agent";
|
|
2
2
|
import registerClear from "./clear.ts";
|
|
3
|
-
import registerDiff from "./diff.ts";
|
|
4
3
|
import { once } from "./once.ts";
|
|
5
4
|
|
|
6
5
|
export default function (pi: ExtensionAPI): void {
|
|
7
6
|
once(pi, "pix-commands", () => {
|
|
8
|
-
registerDiff(pi);
|
|
9
7
|
registerClear(pi);
|
|
10
8
|
});
|
|
11
9
|
}
|
package/src/index.ts
CHANGED
package/src/diff.ts
DELETED
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* /diff — summarise unstaged git diff: what changed, why, and impact.
|
|
3
|
-
*
|
|
4
|
-
* The agent runs `git status` + `git diff`, then replies with:
|
|
5
|
-
* 1. One-line TL;DR of the overall change
|
|
6
|
-
* 2. Per-file summary: what changed and why (not just counts)
|
|
7
|
-
* 3. Brief impact note (behaviour change, bug fix, refactor, etc.)
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import type { ExtensionAPI } from "@earendil-works/pi-coding-agent";
|
|
11
|
-
|
|
12
|
-
const DIFF_PROMPT = `Run \`git status\` and \`git diff\` to inspect all unstaged changes, then respond with:
|
|
13
|
-
|
|
14
|
-
**TL;DR** — one sentence: what is the overall change.
|
|
15
|
-
|
|
16
|
-
**Per-file breakdown** — for each changed file:
|
|
17
|
-
- Filename (+lines/-lines)
|
|
18
|
-
- What changed (describe the actual code change)
|
|
19
|
-
- Why it changed (intent / reason behind the edit)
|
|
20
|
-
|
|
21
|
-
**Impact** — one sentence: what effect does this have on behaviour, tests, or users.
|
|
22
|
-
|
|
23
|
-
Rules: base everything on the actual diff content. Use \`git diff --stat\` for line counts. Skip staged-only changes. Be concise — each file entry should fit in 1-2 lines.`;
|
|
24
|
-
|
|
25
|
-
export default function (pi: ExtensionAPI) {
|
|
26
|
-
pi.registerCommand("diff", {
|
|
27
|
-
description:
|
|
28
|
-
"Summarise unstaged diff: TL;DR, per-file what/why/counts, impact",
|
|
29
|
-
handler: async (_args, ctx) => {
|
|
30
|
-
if (!ctx.isIdle()) {
|
|
31
|
-
pi.sendUserMessage(DIFF_PROMPT, { deliverAs: "followUp" });
|
|
32
|
-
ctx.ui.notify("Queued /diff after the current turn finishes.", "info");
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
pi.sendUserMessage(DIFF_PROMPT);
|
|
36
|
-
},
|
|
37
|
-
});
|
|
38
|
-
}
|