settings.rs

 1//! Provides access to Zed settings.
 2
 3#[path = "../wit/since_v0.2.0/settings.rs"]
 4mod types;
 5
 6use crate::{Project, Result, SettingsLocation, Worktree, wit};
 7use serde_json;
 8pub use types::*;
 9
10impl LanguageSettings {
11    /// Returns the [`LanguageSettings`] for the given language.
12    pub fn for_worktree(language: Option<&str>, worktree: &Worktree) -> Result<Self> {
13        get_settings("language", language, Some(worktree.id()))
14    }
15}
16
17impl LspSettings {
18    /// Returns the [`LspSettings`] for the given language server.
19    pub fn for_worktree(language_server_name: &str, worktree: &Worktree) -> Result<Self> {
20        get_settings("lsp", Some(language_server_name), Some(worktree.id()))
21    }
22}
23
24impl ContextServerSettings {
25    /// Returns the [`ContextServerSettings`] for the given context server.
26    pub fn for_project(context_server_id: &str, project: &Project) -> Result<Self> {
27        let global_setting: Self = get_settings("context_servers", Some(context_server_id), None)?;
28
29        for worktree_id in project.worktree_ids() {
30            let settings = get_settings(
31                "context_servers",
32                Some(context_server_id),
33                Some(worktree_id),
34            )?;
35            if settings != global_setting {
36                return Ok(settings);
37            }
38        }
39
40        Ok(global_setting)
41    }
42}
43
44fn get_settings<T: serde::de::DeserializeOwned>(
45    settings_type: &str,
46    settings_name: Option<&str>,
47    worktree_id: Option<u64>,
48) -> Result<T> {
49    let location = worktree_id.map(|worktree_id| SettingsLocation {
50        worktree_id,
51        path: String::new(),
52    });
53    let settings_json = wit::get_settings(location.as_ref(), settings_type, settings_name)?;
54    let settings: T = serde_json::from_str(&settings_json).map_err(|err| err.to_string())?;
55    Ok(settings)
56}