gm-cc 2.0.195 → 2.0.197

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.
@@ -4,7 +4,7 @@
4
4
  "name": "AnEntrypoint"
5
5
  },
6
6
  "description": "State machine agent with hooks, skills, and automated git enforcement",
7
- "version": "2.0.195",
7
+ "version": "2.0.197",
8
8
  "metadata": {
9
9
  "description": "State machine agent with hooks, skills, and automated git enforcement"
10
10
  },
@@ -18,12 +18,17 @@ const deny = (reason) => isGemini
18
18
  ? { decision: 'deny', reason }
19
19
  : { hookSpecificOutput: { hookEventName: 'PreToolUse', permissionDecision: 'deny', permissionDecisionReason: reason } };
20
20
  const allowWithNoop = (context) => {
21
- const b64 = Buffer.from(context, 'utf-8').toString('base64');
21
+ const tmp = path.join(os.tmpdir(), `gm-out-${Date.now()}.txt`);
22
+ fs.writeFileSync(tmp, context, 'utf-8');
23
+ const IS_WIN = process.platform === 'win32';
24
+ const cmd = IS_WIN
25
+ ? `powershell -NoProfile -NonInteractive -Command "Get-Content -Raw '${tmp}'; Remove-Item '${tmp}'"`
26
+ : `cat '${tmp}'; rm -f '${tmp}'`;
22
27
  return {
23
28
  hookSpecificOutput: {
24
29
  hookEventName: 'PreToolUse',
25
30
  permissionDecision: 'allow',
26
- updatedInput: { command: `bun -e "process.stdout.write(Buffer.from('${b64}','base64').toString())"` }
31
+ updatedInput: { command: cmd }
27
32
  }
28
33
  };
29
34
  };
@@ -78,6 +83,11 @@ const run = () => {
78
83
 
79
84
  if (tool_name === 'Bash') {
80
85
  const command = (tool_input?.command || '').trim();
86
+ const stripFooter = (s) => s.replace(/\n\[Running tools\][\s\S]*$/, '').trimEnd();
87
+ if (/^exec:pm2list\s*$/.test(command)) {
88
+ const r = spawnSync('bun', ['x', 'gm-exec', 'pm2list'], { encoding: 'utf-8', timeout: 15000 });
89
+ return allowWithNoop(`exec:pm2list output:\n\n${stripFooter((r.stdout || '') + (r.stderr || ''))}`);
90
+ }
81
91
  const execMatch = command.match(/^exec(?::(\S+))?\n([\s\S]+)$/);
82
92
  if (execMatch) {
83
93
  const rawLang = (execMatch[1] || '').toLowerCase();
@@ -92,10 +102,9 @@ const run = () => {
92
102
  if (/^\s*(echo |ls |cd |mkdir |rm |cat |grep |find |export |source |#!)/.test(src)) return 'bash';
93
103
  return 'nodejs';
94
104
  };
95
- const aliases = { js: 'nodejs', javascript: 'nodejs', ts: 'typescript', node: 'nodejs', py: 'python', sh: 'bash', shell: 'bash', zsh: 'bash', powershell: 'bash', ps1: 'bash', cmd: 'bash', browser: 'agent-browser', ab: 'agent-browser', codesearch: 'codesearch', search: 'search', status: 'status', sleep: 'sleep', close: 'close', runner: 'runner', type: 'type' };
105
+ const aliases = { js: 'nodejs', javascript: 'nodejs', ts: 'typescript', node: 'nodejs', py: 'python', sh: 'bash', shell: 'bash', zsh: 'bash', powershell: 'bash', ps1: 'bash', cmd: 'bash', browser: 'agent-browser', ab: 'agent-browser', codesearch: 'codesearch', search: 'search', status: 'status', sleep: 'sleep', close: 'close', runner: 'runner', type: 'type', pm2list: 'pm2list' };
96
106
  const lang = aliases[rawLang] || rawLang || detectLang(code);
97
107
  const IS_WIN = process.platform === 'win32';
98
- const stripFooter = (s) => s.replace(/\n\[Running tools\][\s\S]*$/, '').trimEnd();
99
108
  const langExts = { nodejs: 'mjs', typescript: 'ts', deno: 'ts', python: 'py', bash: IS_WIN ? 'ps1' : 'sh', go: 'go', rust: 'rs', c: 'c', cpp: 'cpp', java: 'java' };
100
109
  const spawnDirect = (bin, args, stdin) => {
101
110
  const opts = { encoding: 'utf-8', timeout: 60000, ...(cwd && { cwd }), ...(stdin !== undefined && { input: stdin }) };
@@ -158,6 +167,10 @@ const run = () => {
158
167
  const r = spawnSync('bun', ['x', 'gm-exec', 'type', taskId, input], { encoding: 'utf-8', timeout: 15000 });
159
168
  return allowWithNoop(`exec:type output:\n\n${stripFooter((r.stdout || '') + (r.stderr || ''))}`);
160
169
  }
170
+ if (lang === 'pm2list') {
171
+ const r = spawnSync('bun', ['x', 'gm-exec', 'pm2list'], { encoding: 'utf-8', timeout: 15000 });
172
+ return allowWithNoop(`exec:pm2list output:\n\n${stripFooter((r.stdout || '') + (r.stderr || ''))}`);
173
+ }
161
174
  try {
162
175
  let result;
163
176
  if (lang === 'bash') {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "gm-cc",
3
- "version": "2.0.195",
3
+ "version": "2.0.197",
4
4
  "description": "State machine agent with hooks, skills, and automated git enforcement",
5
5
  "author": "AnEntrypoint",
6
6
  "license": "MIT",
package/plugin.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "gm",
3
- "version": "2.0.195",
3
+ "version": "2.0.197",
4
4
  "description": "State machine agent with hooks, skills, and automated git enforcement",
5
5
  "author": {
6
6
  "name": "AnEntrypoint",
@@ -73,7 +73,7 @@ exec:runner
73
73
  start|stop|status
74
74
  ```
75
75
 
76
- `exec:runner start` launches a single PM2 process (`gm-exec-runner`) that hosts all execution as worker threads inside it. Individual `exec:<lang>` calls are worker threads they do NOT appear as separate entries in `pm2 list`. Only the runner process is visible. Use `exec:runner status` to check it.
76
+ `exec:runner start` launches the `gm-exec-runner` PM2 process. Each `exec:<lang>` call creates its own `gm-exec-task-{id}` PM2 process all appear in `pm2 list`. Use `exec:runner status` to check the runner. Use `exec:pm2list` to see all processes including exec tasks.
77
77
 
78
78
  ## CODEBASE EXPLORATION
79
79