
This PR adds **internal** ability to run arbitrary language servers via WebAssembly extensions. The functionality isn't exposed yet - we're just landing this in this early state because there have been a lot of changes to the `LspAdapter` trait, and other language server logic. ## Next steps * Currently, wasm extensions can only define how to *install* and run a language server, they can't yet implement the other LSP adapter methods, such as formatting completion labels and workspace symbols. * We don't have an automatic way to install or develop these types of extensions * We don't have a way to package these types of extensions in our extensions repo, to make them available via our extensions API. * The Rust extension API crate, `zed-extension-api` has not yet been published to crates.io, because we still consider the API a work in progress. Release Notes: - N/A --------- Co-authored-by: Marshall <marshall@zed.dev> Co-authored-by: Nathan <nathan@zed.dev> Co-authored-by: Marshall Bowers <elliott.codes@gmail.com>
66 lines
1.8 KiB
Rust
66 lines
1.8 KiB
Rust
use std::sync::Arc;
|
|
|
|
use call::Room;
|
|
use client::ChannelId;
|
|
use gpui::{Model, TestAppContext};
|
|
|
|
mod channel_buffer_tests;
|
|
mod channel_guest_tests;
|
|
mod channel_message_tests;
|
|
mod channel_tests;
|
|
mod editor_tests;
|
|
mod following_tests;
|
|
mod integration_tests;
|
|
mod notification_tests;
|
|
mod random_channel_buffer_tests;
|
|
mod random_project_collaboration_tests;
|
|
mod randomized_test_helpers;
|
|
mod test_server;
|
|
|
|
use language::{tree_sitter_rust, Language, LanguageConfig, LanguageMatcher};
|
|
pub use randomized_test_helpers::{
|
|
run_randomized_test, save_randomized_test_plan, RandomizedTest, TestError, UserTestPlan,
|
|
};
|
|
pub use test_server::{TestClient, TestServer};
|
|
|
|
#[derive(Debug, Eq, PartialEq)]
|
|
struct RoomParticipants {
|
|
remote: Vec<String>,
|
|
pending: Vec<String>,
|
|
}
|
|
|
|
fn room_participants(room: &Model<Room>, cx: &mut TestAppContext) -> RoomParticipants {
|
|
room.read_with(cx, |room, _| {
|
|
let mut remote = room
|
|
.remote_participants()
|
|
.iter()
|
|
.map(|(_, participant)| participant.user.github_login.clone())
|
|
.collect::<Vec<_>>();
|
|
let mut pending = room
|
|
.pending_participants()
|
|
.iter()
|
|
.map(|user| user.github_login.clone())
|
|
.collect::<Vec<_>>();
|
|
remote.sort();
|
|
pending.sort();
|
|
RoomParticipants { remote, pending }
|
|
})
|
|
}
|
|
|
|
fn channel_id(room: &Model<Room>, cx: &mut TestAppContext) -> Option<ChannelId> {
|
|
cx.read(|cx| room.read(cx).channel_id())
|
|
}
|
|
|
|
fn rust_lang() -> Arc<Language> {
|
|
Arc::new(Language::new(
|
|
LanguageConfig {
|
|
name: "Rust".into(),
|
|
matcher: LanguageMatcher {
|
|
path_suffixes: vec!["rs".to_string()],
|
|
..Default::default()
|
|
},
|
|
..Default::default()
|
|
},
|
|
Some(tree_sitter_rust::language()),
|
|
))
|
|
}
|