Skip to content

Commit 97ec69f

Browse files
committed
Auto merge of #32325 - alexcrichton:panic-once, r=aturon
std: Rewrite Once with poisoning This commit rewrites the `std::sync::Once` primitive with poisoning in mind in light of #31688. Currently a panic in the initialization closure will cause future initialization closures to run, but the purpose of a Once is usually to initialize some global state so it's highly likely that the global state is corrupt if a panic happened. The same strategy of a mutex is taken where a panic is propagated by default. A new API, `call_once_force`, was added to subvert panics like is available on Mutex as well (for when panicking is handled internally). Adding this support was a significant enough change to the implementation that it was just completely rewritten from scratch, primarily to avoid using a `StaticMutex` which needs to have `destroy()` called on it at some point (a pain to do). Closes #31688
2 parents 13bfd5c + c966c33 commit 97ec69f

File tree

1 file changed

+363
-56
lines changed

1 file changed

+363
-56
lines changed

0 commit comments

Comments
 (0)