Skip to content
Permalink
Browse files

Document that calling Drop, even after it panics, is UB

  • Loading branch information
Mark-Simulacrum committed Dec 23, 2019
1 parent a916ac2 commit a08df28a6fdb5a2c781f01082e630faa2d7ccde9
Showing with 6 additions and 0 deletions.
  1. +6 −0 src/libcore/ops/drop.rs
@@ -99,9 +99,15 @@ pub trait Drop {
/// Given that a [`panic!`] will call `drop` as it unwinds, any [`panic!`]
/// in a `drop` implementation will likely abort.
///
/// Note that even if this panics, the value is considered to be dropped;
/// you must not cause `drop` to be called again. This is normally automatically
/// handled by the compiler, but when using unsafe code, can sometimes occur
/// unintentionally, particularly when using [`std::ptr::drop_in_place`].
///
/// [E0040]: ../../error-index.html#E0040
/// [`panic!`]: ../macro.panic.html
/// [`std::mem::drop`]: ../../std/mem/fn.drop.html
/// [`std::ptr::drop_in_place`]: ../../std/ptr/fn.drop_in_place.html
#[stable(feature = "rust1", since = "1.0.0")]
fn drop(&mut self);
}

0 comments on commit a08df28

Please sign in to comment.
You can’t perform that action at this time.