0e10cea
Bump to 0.221.3 for @osiewicz
Zed Zippy created
0e10cea
Bump to 0.221.3 for @osiewicz
Zed Zippy created
35eb5f6
copilot_chat: Fix Anthropic models not appearing in model picker (#47549) (cherry-pick to preview) (#47591)
Cherry-pick of #47549 to preview
----
## Summary
Fixes #47540 - Anthropic Claude models not appearing in GitHub Copilot
Chat model picker.
## Problem
Users reported that Anthropic Claude models (Claude Sonnet 4, Claude
Opus 4, etc.) were not appearing in the model picker when using GitHub
Copilot Chat, even though:
- The GitHub Copilot API returns these models
- The models have `model_picker_enabled: true`
- Users have valid Copilot subscriptions with access to these models
## Root Cause
The issue was in the `ModelSupportedEndpoint` enum deserialization. The
enum only defined two variants:
```rust
pub enum ModelSupportedEndpoint {
#[serde(rename = "/chat/completions")]
ChatCompletions,
#[serde(rename = "/responses")]
Responses,
}
```
Anthropic Claude models use the `/v1/messages` endpoint, which wasn't
defined. When deserializing the API response, serde failed with:
```
Error("unknown variant `/v1/messages`, expected `/chat/completions` or `/responses`")
```
Because the crate uses resilient deserialization via
`deserialize_models_skip_errors()`, the entire Claude model was silently
skipped rather than causing a hard failure. This meant users saw no
error - the models simply didn't appear.
## Solution
### 1. Added `/v1/messages` endpoint variant
```rust
pub enum ModelSupportedEndpoint {
#[serde(rename = "/chat/completions")]
ChatCompletions,
#[serde(rename = "/responses")]
Responses,
#[serde(rename = "/v1/messages")]
Messages, // NEW: Anthropic models use this endpoint
#[serde(other)]
Unknown, // NEW: Future-proofing for unknown endpoints
}
```
### 2. Removed incorrect `dedup_by()` call
The previous code deduplicated models by family:
```rust
.dedup_by(|a, b| a.capabilities.family == b.capabilities.family)
```
This incorrectly filtered out model variants that share the same family
(e.g., `claude-sonnet-4` and `claude-sonnet-4-thinking`). Removed this
call to preserve all model variants.
### 3. Removed unused import
Removed `use itertools::Itertools;` which was only used for the
now-removed `dedup_by()`.
## Changes
| File | Change |
|------|--------|
| `crates/copilot_chat/src/copilot_chat.rs` | Added `Messages` and
`Unknown` variants to `ModelSupportedEndpoint` enum |
| `crates/copilot_chat/src/copilot_chat.rs` | Removed `.dedup_by()` call
that incorrectly filtered models |
| `crates/copilot_chat/src/copilot_chat.rs` | Removed unused
`itertools::Itertools` import |
| `crates/copilot_chat/src/copilot_chat.rs` | Added 8 new unit tests |
## Test Coverage
Added 8 new unit tests to ensure the fix works and prevent regression:
| Test | Purpose |
|------|---------|
| `test_models_with_pending_policy_deserialize` | Verifies models with
non-"enabled" policy states deserialize correctly (they're filtered
later) |
| `test_multiple_anthropic_models_preserved` | Verifies multiple Claude
models are not incorrectly deduplicated |
| `test_models_with_same_family_both_preserved` | Verifies models
sharing the same family (e.g., thinking variants) are both preserved |
| `test_mixed_vendor_models_all_preserved` | Verifies models from
different vendors (OpenAI, Anthropic, Google) are all preserved |
| `test_model_with_messages_endpoint_deserializes` | **Critical test**:
Verifies `/v1/messages` endpoint deserializes correctly |
| `test_model_with_unknown_endpoint_deserializes` | Verifies unknown
future endpoints deserialize to `Unknown` variant |
| `test_model_with_multiple_endpoints` | Verifies models with multiple
endpoints deserialize correctly |
| `test_supports_response_method` | Verifies the `supports_response()`
method logic for endpoint routing |
### Test Results
```
running 10 tests
test tests::test_model_with_messages_endpoint_deserializes ... ok
test tests::test_model_with_multiple_endpoints ... ok
test tests::test_model_with_unknown_endpoint_deserializes ... ok
test tests::test_models_with_pending_policy_deserialize ... ok
test tests::test_models_with_same_family_both_preserved ... ok
test tests::test_mixed_vendor_models_all_preserved ... ok
test tests::test_multiple_anthropic_models_preserved ... ok
test tests::test_resilient_model_schema_deserialize ... ok
test tests::test_supports_response_method ... ok
test tests::test_unknown_vendor_resilience ... ok
test result: ok. 10 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out
```
## How to Test Manually
1. Sign in to GitHub Copilot in Zed
2. Open the model picker (Agent panel β model selector dropdown)
3. Verify that Anthropic Claude models appear in the list:
- Claude Sonnet 4
- Claude Opus 4
- Other Claude variants (if enabled in your GitHub Copilot settings)
## Checklist
- [x] Code compiles without errors
- [x] `./script/clippy --package copilot_chat` passes with no warnings
- [x] All unit tests pass
- [x] Change is focused on a single bug fix
- [x] No unrelated refactoring or feature additions
<img width="320" height="400" alt="Screenshot 2026-01-24 at 11 57 21β―PM"
src="https://github.com/user-attachments/assets/d5e17e1b-da80-4f4d-a218-d50d35114a21"
/>
Release Notes:
- Fixed Anthropic models not appearing in the Copilot Chat model picker
---------
Co-authored-by: Piotr Osiewicz
<24362066+osiewicz@users.noreply.github.com>
Co-authored-by: Anil Pai <anilpai@users.noreply.github.com>
Co-authored-by: Piotr Osiewicz <24362066+osiewicz@users.noreply.github.com>
zed-zippy[bot] , Anil Pai , and Piotr Osiewicz created
a0f862a
acp: Use the official ACP registry URL (#47564) (cherry-pick to preview) (#47566)
Cherry-pick of #47564 to preview ---- Release Notes: - N/A Co-authored-by: Ben Brandt <benjamin.j.brandt@gmail.com>
zed-zippy[bot] and Ben Brandt created
68e98a5
zed 0.221.2
Anthony Eid created
957e0ab
acp: Add one more registry ID to filter out (#47496) (cherry-pick to preview) (#47504)
Cherry-pick of #47496 to preview ---- Release Notes: - N/A Co-authored-by: Ben Brandt <benjamin.j.brandt@gmail.com>
zed-zippy[bot] and Ben Brandt created
0d3f7e3
editor: Fix panics that could occur when content mask had negative bounds (#47327) (cherry-pick to preview) (#47502)
Cherry-pick of #47327 to preview ---- Closes #47157 This panic happened because the editor was using `window.content_mask` to get the visible bounds, which had a negative value for its height in some cases. This happened for three reasons: 1. `Bounds::from_corners` returns a negative size if callers pass in corners where `bottom_right < top_left`. I originally wanted to add error checking to this function but didn't, because it might be better to move the error checking higher up. For now I'm going to push a fix and figure out a better solution later 2. `Bounds::intersect` could return negative-sized bounds when the two bounds didn't overlap, instead of returning a zero sized bounds. 3. `Style::paint` sometimes passed invalid corner values to `Bounds::from_corners` (where the computed bottom-right was above/left of the top-left). Release Notes: - editor: Fix a crash that could happen when editor visible line height is zero --------- Co-authored-by: Zed Zippy <234243425+zed-zippy[bot]@users.noreply.github.com> Co-authored-by: Anthony Eid <56899983+Anthony-Eid@users.noreply.github.com> Co-authored-by: Zed Zippy <234243425+zed-zippy[bot]@users.noreply.github.com>
zed-zippy[bot] , Anthony Eid , and Zed Zippy created
ac55cb8
copilot: Decouple authentication from the lifetime of any single Copilot instance (#47473) (cherry-pick to preview) (#47492)
Cherry-pick of #47473 to preview ---- Users had trouble signing in due to us relying on the Copilot::global being set, which was never the case. We've decided to use a dedicated LSP instance just for handling auth of Copilot Chat and other goodies. That instance is subscribed to by local Copilot instances for projects. When the Auth instance changes it's state, local instances are prompted to re-check their own sign in status. Closes #47352 Co-authored-by: dino <dinojoaocosta@gmail.com> Release Notes: - Fixed authentication issues with Copilot. --------- Co-authored-by: dino <dinojoaocosta@gmail.com> Co-authored-by: Zed Zippy <234243425+zed-zippy[bot]@users.noreply.github.com> Co-authored-by: Piotr Osiewicz <24362066+osiewicz@users.noreply.github.com> Co-authored-by: dino <dinojoaocosta@gmail.com> Co-authored-by: Zed Zippy <234243425+zed-zippy[bot]@users.noreply.github.com>
zed-zippy[bot] , Piotr Osiewicz , dino , and Zed Zippy created
4c37db6
copilot: Rename enabled_next_edit_suggestions setting to enable_next_edit_suggestions (#47484) (cherry-pick to preview) (#47490)
Cherry-pick of #47484 to preview ---- Co-authored-by: Marshall Bowers <marshall@zed.dev> Closes #ISSUE Release Notes: - N/A Co-authored-by: Marshall Bowers <marshall@zed.dev> Co-authored-by: Piotr Osiewicz <24362066+osiewicz@users.noreply.github.com> Co-authored-by: Marshall Bowers <marshall@zed.dev>
zed-zippy[bot] , Piotr Osiewicz , and Marshall Bowers created
4904fac
copilot: Add the option to disable Next Edit Suggestions (#47438) (cherry-pick to preview) (#47481)
Cherry-pick of #47438 to preview
----
Adds a new setting to GitHub Copilot to toggle the Next Edit Suggestions
feature, it is enabled by default.
## Motivations
Due to some current usability issues with this feature, see #46880, and
some personal anecdotes of using it, it is currently rough to utilize,
so this gives the option to disable it.
## Related
- #47071
- #30124
- #44486
## Release Notes
- Adds the ability to disable GitHub Copilot's Next Edit Suggestions
feature.
## User Interface

## Text Example
The text example will be adding a `z` variable to a `Point3D` class in
TypeScript.
### With Next Edit Suggestions
In this example I am able to just press auto-complete (press TAB) 3x.
```ts
class Point3D {
x: number;
y: number;
z: number; // <-- Cursor before z: suggested
constructor(x: number,
y: number
, z: number // <-- Next Suggestion
) {
this.x = x;
this.y = y;
this.z = z; // <-- Last Suggestion
}
}
```
### Without Next Edit Suggestions
```ts
class Point3D {
x: number;
y: number;
z: number; // <-- Cursor before z: the only suggestion
constructor(x: number, y: number) {
this.x = x;
this.y = y;
}
}
```
Co-authored-by: AndrΓ© Eriksson <andreeriksson444@gmail.com>
zed-zippy[bot] and AndrΓ© Eriksson created
ae5eb75
acp: Promote registry as default way of installing new agents (#47464) (cherry-pick to preview) (#47470)
Cherry-pick of #47464 to preview ---- Release Notes: - acp: Add the ability to install new Agents via the ACP Registry Co-authored-by: Ben Brandt <benjamin.j.brandt@gmail.com>
zed-zippy[bot] and Ben Brandt created
2def683
Bump to 0.221.1 for @cole-miller
Zed Zippy created
0623642
Add "Agent Panel Error Shown" telemetry with ACP error details (#46848) (cherry-pick to preview) (#47428)
Cherry-pick of #46848 to preview ---- Adds a new "Agent Panel Error Shown" telemetry event that fires when users see errors in the agent panel. For errors from external ACP agents (like Claude Code), we capture additional details. Previously, we had no visibility into what errors users were encountering in the agent panel. This made it difficult to diagnose issues, especially with external agents. The new telemetry event includes: - `agent` β The agent telemetry ID - `session_id` β The session ID - `kind` β Error category (payment_required, authentication_required, refusal, other, etc.) - `acp_error_code` β The ACP error code when available (e.g., "InternalError") - `acp_error_message` β The ACP error message when available Release Notes: - N/A --------- Co-authored-by: Michael Benfield <mbenfield@zed.dev> Co-authored-by: Katie Geer <katie@zed.dev> Co-authored-by: Michael Benfield <mbenfield@zed.dev>
zed-zippy[bot] , Katie Geer , and Michael Benfield created
80814ad
agent: Clearer distinction that we are in Text Thread history (#47295) (cherry-pick to preview) (#47380)
Cherry-pick of #47295 to preview ---- Some users were a bit confused that the history between zed agent + text threads is split up now. Making it a bit clearer for the users still using text threads which history they are currently looking at. Release Notes: - N/A Co-authored-by: Ben Brandt <benjamin.j.brandt@gmail.com>
zed-zippy[bot] and Ben Brandt created
6eb5e1c
acp: Add beta label to ACP registry (#47369) (cherry-pick to preview) (#47373)
Cherry-pick of #47369 to preview ---- Release Notes: - N/A Co-authored-by: Ben Brandt <benjamin.j.brandt@gmail.com>
zed-zippy[bot] and Ben Brandt created
fbfdf62
acp: Optimize registry refresh (#47367) (cherry-pick to preview) (#47368)
Cherry-pick of #47367 to preview ---- Before we were checking it even if you weren't using registry agents. Now happens less frfrequently, and only when you are actually using registry agents. Release Notes: - N/A Co-authored-by: Ben Brandt <benjamin.j.brandt@gmail.com>
zed-zippy[bot] and Ben Brandt created
8aea362
v0.221.x preview
Joseph T. Lyons created
099650f
ep: Check whether predictions worsen brace balance (#47301)
Release Notes: - N/A
Oleksiy Syvokon created
40fe799
Use arithmetic expansion instead of `expr` in `./script/clear-target-dir-if-larger-than` (#47298)
Fixes CI failures when the target dir is 0GB in size, which causes `expr` to output a non-zero exit code per the posix spec. See exit status section of https://www.man7.org/linux/man-pages/man1/expr.1p.html Release Notes: - N/A *or* Added/Fixed/Improved ...
Ben Kunkle created
8fb5587
agent_ui: Alphabetically sort edited files in the panel & review view (#47300)
This makes the ordering of files consistent with the Git diff view. Release Notes: - N/A
Danilo Leal created
1b0771e
agent_ui: Improve UI for subagent calls (#47299)
- Improves spacing between consecutive calls - Only show disclosure button (i.e., ability to expand the card) when there's actual content - Fix font size being bigger than the actual thread - Add gradient overlay to communicate that you can't scroll within the card (expanding the subagent call will allow that in the near future) Here's the result of it all, roughly: <img width="600" height="890" alt="Screenshot 2026-01-21 at 12β― 26@2x" src="https://github.com/user-attachments/assets/e5e4a544-611d-48f5-b00d-f69e869726c5" /> Release Notes: - N/A
Danilo Leal created
1103f3b
acp: Allow running NPM agents from registry (#47291)
Release Notes: - N/A
Ben Brandt created
69ea59d
agent_servers: Don't fill in unneeded fields in settings when auto-adding new agent servers (#47293)
Adding some serde magic to avoid adding a bunch of empty fields to the settings file. Release Notes: - N/A
Ben Brandt created
db37fb0
themes: Fix One Light terminal cyan color (#45691)
Closes #45075 The cyan terminal colors in One Light were incorrectly set to the same values as green, making them indistinguishable. This was introduced in https://github.com/zed-industries/zed/pull/44912 Release Notes: - Fixed terminal cyan color displaying as green in One Light theme
Mateo Kruk created
5e1b7ae
agent_ui: Fix keybinding conflict with editing queued messages (#47290)
This PR fixes `shift-e` being used for triggering edits in queued messages, which breaks writing simple capital E in the editor. Release Notes: - N/A
Danilo Leal created
5751aeb
languages: Fix `poetry` environment discovery on Linux (#47100)
Closes #47098 The root cause of this issue is related to how `Poetry` (and the upstream `pet-poetry` library) handles path hashing. While perhaps it's an upstream behavior, we can easily fix it on the Zed side. The related code are https://github.com/zed-industries/zed/blob/7ce845210d3af82a57a7518e0abe8c167d60cc6a/crates/languages/src/python.rs#L1181-L1211 In my debugging, I found that `worktree_root` takes the form `/home/user/project`, but `config.workspace_directories` often ends up as `/home/user/project/`(with a trailing slash). Normally this wouldn't be an issue, but `Poetry` generates environment names based on the hash of the absolute path. Since the hashes for `/home/user/project` and `/home/user/project/` are different, `pet-poetry` fails to find the environment. The fix is straightforward: we just need to ensure the trailing `/` is removed so the hashes match. Release Notes: - Fixed poetry environment not discovered on linux
Xin Zhao created
ed29b46
project_panel: Fix "Add Folder to Project" menu hidden on remote projects (#47283)
Fixes an unintended behavioral change from #40838. Release Notes: - Fixed "Add Folder to Project" and "Remove from Project" menu items being incorrectly hidden on remote projects.
Smit Barmase created
a53017c
ep: Don't compute n-grams for regions that match exactly (#47281)
This makes delta-chrF computation ~50 faster. Release Notes: - N/A
Oleksiy Syvokon created
a608ee6
remote_server: Fix remote project search include/exclude filters for multiple worktrees (#47280)
Closes #45772 Release Notes: - Fixed project search include/exclude filters not working correctly in remote project with multiple folders.
Smit Barmase created
b22d129
acp: Filter out built-in agents from the registry (#47279)
Release Notes: - N/A
Ben Brandt created
6ab03c6
onboarding: Fix theme picker always updating theme based on system appearance (#47245)
The settings store separate themes for Light and Dark modes. When the user clicks a theme, the code uses the system appearance to decide which to update, rather than the mode the user selected in the UI. This causes the wrong theme to be saved when the system appearance differs from the selected mode. <img width="746" height="324" alt="image" src="https://github.com/user-attachments/assets/b8f8d937-172d-4da8-b572-4f3db7f1de9a" /> Release Notes: - Fixed onboarding page sometimes rendering the wrong theme --------- Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com> Co-authored-by: MrSubidubi <finn@zed.dev>
Michael Hackner , Claude Opus 4.5 , and MrSubidubi created
7bd3075
open_ai: Support reasoning content (#43662)
Support for Kimi K2 Thinking Release Notes: - Added support for thinking traces when using OpenAI-API-compatible AI providers --------- Co-authored-by: Bennet Bo Fenner <bennet@zed.dev>
Aero and Bennet Bo Fenner created
5731066
ep: Fix in-place processing (#47274)
Release Notes: - N/A
Oleksiy Syvokon created
67d3804
agent: Allow env overrides for extension and registry agents (#47275)
Align the behavior with built-in and custom agents Release Notes: - N/A
Ben Brandt created
8c8639f
git: Fix buffer diff crash that could occur during the stage all operation (#47265)
Closes https://github.com/zed-industries/zed/issues/46519 This crash happened because we were incorrectly merging pending and unstaged hunks together by always using the pending hunk end offset as the merged hunk bound instead of the max of both hunks. The fix is to use `max()` when updating `buffer_offset_range.end` during pending hunk merging, matching the behavior used for unstaged hunk merging. Release Notes: - N/A
Anthony Eid created
a191444
gpui: Preserve rem_size context for deferred draws (#47263)
Closes #46328 Release Notes: - Fixed agent model selector cutting off models at the end of the list.
Smit Barmase created
21050e2
Fix nested request rate limiting deadlock for subagent edit_file (#47232)
## Problem When subagents use the `edit_file` tool, it creates an `EditAgent` that makes its own model request to get the edit instructions. These "nested" requests compete with the parent subagent conversation requests for rate limiter permits. The rate limiter uses a semaphore with a limit of 4 concurrent requests per model instance. When multiple subagents run in parallel: 1. 3 subagents each hold 1 permit for their ongoing conversation streams (3 permits used) 2. When all 3 try to use `edit_file` simultaneously, their edit agents need permits too 3. Only 1 edit agent can get the 4th permit; the other 2 block waiting 4. The blocked edit agents can't complete, so their parent subagent conversations can't complete 5. The parent conversations hold their permits, so the blocked edit agents stay blocked 6. **Deadlock** ## Solution Added a `bypass_rate_limit` field to `LanguageModelRequest`. When set to `true`, the request skips the rate limiter semaphore entirely. The `EditAgent` sets this flag because its requests are already "part of" a rate-limited parent request. (No release notes because subagents are still feature-flagged.) Release Notes: - N/A --------- Co-authored-by: Zed Zippy <234243425+zed-zippy[bot]@users.noreply.github.com>
Richard Feldman and Zed Zippy created
ff35da2
agent_ui: Fix keybinding conflict with action to clean up the queue (#47254)
This PR frees up `shift-backspace` to work as it did before. Now, the action to remove the first queued message is now assigned to the `cmd-shfit-backspace` keybinding, whereas the action to clear the entire message queue is assigned to `cmd-alt-backspace`. Release Notes: - N/A
Danilo Leal created
aa4e94f
docs: Replace ellipsis with proper character (#47250)
Ultra nit PR to test some end-to-end PR creation workflow with AI. Release Notes: - N/A Co-authored-by: Claude Haiku 4.5 <noreply@anthropic.com>
Danilo Leal and Claude Haiku 4.5 created
ece66be
docs: Big reorganize (#45276)
Release Notes: - N/A Overview Restructures the documentation navigation to be organized by user goals rather than feature lists. Introduces a new "Working with Code" section and reorganizes existing content into clearer groupings. ### Navigation Changes **New top-level sections:** - **Working with Code** β Groups editing, navigation, and execution features by workflow - **Reference** β Dedicated section for lookup-only content (settings, actions, CLI) - **Coming From...** β Migration guides grouped together **Reorganized sections:** - **Customization** β Renamed from "Configuration," focused on appearance and keybindings - **Account & Privacy** β Consolidated auth, privacy, and telemetry pages New Files | File | Purpose | |------|---------| | `editing-code.md` | Overview page for editing features | | `finding-navigating.md` | Overview page for navigation tools with quick reference | | `running-testing.md` | Overview page for tasks, debugger, and REPL | | `reference/all-settings.md` | Settings reference (moved/renamed) | | `reference/cli.md` | CLI reference (moved) | ### Content Moves | Page | From | To | |------|------|-----| | Snippets | Customization | Working with Code β Editing Code | | Code Completions | (flat) | Working with Code β Editing Code | | Diagnostics | (flat) | Working with Code β Editing Code | | Multibuffers | (flat) | Working with Code β Editing Code | | Command Palette | (flat) | Working with Code β Finding & Navigating | | Outline Panel | (flat) | Working with Code β Finding & Navigating | | Tab Switcher | (flat) | Working with Code β Finding & Navigating | | Tasks | (flat) | Working with Code β Running & Testing | | Debugger | (flat) | Working with Code β Running & Testing | | REPL | (flat) | Working with Code β Running & Testing | | All Settings | Configuration | Reference | | CLI | (various) | Reference --------- Co-authored-by: Marshall Bowers <git@maxdeviant.com> Co-authored-by: Zed Zippy <234243425+zed-zippy[bot]@users.noreply.github.com>
Katie Geer , Marshall Bowers , and Zed Zippy created
9c3dc21
Use `anyOf` instead of `oneOf` in keymap schema (#47248)
Closes #ISSUE Resolves some spurious warnings we were seeing in the keymap file due to keybind declarations matching multiple possible shapes which is not allowed with `oneOf` per the json-schema spec Release Notes: - N/A *or* Added/Fixed/Improved ...
Ben Kunkle created
cd0b373
ep_cli: Add filter languages subcommand (#47242)
Closes #ISSUE Release Notes: - N/A *or* Added/Fixed/Improved ...
Ben Kunkle created
d630677
Fix config file watch task leak (#47246)
Follow-Up-For: #47243 Previously, we would detach tasks spawned to watch config files. However, the task blocked on receiving a file event before checking if the receiver for the updates channel was dropped, causing the task to never exit. The fix here was to return the task explicitly, so that it can be dropped instead of calling `.detach()` on it. There is definitely a way to `select!` between the receiver being dropped and the next file system event, but I couldn't figure it out in a reasonable amount of time and decided it wasn't worth it. Release Notes: - Fixed an issue where a few file descriptors would be leaked each time a project was closed
Ben Kunkle created
37185ea
ep_cli: Fix "Too many open files" errors (#47243)
Closes #ISSUE Release Notes: - N/A *or* Added/Fixed/Improved ...
Ben Kunkle created
2ccca66
agent_ui: Add support for editing queued messages (#47234)
This PR adds the ability to edit a queued message, which you can now do by hitting `cmd-e` from the message editor, which will focus the first queued message. To pull that off, I'm also making the queued messages render as an editor, the same way we do with regular user messages. That way, we ensure less layout shift when focusing in and out of the queued message for editing and gain the ability to render context buttons/creases the same way we do in the main message editor. https://github.com/user-attachments/assets/fb68fd48-c0cd-491f-a7d9-5065a9151b0b Note that in the video, I show the state in which you're still editing in the moment in which the queued message would be sent. If that happens, your queued message won't be sent even if you unfocus the queued message editor. In this case, you need to explicitly hit "Send Now". Release Notes: - Agent: Added the ability to edit queued messages.
Danilo Leal created
4731000
settings_ui: Remote project setting files support (#45292)
Closes #ISSUE Release Notes: - settings_ui: Added support for viewing and updating project settings files in remote projects --------- Co-authored-by: Mikayla <mikayla@zed.dev>
Ben Kunkle and Mikayla created
a0728db
Add --offset flag to ep cli (#47175)
Release Notes: - N/A --------- Co-authored-by: Ben Kunkle <ben@zed.dev>
Max Brunsfeld and Ben Kunkle created
a8bf82c
debugger: Fix crash when dragging pane items to split view (#46806)
## Summary Fixes crash when dragging debugger panel items (terminal/console/variables/frames) to another pane as split view. **Root causes:** 1. Double borrow panic - `pane_group.split()` was called synchronously inside a `Context<Pane>` update, causing "cannot update Pane while it is already being updated" 2. `unwrap()` calls that panic when items are in transition during drag operations 3. `debug_assert!` in `pane_at_pixel_position` fails when `members` and `bounding_boxes` are temporarily out of sync after deferred split **Fixes:** - Defer entire split+move operation via `cx.spawn_in()` to avoid double borrow - Replace `unwrap()` with graceful early returns in `activate_item` and `run_in_terminal` - Handle `members.len() != bounding_boxes.len()` gracefully in `pane_at_pixel_position` Closes #46784 Closes #ISSUE Release Notes: - N/A *or* Added/Fixed/Improved ... --------- Co-authored-by: Anthony Eid <anthony@zed.dev>
xcb3d and Anthony Eid created
9fce075
ep: Make --provider optional, skip prediction when results exist (#47225)
When --provider is not provided, `ep` will now use whatever provider is recorded in the data. Release Notes: - N/A
Oleksiy Syvokon created
8e48a16
Add `ep parse-output` command (#47220)
This command takes raw LLM outputs (`predictions.actual_output`) that could be generated elsewhere and parses them into a canonical unified diff (`predictions.actual_patch`). This is useful for simplifying the evaluation pipeline and for rerunning the parser without having to generate LLM outputs. Release Notes: - N/A
Oleksiy Syvokon created
8870bd9
acp: Allow installing ACP agents from the registry (#47218)
This is still behind a feature flag as the registry is still WIP, but allows downloading binary agents from the registry on github. Release Notes: - N/A
Ben Brandt created