From 10efe20d7d3884a4b7d1825790b3a4d57ed0e431 Mon Sep 17 00:00:00 2001 From: mitchell Date: Wed, 28 Aug 2024 15:30:11 -0400 Subject: [PATCH] `state exec` should also search "Path" for exes on Windows. Our runtime.json files use PATH, but Windows uses Path. Workaround this for now. --- internal/runners/exec/exec.go | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/internal/runners/exec/exec.go b/internal/runners/exec/exec.go index 6a307f232d..6ddca60d0a 100644 --- a/internal/runners/exec/exec.go +++ b/internal/runners/exec/exec.go @@ -5,6 +5,7 @@ import ( "os" "os/exec" "path/filepath" + "runtime" "strconv" "strings" @@ -31,7 +32,7 @@ import ( "github.com/ActiveState/cli/pkg/platform/model" "github.com/ActiveState/cli/pkg/project" "github.com/ActiveState/cli/pkg/projectfile" - "github.com/ActiveState/cli/pkg/runtime" + rt "github.com/ActiveState/cli/pkg/runtime" ) type Configurable interface { @@ -98,7 +99,7 @@ func (s *Exec) Run(params *Params, args ...string) (rerr error) { // If the path passed resolves to a runtime dir (ie. has a runtime marker) then the project is not used var proj *project.Project var err error - if params.Path != "" && runtime.IsRuntimeDir(params.Path) { + if params.Path != "" && rt.IsRuntimeDir(params.Path) { projectDir = projectFromRuntimeDir(s.cfg, params.Path) proj, err = project.FromPath(projectDir) if err != nil { @@ -145,14 +146,18 @@ func (s *Exec) Run(params *Params, args ...string) (rerr error) { if !fileutils.TargetExists(exeTarget) { // Report recursive execution of executor: The path for the executable should be different from the default bin dir - exesOnPath := osutils.FilterExesOnPATH(exeTarget, env["PATH"], func(exe string) bool { + filter := func(exe string) bool { v, err := executors.IsExecutor(exe) if err != nil { logging.Error("Could not find out if executable is an executor: %s", errs.JoinMessage(err)) return true // This usually means there's a permission issue, which means we likely don't own it } return !v - }) + } + exesOnPath := osutils.FilterExesOnPATH(exeTarget, env["PATH"], filter) + if runtime.GOOS == "windows" { + exesOnPath = append(exesOnPath, osutils.FilterExesOnPATH(exeTarget, env["Path"], filter)...) + } if len(exesOnPath) > 0 { exeTarget = exesOnPath[0]