mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-27 20:35:09 +00:00
Add config for proc_macro
This commit is contained in:
parent
22e33f308a
commit
a4b0ce07f8
5 changed files with 22 additions and 1 deletions
|
@ -70,7 +70,7 @@ pub(crate) fn load_cargo(
|
||||||
})
|
})
|
||||||
.collect::<FxHashMap<_, _>>();
|
.collect::<FxHashMap<_, _>>();
|
||||||
|
|
||||||
let proc_macro_client = if with_proc_macro {
|
let proc_macro_client = if !with_proc_macro {
|
||||||
ProcMacroClient::dummy()
|
ProcMacroClient::dummy()
|
||||||
} else {
|
} else {
|
||||||
ProcMacroClient::extern_process(Path::new("ra_proc_macro_srv")).unwrap()
|
ProcMacroClient::extern_process(Path::new("ra_proc_macro_srv")).unwrap()
|
||||||
|
|
|
@ -131,6 +131,14 @@ impl Config {
|
||||||
set(value, "/cargo/allFeatures", &mut self.cargo.all_features);
|
set(value, "/cargo/allFeatures", &mut self.cargo.all_features);
|
||||||
set(value, "/cargo/features", &mut self.cargo.features);
|
set(value, "/cargo/features", &mut self.cargo.features);
|
||||||
set(value, "/cargo/loadOutDirsFromCheck", &mut self.cargo.load_out_dirs_from_check);
|
set(value, "/cargo/loadOutDirsFromCheck", &mut self.cargo.load_out_dirs_from_check);
|
||||||
|
|
||||||
|
match get::<bool>(value, "/procMacro/enabled") {
|
||||||
|
Some(true) => {
|
||||||
|
set(value, "/procMacro/serverPath", &mut self.proc_macro_srv);
|
||||||
|
}
|
||||||
|
_ => self.proc_macro_srv = None,
|
||||||
|
}
|
||||||
|
|
||||||
match get::<Vec<String>>(value, "/rustfmt/overrideCommand") {
|
match get::<Vec<String>>(value, "/rustfmt/overrideCommand") {
|
||||||
Some(mut args) if !args.is_empty() => {
|
Some(mut args) if !args.is_empty() => {
|
||||||
let command = args.remove(0);
|
let command = args.remove(0);
|
||||||
|
|
|
@ -64,6 +64,7 @@ pub struct WorldState {
|
||||||
pub latest_requests: Arc<RwLock<LatestRequests>>,
|
pub latest_requests: Arc<RwLock<LatestRequests>>,
|
||||||
pub flycheck: Option<Flycheck>,
|
pub flycheck: Option<Flycheck>,
|
||||||
pub diagnostics: DiagnosticCollection,
|
pub diagnostics: DiagnosticCollection,
|
||||||
|
pub proc_macro_client: ProcMacroClient,
|
||||||
}
|
}
|
||||||
|
|
||||||
/// An immutable snapshot of the world's state at a point in time.
|
/// An immutable snapshot of the world's state at a point in time.
|
||||||
|
@ -192,6 +193,7 @@ impl WorldState {
|
||||||
latest_requests: Default::default(),
|
latest_requests: Default::default(),
|
||||||
flycheck,
|
flycheck,
|
||||||
diagnostics: Default::default(),
|
diagnostics: Default::default(),
|
||||||
|
proc_macro_client,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -388,6 +388,16 @@
|
||||||
"description": "Enable logging of VS Code extensions itself",
|
"description": "Enable logging of VS Code extensions itself",
|
||||||
"type": "boolean",
|
"type": "boolean",
|
||||||
"default": false
|
"default": false
|
||||||
|
},
|
||||||
|
"rust-analyzer.procMacro.enabled": {
|
||||||
|
"description": "Enable Proc macro support, cargo.loadOutDirsFromCheck must be enabled.",
|
||||||
|
"type": "boolean",
|
||||||
|
"default": false
|
||||||
|
},
|
||||||
|
"rust-analyzer.procMacro.serverPath": {
|
||||||
|
"description": "Proc macro server path",
|
||||||
|
"type": "string",
|
||||||
|
"default": "ra_proc_macro_srv"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
@ -12,6 +12,7 @@ export class Config {
|
||||||
private readonly requiresReloadOpts = [
|
private readonly requiresReloadOpts = [
|
||||||
"serverPath",
|
"serverPath",
|
||||||
"cargo",
|
"cargo",
|
||||||
|
"procMacro",
|
||||||
"files",
|
"files",
|
||||||
"highlighting",
|
"highlighting",
|
||||||
"updates.channel",
|
"updates.channel",
|
||||||
|
|
Loading…
Reference in a new issue