polygram 0.10.0-rc.2 → 0.10.0-rc.3

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.
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "$schema": "https://anthropic.com/claude-code/plugin.schema.json",
3
3
  "name": "polygram",
4
- "version": "0.10.0-rc.2",
4
+ "version": "0.10.0-rc.3",
5
5
  "description": "Telegram integration for Claude Code that preserves the OpenClaw per-chat session model. Migration target for OpenClaw users. Multi-bot, multi-chat, per-topic isolation; SQLite transcripts; inline-keyboard approvals. Bundles /polygram:status|logs|pair-code|approvals admin commands plus history (transcript queries) and polygram-send (out-of-turn IPC sends with file-upload validation) skills.",
6
6
  "keywords": [
7
7
  "telegram",
@@ -173,13 +173,16 @@ function createTmuxRunner({ logger = console, runFn = run } = {}) {
173
173
  stderr: err.stderr,
174
174
  });
175
175
  }
176
- // Set a wide pane to reduce capture-pane wrap artifacts.
177
- // Best-effort if the set-option fails, capture-pane -J fallback
178
- // in captureWide() handles the wrap case.
176
+ // Try to widen the detached pane so claude TUI has room to render
177
+ // long lines. `resize-window` is the supported way; older
178
+ // attempts used a non-existent `pane-width` option that always
179
+ // errored (tmux 3.x: pane-width is a format variable, not a
180
+ // settable option). capture-pane -J in captureWide() handles
181
+ // any remaining wrap artifacts.
179
182
  try {
180
- await runFn('tmux', ['set-option', '-t', name, '-w', 'pane-width', String(paneWidth)]);
183
+ await runFn('tmux', ['resize-window', '-t', name, '-x', String(paneWidth)]);
181
184
  } catch (err) {
182
- logger.warn?.(`[tmux-runner] set-option pane-width failed for ${name}: ${err.message}`);
185
+ logger.debug?.(`[tmux-runner] resize-window failed for ${name}: ${err.message} (capture-pane -J handles wrap)`);
183
186
  }
184
187
  return name;
185
188
  }
@@ -200,10 +203,19 @@ function createTmuxRunner({ logger = console, runFn = run } = {}) {
200
203
  * 2. \n → MULTILINE_SEPARATOR (F-spike-3)
201
204
  * 3. set-buffer + paste-buffer (atomic; bracketed-paste-aware
202
205
  * in modern claude TUI versions)
206
+ * 4. brief drain delay so a subsequent send-keys (e.g. Enter) is
207
+ * processed as a key event by the TUI, NOT consumed as part of
208
+ * the paste's bracketed-paste content.
203
209
  *
204
- * NO Enter is sent. Caller follows up with `sendControl(name, 'Enter')`
205
- * when they want to submit. (Splitting paste + Enter lets callers
206
- * verify the text landed via capture-pane before submitting.)
210
+ * INCIDENT (0.10.0-rc.2): without the drain delay, send-keys Enter
211
+ * fired immediately after paste-buffer was being swallowed by
212
+ * claude TUI's bracketed-paste handler — the paste sat in the input
213
+ * area unsubmitted. Manual `tmux send-keys ... Enter` unstuck it.
214
+ * 80ms is enough on macOS tmux 3.6a for the close-bracket ESC[201~
215
+ * to land before any subsequent key arrives.
216
+ *
217
+ * NO Enter is sent here. Caller follows up with
218
+ * `sendControl(name, 'Enter')` when they want to submit.
207
219
  */
208
220
  async function pasteText(name, text) {
209
221
  const sanitized = sanitize(text);
@@ -218,6 +230,8 @@ function createTmuxRunner({ logger = console, runFn = run } = {}) {
218
230
  await runFn('tmux', ['delete-buffer', '-b', bufName]).catch(() => {});
219
231
  throw err;
220
232
  }
233
+ // Drain delay — see incident note above.
234
+ await new Promise((r) => setTimeout(r, 80));
221
235
  return { sanitized, oneLine, stripped: text.length - sanitized.length };
222
236
  }
223
237
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "polygram",
3
- "version": "0.10.0-rc.2",
3
+ "version": "0.10.0-rc.3",
4
4
  "description": "Telegram daemon for Claude Code that preserves the OpenClaw per-chat session model. Migration path for OpenClaw users moving to Claude Code.",
5
5
  "main": "lib/ipc/client.js",
6
6
  "bin": {