Skip to content

fix(cli-ui): enable Ctrl+Backspace for word deletion in Windows Terminal#21447

Merged
cocosheng-g merged 15 commits intogoogle-gemini:mainfrom
dogukanozen:fix/ctrl-backspace-windows-21445
Apr 8, 2026
Merged

fix(cli-ui): enable Ctrl+Backspace for word deletion in Windows Terminal#21447
cocosheng-g merged 15 commits intogoogle-gemini:mainfrom
dogukanozen:fix/ctrl-backspace-windows-21445

Conversation

@dogukanozen
Copy link
Copy Markdown
Contributor

@dogukanozen dogukanozen commented Mar 6, 2026

Summary

windows terminal sends \x08 (ctrl+h) for ctrl+backspace, which was being treated as a plain backspace. this PR updates KeypressContext to correctly parse it as a ctrl+backspace keypress, enabling word deletion.

Details

Related Issues

Closes #21445

How to Validate

Pre-Merge Checklist

  • Updated relevant documentation and README (if needed)
  • Added/updated tests (if needed)
  • Noted breaking changes (if any)
  • Validated on required platforms/methods:
    • MacOS
      • npm run
      • npx
      • Docker
      • Podman
      • Seatbelt
    • Windows
      • npm run
      • npx
      • Docker
    • Linux
      • npm run
      • npx
      • Docker

@dogukanozen dogukanozen requested a review from a team as a code owner March 6, 2026 20:42
@gemini-code-assist
Copy link
Copy Markdown
Contributor

Summary of Changes

Hello, I'm Gemini Code Assist1! I'm currently reviewing this pull request and will post my feedback shortly. In the meantime, here's a summary to help you and other reviewers quickly get up to speed!

This pull request resolves an issue where the KeypressContext incorrectly interpreted the \x08 character sent by Windows Terminal for Ctrl+Backspace. By updating the keypress parsing logic, the system now accurately recognizes Ctrl+Backspace, allowing users to perform word deletion as expected in Windows Terminal environments.

Highlights

  • Windows Terminal Keypress Handling: Correctly parsed the \x08 character, which is sent by Windows Terminal for Ctrl+Backspace, as a Ctrl+Backspace keypress, enabling word deletion functionality.
Changelog
  • packages/cli/src/ui/contexts/KeypressContext.tsx
    • Modified the emitKeys generator to distinguish between \b (Ctrl+Backspace) and \x7f (backspace) for improved keypress interpretation.
Activity
  • No human activity has been recorded on this pull request yet.
Using Gemini Code Assist

The full guide for Gemini Code Assist can be found on our documentation page, here are some quick tips.

Invoking Gemini

You can request assistance from Gemini at any point by creating a comment using either /gemini <command> or @gemini-code-assist <command>. Below is a summary of the supported commands on the current page.

Feature Command Description
Code Review /gemini review Performs a code review for the current pull request in its current state.
Pull Request Summary /gemini summary Provides a summary of the current pull request in its current state.
Comment @gemini-code-assist Responds in comments when explicitly tagged, both in pull request comments and review comments.
Help /gemini help Displays a list of available commands.

Customization

To customize Gemini Code Assist for GitHub experience, repository maintainers can create a configuration file and/or provide a custom code review style guide (such as PEP-8 for Python) by creating and adding files to a .gemini/ folder in the base of the repository. Detailed instructions can be found here.

Limitations & Feedback

Gemini Code Assist may make mistakes. Please leave feedback on any instances where its feedback is incorrect or counter productive. You can react with 👍 and 👎 on @gemini-code-assist comments. If you're interested in giving your feedback about your experience with Gemini Code Assist for Github and other Google products, sign up here.

You can also get AI-powered code generation, chat, as well as code reviews directly in the IDE at no cost with the Gemini Code Assist IDE Extension.

Footnotes

  1. Review the Privacy Notices, Generative AI Prohibited Use Policy, Terms of Service, and learn how to configure Gemini Code Assist in GitHub here. Gemini can make mistakes, so double check it and use code with caution.

Copy link
Copy Markdown
Contributor

@gemini-code-assist gemini-code-assist Bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Review

This pull request addresses a Ctrl+Backspace issue in Windows Terminal. The proposed fix, while correctly identifying the \b character for this combination, introduces a critical regression by altering the Backspace functionality in other terminals. To maintain consistency with existing UI behavior across different terminal environments, as per repository guidelines, the fix should be scoped specifically to Windows Terminal using the WT_SESSION environment variable. This prevents unintended UX changes for other users. Additionally, a unit test is recommended to verify the new behavior and prevent future regressions.

Comment thread packages/cli/src/ui/contexts/KeypressContext.tsx Outdated
@gemini-cli gemini-cli Bot added the area/core Issues related to User Interface, OS Support, Core Functionality label Mar 6, 2026
@dogukanozen
Copy link
Copy Markdown
Contributor Author

@gemini-code-assist please recheck

Copy link
Copy Markdown
Contributor

@gemini-code-assist gemini-code-assist Bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Review

This pull request aims to fix an issue where Ctrl+Backspace does not delete a word on Windows Terminal. The proposed change correctly identifies the \b character sequence and interprets it as a Ctrl+Backspace when running inside Windows Terminal. I've kept the original comment highlighting a potential critical regression if the regular Backspace key also sends the \b sequence, as it would break normal backspace functionality. The comment recommends adding a specific test case to prevent such a regression, following the project's testing conventions.

Comment thread packages/cli/src/ui/contexts/KeypressContext.tsx Outdated
@dogukanozen
Copy link
Copy Markdown
Contributor Author

dogukanozen commented Mar 6, 2026

@gemini-code-assist please recheck

@gemini-code-assist
Copy link
Copy Markdown
Contributor

Thanks for the recheck request, @dogukanozen! I've taken another look at your changes and the new tests.

This is a great first pull request! The solution you've implemented is well-targeted and correctly addresses the issue of Ctrl+Backspace in Windows Terminal. The addition of specific tests for the WT_SESSION environment variable ensures that the fix behaves as expected across different terminal environments without introducing regressions.

Your code is clear, and the new tests demonstrate a good understanding of the problem and how to verify the solution. Excellent work!

I'm happy to confirm that the changes look good and effectively resolve the reported issue. Keep up the great work!

@spencer426 spencer426 requested review from spencer426 and removed request for spencer426 March 7, 2026 04:41
@gemini-cli
Copy link
Copy Markdown
Contributor

gemini-cli Bot commented Mar 21, 2026

Hi there! Thank you for your interest in contributing to Gemini CLI.

To ensure we maintain high code quality and focus on our prioritized roadmap, we have updated our contribution policy (see Discussion #17383).

We only guarantee review and consideration of pull requests for issues that are explicitly labeled as 'help wanted'. All other community pull requests are subject to closure after 14 days if they do not align with our current focus areas. For this reason, we strongly recommend that contributors only submit pull requests against issues explicitly labeled as 'help-wanted'.

This pull request is being closed as it has been open for 14 days without a 'help wanted' designation. We encourage you to find and contribute to existing 'help wanted' issues in our backlog! Thank you for your understanding and for being part of our community!

@gemini-cli gemini-cli Bot closed this Mar 21, 2026
@cocosheng-g cocosheng-g reopened this Apr 8, 2026
@cocosheng-g
Copy link
Copy Markdown
Contributor

@dogukanozen, apologies for the bot closing this PR! We have reopened it. Please sync your branch to the latest main and we will have someone review it shortly.

@gemini-cli gemini-cli Bot added the help wanted We will accept PRs from all issues marked as "help wanted". Thanks for your support! label Apr 8, 2026
@cocosheng-g
Copy link
Copy Markdown
Contributor

/gemini review

Copy link
Copy Markdown
Contributor

@gemini-code-assist gemini-code-assist Bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Review

This pull request updates the keypress handling logic to correctly identify Ctrl+Backspace in Windows Terminal. It specifically checks for the WT_SESSION environment variable when a \b character is received to set the ctrl flag. Corresponding unit tests have been added to verify this behavior across different environment configurations. I have no feedback to provide.

Copy link
Copy Markdown
Contributor

@gemini-code-assist gemini-code-assist Bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Review

This pull request improves backspace handling by distinguishing between standard backspace and Ctrl+Backspace in Windows and Windows Terminal environments. Specifically, it updates the BACKSPACE constant to \x7f in test files and modifies KeypressContext.tsx to treat \b as a control key when the OS environment variable is Windows_NT or WT_SESSION is active. New unit tests have been added to ensure correct behavior across various platforms. I have no feedback to provide.

@dogukanozen
Copy link
Copy Markdown
Contributor Author

@cocosheng-g i believe the ci tests will pass now. the tests were failing previously because settingsdialog.test.tsx and BaseSettingsDialog.test.tsx were simulating the backspace key with \b, which conflicted with the new Ctrl+Backspace logic introduced in this PR. i have updated those test files to use the standard \x7f character, so everything should process correctly now.

Copy link
Copy Markdown
Contributor

@gemini-code-assist gemini-code-assist Bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Review

This pull request updates the backspace handling logic to correctly distinguish between a standard backspace and Ctrl+Backspace in Windows and Windows Terminal environments. It modifies emitKeys in KeypressContext.tsx to treat \b as a control key when OS is Windows_NT or WT_SESSION is present, while \x7f is used for standard backspace. Corresponding updates were made to test constants in SettingsDialog.test.tsx and BaseSettingsDialog.test.tsx, and new test cases were added to KeypressContext.test.tsx to verify the logic across different environments. I have no feedback to provide.

Note: Security Review did not run due to the size of the PR.

@cocosheng-g cocosheng-g enabled auto-merge April 8, 2026 21:14
@cocosheng-g cocosheng-g added this pull request to the merge queue Apr 8, 2026
@github-merge-queue github-merge-queue Bot removed this pull request from the merge queue due to failed status checks Apr 8, 2026
@cocosheng-g cocosheng-g added this pull request to the merge queue Apr 8, 2026
Merged via the queue into google-gemini:main with commit 80764c8 Apr 8, 2026
27 checks passed
student-ankitpandit pushed a commit to student-ankitpandit/gemini-cli that referenced this pull request Apr 9, 2026
flexponsive pushed a commit to flexponsive/gemini-cli that referenced this pull request Apr 9, 2026
@dogukanozen dogukanozen deleted the fix/ctrl-backspace-windows-21445 branch April 9, 2026 14:16
warrenzhu25 pushed a commit to warrenzhu25/gemini-cli that referenced this pull request Apr 9, 2026
ik-gemini-bot added a commit to spigell/gemini-cli that referenced this pull request Apr 23, 2026
* refactor(plan): simplify policy priorities and consolidate read-only rules (google-gemini#24849)

* feat(test-utils): add memory usage integration test harness (google-gemini#24876)

* feat(memory): add /memory inbox command for reviewing extracted skills (google-gemini#24544)

* chore(release): bump version to 0.39.0-nightly.20260408.e77b22e63 (google-gemini#24939)

* fix(core): ensure robust sandbox cleanup in all process execution paths (google-gemini#24763)

Co-authored-by: Spencer <spencertang@google.com>

* chore: update ink version to 6.6.8 (google-gemini#24934)

* Changelog for v0.38.0-preview.0 (google-gemini#24938)

Co-authored-by: gemini-cli-robot <224641728+gemini-cli-robot@users.noreply.github.com>
Co-authored-by: g-samroberts <samroberts@google.com>

* chore: ignore conductor directory (google-gemini#22128)

Co-authored-by: Coco Sheng <cocosheng@google.com>

* Changelog for v0.37.0 (google-gemini#24940)

Co-authored-by: gemini-cli-robot <224641728+gemini-cli-robot@users.noreply.github.com>
Co-authored-by: Sam Roberts <158088236+g-samroberts@users.noreply.github.com>

* feat(plan): require user confirmation for activate_skill in Plan Mode (google-gemini#24946)

* feat(test-utils): add CPU performance integration test harness (google-gemini#24951)

* fix(core): resolve windows symlink bypass and stabilize sandbox integration tests (google-gemini#24834)

* test(sdk): add unit tests for GeminiCliSession (google-gemini#21897)

* fix(cli): restore file path display in edit and write tool confirmations (google-gemini#24974)

* fix(cli-ui): enable Ctrl+Backspace for word deletion in Windows Terminal (google-gemini#21447)

* fix(core): dynamic session ID injection to resolve resume bugs (google-gemini#24972)

* Update ink version to 6.6.9 (google-gemini#24980)

* feat(core): refine shell tool description display logic (google-gemini#24903)

* Generalize evals infra to support more types of evals, organization and queuing of named suites (google-gemini#24941)

* fix(cli): optimize startup with lightweight parent process (google-gemini#24667)

* refactor(sandbox): use centralized sandbox paths in macOS Seatbelt implementation (google-gemini#24984)

* feat(cli): refine tool output formatting for compact mode (google-gemini#24677)

* fix(sdk): skip broken sendStream tests to unblock nightly (google-gemini#25000)

* refactor(core): use centralized path resolution for Linux sandbox (google-gemini#24985)

* Support ctrl+shift+g (google-gemini#25035)

* feat(core): refactor subagent tool to unified invoke_subagent tool (google-gemini#24489)

* fix(core): add explicit git identity env vars to prevent sandbox checkpointing error (google-gemini#19775)

Co-authored-by: David Pierce <davidapierce@google.com>

* fix: respect hideContextPercentage when FooterConfigDialog is closed without changes (google-gemini#24773)

Co-authored-by: Coco Sheng <cocosheng@google.com>

* fix(cli): suppress unhandled AbortError logs during request cancellation (google-gemini#22621)

* Automated documentation audit (google-gemini#24567)

* feat(cli): implement useAgentStream hook (google-gemini#24292)

Co-authored-by: Adam Weidman <adamfweidman@gmail.com>
Co-authored-by: Adam Weidman <adamfweidman@google.com>

* refactor(core): remove legacy subagent wrapping tools (google-gemini#25053)

* refactor(plan) Clean default plan toml (google-gemini#25037)

* fix(core): honor retryDelay in RetryInfo for 503 errors (google-gemini#25057)

* fix(core): remediate subagent memory leaks using AbortSignal in MessageBus (google-gemini#25048)

* feat(cli): wire up useAgentStream in AppContainer (google-gemini#24297)

Co-authored-by: Adam Weidman <adamfweidman@gmail.com>
Co-authored-by: Adam Weidman <adamfweidman@google.com>

* feat(core): migrate chat recording to JSONL streaming (google-gemini#23749)

* fix(core): clear 5-minute timeouts in oauth flow to prevent memory leaks (google-gemini#24968)

* fix(sandbox): centralize async git worktree resolution and enforce read-only security (google-gemini#25040)

* feat(test): add high-volume shell test and refine perf harness (google-gemini#24983)

* fix(core): silently handle EPERM when listing dir structure (google-gemini#25066)

* Changelog for v0.37.1 (google-gemini#25055)

Co-authored-by: gemini-cli-robot <224641728+gemini-cli-robot@users.noreply.github.com>

* fix: decode Uint8Array and multi-byte UTF-8 in API error messages (google-gemini#23341)

Co-authored-by: Coco Sheng <cocosheng@google.com>

* Automated documentation audit results (google-gemini#22755)

* debugging(ui): add optional debugRainbow setting (google-gemini#25088)

* fix: resolve lifecycle memory leaks by cleaning up listeners and root closures (google-gemini#25049)

* docs(cli): updates f12 description to be more precise (google-gemini#15816)

* fix(cli): mark /settings as unsafe to run concurrently (google-gemini#25061)

* fix(core): remove buffer slice to prevent OOM on large output streams (google-gemini#25094)

* feat(core): persist subagent agentId in tool call records (google-gemini#25092)

* chore(core): increase codebase investigator turn limits to 50 (google-gemini#25125)

* refactor(core): consolidate execute() arguments into ExecuteOptions (google-gemini#25101)

* feat(core): add Strategic Re-evaluation guidance to system prompt (google-gemini#25062)

* fix(core): preserve shell execution config fields on update (google-gemini#25113)

* docs: add vi shortcuts and clarify MCP sandbox setup (google-gemini#21679)

Co-authored-by: Jenna Inouye <jinouye@google.com>

* fix(cli): pass session id to interactive shell executions (google-gemini#25114)

* fix(cli): resolve text sanitization data loss due to C1 control characters (google-gemini#22624)

* feat(core): add large memory regression test (google-gemini#25059)

* fix(core): resolve PTY exhaustion and orphan MCP subprocess leaks (google-gemini#25079)

* chore: switch from keytar to @github/keytar (google-gemini#25143)

* chore(deps): update vulnerable dependencies via npm audit fix (google-gemini#25140)

* perf(sandbox): optimize Windows sandbox initialization via native ACL application (google-gemini#25077)

* fix: improve audio MIME normalization and validation in file reads (google-gemini#21636)

Co-authored-by: Coco Sheng <cocosheng@google.com>

* docs: Update docs-audit to include changes in PR body (google-gemini#25153)

* docs: correct documentation for enforced authentication type (google-gemini#25142)

* fix(cli): exclude update_topic from confirmation queue count (google-gemini#24945)

* Memory fix for trace's streamWrapper. (google-gemini#25089)

* fix(core): fix quota footer for non-auto models and improve display (google-gemini#25121)

* docs(contributing): clarify self-assignment policy for issues (google-gemini#23087)

* feat(core): add skill patching support with /memory inbox integration (google-gemini#25148)

* Stop suppressing thoughts and text in model response (google-gemini#25073)

* fix(release): prefix git hash in nightly versions to prevent semver normalization (google-gemini#25304)

* feat(cli): extract QuotaContext and resolve infinite render loop (google-gemini#24959)

* refactor(core): extract and centralize sandbox path utilities (google-gemini#25305)

Co-authored-by: David Pierce <davidapierce@google.com>

* feat(ui): added enhancements to scroll momentum (google-gemini#24447)

* fix(core): replace custom binary detection with isbinaryfile to correctly handle UTF-8 (U+FFFD) (google-gemini#25297)

* feat(agent): implement tool-controlled display protocol (Steps 2-3) (google-gemini#25134)

* Stop showing scrollbar unless we are in terminalBuffer mode (google-gemini#25320)

* fix(core): expose GEMINI_PLANS_DIR to hook environment (google-gemini#25296)

Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com>

* feat: support auth block in MCP servers config in agents (google-gemini#24770)

* feat(core): implement silent fallback for Plan Mode model routing (google-gemini#25317)

* fix: correct redirect count increment in fetchJson (google-gemini#24896)

Co-authored-by: Tommaso Sciortino <sciortino@gmail.com>

* fix(core): prevent secondary crash in ModelRouterService finally block (google-gemini#25333)

* feat(core): introduce decoupled ContextManager and Sidecar architecture (google-gemini#24752)

* docs(core): update generalist agent documentation (google-gemini#25325)

* chore(mcp): check MCP error code over brittle string match (google-gemini#25381)

* test(core): improve sandbox integration test coverage and fix OS-specific failures (google-gemini#25307)

Co-authored-by: David Pierce <davidapierce@google.com>

* feat(plan): update plan mode prompt to allow showing plan content (google-gemini#25058)

* fix(core): use debug level for keychain fallback logging (google-gemini#25398)

* feat(test): add a performance test in asian language (google-gemini#25392)

* feat(cli): enable mouse clicking for cursor positioning in AskUser multi-line answers (google-gemini#24630)

* fix(core): detect kmscon terminal as supporting true color (google-gemini#25282)

Co-authored-by: Adib234 <30782825+Adib234@users.noreply.github.com>
Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com>

* ci: add agent session drift check workflow (google-gemini#25389)

* use macos-latest-large runner where applicable. (google-gemini#25413)

* Changelog for v0.37.2 (google-gemini#25336)

Co-authored-by: gemini-cli-robot <224641728+gemini-cli-robot@users.noreply.github.com>

* chore(release): v0.39.0-preview.0

* fix(patch): cherry-pick a4e98c0 to release/v0.39.0-preview.0-pr-25138 to patch version v0.39.0-preview.0 and create version 0.39.0-preview.1 (google-gemini#25766)

Co-authored-by: Mahima Shanware <mahima.shanware@gmail.com>

* chore(release): v0.39.0-preview.1

* fix(patch): cherry-pick d6f88f8 to release/v0.39.0-preview.1-pr-25670 to patch version v0.39.0-preview.1 and create version 0.39.0-preview.2 (google-gemini#25776)

Co-authored-by: Adam Weidman <65992621+adamfweidman@users.noreply.github.com>

* chore(release): v0.39.0-preview.2

* chore(release): v0.39.0

---------

Co-authored-by: ruomeng <ruomeng@google.com>
Co-authored-by: Sri Pasumarthi <111310667+sripasg@users.noreply.github.com>
Co-authored-by: Sandy Tao <sandytao520@icloud.com>
Co-authored-by: gemini-cli-robot <gemini-cli-robot@google.com>
Co-authored-by: Emily Hedlund <ehedlund@google.com>
Co-authored-by: Spencer <spencertang@google.com>
Co-authored-by: Jacob Richman <jacob314@gmail.com>
Co-authored-by: gemini-cli-robot <224641728+gemini-cli-robot@users.noreply.github.com>
Co-authored-by: g-samroberts <samroberts@google.com>
Co-authored-by: JAYADITYA <96861162+JayadityaGit@users.noreply.github.com>
Co-authored-by: Coco Sheng <cocosheng@google.com>
Co-authored-by: Sam Roberts <158088236+g-samroberts@users.noreply.github.com>
Co-authored-by: Adamya Singh <adamyasingh54@gmail.com>
Co-authored-by: Jarrod Whelan <150866123+jwhelangoog@users.noreply.github.com>
Co-authored-by: dogukanozen <dogukannozen@hotmail.com>
Co-authored-by: Tommaso Sciortino <sciortino@gmail.com>
Co-authored-by: Christian Gunderman <gundermanc@google.com>
Co-authored-by: Sehoon Shon <sshon@google.com>
Co-authored-by: Abhi <43648792+abhipatel12@users.noreply.github.com>
Co-authored-by: MD. MOHIBUR RAHMAN <35300157+mrpmohiburrahman@users.noreply.github.com>
Co-authored-by: David Pierce <davidapierce@google.com>
Co-authored-by: chernistry <73943355+chernistry@users.noreply.github.com>
Co-authored-by: euxaristia <25621994+euxaristia@users.noreply.github.com>
Co-authored-by: Michael Bleigh <mbleigh@mbleigh.com>
Co-authored-by: Adam Weidman <adamfweidman@gmail.com>
Co-authored-by: Adam Weidman <adamfweidman@google.com>
Co-authored-by: Yuna Seol <yunaseol@gmail.com>
Co-authored-by: June <kimjune01@gmail.com>
Co-authored-by: Aishanee Shah <aishaneeshah@google.com>
Co-authored-by: Jason Matthew Suhari <jasonmatthewsuhari@gmail.com>
Co-authored-by: Christopher Thomas <cobekgn@gmail.com>
Co-authored-by: Jenna Inouye <jinouye@google.com>
Co-authored-by: cynthialong0-0 <82900738+cynthialong0-0@users.noreply.github.com>
Co-authored-by: M Junaid Shaukat <154750865+junaiddshaukat@users.noreply.github.com>
Co-authored-by: Abhijit Balaji <abhijitbalaji@google.com>
Co-authored-by: Mark Griffith <anthraxmilkshake@hotmail.com>
Co-authored-by: Jack Wotherspoon <jackwoth@google.com>
Co-authored-by: Jesse Rosenstock <jesse.rosenstock@gmail.com>
Co-authored-by: Adib234 <30782825+Adib234@users.noreply.github.com>
Co-authored-by: Dev Randalpura <devrandalpura@google.com>
Co-authored-by: Anjaligarhwal <anjaligarhwal1610@gmail.com>
Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com>
Co-authored-by: Tanmay Vartak <9002434+TanmayVartak@users.noreply.github.com>
Co-authored-by: Jerop Kipruto <jerop@google.com>
Co-authored-by: Kevin Zhao <kevin8093@126.com>
Co-authored-by: joshualitt <joshualitt@google.com>
Co-authored-by: Clay <claygeo6@gmail.com>
Co-authored-by: Adam Weidman <65992621+adamfweidman@users.noreply.github.com>
Co-authored-by: Mahima Shanware <mahima.shanware@gmail.com>
Co-authored-by: codex-bot <spigelly+gh-bot@gmail.com>
@biodbg
Copy link
Copy Markdown

biodbg commented Apr 23, 2026

(Windows terminal; Win10) I am experiencing word deletion even without holding "control" with backspace. This is a new behavior in 0.39 that was not in 0.38.2, afaik

@dogukanozen
Copy link
Copy Markdown
Contributor Author

Hi @biodbg could you provide a bit more detail?

Environment: Which terminal (Windows Terminal, CMD, PowerShell) and shell (Bash, PowerShell, etc.) are you using?
Reproduction: Does this happen immediately upon starting the CLI, or does it trigger after a long conversation or
a specific event/tool call?
Connection: Are you running the CLI locally, or are you connected to a remote machine via SSH/WSL?
Key Check: What happens when you press Ctrl+H? Does it delete a single character or a whole word?
Terminal Version: If you are using Windows Terminal, could you share the version number?

This information will help me understand why your environment is sending the \b code for a regular backspace.

dogukanozen added a commit to dogukanozen/gemini-cli that referenced this pull request Apr 23, 2026
The previous fix (google-gemini#21447) treated OS=Windows_NT as sufficient to mark
\b as Ctrl+Backspace, but cmd.exe and PowerShell also send \b for plain
backspace, causing every backspace to delete a whole word on those terminals.

Scope the ctrl=true path to WT_SESSION only (Windows Terminal), which is
the terminal that actually sends \b for Ctrl+Backspace and \x7f for plain
backspace. Update the corresponding test expectation.

Fixes google-gemini#25867
dogukanozen added a commit to dogukanozen/gemini-cli that referenced this pull request Apr 23, 2026
The previous fix (google-gemini#21447) treated OS=Windows_NT as sufficient to mark
\b as Ctrl+Backspace, but cmd.exe and PowerShell also send \b for plain
backspace, causing every backspace to delete a whole word on those terminals.

Scope the ctrl=true path to WT_SESSION only (Windows Terminal), which is
the terminal that actually sends \b for Ctrl+Backspace and \x7f for plain
backspace. Update the corresponding test expectation.

Fixes google-gemini#25867
@biodbg
Copy link
Copy Markdown

biodbg commented Apr 24, 2026

Thanks! Here's my info:

Environment: Which terminal (Windows Terminal, CMD, PowerShell) and shell (Bash, PowerShell, etc.) are you using?

Windows terminal w/ cmd.exe, with Gemini-CLI running shell PowerShell commands.
Same behavior with Windows terminal w/ cygwin tcsh, with Gemini-CLI running PowerShell commands.

Reproduction: Does this happen immediately upon starting the CLI, or does it trigger after a long conversation or a specific event/tool call?

Yes- from the start, and on every re-invocation (with v0.39)

Connection: Are you running the CLI locally, or are you connected to a remote machine via SSH/WSL?

Local

Key Check: What happens when you press Ctrl+H? Does it delete a single character or a whole word?

Ctrl-H deletes a single character

Terminal Version: If you are using Windows Terminal, could you share the version number?

Windows Terminal Preview Version: 1.25.923.0

@scidomino
Copy link
Copy Markdown
Collaborator

The bug only seems to happen if you're using node 22. Node 24 works fine. I'm going to revert this for now. We can reexamine later.

@dogukanozen
Copy link
Copy Markdown
Contributor Author

The bug only seems to happen if you're using node 22. Node 24 works fine. I'm going to revert this for now. We can reexamine later.

thanks for checking.
i’m using node 24 as well and couldn’t reproduce it on my side.
i also tested this pr across different terminal environments locally and everything looked fine for me.

@scidomino
Copy link
Copy Markdown
Collaborator

node sits between us and keyboard so it makes sense that it could have an effect like this. My guess is in node 24 they introduced some kind of backspace normalization that this PR relies on.

@biodbg
Copy link
Copy Markdown

biodbg commented Apr 24, 2026

Thanks for digging into this, and diagnosing the Node dependency so quickly!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

area/core Issues related to User Interface, OS Support, Core Functionality help wanted We will accept PRs from all issues marked as "help wanted". Thanks for your support!

Projects

None yet

Development

Successfully merging this pull request may close these issues.

fix cli ui: ctrl+backspace does not delete word in windows terminals

4 participants