Merge pull request #537 from kindy/fix-expand-env

limit expand env to cmd pkg-config & llvm-config
This commit is contained in:
xushiwei
2024-07-19 09:39:42 +08:00
committed by GitHub

43
xtool/env/env.go vendored
View File

@@ -17,32 +17,49 @@
package env
import (
"fmt"
"os"
"os/exec"
"regexp"
"runtime"
"strings"
)
var (
reSubcmd = regexp.MustCompile(`\$\([^)]+\)`)
reFlag = regexp.MustCompile(`[^ \t\n]+`)
)
func ExpandEnv(s string) string {
return expandEnvWithCmd(s)
}
func expandEnvWithCmd(s string) string {
re := regexp.MustCompile(`\$\(([^)]+)\)`)
expanded := re.ReplaceAllStringFunc(s, func(m string) string {
cmd := re.FindStringSubmatch(m)[1]
var out []byte
var err error
if runtime.GOOS == "windows" {
out, err = exec.Command("cmd", "/C", cmd).Output()
} else {
out, err = exec.Command("sh", "-c", cmd).Output()
}
if err != nil {
expanded := reSubcmd.ReplaceAllStringFunc(s, func(m string) string {
subcmd := strings.TrimSpace(s[2 : len(s)-1])
args := parseSubcmd(subcmd)
cmd := args[0]
if cmd != "pkg-config" && cmd != "llvm-config" {
fmt.Fprintf(os.Stderr, "expand cmd only support pkg-config and llvm-config: '%s'\n", subcmd)
return ""
}
return strings.TrimSpace(string(out))
var out []byte
var err error
out, err = exec.Command(cmd, args[1:]...).Output()
if err != nil {
// TODO(kindy): log in verbose mode
return ""
}
return string(out)
})
return os.Expand(expanded, os.Getenv)
}
func parseSubcmd(s string) []string {
return reFlag.FindAllString(s, -1)
}