Skip to content

Commit

Permalink
Allow spaces in envvar values
Browse files Browse the repository at this point in the history
`strings.Fields` will split on any space, including space inside
environment variable values. This precludes the reasonable use of such
values.

Now, define a func (`isNewLine`) and use `strings.FieldsFunc` to split
explicitly on newlines. Update tests to demonstrate fix.

Reported and proposed by @jklukas in #4.
  • Loading branch information
whilp committed Oct 14, 2014
1 parent 383ca45 commit d6eba61
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 1 deletion.
10 changes: 9 additions & 1 deletion envcrypt.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,9 +25,17 @@ func decrypt(path string) ([]byte, error) {
return out, nil
}

func isNewLine(r rune) bool {
switch r {
case '\n':
return true
}
return false
}

// The parse function splits a byte array on whitespace.
func parse(data []byte) ([]string, error) {
return strings.Fields(string(data)), nil
return strings.FieldsFunc(string(data), isNewLine), nil
}

// The run function runs a command in an environment.
Expand Down
8 changes: 8 additions & 0 deletions envcrypt_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,3 +11,11 @@ func TestParseOK(t *testing.T) {
t.Errorf("")
}
}

func TestParseSpaces(t *testing.T) {
in := []byte("FOO=bar baz\n")
out := []string{"FOO=bar baz"}
if result, _ := parse(in); result[0] != out[0] {
t.Errorf("")
}
}

0 comments on commit d6eba61

Please sign in to comment.