#

alloy-encode-packed

**Ethereum abi.encodePacked() in Rust** `alloy-encode-packed` is a Rust library that provides an implementation of Ethereum's `abi.encodePacked()` function. This crate is an adaptation of the [eth-encode-packed](https://github.com/roberts-pumpurs/eth-encode-packed-rs) library, replacing the `ethers.rs` dependency with `alloy`, offering improved performance and compatibility with the latest Rust ecosystem. The library is designed to facilitate encoding of Ethereum contract data in a packed format, which is essential for certain cryptographic operations and smart contract interactions. ## Example usage ### packing an uint24 ```rust let input = vec![ // this is supposed to be uint24 variable in solidity SolidityDataType::NumberWithShift(U256::from(4001), TakeLastXBytes(24)) ]; let (bytes, hash) = abi::encode_packed(&input); let hash = format!("0x{:}", hash); let expected = "0x000fa1"; assert_eq!(hash, expected); ``` ### Packing a lot of data Solidity ```solidity function packer( uint24 uint24_data, uint256 tokenId, string calldata ipfsURI, address sample, uint256 id ) public pure returns (bytes memory ){ bytes memory res = abi.encodePacked(uint24_data, tokenId, ipfsURI, sample, id); return res; } ``` Rust ```rust let address = hex::decode("d8b934580fcE35a11B58C6D73aDeE468a2833fa8").unwrap(); let address: [u8; 20] = address.try_into().unwrap(); let input = vec![ SolidityDataType::NumberWithShift(U256::from(3838), TakeLastXBytes(24)), SolidityDataType::Number(U256::from(4001)), SolidityDataType::String("this-is-a-sample-string"), SolidityDataType::Address(Address::from(address)), SolidityDataType::Number(U256::from(1)), ]; let (_bytes, hash) = abi::encode_packed(&input); let hash = format!("0x{:}", hash); let expected = "0x000efe0000000000000000000000000000000000000000000000000000000000000fa1746869732d69732d612d73616d706c652d737472696e67d8b934580fce35a11b58c6d73adee468a2833fa80000000000000000000000000000000000000000000000000000000000000001"; assert_eq!(hash, expected); ```