Commit log

109f1d4 agent: Simplify user message design (#29165)

Click to expand commit body
Mainly removing the "You" label, which didn't add a lot of value. Still
figuring out an issue with font size Markdown rendering before merging
this PR.

Release Notes:

- N/A

Danilo Leal created

a5852d4 agent: Support inserting selections as context via `@selection` (#29045)

Click to expand commit body
WIP

Release Notes:

- N/A

Bennet Bo Fenner created

10ded0a agent: Add support for google gemini 2.5 flash preview (#29205)

Click to expand commit body
Adds support for the new gemini-2.5-flash-preview-04-17

Release Notes:

- agent: Added support for gemini-2.5-flash-preview

Stephan Seidt created

b0b620a gemini: Add support for passing images as part of the prompt (#29203)

Click to expand commit body
Release Notes:

- agent: Add support for adding images as context when using Google
Gemini

Bennet Bo Fenner created

eca6d5a agent: Support pasting images as context (#29177)

Click to expand commit body
https://github.com/user-attachments/assets/d6a27b05-3590-4f40-a820-f6f99f6bd581

Release Notes:

- agent: Added support for pasting images as context

---------

Co-authored-by: Danilo Leal <daniloleal09@gmail.com>

Bennet Bo Fenner and Danilo Leal created

3357736 Fix duplicated multi-buffer excerpts (#29193)

Click to expand commit body
- **add test case**
- **Merge excerpts more aggressively**
- **Randomized test for set_excerpts_for_path**

Closes #ISSUE

Release Notes:

- Fixed duplicted excerpts (and resulting panics)

---------

Co-authored-by: João Marcos <marcospb19@hotmail.com>

Conrad Irwin and João Marcos created

458ffaa Add new action to run agent eval (#29158)

Click to expand commit body
The old one wasn't linking, and
https://github.com/zed-industries/zed/pull/29081 has a bunch of merge
conflicts. Wanted to start simple/small.

## Todo

* [x] Remove low-signal examples
* [x] Make the eval run on a cron, on main, and on any PR with the
`run-eval` label
* [x] Noise in logs about failure to write settings
    ```
[2025-04-21T20:45:04Z ERROR settings] Failed to write settings to file
"/home/runner/.config/zed/settings.json"
    
       Caused by:
No such file or directory (os error 2) at path
"/home/runner/.config/zed/.tmpLewFEs"
    ```
* [x] `Agentic loop stalled`
(https://github.com/zed-industries/zed/actions/runs/14581044243/job/40897622894)
* [x] Make sure that events are recorded in snowflake
* [ ] Change judge criteria to be more explicit about meanings of scores

Release Notes:

- N/A

---------

Co-authored-by: Antonio Scandurra <me@as-cii.com>
Co-authored-by: Agus Zubiaga <hi@aguz.me>
Co-authored-by: Max Brunsfeld <maxbrunsfeld@gmail.com>
Co-authored-by: Thomas Mickley-Doyle <tmickleydoyle@gmail.com>

Nathan Sobo , Antonio Scandurra , Agus Zubiaga , Max Brunsfeld , and Thomas Mickley-Doyle created

b14356d agent: Do not add `<using_tool>` placeholder (#29194)

Click to expand commit body
Our provider code in `language_models` filters out messages for which
`LanguageModelRequestMessage::contents_empty` returns `false`. This
doesn't seem wrong by itself, but `contents_empty` was returning `false`
for messages whose first segment didn't contain non-whitespace text even
if they contained other non-empty segments. This caused requests to fail
when a message with a tool call didn't contain any preceding text.

Release Notes:

- N/A

Agus Zubiaga created

19ef56b agent: Fix file context renames affecting display + simplify loading code (#29192)

Click to expand commit body
Release Notes:

- N/A

Michael Sloan created

dfbd132 Update Split bindings in terminal (#29188)

Click to expand commit body
Closes #29087

Release Notes:

- Changed default bindings for splitting terminals from `ctrl-k
{up,down,left,right}` to `ctrl-alt-{up,down,left,right}`. `ctrl-k` is
used by Readline to cut to the end of the line.

Conrad Irwin created

2e8ee9b agent: Make directory context display update on rename (#29189)

Click to expand commit body
Release Notes:

- N/A

Michael Sloan created

c15382c vim: Add cursor shape settings for each vim mode (#28636)

Click to expand commit body
Closes #4495

Release Notes:

- vim: add cursor shape settings for each vim mode

---

Add cursor shape settings for each vim mode to enable users to specify
them.

Example of `settings.json`:

```json
{
  "vim_mode": true,
  "vim": {
    "cursor_shape": {
      "normal": "hollow",
      "insert": "bar",
      "replace": "block",
      "visual": "underline"
    }
  }
}
```

After this change is applied,

- The cursor shape specified by the user for each mode is used.
- In insert mode, the `vim > cursor_shape > insert` setting takes
precedence over the primary `cursor_shape` setting.
- If `vim > cursor_shape > insert` is not set, the primary
`cursor_shape` will be used in insert mode.
- The cursor shape will remain unchanged before and after this update
when the user does not set the `vim > cursor_shape` setting.

Video:


[screen-record.webm](https://github.com/user-attachments/assets/b87461a1-6b3a-4a77-a607-a340f106def5)

Gaku Kanematsu created

70c51b5 agent eval: Default to also running typescript examples (#29185)

Click to expand commit body
Release Notes:

- N/A

Michael Sloan created

38afae8 Use buffer size for markdown preview (#29172)

Click to expand commit body
Note:

This is implemented in a very hacky and one-off manner. The primary
change is to pass a rem size through the markdown render tree, and scale
all sizing (rems & pixels) based on the passed in rem size manually.
This required copying in the `CheckBox` component from `ui::CheckBox` to
make it use the manual rem scaling without modifying the `CheckBox`
implementation directly as it is used elsewhere.

A better solution is required, likely involving `window.with_rem_size`
and/or _actual_ `em` units that allow text-size-relative scaling.

Release Notes:

- Made it so Markdown preview uses the _buffer_ font size instead of the
_ui_ font size.

---------

Co-authored-by: Ben Kunkle <ben@zed.dev>
Co-authored-by: Nate Butler <nate@zed.dev>

Mikayla Maki , Ben Kunkle , and Nate Butler created

9249919 Write `{result_count}.diff` and `last.diff` eval run outputs (#29181)

Click to expand commit body
These are only written when the diff has changed. `patch.diff` has been
removed as its redundant with `last.diff`.

It can be convenient to open `last.diff` and use undo/redo to navigate
its history.

Release Notes:

- N/A

Michael Sloan created

9fe4a14 Add a brief description of GPUI 2->GPUI 3 changes to `.rules` (#29180)

Click to expand commit body
Release Notes:

- N/A

Michael Sloan created

7cc3c03 editor: Fix hang when scrolling over single line input fields (#28471)

Click to expand commit body
Closes #21684
Closes #28463
Closes #28264 

This PR fixes Zed hanging when scrolling over single line input fields
with `scroll_beyond_last_line` set to `vertical_scroll_margin`. The
change here is to fix the calculations of available lines.

The issue only arises with the setting present because with all
overscroll settings and `max_row` being 1 for single-line editors, the
calculation would still return the correct value of available lines,
which is 1. However, with overscrolling set to `vertical_scroll_margin`
and that set to any value greater than 0, the calculation would return
that the single-line editor has more than one line, which caused the
issues described above (Actually, setting `vertical_scroll_margin` to 1
works for some reason, overscrolls "properly" and does not cause a
crash. But I really did not want to investigate this buggy behavior
further).

This PR fixes this by always reporting the number of available lines as
the line number value for single line editors, which will (mostly) be 1
(for more context see the discussion in this PR).

Release Notes:

- Fixed an issue where Zed would crash when scrolling over single line
input fields and `scroll_beyond_last_line` set to
`vertical_scroll_margin`.

Finn Evers created

4f2f9ff Streaming tool calls (#29179)

Click to expand commit body
https://github.com/user-attachments/assets/7854a737-ef83-414c-b397-45122e4f32e8



Release Notes:

- Create file and edit file tools now stream their tool descriptions, so
you can see what they're doing sooner.

---------

Co-authored-by: Marshall Bowers <git@maxdeviant.com>

Richard Feldman and Marshall Bowers created

7aa0fa1 Add ability to attach rules as context (#29109)

Click to expand commit body
Release Notes:

- agent: Added support for adding rules as context.

Michael Sloan created

3b31860 Add to `.rules`: Avoid creating `mod.rs` paths (#29174)

Click to expand commit body
Release Notes:

- N/A

Michael Sloan created

733cd6b agent: Remove non-rust examples from evals (#29139)

Click to expand commit body
Release Notes:

- N/A

Thomas Mickley-Doyle created

e8fe0eb debugger: Fix restarting terminated child sessions (#29173)

Click to expand commit body
This fixes a bug where terminated child session failed to restart
because they were using the wrong configuration/binary to start a new
session

Release Notes:

- N/A

Anthony Eid created

0f3ac38 Agent eval: Copy `.rules` file into eval worktree for examples based on Zed (#29116)

Click to expand commit body
Also reverts #29108, which cherry-picked the rules file for an eval
example.

Release Notes:

- N/A

Michael Sloan created

32e9757 Fix ctrl-c in vim normal mode (#29167)

Click to expand commit body
This was broken when we added helix keybindings because we populate the
menu's shortcut based on the "last" seen binding for an action ignoring
context.

Release Notes:

- Fix `ctrl-c` in vim normal mode

Conrad Irwin created

be76942 agent: Migrate tool names in settings (#29168)

Click to expand commit body
Release Notes:

- agent: Add migration to rename `find_replace_file` tool to
`edit_file`, and `regex_search` to `grep`.

Agus Zubiaga created

942d4eb agent: Add additional fields to `Agent Tool Finished` telemetry event (#29163)

Click to expand commit body
This PR adds additional fields to the `Agent Tool Finished` telemetry
event:

- `model`
- `model_provider`
- `thread_id`
- `prompt_id`

Release Notes:

- N/A

Marshall Bowers created

9d35f03 debugger: More tidy up for SSH (#28993)

Click to expand commit body
Split `locator` out of DebugTaskDefinition to make it clearer when
location needs to happen.

Release Notes:

- N/A

---------

Co-authored-by: Anthony Eid <hello@anthonyeid.me>
Co-authored-by: Anthony <anthony@zed.dev>
Co-authored-by: Cole Miller <m@cole-miller.net>

Conrad Irwin , Anthony Eid , Anthony , and Cole Miller created

d13cd00 zlog: Module-level configuration and other improvements (#29161)

Click to expand commit body
Various improvements to `zlog` including:

- Enable filtering by module (reproducing `env_logger` behavior) both
through env and settings.
- Note: filtering by module currently does not account for parent module
configuration, but does account for crate configuration.
i.e. `crate=trace` will enable `TRACE` messages in `crate::a` and
`crate::a::b` modules, but `crate::a=trace` will not enable trace
messages in module `crate::a::b`
- Implementing the `Log` trait for `zlog::Logger` to support gradual
transition and evaluate tradeoffs of always going through `log` crate.
- Added the ability to turn off logging for a specific filter (module or
scope) completely by setting it to `off` (in env: `crate::a=off`, in
settings: `"project.foo": "off"`)
- Made it so the `zlog::scoped!` macro can be used in constant
expressions, so scoped loggers can be declared as global constants

Release Notes:

- N/A

Ben Kunkle created

f8ac6ee terminal: Add right-click in terminal to create a new selection if none is present (#29131)

Click to expand commit body
This PR adds functionality to right click in terminal create new
selection if none present. The selection is identical with double click
a text in terminal, plus the logic is moved from the double-click in the
terminal::mouse_down.

Closes #28237 

Release Notes:
- Adds functionality to right click in terminal create new selection if
none present

Ho Chun Lau created

6d2bdc3 editor: Hide mouse context menu when modal is opened (#29127)

Click to expand commit body
Closes #28787 

The context menu appears before the modal because it is a Deferred
element, which is always displayed above normal elements.

Release Notes:

Previously, the editor context menu appeared before the Command Palette.
This commit ensures the editor context menu is hidden when a modal,
including the Command Palette, is opened.

redforks created

9a3434e component preview: Focus search input immediately upon opening (#29155)

Click to expand commit body
Just a quick quality of life improvement to make keyboard navigation in
this view a bit better. When you open the Component Preview view now,
the "filter" search input will be focused right off the bat.

Release Notes:

- N/A

Danilo Leal created

333de5d agent: Update Switch color in the settings view (#29154)

Click to expand commit body
Just using the color method for the Switch component added in
https://github.com/zed-industries/zed/pull/29074.

Release Notes:

- N/A

Danilo Leal created

97ab098 Start tracking tool failure rates in eval (#29122)

Click to expand commit body
This pull request will print all the used tools and their failure rates.
The objective goal should be to minimize that failure rate.

@tmickleydoyle: this also changes the telemetry event to report
`tool_metrics` as opposed to `tool_use_counts`. Ideally I'd love to be
able to plot failure rates by tool and hopefully see that percentage go
down. Can we do that with the data we're tracking with this pull
request?

Release Notes:

- N/A

Antonio Scandurra created

3a27e8c edit tool: Handle over-indentation in `replace_with_flexible_indent` (#29153)

Click to expand commit body
Release Notes:

- agent: Correct over-indentation in search/replace strings from model

Agus Zubiaga created

bfb2ed3 ui: Add `.color` method to the Switch (#29074)

Click to expand commit body
This allows to pass, for example, `.color(SwitchColor::Accent)` to the
Switch component and have it render differently.

<img
src="https://github.com/user-attachments/assets/c60bac8a-c5ae-4693-912a-c754e5081f45"
width="550"/>

Release Notes:

- N/A

Danilo Leal created

9db0c4f editor: Hide signature popover on editor scroll (#29149)

Click to expand commit body
Closes #27845

This is also how VSCode tackles this issue. I think this should be
applicable to even more popovers across the editor and context menu, but
it can be addressed later.

Release Notes:

- Fixed the signature popover not hiding on editor scroll.

Smit Barmase created

a4f5c4f windows: Fix `window_min_size` (#29118)

Click to expand commit body
Closes #29117

This makes `window_min_size` work by using the `WM_GETMINMAXINFO` window
message.


Release Notes:

- N/A

---------

Co-authored-by: 张小白 <364772080@qq.com>

angelrecovery and 张小白 created

4dcfe0c Omit duplicate LSP data when generating completion item labels (#29137)

Click to expand commit body
Before: 
<img width="875" alt="before"
src="https://github.com/user-attachments/assets/eec34f4e-3665-47e1-a224-16f1b98d5b29"
/>

After:
<img width="769" alt="after"
src="https://github.com/user-attachments/assets/4ce6a24b-6fd0-4043-b67c-c92105c1501a"
/>

Release Notes:

- N/A

Kirill Bulatov created

4473b45 inline assistant: Fix model picker (#29136)

Click to expand commit body
Release Notes:

- inline assistant: Fixed a bug where the default model would be used
even when a specific inline assistant model was configured

Agus Zubiaga created

ceeae79 eval: Improve lang server idle detection (#29135)

Click to expand commit body
Brings back #29013 after it was accidentally reverted by
https://github.com/zed-industries/zed/pull/28961/commits/e9bb15b9063615762c866c30aaf646acb12af1f3.

Release Notes:

- N/A

Agus Zubiaga created

107d8ca Rename regex search tool to grep and accept an include glob pattern (#29100)

Click to expand commit body
This PR renames the `regex_search` tool to `grep` because I think it
conveys more meaning to the model, the idea of searching the filesystem
with a regular expression. It's also one word and the model seems to be
using it effectively after some additional prompt tuning.

It also takes an include pattern to filter on the specific files we try
to search. I'd like to encourage the model to scope its searches more
aggressively, as in my testing, I'm only seeing it filter on file
extension.

Release Notes:

- N/A

Nathan Sobo created

4278d89 Update `find_and_replace_diff_card` eval example to include `.rules` file (#29108)

Click to expand commit body
Release Notes:

- N/A

Michael Sloan created

a91948a agent: Reorder some linux keybindings to match mac keybindings (#29107)

Click to expand commit body
Release Notes:

- Made keybindings for agent panel closer to the precedence order used
on Mac. This fixes use of `enter` to add context from the menu triggered
by `@` referencing.

Michael Sloan created

2178b36 Add eval worktrees and repos to file_scan_exclusions in zed project settings (#29106)

Click to expand commit body
Release Notes:

- N/A

Michael Sloan created

0fb0059 Switch from `open-codestral-mamba` to `codestral-latest` for default mistral model (#29104)

Click to expand commit body
Couldn't find mistral cloud pricing for open-codestral-mamba on the
mistral site, but codestral-latest is newer and appears to be cheaper
based on
https://sdk.vercel.ai/playground/mistral:codestral-mamba-latest,mistral:codestral-2501

Release Notes:

- N/A

Michael Sloan created

fbf7caf Default to fast model for thread summaries and titles + don't include system prompt / context / thinking segments (#29102)

Click to expand commit body
* Adds a fast / cheaper model to providers and defaults thread
summarization to this model. Initial motivation for this was that
https://github.com/zed-industries/zed/pull/29099 would cause these
requests to fail when used with a thinking model. It doesn't seem
correct to use a thinking model for summarization.

* Skips system prompt, context, and thinking segments.

* If tool use is happening, allows 2 tool uses + one more agent response
before summarizing.

Downside of this is that there was potential for some prefix cache reuse
before, especially for title summarization (thread summarization omitted
tool results and so would not share a prefix for those). This seems fine
as these requests should typically be fairly small. Even for full thread
summarization, skipping all tool use / context should greatly reduce the
token use.

Release Notes:

- N/A

Michael Sloan created

d48152d Don't send dummy user text with tool results (#29099)

Click to expand commit body
Previously, we were including the dummy text "Here are the tool
results." whenever reporting tool call results. I'm worried this is
adding noise and confusing the model, because the user didn't actually
say anything. This inserts an empty message to be populated later. My
preference would be something less stateful, where tool results (or
batches of them requested simultaneously) would be sent to the model as
soon as they were ready, without bothering to do this message
association dance. But for now, this seems to work.

Release Notes:

- N/A

Nathan Sobo created

bafc086 agent: Preserve thinking blocks between requests (#29055)

Click to expand commit body
Looks like the required backend component of this was deployed.

https://github.com/zed-industries/monorepo/actions/runs/14541199197

Release Notes:

- N/A

---------

Co-authored-by: Antonio Scandurra <me@as-cii.com>
Co-authored-by: Agus Zubiaga <hi@aguz.me>
Co-authored-by: Richard Feldman <oss@rtfeldman.com>
Co-authored-by: Nathan Sobo <nathan@zed.dev>

Bennet Bo Fenner , Antonio Scandurra , Agus Zubiaga , Richard Feldman , and Nathan Sobo created

f737c4d editor: Improve selection highlights speed (#29097)

Click to expand commit body
Before, we used to debounce selection highlight because it needed to
search the whole file to show gutter line highlights, etc. This
experience felt extremely laggy.

This PR introduces a new approach where:
1. We query only visible rows without debounce. The search function
itself is async and runs in a background thread, so it's not blocking
anything. With no debounce and such a small search space, highlights
feel realtime.
2. In parallel, we also query the whole file (still debounced, like
before). Once this query resolves, it updates highlights across the
file, making scrollbar markers visible.

This hybrid way gives the feeling of realtime, while keeping the same
functionality.


https://github.com/user-attachments/assets/432b65f1-89d2-4658-ad5e-048921b06a23

P.S. I have removed the user setting for custom debounce delay, because
(one) now it doesn't really make sense to configure that, and (two) the
whole logic is based on the assumption that the fast query will resolve
before the debounced query. A static debounce time makes sure of that.
Configuring it might lead to cases where the fast query resolves after
the debounced query, and we end up only seeing visible viewport
highlights.

Release Notes:

- Improved selection highlight speed.

Smit Barmase created

8f308d8 Add `zed` to Flatpak config and data directories (#28952)

Click to expand commit body
Closes #28944 

Release Notes:

- linux: Fixed incorrect config directory being used when Zed is
installed via Flatpak

Signed-off-by: Marko Kungla <marko.kungla@gmail.com>

Marko Kungla created