html: Bump to 0.1.1 (#12093)

Moves to using the npm package as installation method.

Release Notes:

- N/A
This commit is contained in:
Piotr Osiewicz 2024-05-21 18:36:47 +02:00 committed by GitHub
parent 14436a75b1
commit 0563472832
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 46 additions and 59 deletions

2
Cargo.lock generated
View file

@ -13208,7 +13208,7 @@ dependencies = [
[[package]] [[package]]
name = "zed_html" name = "zed_html"
version = "0.1.0" version = "0.1.1"
dependencies = [ dependencies = [
"zed_extension_api 0.0.6 (registry+https://github.com/rust-lang/crates.io-index)", "zed_extension_api 0.0.6 (registry+https://github.com/rust-lang/crates.io-index)",
] ]

View file

@ -1,6 +1,6 @@
[package] [package]
name = "zed_html" name = "zed_html"
version = "0.1.0" version = "0.1.1"
edition = "2021" edition = "2021"
publish = false publish = false
license = "Apache-2.0" license = "Apache-2.0"

View file

@ -1,7 +1,7 @@
id = "html" id = "html"
name = "HTML" name = "HTML"
description = "HTML support." description = "HTML support."
version = "0.1.0" version = "0.1.1"
schema_version = 1 schema_version = 1
authors = ["Isaac Clayton <slightknack@gmail.com>"] authors = ["Isaac Clayton <slightknack@gmail.com>"]
repository = "https://github.com/zed-industries/zed" repository = "https://github.com/zed-industries/zed"

View file

@ -1,94 +1,80 @@
use crate::zed::settings::LspSettings; use std::{env, fs};
use std::{env, fs, path::PathBuf}; use zed::settings::LspSettings;
use zed_extension_api::{self as zed, Result}; use zed_extension_api::{self as zed, LanguageServerId, Result};
const PACKAGE_NAME: &str = "vscode-language-server"; const SERVER_PATH: &str =
"node_modules/@zed-industries/vscode-langservers-extracted/bin/vscode-html-language-server";
const PACKAGE_NAME: &str = "@zed-industries/vscode-langservers-extracted";
struct HtmlExtension { struct HtmlExtension {
path: Option<PathBuf>, did_find_server: bool,
} }
impl HtmlExtension { impl HtmlExtension {
fn server_script_path(&self, language_server_id: &zed::LanguageServerId) -> Result<PathBuf> { fn server_exists(&self) -> bool {
if let Some(path) = self.path.as_ref() { fs::metadata(SERVER_PATH).map_or(false, |stat| stat.is_file())
if fs::metadata(path).map_or(false, |stat| stat.is_dir()) { }
return Ok(path.clone());
} fn server_script_path(&mut self, language_server_id: &LanguageServerId) -> Result<String> {
let server_exists = self.server_exists();
if self.did_find_server && server_exists {
return Ok(SERVER_PATH.to_string());
} }
zed::set_language_server_installation_status( zed::set_language_server_installation_status(
language_server_id, language_server_id,
&zed::LanguageServerInstallationStatus::CheckingForUpdate, &zed::LanguageServerInstallationStatus::CheckingForUpdate,
); );
let release = zed::latest_github_release( let version = zed::npm_package_latest_version(PACKAGE_NAME)?;
"zed-industries/vscode-langservers-extracted",
zed::GithubReleaseOptions {
require_assets: true,
pre_release: false,
},
)?;
let asset_name = "vscode-language-server.tar.gz"; if !server_exists
|| zed::npm_package_installed_version(PACKAGE_NAME)?.as_ref() != Some(&version)
let asset = release {
.assets
.iter()
.find(|asset| asset.name == asset_name)
.ok_or_else(|| format!("no asset found matching {:?}", asset_name))?;
let version_dir = format!("{}-{}", PACKAGE_NAME, release.version);
if !fs::metadata(&version_dir).map_or(false, |stat| stat.is_dir()) {
zed::set_language_server_installation_status( zed::set_language_server_installation_status(
&language_server_id, &language_server_id,
&zed::LanguageServerInstallationStatus::Downloading, &zed::LanguageServerInstallationStatus::Downloading,
); );
let result = zed::npm_install_package(PACKAGE_NAME, &version);
zed::download_file( match result {
&asset.download_url, Ok(()) => {
&version_dir, if !self.server_exists() {
zed::DownloadedFileType::GzipTar, Err(format!(
) "installed package '{PACKAGE_NAME}' did not contain expected path '{SERVER_PATH}'",
.map_err(|e| format!("failed to download file: {e}"))?; ))?;
}
let entries = }
fs::read_dir(".").map_err(|e| format!("failed to list working directory {e}"))?; Err(error) => {
for entry in entries { if !self.server_exists() {
let entry = entry.map_err(|e| format!("failed to load directory entry {e}"))?; Err(error)?;
if entry.file_name().to_str() != Some(&version_dir) { }
fs::remove_dir_all(&entry.path()).ok();
} }
} }
} }
Ok(PathBuf::from(version_dir)
.join("bin") self.did_find_server = true;
.join("vscode-html-language-server")) Ok(SERVER_PATH.to_string())
} }
} }
impl zed::Extension for HtmlExtension { impl zed::Extension for HtmlExtension {
fn new() -> Self { fn new() -> Self {
Self { path: None } Self {
did_find_server: false,
}
} }
fn language_server_command( fn language_server_command(
&mut self, &mut self,
language_server_id: &zed::LanguageServerId, language_server_id: &LanguageServerId,
_worktree: &zed::Worktree, _worktree: &zed::Worktree,
) -> Result<zed::Command> { ) -> Result<zed::Command> {
let path = match &self.path { let server_path = self.server_script_path(language_server_id)?;
Some(path) => path,
None => {
let path = self.server_script_path(language_server_id)?;
self.path = Some(path);
self.path.as_ref().unwrap()
}
};
Ok(zed::Command { Ok(zed::Command {
command: zed::node_binary_path()?, command: zed::node_binary_path()?,
args: vec![ args: vec![
env::current_dir() env::current_dir()
.unwrap() .unwrap()
.join(path) .join(&server_path)
.to_string_lossy() .to_string_lossy()
.to_string(), .to_string(),
"--stdio".to_string(), "--stdio".to_string(),
@ -96,9 +82,10 @@ impl zed::Extension for HtmlExtension {
env: Default::default(), env: Default::default(),
}) })
} }
fn language_server_workspace_configuration( fn language_server_workspace_configuration(
&mut self, &mut self,
server_id: &zed::LanguageServerId, server_id: &LanguageServerId,
worktree: &zed::Worktree, worktree: &zed::Worktree,
) -> Result<Option<zed::serde_json::Value>> { ) -> Result<Option<zed::serde_json::Value>> {
let settings = LspSettings::for_worktree(server_id.as_ref(), worktree) let settings = LspSettings::for_worktree(server_id.as_ref(), worktree)