From 962bbcab4e0e7db9643e50410114c9802fa81c76 Mon Sep 17 00:00:00 2001 From: Erik Osterman Date: Tue, 15 Jan 2019 08:39:10 -0800 Subject: [PATCH] Support empty values (#8) * Support empty values * fix logic * Update example --- README.md | 6 ++++++ README.yaml | 6 ++++++ main.go | 16 +++++++++++++--- 3 files changed, 25 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index a2adfc0..b6509a9 100644 --- a/README.md +++ b/README.md @@ -107,6 +107,12 @@ Example `.envrc`: source <(tfenv) ``` +or... +```sh +# Export terraform environment +eval "$(tfenv)" +``` + ### Bash Load the terraform environment into your shell. diff --git a/README.yaml b/README.yaml index 730bf06..695923f 100644 --- a/README.yaml +++ b/README.yaml @@ -103,6 +103,12 @@ usage: |- source <(tfenv) ``` + or... + ```sh + # Export terraform environment + eval "$(tfenv)" + ``` + ### Bash Load the terraform environment into your shell. diff --git a/main.go b/main.go index 222516a..c030559 100644 --- a/main.go +++ b/main.go @@ -79,7 +79,10 @@ func main() { arg := strings.ToLower(match[1]) // Combine parameters into something like `-backend-config=role_arn=xxx` - arg = "-backend-config=" + arg + "=" + pair[1] + arg = "-backend-config=" + arg + if len(pair[1]) > 0 && pair[1] != "true" { + arg += "=" + pair[1] + } tfCliArgsInit = append(tfCliArgsInit, arg) } else if reTfCliCommand.MatchString(pair[0]) { // `TF_CLI_ARGS_plan`: Map `TF_CLI_PLAN_SOMETHING=value` to `-something=value` @@ -89,7 +92,11 @@ func main() { param := reUnderscores.ReplaceAllString(match[2], "-") param = strings.ToLower(param) - arg := "-" + param + "=" + pair[1] + arg := "-" + param + // Append non-empty parameters or non-true values. + if len(pair[1]) > 0 && pair[1] != "true" { + arg += "=" + pair[1] + } switch cmd { case "init": tfCliArgsInit = append(tfCliArgsInit, arg) @@ -105,7 +112,10 @@ func main() { match := reTfCliDefault.FindStringSubmatch(pair[0]) param := reUnderscores.ReplaceAllString(match[1], "-") param = strings.ToLower(param) - arg := "-" + param + "=" + pair[1] + arg := "-" + param + if len(pair[1]) > 0 && pair[1] != "true" { + arg += "=" + pair[1] + } tfCliArgs = append(tfCliArgs, arg) } else if !reBlacklist.MatchString(pair[0]) && reWhitelist.MatchString(pair[0]) { // Process the blacklist for exclusions, then the whitelist for inclusions