From f5c2184858a38b3ce9efa94a5ee3250f33df33c1 Mon Sep 17 00:00:00 2001 From: lihan Date: Mon, 29 Apr 2024 14:58:26 +0800 Subject: [PATCH] fix: adjust .tool-versions behavior The current vfox strategy is that if we have a .tool-version in the project (project/.tool-versions), that version will be used in the current shell, regardless of whether you switch directories or not, the version is not changed until the next .tool-versions file is encountered, or vfox use command is executed manually. fix #228 --- cmd/commands/env.go | 20 +++++++++++++++----- 1 file changed, 15 insertions(+), 5 deletions(-) diff --git a/cmd/commands/env.go b/cmd/commands/env.go index fe30f9a9..22d9c376 100644 --- a/cmd/commands/env.go +++ b/cmd/commands/env.go @@ -166,15 +166,25 @@ func aggregateEnvKeys(manager *internal.Manager) (*env.Envs, error) { }); err != nil { return nil, err } - tvs, err := toolset.NewMultiToolVersions([]string{ - manager.PathMeta.CurTmpPath, - manager.PathMeta.HomePath, - }) + + curToolVersion, err := toolset.NewToolVersion(manager.PathMeta.CurTmpPath) if err != nil { return nil, err } + // If we encounter a .tool-versions file, it is valid for the entire shell session, + // unless we encounter the next .tool-versions file or manually switch to the use command. + for k, v := range workToolVersion.Record { + curToolVersion.Record[k] = v + } + _ = curToolVersion.Save() + + homeToolVersion, err := toolset.NewToolVersion(manager.PathMeta.HomePath) + if err != nil { + return nil, err + } + // Add the working directory to the first - tvs = append(toolset.MultiToolVersions{workToolVersion}, tvs...) + tvs := append(toolset.MultiToolVersions{}, workToolVersion, curToolVersion, homeToolVersion) return manager.EnvKeys(tvs) }