open-nomad/vendor/github.com/hashicorp/go-envparse/README.md

93 lines
2.9 KiB
Markdown
Raw Normal View History

2017-06-02 22:58:52 +00:00
[![GoDoc](https://godoc.org/github.com/hashicorp/go-envparse?status.svg)](https://godoc.org/github.com/hashicorp/go-envparse)
[![Build Status](https://travis-ci.org/hashicorp/go-envparse.svg?branch=master)](https://travis-ci.org/hashicorp/go-envparse)
[![Coverage Status](https://coveralls.io/repos/github/hashicorp/go-envparse/badge.svg?branch=master)](https://coveralls.io/github/hashicorp/go-envparse?branch=master)
2017-06-02 22:03:27 +00:00
# go-envparse
A minimal Go environment variable parser. It's intended to be used to parse
`.env` style files similar to [godotenv](https://github.com/joho/godotenv) or
[rubydotenv](https://github.com/bkeepers/dotenv), but perform minimal
allocations, handle more complex quoting, and be better tested.
Parsing a line does 2 allocations regardless of line length or complexity.
The parser supports JSON strings which allows for cross-language/platform
encoding of arbitrarily complex data.
For example if you are parsing environment variables from a templated file, the
template can JSON encode data that may contain newlines:
```
FOO={{ some_template_function | toJSON }}
```
...would be templated to:
```
FOO="The template value\nmay have included\nsome newlines!\n\ud83d\udd25"
```
...and `envparse.Parse()` would return:
```go
map[string]string{
"FOO": "The template value\nmay have included\nsome newlines!\n🔥",
}
```
## Minimal
The following common features *are intentionaly missing*:
* Full shell quoting semantics
* Full shell escape sequence support
* Only JSON escape sequences are supported (see below)
* Variable interpolation
* Use [Go's os.Expand](https://golang.org/pkg/os/#Expand) on the parsed
values
* Anything YAML related
* No
However, comments, unquoted, single quoted, and double quoted text may all be
used within a single value:
```
SOME_KEY = normal unquoted \text 'plus single quoted\' "\"double quoted " # EOL
```
...parses to:
```go
map[string]string{
"SOME_KEY": `normal unquoted \text plus single quoted\ "double quoted `
}
```
(Note the trailing space inside the double quote is kept, but the space between
the final `"` and `#` is trimmed.)
## Format
* Keys should be of the form: `[A-Za-z_][A-Za-z0-9_]?`
* Keys may be prefixed with `export ` which will be ignored
* Whitespace around keys will be trimmed
* Values should be valid ASCII or UTF-8 encoded.
* Newlines are always treated as delimiters, so newlines within values *must*
be escaped.
* Values may use one of more quoting styles:
* Unquoted - `FOO=bar baz`
* No escape sequences
* Ends at `#`, `"`, `'`, or newline
* Preceeding and trailing whitespace will be trimmed
* Double Quotes - `FOO="bar baz"`
* Supports JSON escape sequences: `\uXXXX`, `\r`, `\n`, `\t`, `\\`, and
`\"`
* Ends at unescaped `"`
* No whitespace trimming
* Single Quotes - `FOO='bar baz'`
* No escape sequences
* Ends at `'`
* No whitespace trimming
See `envparse_test.go` for examples of valid and invalid data.