0415e85
debugger: Use current worktree directory when spawning an adapter (#31054)
Click to expand commit body
/cc @osiewicz
I think bringing this back should fix **bloveless** his issue with go
debugger.
This is also nice, so people are not forced to give us a working
directory, because most adapters will use their **cwd** as the project
root directory. For JavaScript, you don't need to specify the **cwd**
anymore because it can already infer it
Release Notes:
- debugger beta: Fixed some adapters fail to determine the right root level of the
debug program.
Remco Smits
created
1c9b818
debugger: Use DAP schema to configure daps (#30833)
Click to expand commit body
This PR allows DAPs to define their own schema so users can see
completion items when editing their debug.json files.
Users facing this aren’t the biggest chance, but behind the scenes, this
affected a lot of code because we manually translated common fields from
Zed's config format to be adapter-specific. Now we store the raw JSON
from a user's configuration file and just send that.
I'm ignoring the Protobuf CICD error because the DebugTaskDefinition
message is not yet user facing and we need to deprecate some fields in
it.
Release Notes:
- debugger beta: Show completion items when editing debug.json
- debugger beta: Breaking change, debug.json schema now relays on what
DAP you have selected instead of always having the same based values.
---------
Co-authored-by: Remco Smits <djsmits12@gmail.com>
Co-authored-by: Cole Miller <m@cole-miller.net>
Co-authored-by: Cole Miller <cole@zed.dev>
Anthony Eid
,
Remco Smits
,
Cole Miller
, and
Cole Miller
created
0d7f484
Restore scroll after undo edit prediction (#31162)
Click to expand commit body
Closes #29652
Release Notes:
- Fixed an issue where the scroll and cursor position would not be
restored after undoing an inline completion
Ben Kunkle
created
ab01712
agent: Improve Gemini support in the edit_file tool (#31116)
Click to expand commit body
This change improves `eval_extract_handle_command_output` results for
all models:
Model | Pass rate before | Pass rate after
----------------------------|------------------|----------------
claude-3.7-sonnet | 0.96 | 0.98
gemini-2.5-pro | 0.35 | 0.86
gpt-4.1 | 0.81 | 1.00
Part of this improvement comes from more robust evaluation, which now
accepts multiple possible outcomes. Another part is from the prompt
adaptation: addressing common Gemini failure modes, adding a few-shot
example, and, in the final commit, auto-rewriting instructions for
clarity and conciseness.
This change still needs validation from larger end-to-end evals.
Release Notes:
- N/A
Oleksiy Syvokon
created
71fb17c
debugger: Update the default layout (#31057)
Click to expand commit body
- Remove the modules list and loaded sources list from the default
layout
- Move the console to the center pane so it's visible initially
Release Notes:
- Debugger Beta: changed the default layout of the debugger panel,
hiding the modules list and loaded sources list by default and making
the console more prominent.
---------
Co-authored-by: Remco Smits <djsmits12@gmail.com>
Cole Miller
and
Remco Smits
created
97e437c
Remove test-support feature from auto_update's gpui dep (#31147)
Click to expand commit body
Fixes `cargo run` on main.
Release Notes:
- N/A
Cole Miller
created
66667d1
Add kernel detection for language support of runnable markdown cells (#29664)
Click to expand commit body
Closes #27757
Release Notes:
- List of runnable markdown cells is now based on detected jupyter
kernels instead of hardcoded to Python and TypeScript
Jon Gretar Borgthorsson
created
dce22a9
project search: Reduce clones and allocations (#31133)
Click to expand commit body
Release Notes:
- N/A
Remco Smits
created
5f452db
debugger: Add a couple more keybindings (#31103)
Click to expand commit body
- Add missing handler for `debugger::Continue` so `f5` works
- Add bindings based on VS Code for `debugger::Restart` and
`debug_panel::ToggleFocus`
- Remove breakpoint-related buttons from the debug panel's top strip,
and surface the bindings for `editor::ToggleBreakpoint` in gutter
tooltip instead
Release Notes:
- Debugger Beta: Added keybindings for `debugger::Continue`,
`debugger::Restart`, and `debug_panel::ToggleFocus`.
- Debugger Beta: Removed breakpoint-related buttons from the top of the
debug panel.
- Compatibility note: on Linux, `ctrl-shift-d` is now bound to
`debug_panel::ToggleFocus` by default, instead of
`editor::DuplicateLineDown`.
Cole Miller
created
b2a9209
debugger: Add actions and keybindings for opening the thread and session menus (#31135)
Click to expand commit body
Makes it possible to open and navigate these menus from the keyboard.
I also removed the eager previewing behavior for the thread picker,
which was buggy and came with a jarring layout shift.
Release Notes:
- Debugger Beta: Added the `debugger: open thread picker` and `debugger:
open session picker` actions.
Cole Miller
created
eb35d25
collab: Drop `billing_events` table (#31131)
Click to expand commit body
This PR drops the `billing_events` table, as we're no longer using it.
Release Notes:
- N/A
Marshall Bowers
created
8742d4a
editor: Fix regression causing incorrect delimiter on newline in case of multiple comment prefixes (#31129)
Click to expand commit body
Closes #31115
This fixes regression caused by
https://github.com/zed-industries/zed/pull/30824 while keeping that fix.
- [x] Test
Release Notes:
- Fixed the issue where adding a newline after the `///` comment would
extend it with `//` instead of `///` in Rust and other similar
languages.
smit
created
b829f72
collab: Prefer the plan on the subscription over the one on the usage (#31127)
Click to expand commit body
This PR makes it so we always prefer the plan on the subscription.
The plan stored on the subscription usage is informational only.
Release Notes:
- N/A
Marshall Bowers
created
ffa8310
collab: Drop `monthly_usages` and `lifetime_usages` tables (#31124)
Click to expand commit body
This PR drops the `monthly_usages` and `lifetime_usages` tables from the
LLM database, as they are no longer used.
Release Notes:
- N/A
Marshall Bowers
created
3fda539
Allow updater to check for updates after downloading one (#31066)
Click to expand commit body
This PR brings back https://github.com/zed-industries/zed/pull/30969 and
adds some initial testing.
https://github.com/zed-industries/zed/pull/30969 did indeed allow Zed to
continue doing downloads after downloading one, but it introduced a bug
where Zed would download a new binary every time it polled, even if the
version was the same as the running instance.
This code could use a refactor to allow more / better testing, but this
is a start.
Release Notes:
- N/A
This PR removes the `GET /billing/monthly_spend` endpoint, as it is no
longer used.
Release Notes:
- N/A
Marshall Bowers
created
f196288
docs: Fix broken link in ai/configuration (#31119)
Click to expand commit body
Release Notes:
- N/A
Peter Tripp
created
e30cc13
Rename 'Quit' to 'Quit Zed' in macOS menu (#31109)
Click to expand commit body
This is standard for Mac apps.
I should have included this with [my other
PR](https://github.com/zed-industries/zed/pull/30697), but didn’t catch
it. 🤦🏻♂️
Release Notes:
- N/A
Rob McBroom
created
09c8a84
docs: Link to models supported directly from table (#31112)
This PR updates the `Cargo.lock` file, as running `cargo check` was
producing a diff on `main`.
Release Notes:
- N/A
Marshall Bowers
created
cfd3b0f
Meter edit predictions by acceptance in free plan (#30984)
Click to expand commit body
TODO:
- [x] Release a new version of `zed_llm_client`
Release Notes:
- N/A
---------
Co-authored-by: Mikayla Maki <mikayla.c.maki@gmail.com>
Co-authored-by: Antonio Scandurra <me@as-cii.com>
Co-authored-by: Ben Brandt <benjamin.j.brandt@gmail.com>
Co-authored-by: Marshall Bowers <git@maxdeviant.com>
Max Brunsfeld
,
Mikayla Maki
,
Antonio Scandurra
,
Ben Brandt
, and
Marshall Bowers
created
f915c24
copilot: Fix rate limit due to Copilot-Vision-Request header (#30989)
Click to expand commit body
Issues: #30994
I've implemented an important optimisation in response to GitHub
Copilot's recent rate limit on concurrent Vision API calls. Previously,
our system was defaulting to vision header: true for all API calls. To
prevent unnecessary calls and adhere to the new limits, I've updated our
logic: the vision header is now only sent if the current message is a
vision message, specifically when the preceding message includes an
image.
Prompt used to reproduce and verify the fix: `Give me a context for my
agent crate about. Browse my repo.`
Release Notes:
- copilot: Set Copilot-Vision-Request header based on message content
6bbab4b
editor: Fix multi-cursor not added to lines shorter than current cursor column (#31100)
Click to expand commit body
Closes #5255, #1046, #28322, #15728
This PR makes `AddSelectionBelow` and `AddSelectionAbove` not skip lines
that are shorter than the current cursor column. This follows the same
behavior as VSCode and Sublime.
This change is only applicable in the case of an empty selection; if
there is a non-empty selection, it continues to skip empty and shorter
lines to create a Vim-like column selection, which is the better default
for that case.
- [x] Tests
The empty selection no longer skips shorter lines:
https://github.com/user-attachments/assets/4bde2357-20b6-44f2-a9d9-b595c12d3939
Non-empty selection continues to skip shorter lines.
https://github.com/user-attachments/assets/4cd47c9f-b698-40fc-ad50-f2bf64f5519b
Release Notes:
- Improved `AddSelectionBelow` and `AddSelectionAbove` to no longer skip
shorter lines when the selection is empty, aligning with VSCode and
Sublime behavior.
smit
created
7450b78
editor: Prevent overlapping of signature/hover popovers and context menus (#31090)
Click to expand commit body
Closes #29358
If hover popovers or signature popovers ever clash with the context menu
(like code completion or code actions), they find the best spot by
trying different directions around the context menu to show the popover.
If they can’t find a good spot, they just overlap with the context menu.
Not overlapping state:
<img width="350" alt="image"
src="https://github.com/user-attachments/assets/2f1bdc4c-eb01-405c-b5fb-eb28eadc9957"
/>
Overlapping case, moves popover to bottom of context menu:
<img width="350" alt="image"
src="https://github.com/user-attachments/assets/3ce4be23-7701-4711-b604-5e29682360e1"
/>
Overlapping case, moves popover to right of context menu:
<img width="350" alt="image"
src="https://github.com/user-attachments/assets/60d47518-e412-4d64-9d17-a69a17248bdf"
/> <img width="350" alt="image"
src="https://github.com/user-attachments/assets/2a3de176-7443-46d8-99d1-b2973a0ffaa6"
/>
Overlapping case, moves popover to left of context menu:
<img width="350" alt="image"
src="https://github.com/user-attachments/assets/015b799b-8c6e-4405-aee6-e205d4caebec"
/>
Overlapping case, moves popover to top of context menu:
<img width="350" alt="image"
src="https://github.com/user-attachments/assets/fbd03d84-9a49-44eb-846b-a9852d2ff43e"
/>
Release Notes:
- Fixed an issue where hover popovers or signature popovers would
overlap with existing opened completion or code actions context menus.
The panic occurred when querying a second search in the project search
multibuffer while there were dirty buffers.
The panic only happened in Nightly so there's no release notes
Release Notes:
- N/A
Anthony Eid
created
636eff2
Revert "Allow updater to check for updates after downloading one (#30969)" (#31086)
Click to expand commit body
This reverts commit 5c4f9e57d8f919f58e39d660515e1dbec7d71483.
Release Notes:
- N/A
Joseph T. Lyons
created
6c8f400
nix: Prevent spurious bindgen rebuilds in the devshell (#31083)
Click to expand commit body
Release Notes:
- N/A
Julia Ryan
created
91bc5ae
evals: Add system prompt to edit agent evals + fix edit agent (#31082)
Click to expand commit body
1. Add system prompt: this is how it's called from threads. Previously,
we were sending
2. Fix an issue with writing agent thought into a newly created empty
file.
Release Notes:
- N/A
---------
Co-authored-by: Ben Brandt <benjamin.j.brandt@gmail.com>
Co-authored-by: Antonio Scandurra <me@as-cii.com>
Oleksiy Syvokon
,
Ben Brandt
, and
Antonio Scandurra
created
2f3564b
Add icons to the built-in picker for Open (#30893)
Click to expand commit body

Release Notes:
- Added icons to the built-in picker for `Open` dialog
Currently, `search::ReplaceNext` works only first time it is executed
because Zed switches the focus to the editor. It seems
`self.editor_focus` call is unnecessary.
Closes #17466
Release Notes:
- Fixed `Replace Next Match` command. Previously it worked once, then
Zed incorrectly switched the focus to the editor
https://github.com/user-attachments/assets/66ef61d6-1efe-43ca-8d8c-6b40540a9930
Aleksei Gusev
created
8061bac
Add excluded_files to pane::DeploySearch (#30699)
Click to expand commit body
In accordance with #30327, I saw no reason for included files to get
special treatment, and I actually get use out of prefilling excluded
files because I like not to search symlinked files which, in my
workflow, use a naming convention.
This is simply implementing the same exact changes, but for excluded. It
was tested with `"space /": ["pane::DeploySearch", { "excluded_files":
"**/_*.tf" }]` and works just fine.
Release Notes:
- Added `excluded_files` to `pane::DeploySearch`.
Adam Sherwood
created
77dadfe
chore: Make terminal_view own the TerminalSlashCommand (#31070)
Click to expand commit body
This reduces 'touch crates/editor/src/editor.rs && cargo +nightly build'
from 8.9s to 8.5s. That same scenario used to take 8s less than a week
ago. :)
I'm measuring with nightly rustc, because it's compile times are better
than those of stable thanks to
https://github.com/rust-lang/rust/pull/138522
main (8.2s total):

[cargo-timing.html.zip](https://github.com/user-attachments/files/20364175/cargo-timing.html.zip)
#22be776 (7.5s total):
[cargo-timing-20250521T085303.892834Z.html.zip](https://github.com/user-attachments/files/20364391/cargo-timing-20250521T085303.892834Z.html.zip)

Release Notes:
- N/A
Missed because of lack of rebase
Release Notes:
- N/A
Ben Brandt
created
4ece4a6
extension_host: Use wasmtime incremental compilation (#30948)
Click to expand commit body
Builds on top of https://github.com/zed-industries/zed/pull/30942
This turns on incremental compilation and decreases extension
compilation times by up to another 41%
Putting us at roughly 92% improved extension load times from what is in
the app today.
Because we only have a static engine, I can't reset the cache between
every run. So technically the benchmarks are always running with a
warmed cache. So the first extension we load will take the 8.8ms, and
then any subsequent extensions will be closer to the measured time in
this benchmark.
This is also measuring the entire load process, not just the
compilation. However, since this is the loading we likely think of when
thinking about extensions, I felt it was likely more helpful to see the
impact on the overall time.
This works because our extensions are largely the same Wasm bytecode
(SDK code + std lib functions etc) with minor changes in the trait impl.
The more different that extensions implementation is, there will be less
benefit, however, there will always be a large part of every extension
that is always the same across extensions, so this should be a speedup
regardless.
I used `moka` to provide a bound to the cache. We could use a bare
`DashMap`, however if there was some issue this could lead to a memory
leak. `moka` has some slight overhead, but makes sure that we don't go
over 32mb while using an LRU-style mechanism for deciding which
compilation artifacts to keep.
I measured our current extensions to take roughly 512kb in the cache.
Which means with a cap of 32mb, we can keep roughly 64 *completely
novel* extensions with no overlap. Since our extensions will have more
overlap than this though, we can actually keep much more in the cache
without having to worry about it.
#### Before:
```
load/1 time: [8.8301 ms 8.8616 ms 8.8931 ms]
change: [-0.1880% +0.3221% +0.8679%] (p = 0.23 > 0.05)
No change in performance detected.
```
#### After:
```
load/1 time: [5.1575 ms 5.1726 ms 5.1876 ms]
change: [-41.894% -41.628% -41.350%] (p = 0.00 < 0.05)
Performance has improved.
```
Release Notes:
- N/A
Ben Brandt
created
77c2aec
Fix socks proxy local DNS resolution not respected (#30619)
This PR adds a new `GET /users/look_up` endpoint for retrieving users by
various identifiers.
This endpoint can look up users by the following identifiers:
- Zed user ID
- Stripe Customer ID
- Stripe Subscription ID
- Email address
- GitHub login
Release Notes:
- N/A
Marshall Bowers
created
3b1f6ea
client: Try to re-introduce HTTP/HTTPS proxy (#31002)
Click to expand commit body
When building for the `x86_64-unknown-linux-musl` target, the default
`openssl-dev` is compiled for the GNU toolchain, which causes a build
error due to missing OpenSSL. This PR fixes the issue by avoiding the
use of OpenSSL on non-macOS and non-Windows platforms.
Release Notes:
- N/A
张小白
created
44fbe27
wrap_map: Add capacity to vectors for better performance (#31055)
Click to expand commit body
Release Notes:
- N/A
Remco Smits
created
a824119
Fix performance issues in project search related to detecting JSX tag auto-closing (#30842)
Click to expand commit body
This PR changes it so we only create a snapshot and get the syntax tree
for a buffer if we didn't detect that auto_close is enabled.
<img width="1205" alt="Screenshot 2025-05-16 at 21 10 28"
src="https://github.com/user-attachments/assets/1ada445f-77bc-4c7c-bffe-953f34ee5384"
/>
Release Notes:
- Improved project search performance
https://github.com/zed-industries/zed/issues/30972 brought up another
case where our context is not enough to track the actual source of the
issue: we get a general top-level error without inner error.
The reason for this was `.ok_or_else(|| anyhow!("failed to read HEAD
SHA"))?; ` on the top level.
The PR finally reworks the way we use anyhow to reduce such issues (or
at least make it simpler to bubble them up later in a fix).
On top of that, uses a few more anyhow methods for better readability.
* `.ok_or_else(|| anyhow!("..."))`, `map_err` and other similar error
conversion/option reporting cases are replaced with `context` and
`with_context` calls
* in addition to that, various `anyhow!("failed to do ...")` are
stripped with `.context("Doing ...")` messages instead to remove the
parasitic `failed to` text
* `anyhow::ensure!` is used instead of `if ... { return Err(...); }`
calls
* `anyhow::bail!` is used instead of `return Err(anyhow!(...));`
Release Notes:
- N/A
Kirill Bulatov
created
1e51a7a
Don't pass `-z` flag to git-cat-file (#31053)
Click to expand commit body
Closes #30972
Release Notes:
- Fixed a bug that prevented the `copy permalink to line` action from
working on systems with older versions of git.
Cole Miller
created
d547a86
editor: Hide hover popover when code actions context menu is triggered (#31042)
Click to expand commit body
This PR hides hover info/diagnostic popovers when code action menu is
shown. We already hide hover info/diagnostic popover on code completion
menu trigger (handled on input).
Note: It is still possible to see hover popover if code completion or
code action menu is already open. This is intended behavior.
- [x] Test hover popover hides when code action is triggered
Release Notes:
- Fixed issue where info and diagnostic hover popovers were still
visible when code action menu is triggered.
smit
created
4bb04ce
Accept wrapped text content from LLM providers (#31048)
Click to expand commit body
Some providers sometimes send `{ "type": "text", "text": ... }` instead
of just the text as a string. Now we accept those instead of erroring.
Release Notes:
- N/A
Richard Feldman
created
89700c3
sublime: Don't map editor::FindNextMatch by default (#31029)
Click to expand commit body
Closes: https://github.com/zed-industries/zed/issues/29535
Broken in: https://github.com/zed-industries/zed/pull/28559/files
Removes `editor::FindNextMatch` and `editor::FindPreviousMatch` from the
default sublime mappings. If you would like to use this, you will have
to add them to your user keymap. Reverts the previous behavior where
cmd-g / cmd-shift-g relies on the base keymap.
Linux:
```json
{
"context": "Editor && mode == full",
"bindings": {
"f3": "editor::FindNextMatch",
"shift-f3": "editor::FindPreviousMatch"
}
}
```
MacOS:
```json
{
"context": "Editor && mode == full",
"bindings": {
"cmd-g": "editor::FindNextMatch",
"cmd-shift-g": "editor::FindPreviousMatch"
}
},
```
Release Notes:
- Fixed a regression in Sublime Text keymap for find next/previous in
the search bar
Peter Tripp
created
7609402
Remove `alt-.` keybinding from terminal on macOS (#30827)
Click to expand commit body
Closes: #30730
It conflicts with the `>` key on the Czech keyboard layout
If you want the previous behavior, add `"alt-.": ["terminal::SendText",
"\u001b."]` to your keymap under the `Terminal` context.
Release Notes:
- Improved the default terminal keybind to not conflict on Czech
keyboards
Co-authored-by: Peter Tripp <peter@zed.dev>
Erik Funder Carstensen
and
Peter Tripp
created
a0ec9cf
telemetry: Consider the entire chain of config sources when merging (#31039)
Click to expand commit body
Global settings were implemented in #30444, but `Settings`
implementations need to consider that source for it to be useful. This
PR does just that for `TelemetrySettings` so these can be controlled via
global settings.
Release Notes:
- N/A
Andres Suarez
created
eb318c1
Revert "linux(x11): Add support for pasting images from clipboard (#29387)" (#31033)
Click to expand commit body
Closes: #30523
Release Notes:
- linux: Reverted the ability to paste images on X11, as the change
broke pasting from some external applications