A modified version Weiroll that separates state into calldata (provided state) and memory (return data state). This implementation uses very little memory and currently uses about 1/3 the gas compared to the solidity implementation.
There is a janky solidity planner included for building the weiroll scripts:
uint a = 1e18;
uint b = 5;
ERC20 erc20 = new ERC20();
Math math = new Math();
PlannerHuff planner = new PlannerHuff();
// Plan a new static call to do some maths
planner.staticCall(address(math), math.add.selector);
// Add raw argument 'a'
planner.withRawArg(abi.encode(a));
// Add raw argument 'b'
planner.withRawArg(abi.encode(b));
// Tell planner to save the output of this call to use later
(uint8 stateIndex, uint8 cmdIndex) = plannerHuff.saveOutput();
// Plan a regular call to transfer tokens using math output for value
planner.regularCall(address(erc20), erc20.transfer.selector);
// to
planner.withRawArg(abi.encode(address(0xCAFE)));
// value
plannerHuff.withArg(stateIndex, cmdIndex);
// encode weiroll script
(bytes32[] memory _commands, bytes[] memory _state) = plannerHuff.encode();
weiroll.execute(_commands, _state);
Planner.sol
is compatible with regular weiroll.
PlannerHuff.sol
seperates memory/calldata state values and is compatible with Weiroll.huff
- Git
- You'll know you've done it right if you can run
git --version
- You'll know you've done it right if you can run
- Foundry / Foundryup
- This will install
forge
,cast
, andanvil
- You can test you've installed them right by running
forge --version
and get an output like:forge 0.2.0 (92f8951 2022-08-06T00:09:32.96582Z)
- To get the latest of each, just run
foundryup
- This will install
- Huff Compiler
- You'll know you've done it right if you can run
huffc --version
and get an output like:huffc 0.3.0
- You'll know you've done it right if you can run
- Clone this repo
git clone https://github.com/kyledewy/weiroll-huff/
cd weiroll-huff
- Install dependencies
forge install
- Build & Test
forge build
forge test
- Static calls
- Regular calls
- Calls with value
- Dynamic variables
- USE_STATE command
- Extended commands
These smart contracts are being provided as is. No guarantee, representation or warranty is being made, express or implied, as to the safety or correctness of the user interface or the smart contracts. They have not been audited and as such there can be no assurance they will work as intended, and users may experience delays, failures, errors, omissions, loss of transmitted information or loss of funds. The creators are not liable for any of the foregoing. Users should proceed with caution and use at their own risk.