@cydm/pie 1.0.6 → 1.0.7

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 (59) hide show
  1. package/README.md +151 -9
  2. package/dist/builtin/extensions/ask-user/index.js +2 -3
  3. package/dist/builtin/extensions/kimi-attachments/index.js +3 -3
  4. package/dist/builtin/extensions/plan-mode/index.js +85 -87
  5. package/dist/builtin/extensions/subagent/index.js +73 -8
  6. package/dist/builtin/extensions/todo/index.js +51 -22
  7. package/dist/builtin/skills/browser-tools/CHANGELOG.md +2 -44
  8. package/dist/builtin/skills/browser-tools/README.md +10 -99
  9. package/dist/builtin/skills/browser-tools/SKILL.md +21 -174
  10. package/dist/builtin/skills/browser-tools/package.json +6 -13
  11. package/dist/builtin/skills/browser-tools/playwright-cli.js +24 -0
  12. package/dist/builtin/skills/pie-unity-rpc/SKILL.md +121 -0
  13. package/dist/builtin/skills/pie-unity-rpc/pie-unity-rpc.js +417 -0
  14. package/dist/builtin/skills/skill-creator/SKILL.md +17 -17
  15. package/dist/builtin/skills/skill-creator/eval-viewer/generate_review.mjs +285 -0
  16. package/dist/builtin/skills/skill-creator/eval-viewer/viewer.html +1 -1
  17. package/dist/builtin/skills/skill-creator/scripts/aggregate_benchmark.mjs +271 -0
  18. package/dist/builtin/skills/skill-creator/scripts/claude_cli.mjs +115 -0
  19. package/dist/builtin/skills/skill-creator/scripts/generate_report.mjs +224 -0
  20. package/dist/builtin/skills/skill-creator/scripts/improve_description.mjs +198 -0
  21. package/dist/builtin/skills/skill-creator/scripts/package_skill.mjs +132 -0
  22. package/dist/builtin/skills/skill-creator/scripts/pie_runner.mjs +115 -0
  23. package/dist/builtin/skills/skill-creator/scripts/quick_validate.mjs +44 -0
  24. package/dist/builtin/skills/skill-creator/scripts/run_eval.mjs +169 -0
  25. package/dist/builtin/skills/skill-creator/scripts/run_loop.mjs +297 -0
  26. package/dist/builtin/skills/skill-creator/scripts/skill_metadata.mjs +134 -0
  27. package/dist/chunks/{chunk-MWFBYJOI.js → chunk-A5JSJAPK.js} +3973 -1313
  28. package/dist/chunks/chunk-BHNULR7U.js +7991 -0
  29. package/dist/chunks/chunk-GDTN4UPJ.js +701 -0
  30. package/dist/chunks/{src-EGWRDMLB.js → src-3X3HBT2G.js} +1 -2
  31. package/dist/chunks/typescript-GSKWJIO4.js +210747 -0
  32. package/dist/cli.js +14664 -11973
  33. package/models.schema.json +238 -0
  34. package/package.json +34 -8
  35. package/dist/builtin/skills/browser-tools/browser-content.js +0 -103
  36. package/dist/builtin/skills/browser-tools/browser-cookies.js +0 -35
  37. package/dist/builtin/skills/browser-tools/browser-eval.js +0 -49
  38. package/dist/builtin/skills/browser-tools/browser-hn-scraper.js +0 -108
  39. package/dist/builtin/skills/browser-tools/browser-nav.js +0 -44
  40. package/dist/builtin/skills/browser-tools/browser-pick.js +0 -162
  41. package/dist/builtin/skills/browser-tools/browser-screenshot.js +0 -34
  42. package/dist/builtin/skills/browser-tools/browser-start.js +0 -86
  43. package/dist/builtin/skills/skill-creator/eval-viewer/generate_review.py +0 -471
  44. package/dist/builtin/skills/skill-creator/scripts/__init__.py +0 -0
  45. package/dist/builtin/skills/skill-creator/scripts/aggregate_benchmark.py +0 -401
  46. package/dist/builtin/skills/skill-creator/scripts/generate_report.py +0 -326
  47. package/dist/builtin/skills/skill-creator/scripts/improve_description.py +0 -247
  48. package/dist/builtin/skills/skill-creator/scripts/package_skill.py +0 -136
  49. package/dist/builtin/skills/skill-creator/scripts/quick_validate.py +0 -103
  50. package/dist/builtin/skills/skill-creator/scripts/run_eval.py +0 -310
  51. package/dist/builtin/skills/skill-creator/scripts/run_loop.py +0 -328
  52. package/dist/builtin/skills/skill-creator/scripts/utils.py +0 -47
  53. package/dist/chunks/capabilities-FENCOHVA.js +0 -9
  54. package/dist/chunks/chunk-JYBXCEJJ.js +0 -315
  55. package/dist/chunks/chunk-RID3574D.js +0 -2718
  56. package/dist/chunks/chunk-TBJ25UWB.js +0 -3657
  57. package/dist/chunks/chunk-XZXLO7YB.js +0 -322
  58. package/dist/chunks/file-logger-AL5VVZHH.js +0 -22
  59. package/dist/chunks/src-WRUACRN2.js +0 -132
@@ -1,162 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- import puppeteer from "puppeteer-core";
4
-
5
- const message = process.argv.slice(2).join(" ");
6
- if (!message) {
7
- console.log("Usage: browser-pick.js 'message'");
8
- console.log("\nExample:");
9
- console.log(' browser-pick.js "Click the submit button"');
10
- process.exit(1);
11
- }
12
-
13
- const b = await Promise.race([
14
- puppeteer.connect({
15
- browserURL: "http://localhost:9222",
16
- defaultViewport: null,
17
- }),
18
- new Promise((_, reject) => setTimeout(() => reject(new Error("timeout")), 5000)),
19
- ]).catch((e) => {
20
- console.error("✗ Could not connect to browser:", e.message);
21
- console.error(" Run: browser-start.js");
22
- process.exit(1);
23
- });
24
-
25
- const p = (await b.pages()).at(-1);
26
-
27
- if (!p) {
28
- console.error("✗ No active tab found");
29
- process.exit(1);
30
- }
31
-
32
- // Inject pick() helper into current page
33
- await p.evaluate(() => {
34
- if (!window.pick) {
35
- window.pick = async (message) => {
36
- if (!message) {
37
- throw new Error("pick() requires a message parameter");
38
- }
39
- return new Promise((resolve) => {
40
- const selections = [];
41
- const selectedElements = new Set();
42
-
43
- const overlay = document.createElement("div");
44
- overlay.style.cssText =
45
- "position:fixed;top:0;left:0;width:100%;height:100%;z-index:2147483647;pointer-events:none";
46
-
47
- const highlight = document.createElement("div");
48
- highlight.style.cssText =
49
- "position:absolute;border:2px solid #3b82f6;background:rgba(59,130,246,0.1);transition:all 0.1s";
50
- overlay.appendChild(highlight);
51
-
52
- const banner = document.createElement("div");
53
- banner.style.cssText =
54
- "position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#1f2937;color:white;padding:12px 24px;border-radius:8px;font:14px sans-serif;box-shadow:0 4px 12px rgba(0,0,0,0.3);pointer-events:auto;z-index:2147483647";
55
-
56
- const updateBanner = () => {
57
- banner.textContent = `${message} (${selections.length} selected, Cmd/Ctrl+click to add, Enter to finish, ESC to cancel)`;
58
- };
59
- updateBanner();
60
-
61
- document.body.append(banner, overlay);
62
-
63
- const cleanup = () => {
64
- document.removeEventListener("mousemove", onMove, true);
65
- document.removeEventListener("click", onClick, true);
66
- document.removeEventListener("keydown", onKey, true);
67
- overlay.remove();
68
- banner.remove();
69
- selectedElements.forEach((el) => {
70
- el.style.outline = "";
71
- });
72
- };
73
-
74
- const onMove = (e) => {
75
- const el = document.elementFromPoint(e.clientX, e.clientY);
76
- if (!el || overlay.contains(el) || banner.contains(el)) return;
77
- const r = el.getBoundingClientRect();
78
- highlight.style.cssText = `position:absolute;border:2px solid #3b82f6;background:rgba(59,130,246,0.1);top:${r.top}px;left:${r.left}px;width:${r.width}px;height:${r.height}px`;
79
- };
80
-
81
- const buildElementInfo = (el) => {
82
- const parents = [];
83
- let current = el.parentElement;
84
- while (current && current !== document.body) {
85
- const parentInfo = current.tagName.toLowerCase();
86
- const id = current.id ? `#${current.id}` : "";
87
- const cls = current.className
88
- ? `.${current.className.trim().split(/\s+/).join(".")}`
89
- : "";
90
- parents.push(parentInfo + id + cls);
91
- current = current.parentElement;
92
- }
93
-
94
- return {
95
- tag: el.tagName.toLowerCase(),
96
- id: el.id || null,
97
- class: el.className || null,
98
- text: el.textContent?.trim().slice(0, 200) || null,
99
- html: el.outerHTML.slice(0, 500),
100
- parents: parents.join(" > "),
101
- };
102
- };
103
-
104
- const onClick = (e) => {
105
- if (banner.contains(e.target)) return;
106
- e.preventDefault();
107
- e.stopPropagation();
108
- const el = document.elementFromPoint(e.clientX, e.clientY);
109
- if (!el || overlay.contains(el) || banner.contains(el)) return;
110
-
111
- if (e.metaKey || e.ctrlKey) {
112
- if (!selectedElements.has(el)) {
113
- selectedElements.add(el);
114
- el.style.outline = "3px solid #10b981";
115
- selections.push(buildElementInfo(el));
116
- updateBanner();
117
- }
118
- } else {
119
- cleanup();
120
- const info = buildElementInfo(el);
121
- resolve(selections.length > 0 ? selections : info);
122
- }
123
- };
124
-
125
- const onKey = (e) => {
126
- if (e.key === "Escape") {
127
- e.preventDefault();
128
- cleanup();
129
- resolve(null);
130
- } else if (e.key === "Enter" && selections.length > 0) {
131
- e.preventDefault();
132
- cleanup();
133
- resolve(selections);
134
- }
135
- };
136
-
137
- document.addEventListener("mousemove", onMove, true);
138
- document.addEventListener("click", onClick, true);
139
- document.addEventListener("keydown", onKey, true);
140
- });
141
- };
142
- }
143
- });
144
-
145
- const result = await p.evaluate((msg) => window.pick(msg), message);
146
-
147
- if (Array.isArray(result)) {
148
- for (let i = 0; i < result.length; i++) {
149
- if (i > 0) console.log("");
150
- for (const [key, value] of Object.entries(result[i])) {
151
- console.log(`${key}: ${value}`);
152
- }
153
- }
154
- } else if (typeof result === "object" && result !== null) {
155
- for (const [key, value] of Object.entries(result)) {
156
- console.log(`${key}: ${value}`);
157
- }
158
- } else {
159
- console.log(result);
160
- }
161
-
162
- await b.disconnect();
@@ -1,34 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- import { tmpdir } from "node:os";
4
- import { join } from "node:path";
5
- import puppeteer from "puppeteer-core";
6
-
7
- const b = await Promise.race([
8
- puppeteer.connect({
9
- browserURL: "http://localhost:9222",
10
- defaultViewport: null,
11
- }),
12
- new Promise((_, reject) => setTimeout(() => reject(new Error("timeout")), 5000)),
13
- ]).catch((e) => {
14
- console.error("✗ Could not connect to browser:", e.message);
15
- console.error(" Run: browser-start.js");
16
- process.exit(1);
17
- });
18
-
19
- const p = (await b.pages()).at(-1);
20
-
21
- if (!p) {
22
- console.error("✗ No active tab found");
23
- process.exit(1);
24
- }
25
-
26
- const timestamp = new Date().toISOString().replace(/[:.]/g, "-");
27
- const filename = `screenshot-${timestamp}.png`;
28
- const filepath = join(tmpdir(), filename);
29
-
30
- await p.screenshot({ path: filepath });
31
-
32
- console.log(filepath);
33
-
34
- await b.disconnect();
@@ -1,86 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- import { spawn, execSync } from "node:child_process";
4
- import puppeteer from "puppeteer-core";
5
-
6
- const useProfile = process.argv[2] === "--profile";
7
-
8
- if (process.argv[2] && process.argv[2] !== "--profile") {
9
- console.log("Usage: browser-start.js [--profile]");
10
- console.log("\nOptions:");
11
- console.log(" --profile Copy your default Chrome profile (cookies, logins)");
12
- process.exit(1);
13
- }
14
-
15
- const SCRAPING_DIR = `${process.env.HOME}/.cache/browser-tools`;
16
-
17
- // Check if already running on :9222
18
- try {
19
- const browser = await puppeteer.connect({
20
- browserURL: "http://localhost:9222",
21
- defaultViewport: null,
22
- });
23
- await browser.disconnect();
24
- console.log("✓ Chrome already running on :9222");
25
- process.exit(0);
26
- } catch {}
27
-
28
- // Setup profile directory
29
- execSync(`mkdir -p "${SCRAPING_DIR}"`, { stdio: "ignore" });
30
-
31
- // Remove SingletonLock to allow new instance
32
- try {
33
- execSync(`rm -f "${SCRAPING_DIR}/SingletonLock" "${SCRAPING_DIR}/SingletonSocket" "${SCRAPING_DIR}/SingletonCookie"`, { stdio: "ignore" });
34
- } catch {}
35
-
36
- if (useProfile) {
37
- console.log("Syncing profile...");
38
- execSync(
39
- `rsync -a --delete \
40
- --exclude='SingletonLock' \
41
- --exclude='SingletonSocket' \
42
- --exclude='SingletonCookie' \
43
- --exclude='*/Sessions/*' \
44
- --exclude='*/Current Session' \
45
- --exclude='*/Current Tabs' \
46
- --exclude='*/Last Session' \
47
- --exclude='*/Last Tabs' \
48
- "${process.env.HOME}/Library/Application Support/Google/Chrome/" "${SCRAPING_DIR}/"`,
49
- { stdio: "pipe" },
50
- );
51
- }
52
-
53
- // Start Chrome with flags to force new instance
54
- spawn(
55
- "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome",
56
- [
57
- "--remote-debugging-port=9222",
58
- `--user-data-dir=${SCRAPING_DIR}`,
59
- "--no-first-run",
60
- "--no-default-browser-check",
61
- ],
62
- { detached: true, stdio: "ignore" },
63
- ).unref();
64
-
65
- // Wait for Chrome to be ready
66
- let connected = false;
67
- for (let i = 0; i < 30; i++) {
68
- try {
69
- const browser = await puppeteer.connect({
70
- browserURL: "http://localhost:9222",
71
- defaultViewport: null,
72
- });
73
- await browser.disconnect();
74
- connected = true;
75
- break;
76
- } catch {
77
- await new Promise((r) => setTimeout(r, 500));
78
- }
79
- }
80
-
81
- if (!connected) {
82
- console.error("✗ Failed to connect to Chrome");
83
- process.exit(1);
84
- }
85
-
86
- console.log(`✓ Chrome started on :9222${useProfile ? " with your profile" : ""}`);