codebuff 1.0.635 → 1.0.637

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 (2) hide show
  1. package/index.js +60 -8
  2. package/package.json +1 -1
package/index.js CHANGED
@@ -13,6 +13,40 @@ const tar = require('tar')
13
13
 
14
14
  const packageName = 'codebuff'
15
15
 
16
+ /**
17
+ * Terminal escape sequences to reset terminal state after the child process exits.
18
+ * When the binary is SIGKILL'd, it can't clean up its own terminal state.
19
+ * The wrapper (this process) survives and must reset these modes.
20
+ *
21
+ * Keep in sync with TERMINAL_RESET_SEQUENCES in cli/src/utils/renderer-cleanup.ts
22
+ */
23
+ const TERMINAL_RESET_SEQUENCES =
24
+ '\x1b[?1049l' + // Exit alternate screen buffer
25
+ '\x1b[?1000l' + // Disable X10 mouse mode
26
+ '\x1b[?1002l' + // Disable button event mouse mode
27
+ '\x1b[?1003l' + // Disable any-event mouse mode (all motion)
28
+ '\x1b[?1006l' + // Disable SGR extended mouse mode
29
+ '\x1b[?1004l' + // Disable focus reporting
30
+ '\x1b[?2004l' + // Disable bracketed paste mode
31
+ '\x1b[?25h' // Show cursor
32
+
33
+ function resetTerminal() {
34
+ try {
35
+ if (process.stdin.isTTY && process.stdin.setRawMode) {
36
+ process.stdin.setRawMode(false)
37
+ }
38
+ } catch {
39
+ // stdin may be closed
40
+ }
41
+ try {
42
+ if (process.stdout.isTTY) {
43
+ process.stdout.write(TERMINAL_RESET_SEQUENCES)
44
+ }
45
+ } catch {
46
+ // stdout may be closed
47
+ }
48
+ }
49
+
16
50
  function createConfig(packageName) {
17
51
  const homeDir = os.homedir()
18
52
  const configDir = path.join(homeDir, '.config', 'manicode')
@@ -526,18 +560,24 @@ async function checkForUpdates(runningProcess, exitListener) {
526
560
  term.clearLine()
527
561
 
528
562
  runningProcess.removeListener('exit', exitListener)
529
- runningProcess.kill('SIGTERM')
530
563
 
531
564
  await new Promise((resolve) => {
532
- runningProcess.on('exit', resolve)
565
+ let exited = false
566
+ runningProcess.once('exit', () => {
567
+ exited = true
568
+ resolve()
569
+ })
570
+ runningProcess.kill('SIGTERM')
533
571
  setTimeout(() => {
534
- if (!runningProcess.killed) {
572
+ if (!exited) {
535
573
  runningProcess.kill('SIGKILL')
574
+ // Safety: resolve after giving SIGKILL time to take effect
575
+ setTimeout(() => resolve(), 1000)
536
576
  }
537
- resolve()
538
577
  }, 5000)
539
578
  })
540
579
 
580
+ resetTerminal()
541
581
  console.log(`Update available: ${currentVersion} → ${latestVersion}`)
542
582
 
543
583
  await downloadBinary(latestVersion)
@@ -547,8 +587,14 @@ async function checkForUpdates(runningProcess, exitListener) {
547
587
  detached: false,
548
588
  })
549
589
 
550
- newChild.on('exit', (code) => {
551
- process.exit(code || 0)
590
+ newChild.on('exit', (code, signal) => {
591
+ resetTerminal()
592
+ process.exit(signal ? 1 : (code || 0))
593
+ })
594
+
595
+ newChild.on('error', (err) => {
596
+ console.error('Failed to start codebuff:', err.message)
597
+ process.exit(1)
552
598
  })
553
599
 
554
600
  return new Promise(() => {})
@@ -565,12 +611,18 @@ async function main() {
565
611
  stdio: 'inherit',
566
612
  })
567
613
 
568
- const exitListener = (code) => {
569
- process.exit(code || 0)
614
+ const exitListener = (code, signal) => {
615
+ resetTerminal()
616
+ process.exit(signal ? 1 : (code || 0))
570
617
  }
571
618
 
572
619
  child.on('exit', exitListener)
573
620
 
621
+ child.on('error', (err) => {
622
+ console.error('Failed to start codebuff:', err.message)
623
+ process.exit(1)
624
+ })
625
+
574
626
  setTimeout(() => {
575
627
  checkForUpdates(child, exitListener)
576
628
  }, 100)
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "codebuff",
3
- "version": "1.0.635",
3
+ "version": "1.0.637",
4
4
  "description": "AI coding agent",
5
5
  "license": "MIT",
6
6
  "bin": {