-
Notifications
You must be signed in to change notification settings - Fork 151
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Implement specific bit types for integers #677
Conversation
This is currently WIP as there are a few tests that are currently panicking due to failed library assertions.
The motivation for this PR is the same as #545 |
OK with this, however this will have worse devex as ruint has worse APIs for conversions with primitives. Will look into the failures as well this week and get a breaking release out. |
crates/sol-types/src/types/value.rs
Outdated
@@ -181,23 +181,128 @@ macro_rules! impl_sol_value { | |||
)*}; | |||
} | |||
|
|||
type U24 = alloy_primitives::Uint<24, 1>; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should re-export all of these in primitives::aliases and import them here with a glob import
Note that we have already worked around the issue for now with this PR that will be merged soon: The concern about |
It's also intuitive that u24 -> U24 rather than u32, but there is also the concern that storing it is 8 bytes instead of 3/4 I'm OK with it TBH wdyt @prestwich @gakonst @mattsse also FYI if you update to latest alloy versions we have made the string representation of types const too, so you can use it in your const ABI stuff: https://docs.rs/alloy-sol-types/latest/alloy_sol_types/trait.SolType.html#associatedconstant.SOL_NAME |
reasonable imo |
Use generic integer types with specific bit sizes to allow 1:1 mapping between rust and solidity types.
Motivation
I am doing some work on OffchainLabs/stylus-sdk-rs and am having some issues with the way that integer types are currently implemented here. For stylus, we require a 1:1 type mapping between rust types and solidity types. This breaks down for us because in alloy, currently, there is many solidity types that map to each rust integer type. For instance, both uint24 and uint32 in solidity map to u32 in rust.
Solution
Our proposed solution is to use
alloy_primitves::{Signed, Uint}
with the proper number of bits for each integer type.PR Checklist
Note
This is currently WIP as there are a few tests that are currently panicking due to failed library assertions. I believe the issue is in the
int_impls!
macro incore/crates/sol-types/src/types/data_type.rs
. I need to review the usage of the generic bit sizes that are used here. I also need to check thetry_from
implementation used in a couple other tests.