Add vendor directory and update vendorHash to null
This commit is contained in:
parent
523831cb8d
commit
1e5424c844
778 changed files with 407919 additions and 1 deletions
53
vendor/github.com/mfridman/interpolate/env.go
generated
vendored
Normal file
53
vendor/github.com/mfridman/interpolate/env.go
generated
vendored
Normal file
|
|
@ -0,0 +1,53 @@
|
|||
package interpolate
|
||||
|
||||
import (
|
||||
"runtime"
|
||||
"strings"
|
||||
)
|
||||
|
||||
// Env is an interface for getting environment variables by name and returning a boolean indicating
|
||||
// whether the variable was found.
|
||||
type Env interface {
|
||||
Get(key string) (string, bool)
|
||||
}
|
||||
|
||||
// NewSliceEnv creates an Env from a slice of environment variables in the form "key=value".
|
||||
//
|
||||
// This can be used with [os.Environ] to create an Env.
|
||||
func NewSliceEnv(env []string) Env {
|
||||
envMap := mapEnv{}
|
||||
for _, l := range env {
|
||||
parts := strings.SplitN(l, "=", 2)
|
||||
if len(parts) == 2 {
|
||||
envMap[normalizeKeyName(parts[0])] = parts[1]
|
||||
}
|
||||
}
|
||||
return envMap
|
||||
}
|
||||
|
||||
// NewMapEnv creates an Env from a map of environment variables.
|
||||
func NewMapEnv(env map[string]string) Env {
|
||||
envMap := mapEnv{}
|
||||
for k, v := range env {
|
||||
envMap[normalizeKeyName(k)] = v
|
||||
}
|
||||
return envMap
|
||||
}
|
||||
|
||||
type mapEnv map[string]string
|
||||
|
||||
func (m mapEnv) Get(key string) (string, bool) {
|
||||
if m == nil {
|
||||
return "", false
|
||||
}
|
||||
val, ok := m[normalizeKeyName(key)]
|
||||
return val, ok
|
||||
}
|
||||
|
||||
// Windows isn't case sensitive for env
|
||||
func normalizeKeyName(key string) string {
|
||||
if runtime.GOOS == "windows" {
|
||||
return strings.ToUpper(key)
|
||||
}
|
||||
return key
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue