Skip to content

Commit

Permalink
Make rustup override and rust-toolchain.toml hierarchical
Browse files Browse the repository at this point in the history
  • Loading branch information
rami3l committed Oct 10, 2023
1 parent d6136e6 commit 3a6a343
Showing 1 changed file with 9 additions and 6 deletions.
15 changes: 9 additions & 6 deletions src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -580,14 +580,15 @@ impl Cfg {
dir: &Path,
settings: &Settings,
) -> Result<Option<(OverrideFile, OverrideReason)>> {
let mut override_ = None;

let notify = self.notify_handler.as_ref();
let mut dir = Some(dir);

while let Some(d) = dir {
for d in std::iter::successors(Some(dir), |d| d.parent()) {
// First check the override database
if let Some(name) = settings.dir_override(d, notify) {
let reason = OverrideReason::OverrideDB(d.to_owned());
return Ok(Some((name.into(), reason)));
update_override(&mut override_, name.into(), reason);
}

// Then look for 'rust-toolchain' or 'rust-toolchain.toml'
Expand Down Expand Up @@ -662,13 +663,15 @@ impl Cfg {
}

let reason = OverrideReason::ToolchainFile(toolchain_file);
return Ok(Some((override_file, reason)));
update_override(&mut override_, override_file, reason);
}

dir = d.parent();
if override_.is_some() {
break;
}
}

Ok(None)
Ok(override_)
}

fn parse_override_file<S: AsRef<str>>(
Expand Down

0 comments on commit 3a6a343

Please sign in to comment.