mirror of
https://github.com/Lokathor/bytemuck.git
synced 2024-11-21 14:22:26 +00:00
Improve assembly of Contiguous derive (#200)
`from_integer` and `into_integer` are usually provided by the trait's default implementation. We override this implementation because it goes through `transmute_copy`, which can lead to inefficient assembly as seen in https://github.com/Lokathor/bytemuck/issues/175 .
This commit is contained in:
parent
f047fb6aeb
commit
3c1a0d9b35
@ -378,12 +378,31 @@ impl Derivable for Contiguous {
|
||||
let min_lit = LitInt::new(&format!("{}", min), input.span());
|
||||
let max_lit = LitInt::new(&format!("{}", max), input.span());
|
||||
|
||||
// `from_integer` and `into_integer` are usually provided by the trait's default implementation.
|
||||
// We override this implementation because it goes through `transmute_copy`, which can lead to
|
||||
// inefficient assembly as seen in https://github.com/Lokathor/bytemuck/issues/175 .
|
||||
|
||||
Ok((
|
||||
quote!(),
|
||||
quote! {
|
||||
type Int = #integer_ty;
|
||||
const MIN_VALUE: #integer_ty = #min_lit;
|
||||
const MAX_VALUE: #integer_ty = #max_lit;
|
||||
|
||||
#[inline]
|
||||
fn from_integer(value: Self::Int) -> Option<Self> {
|
||||
#[allow(clippy::manual_range_contains)]
|
||||
if Self::MIN_VALUE <= value && value <= Self::MAX_VALUE {
|
||||
Some(unsafe { ::core::mem::transmute(value) })
|
||||
} else {
|
||||
None
|
||||
}
|
||||
}
|
||||
|
||||
#[inline]
|
||||
fn into_integer(self) -> Self::Int {
|
||||
self as #integer_ty
|
||||
}
|
||||
},
|
||||
))
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user