Type conversion, success expected
This library is written to make numeric type conversions easy. Such conversions usually fall into one of the following cases:
From
] or [Into
]
or [Conv
] or [Cast
])Conv
] or [Cast
])TryFrom
] or [TryInto
] or [Conv::try_conv
] or [Cast::try_cast
])ConvFloat
] or [CastFloat
])f32
to f64
or vice-versa; in this case use of
as f32
/ as f64
is likely acceptable since f32
has special
representations for non-finite values and conversion to f64
is exactas
probably does exactly what you wantIf you are wondering "why not just use as
", there are a few reasons:
When should you not use this library?
All type conversions which are potentially fallible assert on failure in debug builds. In release builds assertions may be omitted, thus making incorrect conversions possible.
If the always_assert
feature flag is set, assertions will be turned on in
all builds. Some additional feature flags are available for finer-grained
control (see Cargo.toml).
The Minumum Supported Rust Version is 1.32.0 (first release of Edition 2018).
By default, std
support is required. With default features disabled no_std
is supported, but the ConvFloat
and CastFloat
traits are unavailable.
Enabling the libm
feature will re-enable these traits.
The COPYRIGHT file includes a list of contributors who claim copyright on this project. This list may be incomplete; new contributors may optionally add themselves to this list.
The easy-cast library is published under the terms of the Apache License, Version 2.0. You may obtain a copy of this licence from the LICENSE file or on the following webpage: https://www.apache.org/licenses/LICENSE-2.0