-
-
Notifications
You must be signed in to change notification settings - Fork 530
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
v1.3.1 fails Go race detector when used concurrently #395
Comments
Ah yeah, do'h; how silly >_< Using sync.Once won't work though, as I want people to be able to control it for every parser invocation. I also want to avoid adding a new API for this (as we will never be able to remove it for compatibility) hence the environment variable. I wanted to avoid getting the environment variable on every
Benchmark codepackage main As it's checked thousands of times even for relatively small documents (once for every character in a key for starters) so it adds up. Then again, maybe that's not really a big deal. There's were a bunch of "micro benchmarks" and I just added a benchmark for a large document – if that doesn't regress too much then it's okay to just convert Otherwise the solution is to check the environment variable once on startup and add a struct field to the parser and lexer and check that. I don't have time for this today, but if you want to create a PR then I can merge it this evening. Would also be nice to test the parallel case (and run the tests with -race in the CI). Otherwise I'll look tomorrow, that's fine too. |
Actually maybe a struct field is better in any case, otherwise setting the environment variable while the parser is running will change the operation of the parser half-way through. |
And 1.3.0 doesn't have this bug; so you can use that in the meanwhile – I changed it for #394 |
If you want the setting to be able to changed per-invocation, you can't use environment anywhere this might be used concurrently. For a given goroutine, between setting the environment and calling Unmarshal, the value may be reset by a different goroutine. This is why I suggested |
That's an obscure enough edge case I can live with: it will only affect people who 1) run this concurrently, 2) want to use TOML 1.1 draft, and 3) also want to use TOML 1.0 for other documents (concurrently). The number of people that will affect is very likely to be 0. |
Tagged v1.3.2 |
The
BURNTSUSHI_TOML_110
check in v1.3.1 writes to a package global at each invocation ofparse()
without any locking:This could maybe use
sync.Once()
instead?It currently fails Go's race detector when used concurrently:
I'd be happy to provide code to demonstrate this if that's useful.
The text was updated successfully, but these errors were encountered: