Expand description
This module provides several integer oriented traits for converting between
both fixed size integers and integers whose size varies based on the target
(like usize
).
The driving design principle of this module is to attempt to centralize as many
as
casts as possible here. And in particular, we separate casts into two
buckets:
- Casts that we use for their truncating behavior. In this case, we use more
descriptive names, like
low_u32
andhigh_u32
. - Casts that we use for converting back-and-forth between
usize
. These conversions are generally necessary because we often store indices in different formats to save on memory, which requires converting to and fromusize
. In this case, we very specifically do not want to overflow, and so the methods defined here will panic if theas
cast would be lossy in debug mode. (A normalas
cast will never panic!)
For as
casts between raw pointers, we use cast
, so as
isn’t needed there.
For regex engines, floating point is just never used, so we don’t have to worry
about as
casts for those.
Otherwise, this module pretty much covers all of our as
needs except for one
thing: const contexts. There are a select few places in this crate where we
still need to use as
because const functions on traits aren’t stable yet.
If we wind up significantly expanding our const footprint in this crate, it
might be worth defining free functions to handle those cases. But at the time
of writing, that just seemed like too much ceremony. Instead, I comment each
such use of as
in a const context with a “fixme” notice.
NOTE: for simplicity, we don’t take target pointer width into account here for
usize
conversions. Since we currently only panic in debug mode, skipping the
check when it can be proven it isn’t needed at compile time doesn’t really
matter. Now, if we wind up wanting to do as many checks as possible in release
mode, then we would want to skip those when we know the conversions are always
non-lossy.
NOTE: this module isn’t an exhaustive API. For example, we still use things
like u64::from
where possible, or even usize::try_from()
for when we do
explicitly want to panic or when we want to return an error for overflow.