Skip to content

Commit

Permalink
Tidy
Browse files Browse the repository at this point in the history
  • Loading branch information
Vectorized committed Apr 8, 2024
1 parent 0f94bba commit 4986780
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 26 deletions.
34 changes: 17 additions & 17 deletions .gas-snapshot
Original file line number Diff line number Diff line change
@@ -1,30 +1,30 @@
MulticallerTest:testMultiCallerWithSignerIncrementNonceSalt(uint256) (runs: 256, μ: 80096, ~: 82389)
MulticallerTest:testMultiCallerWithSignerIncrementNonceSaltWithERC1271(uint256) (runs: 256, μ: 614013, ~: 614058)
MulticallerTest:testMulticallerCdFallback(string) (runs: 256, μ: 305244, ~: 301384)
MulticallerTest:testMultiCallerWithSignerIncrementNonceSalt(uint256) (runs: 256, μ: 83584, ~: 83538)
MulticallerTest:testMultiCallerWithSignerIncrementNonceSaltWithERC1271(uint256) (runs: 256, μ: 614876, ~: 614922)
MulticallerTest:testMulticallerCdFallback(string) (runs: 256, μ: 295907, ~: 281868)
MulticallerTest:testMulticallerForwardsMessageValue() (gas: 214013)
MulticallerTest:testMulticallerGetNames() (gas: 147637)
MulticallerTest:testMulticallerReentrancyGuard() (gas: 18392)
MulticallerTest:testMulticallerRefund(uint256) (runs: 256, μ: 169611, ~: 171890)
MulticallerTest:testMulticallerReentrancyGuard() (gas: 19980)
MulticallerTest:testMulticallerRefund(uint256) (runs: 256, μ: 169488, ~: 171890)
MulticallerTest:testMulticallerReturnDataIsProperlyEncoded() (gas: 122173)
MulticallerTest:testMulticallerReturnDataIsProperlyEncoded(string,string,uint256) (runs: 256, μ: 507252, ~: 500013)
MulticallerTest:testMulticallerReturnDataIsProperlyEncoded(string,string,uint256) (runs: 256, μ: 486042, ~: 450256)
MulticallerTest:testMulticallerReturnDataIsProperlyEncoded(uint256,uint256,uint256,uint256) (runs: 256, μ: 122252, ~: 122252)
MulticallerTest:testMulticallerRevertWithCustomError() (gas: 32065)
MulticallerTest:testMulticallerRevertWithMessage() (gas: 34815)
MulticallerTest:testMulticallerRevertWithMessage(string) (runs: 256, μ: 35677, ~: 35747)
MulticallerTest:testMulticallerRevertWithNothing() (gas: 31886)
MulticallerTest:testMulticallerRevertWithCustomError() (gas: 35485)
MulticallerTest:testMulticallerRevertWithMessage() (gas: 38244)
MulticallerTest:testMulticallerRevertWithMessage(string) (runs: 256, μ: 38922, ~: 38644)
MulticallerTest:testMulticallerRevertWithNothing() (gas: 35306)
MulticallerTest:testMulticallerSenderDoesNotRevertWithoutMulticallerDeployed() (gas: 3463)
MulticallerTest:testMulticallerTargetGetMulticallerSender() (gas: 27523)
MulticallerTest:testMulticallerWithNoData() (gas: 16213)
MulticallerTest:testMulticallerWithSigner(uint256) (runs: 256, μ: 130160, ~: 119724)
MulticallerTest:testMulticallerWithSigner(uint256) (runs: 256, μ: 128165, ~: 119136)
MulticallerTest:testMulticallerWithSignerEIP712Domain() (gas: 12375)
MulticallerTest:testMulticallerWithSignerGetMulticallerSigner() (gas: 136504)
MulticallerTest:testMulticallerWithSignerInvalidateNonces(uint256) (runs: 256, μ: 81303, ~: 79648)
MulticallerTest:testMulticallerWithSignerInvalidateNoncesWithERC1271(uint256) (runs: 256, μ: 615724, ~: 616377)
MulticallerTest:testMulticallerWithSignerInvalidateNonces(uint256) (runs: 256, μ: 79177, ~: 77798)
MulticallerTest:testMulticallerWithSignerInvalidateNoncesWithERC1271(uint256) (runs: 256, μ: 617027, ~: 616455)
MulticallerTest:testMulticallerWithSignerNonPayableFunctions() (gas: 48884)
MulticallerTest:testMulticallerWithSignerReentrancyGuard() (gas: 123271)
MulticallerTest:testMulticallerWithSignerRevert() (gas: 200311)
MulticallerTest:testMulticallerWithSignerWithERC1271(uint256) (runs: 256, μ: 659458, ~: 651359)
MulticallerTest:testMulticallerWithSignerWithNoData() (gas: 128470)
MulticallerTest:testMulticallerWithSignerReentrancyGuard() (gas: 124909)
MulticallerTest:testMulticallerWithSignerRevert() (gas: 206240)
MulticallerTest:testMulticallerWithSignerWithERC1271(uint256) (runs: 256, μ: 661769, ~: 651359)
MulticallerTest:testMulticallerWithSignerWithNoData() (gas: 130147)
MulticallerTest:testNastyCalldataRevert() (gas: 3420)
MulticallerTest:testOffsetTrick(uint256,uint256,uint256) (runs: 256, μ: 571, ~: 571)
MulticallerTest:test__codesize() (gas: 50297)
Expand Down
26 changes: 17 additions & 9 deletions src/LibMulticaller.sol
Original file line number Diff line number Diff line change
Expand Up @@ -36,14 +36,14 @@ library LibMulticaller {
* @dev Returns the caller of `aggregateWithSender` on `MULTICALLER_WITH_SENDER`.
*/
function multicallerSender() internal view returns (address result) {
return multicallerGetAt(MULTICALLER_WITH_SENDER);
return at(MULTICALLER_WITH_SENDER);
}

/**
* @dev Returns the signer of `aggregateWithSigner` on `MULTICALLER_WITH_SIGNER`.
*/
function multicallerSigner() internal view returns (address result) {
return multicallerGetAt(MULTICALLER_WITH_SIGNER);
return at(MULTICALLER_WITH_SIGNER);
}

/**
Expand All @@ -52,7 +52,7 @@ library LibMulticaller {
* Otherwise, returns `msg.sender`.
*/
function sender() internal view returns (address result) {
return getAt(MULTICALLER_WITH_SENDER);
return resolve(MULTICALLER_WITH_SENDER);
}

/**
Expand All @@ -61,26 +61,34 @@ library LibMulticaller {
* Otherwise, returns `msg.sender`.
*/
function signer() internal view returns (address) {
return getAt(MULTICALLER_WITH_SIGNER);
return resolve(MULTICALLER_WITH_SIGNER);
}

function multicallerGetAt(address loc) internal view returns (address result) {
/**
* @dev Returns the caller or signer at `a`.
* @param a The multicaller with sender / signer.
*/
function at(address a) internal view returns (address result) {
/// @solidity memory-safe-assembly
assembly {
mstore(0x00, 0x00)
if iszero(staticcall(gas(), loc, codesize(), 0x00, 0x00, 0x20)) {
if iszero(staticcall(gas(), a, codesize(), 0x00, 0x00, 0x20)) {
revert(codesize(), codesize()) // For better gas estimation.
}
result := mload(0x00)
}
}

function getAt(address loc) internal view returns (address result) {
/**
* @dev Returns the caller or signer at `a`, if the caller is `a`.
* @param a The multicaller with sender / signer.
*/
function resolve(address a) internal view returns (address result) {
/// @solidity memory-safe-assembly
assembly {
mstore(0x00, caller())
if eq(caller(), loc) {
if iszero(staticcall(gas(), loc, codesize(), 0x00, 0x00, 0x20)) {
if eq(caller(), a) {
if iszero(staticcall(gas(), a, codesize(), 0x00, 0x00, 0x20)) {
revert(codesize(), codesize()) // For better gas estimation.
}
}
Expand Down

0 comments on commit 4986780

Please sign in to comment.