elvish/pkg/eval/builtin_fn_env.go

120 lines
2.3 KiB
Go

package eval
import (
"errors"
"os"
)
// ErrNonExistentEnvVar is raised by the get-env command when the environment
// variable does not exist.
var ErrNonExistentEnvVar = errors.New("non-existent environment variable")
//elvdoc:fn set-env
//
// ```elvish
// set-env $name $value
// ```
//
// Sets an environment variable to the given value. Calling `set-env VAR_NAME
// value` is similar to `set E:VAR_NAME = value`, but allows the variable name
// to be dynamic.
//
// Example:
//
// ```elvish-transcript
// ~> set-env X foobar
// ~> put $E:X
// ▶ foobar
// ```
//
// @cf get-env has-env unset-env
//elvdoc:fn unset-env
//
// ```elvish
// unset-env $name
// ```
//
// Unset an environment variable. Calling `unset-env VAR_NAME` is similar to
// `del E:VAR_NAME`, but allows the variable name to be dynamic.
//
// Example:
//
// ```elvish-transcript
// ~> set E:X = foo
// ~> unset-env X
// ~> has-env X
// ▶ $false
// ~> put $E:X
// ▶ ''
// ```
//
// @cf has-env get-env set-env
func init() {
addBuiltinFns(map[string]any{
"has-env": hasEnv,
"get-env": getEnv,
"set-env": os.Setenv,
"unset-env": os.Unsetenv,
})
}
//elvdoc:fn has-env
//
// ```elvish
// has-env $name
// ```
//
// Test whether an environment variable exists. This command has no equivalent
// operation using the `E:` namespace (but see https://b.elv.sh/1026).
//
// Examples:
//
// ```elvish-transcript
// ~> has-env PATH
// ▶ $true
// ~> has-env NO_SUCH_ENV
// ▶ $false
// ```
//
// @cf get-env set-env unset-env
func hasEnv(key string) bool {
_, ok := os.LookupEnv(key)
return ok
}
//elvdoc:fn get-env
//
// ```elvish
// get-env $name
// ```
//
// Gets the value of an environment variable. Throws an exception if the
// environment variable does not exist.
//
// Calling `get-env VAR_NAME` is similar to `put $E:VAR_NAME`, but allows the
// variable name to be dynamic, and throws an exception instead of producing an
// empty string for nonexistent environment variables.
//
// Examples:
//
// ```elvish-transcript
// ~> get-env LANG
// ▶ zh_CN.UTF-8
// ~> get-env NO_SUCH_ENV
// Exception: non-existent environment variable
// [tty], line 1: get-env NO_SUCH_ENV
// ```
//
// @cf has-env set-env unset-env
func getEnv(key string) (string, error) {
value, ok := os.LookupEnv(key)
if !ok {
return "", ErrNonExistentEnvVar
}
return value, nil
}