mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 21:54:42 +00:00
Merge #5457
5457: Simplify r=matklad a=matklad
bors r+
🤖
Co-authored-by: Aleksey Kladov <aleksey.kladov@gmail.com>
This commit is contained in:
commit
7a089a7bab
2 changed files with 41 additions and 33 deletions
|
@ -34,6 +34,7 @@ pub struct Crate {
|
|||
pub(crate) target: Option<String>,
|
||||
pub(crate) out_dir: Option<AbsPathBuf>,
|
||||
pub(crate) proc_macro_dylib_path: Option<AbsPathBuf>,
|
||||
pub(crate) is_workspace_member: bool,
|
||||
}
|
||||
|
||||
impl ProjectJson {
|
||||
|
@ -43,32 +44,42 @@ impl ProjectJson {
|
|||
crates: data
|
||||
.crates
|
||||
.into_iter()
|
||||
.map(|crate_data| Crate {
|
||||
root_module: base.join(crate_data.root_module),
|
||||
edition: crate_data.edition.into(),
|
||||
deps: crate_data
|
||||
.deps
|
||||
.into_iter()
|
||||
.map(|dep_data| Dependency {
|
||||
crate_id: CrateId(dep_data.krate as u32),
|
||||
name: dep_data.name,
|
||||
})
|
||||
.collect::<Vec<_>>(),
|
||||
cfg: {
|
||||
let mut cfg = CfgOptions::default();
|
||||
for entry in &crate_data.cfg {
|
||||
match split_delim(entry, '=') {
|
||||
Some((key, value)) => {
|
||||
cfg.insert_key_value(key.into(), value.into());
|
||||
.map(|crate_data| {
|
||||
let is_workspace_member = crate_data.is_workspace_member.unwrap_or_else(|| {
|
||||
crate_data.root_module.is_relative()
|
||||
&& !crate_data.root_module.starts_with("..")
|
||||
|| crate_data.root_module.starts_with(base)
|
||||
});
|
||||
Crate {
|
||||
root_module: base.join(crate_data.root_module),
|
||||
edition: crate_data.edition.into(),
|
||||
deps: crate_data
|
||||
.deps
|
||||
.into_iter()
|
||||
.map(|dep_data| Dependency {
|
||||
crate_id: CrateId(dep_data.krate as u32),
|
||||
name: dep_data.name,
|
||||
})
|
||||
.collect::<Vec<_>>(),
|
||||
cfg: {
|
||||
let mut cfg = CfgOptions::default();
|
||||
for entry in &crate_data.cfg {
|
||||
match split_delim(entry, '=') {
|
||||
Some((key, value)) => {
|
||||
cfg.insert_key_value(key.into(), value.into());
|
||||
}
|
||||
None => cfg.insert_atom(entry.into()),
|
||||
}
|
||||
None => cfg.insert_atom(entry.into()),
|
||||
}
|
||||
}
|
||||
cfg
|
||||
},
|
||||
target: crate_data.target,
|
||||
out_dir: crate_data.out_dir.map(|it| base.join(it)),
|
||||
proc_macro_dylib_path: crate_data.proc_macro_dylib_path.map(|it| base.join(it)),
|
||||
cfg
|
||||
},
|
||||
target: crate_data.target,
|
||||
out_dir: crate_data.out_dir.map(|it| base.join(it)),
|
||||
proc_macro_dylib_path: crate_data
|
||||
.proc_macro_dylib_path
|
||||
.map(|it| base.join(it)),
|
||||
is_workspace_member,
|
||||
}
|
||||
})
|
||||
.collect::<Vec<_>>(),
|
||||
}
|
||||
|
@ -91,6 +102,7 @@ struct CrateData {
|
|||
target: Option<String>,
|
||||
out_dir: Option<PathBuf>,
|
||||
proc_macro_dylib_path: Option<PathBuf>,
|
||||
is_workspace_member: Option<bool>,
|
||||
}
|
||||
|
||||
#[derive(Deserialize)]
|
||||
|
|
|
@ -83,11 +83,11 @@ impl Directories {
|
|||
self.includes_path(path)
|
||||
}
|
||||
fn includes_path(&self, path: &AbsPath) -> bool {
|
||||
let mut include = None;
|
||||
let mut include: Option<&AbsPathBuf> = None;
|
||||
for incl in &self.include {
|
||||
if is_prefix(incl, path) {
|
||||
if path.starts_with(incl) {
|
||||
include = Some(match include {
|
||||
Some(prev) if is_prefix(incl, prev) => prev,
|
||||
Some(prev) if prev.starts_with(incl) => prev,
|
||||
_ => incl,
|
||||
})
|
||||
}
|
||||
|
@ -97,15 +97,11 @@ impl Directories {
|
|||
None => return false,
|
||||
};
|
||||
for excl in &self.exclude {
|
||||
if is_prefix(excl, path) && is_prefix(include, excl) {
|
||||
if path.starts_with(excl) && excl.starts_with(include) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
|
||||
fn is_prefix(short: &AbsPath, long: &AbsPath) -> bool {
|
||||
long.strip_prefix(short).is_some()
|
||||
}
|
||||
true
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue