mirror of
https://github.com/rust-lang/rust.git
synced 2025-05-14 02:49:40 +00:00
argue why at_exit_imp is fine
This commit is contained in:
parent
22457deef7
commit
ab3e4a2789
@ -64,6 +64,7 @@ pub fn cleanup() {
|
||||
if !queue.is_null() {
|
||||
let queue: Box<Queue> = Box::from_raw(queue);
|
||||
for to_run in *queue {
|
||||
// We are not holding any lock, so reentrancy is fine.
|
||||
to_run();
|
||||
}
|
||||
}
|
||||
@ -75,9 +76,8 @@ pub fn push(f: Box<dyn FnBox()>) -> bool {
|
||||
unsafe {
|
||||
let _guard = LOCK.lock();
|
||||
if init() {
|
||||
// This could reentrantly call `push` again, which is a problem because
|
||||
// `LOCK` allows reentrancy!
|
||||
// FIXME: Add argument why this is okay.
|
||||
// We are just moving `f` around, not calling it.
|
||||
// There is no possibility of reentrancy here.
|
||||
(*QUEUE).push(f);
|
||||
true
|
||||
} else {
|
||||
|
Loading…
Reference in New Issue
Block a user