From 96fcef232f3c6f201cd851db0ac37822e36afadb Mon Sep 17 00:00:00 2001 From: Martin Tournoij Date: Tue, 6 Jun 2023 11:25:54 +0200 Subject: [PATCH] Check BURNTSUSHI_TOML_110 in the parser Checking it on import means applications won't be to set it with SetEnv in the application itself. Fixes #394 --- decode_test.go | 4 ++-- parse.go | 8 ++++---- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/decode_test.go b/decode_test.go index 6ca4a06f..45d0cf20 100644 --- a/decode_test.go +++ b/decode_test.go @@ -18,8 +18,8 @@ import ( ) func WithTomlNext(f func()) { - tomlNext = true - defer func() { tomlNext = false }() + os.Setenv("BURNTSUSHI_TOML_110", "") + defer func() { os.Unsetenv("BURNTSUSHI_TOML_110") }() f() } diff --git a/parse.go b/parse.go index 2aeb4f16..ceceb1d1 100644 --- a/parse.go +++ b/parse.go @@ -11,10 +11,7 @@ import ( "github.com/BurntSushi/toml/internal" ) -var tomlNext = func() bool { - _, ok := os.LookupEnv("BURNTSUSHI_TOML_110") - return ok -}() +var tomlNext bool type parser struct { lx *lexer @@ -35,6 +32,9 @@ type keyInfo struct { } func parse(data string) (p *parser, err error) { + _, ok := os.LookupEnv("BURNTSUSHI_TOML_110") + tomlNext = ok + defer func() { if r := recover(); r != nil { if pErr, ok := r.(ParseError); ok {