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>
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
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`.
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)
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
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`.
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.
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)
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
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>