Skip to content

Commit

Permalink
fix: elixir installation failed
Browse files Browse the repository at this point in the history
  • Loading branch information
roele committed Jan 22, 2025
1 parent de703d8 commit f2f8d5f
Show file tree
Hide file tree
Showing 5 changed files with 47 additions and 5 deletions.
39 changes: 38 additions & 1 deletion src/backend/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,9 @@ use crate::plugins::{Plugin, PluginType, VERSION_REGEX};
use crate::registry::REGISTRY;
use crate::runtime_symlinks::is_runtime_symlink;
use crate::toolset::outdated_info::OutdatedInfo;
use crate::toolset::{install_state, is_outdated_version, ToolRequest, ToolVersion, Toolset};
use crate::toolset::{
install_state, is_outdated_version, ToolRequest, ToolSource, ToolVersion, Toolset,
};
use crate::ui::progress_report::SingleReport;
use crate::{dirs, env, file, hash, lock_file, plugins, versions_host};
use backend_type::BackendType;
Expand Down Expand Up @@ -588,6 +590,33 @@ pub trait Backend: Debug + Send + Sync {
Ok(ts)
}

fn dependency_toolset_with_ctx(&self, ctx: &InstallContext) -> eyre::Result<Toolset> {
let config = Config::get();
let dependencies: HashSet<String> = self
.get_all_dependencies(true)?
.into_iter()
.map(|ba| ba.short)
.collect();
let mut ts: Toolset = config
.get_tool_request_set()?
.filter_by_tool(dependencies.clone())
.into();
let tr_args = match &ctx.tr {
Some(tr) => tr
.into_iter()
.filter(|tr| dependencies.contains(&tr.ba().short))
.collect(),
None => vec![],
};
let mut ts_args = Toolset::new(ToolSource::Unknown);
for tr in tr_args {
ts_args.add_version(tr.clone());
}
ts.merge(ts_args);
ts.resolve()?;
Ok(ts)
}

fn dependency_which(&self, bin: &str) -> Option<PathBuf> {
file::which_non_pristine(bin).or_else(|| {
self.dependency_toolset()
Expand All @@ -603,6 +632,14 @@ pub trait Backend: Debug + Send + Sync {
self.dependency_toolset()?.full_env(&config)
}

fn dependency_env_with_ctx(
&self,
ctx: &InstallContext,
) -> eyre::Result<BTreeMap<String, String>> {
let config = Config::get();
self.dependency_toolset_with_ctx(ctx)?.full_env(&config)
}

fn fuzzy_match_filter(&self, versions: Vec<String>, query: &str) -> eyre::Result<Vec<String>> {
let escaped_query = regex::escape(query);
let query = if query == "latest" {
Expand Down
1 change: 1 addition & 0 deletions src/cli/install_into.rs
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ impl InstallInto {
let backend = tv.backend()?;
let mpr = MultiProgressReport::get();
let install_ctx = InstallContext {
tr: None,
ts: &ts,
pr: mpr.add(&tv.style()),
force: true,
Expand Down
3 changes: 2 additions & 1 deletion src/install_context.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
use crate::toolset::Toolset;
use crate::toolset::{ToolRequest, Toolset};
use crate::ui::progress_report::SingleReport;

pub struct InstallContext<'a> {
pub tr: Option<Vec<ToolRequest>>,
pub ts: &'a Toolset,
pub pr: Box<dyn SingleReport>,
pub force: bool,
Expand Down
2 changes: 1 addition & 1 deletion src/plugins/core/elixir.rs
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ impl ElixirPlugin {
ctx.pr.set_message("elixir --version".into());
CmdLineRunner::new(self.elixir_bin(tv))
.with_pr(&ctx.pr)
.envs(self.dependency_env()?)
.envs(self.dependency_env_with_ctx(&ctx)?)
.arg("--version")
.execute()
}
Expand Down
7 changes: 5 additions & 2 deletions src/toolset/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -235,14 +235,15 @@ impl Toolset {
hooks::run_one_hook(self, Hooks::Preinstall, None);
self.init_request_options(&mut versions);
show_python_install_hint(&versions);
let tool_request = versions.clone();
let mut installed = vec![];
let mut leaf_deps = get_leaf_dependencies(&versions)?;
while !leaf_deps.is_empty() {
if leaf_deps.len() < versions.len() {
debug!("installing {} leaf tools first", leaf_deps.len());
}
versions.retain(|tr| !leaf_deps.contains(tr));
installed.extend(self.install_some_versions(leaf_deps, mpr, opts)?);
installed.extend(self.install_some_versions(&tool_request, leaf_deps, mpr, opts)?);
leaf_deps = get_leaf_dependencies(&versions)?;
}

Expand Down Expand Up @@ -278,6 +279,7 @@ impl Toolset {

fn install_some_versions(
&mut self,
tool_request: &[ToolRequest],
versions: Vec<ToolRequest>,
mpr: &MultiProgressReport,
opts: &InstallOptions,
Expand Down Expand Up @@ -319,9 +321,10 @@ impl Toolset {
let next_job = || queue.lock().unwrap().pop();
let mut installed = vec![];
while let Some((t, versions)) = next_job() {
for tr in versions {
for tr in versions.clone() {
let tv = tr.resolve(&opts.resolve_options)?;
let ctx = InstallContext {
tr: Some(tool_request.to_owned()),
ts,
pr: mpr.add(&tv.style()),
force: opts.force,
Expand Down

0 comments on commit f2f8d5f

Please sign in to comment.