5457: Simplify r=matklad a=matklad



bors r+
🤖

Co-authored-by: Aleksey Kladov <aleksey.kladov@gmail.com>
This commit is contained in:
bors[bot] 2020-07-20 16:13:18 +00:00 committed by GitHub
commit 7a089a7bab
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 41 additions and 33 deletions

View file

@ -34,6 +34,7 @@ pub struct Crate {
pub(crate) target: Option<String>, pub(crate) target: Option<String>,
pub(crate) out_dir: Option<AbsPathBuf>, pub(crate) out_dir: Option<AbsPathBuf>,
pub(crate) proc_macro_dylib_path: Option<AbsPathBuf>, pub(crate) proc_macro_dylib_path: Option<AbsPathBuf>,
pub(crate) is_workspace_member: bool,
} }
impl ProjectJson { impl ProjectJson {
@ -43,32 +44,42 @@ impl ProjectJson {
crates: data crates: data
.crates .crates
.into_iter() .into_iter()
.map(|crate_data| Crate { .map(|crate_data| {
root_module: base.join(crate_data.root_module), let is_workspace_member = crate_data.is_workspace_member.unwrap_or_else(|| {
edition: crate_data.edition.into(), crate_data.root_module.is_relative()
deps: crate_data && !crate_data.root_module.starts_with("..")
.deps || crate_data.root_module.starts_with(base)
.into_iter() });
.map(|dep_data| Dependency { Crate {
crate_id: CrateId(dep_data.krate as u32), root_module: base.join(crate_data.root_module),
name: dep_data.name, edition: crate_data.edition.into(),
}) deps: crate_data
.collect::<Vec<_>>(), .deps
cfg: { .into_iter()
let mut cfg = CfgOptions::default(); .map(|dep_data| Dependency {
for entry in &crate_data.cfg { crate_id: CrateId(dep_data.krate as u32),
match split_delim(entry, '=') { name: dep_data.name,
Some((key, value)) => { })
cfg.insert_key_value(key.into(), value.into()); .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
cfg },
}, target: crate_data.target,
target: crate_data.target, out_dir: crate_data.out_dir.map(|it| base.join(it)),
out_dir: crate_data.out_dir.map(|it| base.join(it)), proc_macro_dylib_path: crate_data
proc_macro_dylib_path: crate_data.proc_macro_dylib_path.map(|it| base.join(it)), .proc_macro_dylib_path
.map(|it| base.join(it)),
is_workspace_member,
}
}) })
.collect::<Vec<_>>(), .collect::<Vec<_>>(),
} }
@ -91,6 +102,7 @@ struct CrateData {
target: Option<String>, target: Option<String>,
out_dir: Option<PathBuf>, out_dir: Option<PathBuf>,
proc_macro_dylib_path: Option<PathBuf>, proc_macro_dylib_path: Option<PathBuf>,
is_workspace_member: Option<bool>,
} }
#[derive(Deserialize)] #[derive(Deserialize)]

View file

@ -83,11 +83,11 @@ impl Directories {
self.includes_path(path) self.includes_path(path)
} }
fn includes_path(&self, path: &AbsPath) -> bool { fn includes_path(&self, path: &AbsPath) -> bool {
let mut include = None; let mut include: Option<&AbsPathBuf> = None;
for incl in &self.include { for incl in &self.include {
if is_prefix(incl, path) { if path.starts_with(incl) {
include = Some(match include { include = Some(match include {
Some(prev) if is_prefix(incl, prev) => prev, Some(prev) if prev.starts_with(incl) => prev,
_ => incl, _ => incl,
}) })
} }
@ -97,15 +97,11 @@ impl Directories {
None => return false, None => return false,
}; };
for excl in &self.exclude { 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 false;
} }
} }
return true; true
fn is_prefix(short: &AbsPath, long: &AbsPath) -> bool {
long.strip_prefix(short).is_some()
}
} }
} }