mirror of
https://github.com/zed-industries/zed.git
synced 2024-11-10 05:37:29 +03:00
268fa1cbaf
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>
81 lines
2.2 KiB
Plaintext
81 lines
2.2 KiB
Plaintext
package zed:extension;
|
|
|
|
world extension {
|
|
export init-extension: func();
|
|
|
|
record github-release {
|
|
version: string,
|
|
assets: list<github-release-asset>,
|
|
}
|
|
|
|
record github-release-asset {
|
|
name: string,
|
|
download-url: string,
|
|
}
|
|
|
|
record github-release-options {
|
|
require-assets: bool,
|
|
pre-release: bool,
|
|
}
|
|
|
|
enum os {
|
|
mac,
|
|
linux,
|
|
windows,
|
|
}
|
|
|
|
enum architecture {
|
|
aarch64,
|
|
x86,
|
|
x8664,
|
|
}
|
|
|
|
enum downloaded-file-type {
|
|
gzip,
|
|
gzip-tar,
|
|
zip,
|
|
uncompressed,
|
|
}
|
|
|
|
variant language-server-installation-status {
|
|
checking-for-update,
|
|
downloaded,
|
|
downloading,
|
|
cached,
|
|
failed(string),
|
|
}
|
|
|
|
/// Gets the current operating system and architecture
|
|
import current-platform: func() -> tuple<os, architecture>;
|
|
|
|
/// Gets the latest version of the given NPM package.
|
|
import npm-package-latest-version: func(package-name: string) -> result<string, string>;
|
|
|
|
/// Gets the latest release for the given GitHub repository.
|
|
import latest-github-release: func(repo: string, options: github-release-options) -> result<github-release, string>;
|
|
|
|
/// Downloads a file from the given url, and saves it to the given filename within the extension's
|
|
/// working directory. Extracts the file according to the given file type.
|
|
import download-file: func(url: string, output-filename: string, file-type: downloaded-file-type) -> result<_, string>;
|
|
|
|
/// Updates the installation status for the given language server.
|
|
import set-language-server-installation-status: func(language-server-name: string, status: language-server-installation-status);
|
|
|
|
record command {
|
|
command: string,
|
|
args: list<string>,
|
|
env: list<tuple<string, string>>,
|
|
}
|
|
|
|
resource worktree {
|
|
read-text-file: func(path: string) -> result<string, string>;
|
|
}
|
|
|
|
record language-server-config {
|
|
name: string,
|
|
language-name: string,
|
|
}
|
|
|
|
export language-server-command: func(config: language-server-config, worktree: borrow<worktree>) -> result<command, string>;
|
|
}
|