Rollup merge of #67722 - petertodd:2019-improve-any-comment, r=Mark-Simulacrum
Minor: note how Any is an unsafe trait in SAFETY comments Motivation: helpful to people like myself reading the standard library source to better understand how to use Any, especially if we do go ahead with https://github.com/rust-lang/rust/pull/67562 and make it an unsafe trait.
This commit is contained in:
commit
36fd7b9a59
@ -194,7 +194,9 @@ impl dyn Any {
|
|||||||
#[inline]
|
#[inline]
|
||||||
pub fn downcast_ref<T: Any>(&self) -> Option<&T> {
|
pub fn downcast_ref<T: Any>(&self) -> Option<&T> {
|
||||||
if self.is::<T>() {
|
if self.is::<T>() {
|
||||||
// SAFETY: just checked whether we are pointing to the correct type
|
// SAFETY: just checked whether we are pointing to the correct type, and we can rely on
|
||||||
|
// that check for memory safety because we have implemented Any for all types; no other
|
||||||
|
// impls can exist as they would conflict with our impl.
|
||||||
unsafe { Some(&*(self as *const dyn Any as *const T)) }
|
unsafe { Some(&*(self as *const dyn Any as *const T)) }
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
@ -228,7 +230,9 @@ impl dyn Any {
|
|||||||
#[inline]
|
#[inline]
|
||||||
pub fn downcast_mut<T: Any>(&mut self) -> Option<&mut T> {
|
pub fn downcast_mut<T: Any>(&mut self) -> Option<&mut T> {
|
||||||
if self.is::<T>() {
|
if self.is::<T>() {
|
||||||
// SAFETY: just checked whether we are pointing to the correct type
|
// SAFETY: just checked whether we are pointing to the correct type, and we can rely on
|
||||||
|
// that check for memory safety because we have implemented Any for all types; no other
|
||||||
|
// impls can exist as they would conflict with our impl.
|
||||||
unsafe { Some(&mut *(self as *mut dyn Any as *mut T)) }
|
unsafe { Some(&mut *(self as *mut dyn Any as *mut T)) }
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
|
Loading…
Reference in New Issue
Block a user