From 76244d4e0f487de1ef2b3cabcf101db2501b32f8 Mon Sep 17 00:00:00 2001 From: chefburger Date: Thu, 9 May 2024 14:37:40 +0800 Subject: [PATCH] optimization: cache memory variable in clpool#swap --- .../CLPoolManagerTest#swap_againstLiquidity.snap | 2 +- .../CLPoolManagerTest#swap_leaveSurplusTokenInVault.snap | 2 +- .../CLPoolManagerTest#swap_runOutOfLiquidity.snap | 2 +- .forge-snapshots/CLPoolManagerTest#swap_simple.snap | 2 +- .../CLPoolManagerTest#swap_useSurplusTokenAsInput.snap | 2 +- .forge-snapshots/CLPoolManagerTest#swap_withHooks.snap | 2 +- .forge-snapshots/CLPoolManagerTest#swap_withNative.snap | 2 +- .../CLPoolManagerTest#testFuzzUpdateDynamicLPFee.snap | 2 +- src/pool-cl/libraries/CLPool.sol | 7 +++---- 9 files changed, 11 insertions(+), 12 deletions(-) diff --git a/.forge-snapshots/CLPoolManagerTest#swap_againstLiquidity.snap b/.forge-snapshots/CLPoolManagerTest#swap_againstLiquidity.snap index 01f96271..9a2af0bc 100644 --- a/.forge-snapshots/CLPoolManagerTest#swap_againstLiquidity.snap +++ b/.forge-snapshots/CLPoolManagerTest#swap_againstLiquidity.snap @@ -1 +1 @@ -148799 \ No newline at end of file +148772 \ No newline at end of file diff --git a/.forge-snapshots/CLPoolManagerTest#swap_leaveSurplusTokenInVault.snap b/.forge-snapshots/CLPoolManagerTest#swap_leaveSurplusTokenInVault.snap index bf6fe7da..9b016f69 100644 --- a/.forge-snapshots/CLPoolManagerTest#swap_leaveSurplusTokenInVault.snap +++ b/.forge-snapshots/CLPoolManagerTest#swap_leaveSurplusTokenInVault.snap @@ -1 +1 @@ -177249 \ No newline at end of file +177222 \ No newline at end of file diff --git a/.forge-snapshots/CLPoolManagerTest#swap_runOutOfLiquidity.snap b/.forge-snapshots/CLPoolManagerTest#swap_runOutOfLiquidity.snap index fb017b01..43f2e4ad 100644 --- a/.forge-snapshots/CLPoolManagerTest#swap_runOutOfLiquidity.snap +++ b/.forge-snapshots/CLPoolManagerTest#swap_runOutOfLiquidity.snap @@ -1 +1 @@ -25086651 \ No newline at end of file +25086624 \ No newline at end of file diff --git a/.forge-snapshots/CLPoolManagerTest#swap_simple.snap b/.forge-snapshots/CLPoolManagerTest#swap_simple.snap index dcdebedc..061f91d4 100644 --- a/.forge-snapshots/CLPoolManagerTest#swap_simple.snap +++ b/.forge-snapshots/CLPoolManagerTest#swap_simple.snap @@ -1 +1 @@ -78894 \ No newline at end of file +78867 \ No newline at end of file diff --git a/.forge-snapshots/CLPoolManagerTest#swap_useSurplusTokenAsInput.snap b/.forge-snapshots/CLPoolManagerTest#swap_useSurplusTokenAsInput.snap index ab7237d9..f71d0575 100644 --- a/.forge-snapshots/CLPoolManagerTest#swap_useSurplusTokenAsInput.snap +++ b/.forge-snapshots/CLPoolManagerTest#swap_useSurplusTokenAsInput.snap @@ -1 +1 @@ -158466 \ No newline at end of file +158439 \ No newline at end of file diff --git a/.forge-snapshots/CLPoolManagerTest#swap_withHooks.snap b/.forge-snapshots/CLPoolManagerTest#swap_withHooks.snap index 3de33ffd..a19d1d77 100644 --- a/.forge-snapshots/CLPoolManagerTest#swap_withHooks.snap +++ b/.forge-snapshots/CLPoolManagerTest#swap_withHooks.snap @@ -1 +1 @@ -95401 \ No newline at end of file +95374 \ No newline at end of file diff --git a/.forge-snapshots/CLPoolManagerTest#swap_withNative.snap b/.forge-snapshots/CLPoolManagerTest#swap_withNative.snap index 0b12e8be..bff11caf 100644 --- a/.forge-snapshots/CLPoolManagerTest#swap_withNative.snap +++ b/.forge-snapshots/CLPoolManagerTest#swap_withNative.snap @@ -1 +1 @@ -78897 \ No newline at end of file +78870 \ No newline at end of file diff --git a/.forge-snapshots/CLPoolManagerTest#testFuzzUpdateDynamicLPFee.snap b/.forge-snapshots/CLPoolManagerTest#testFuzzUpdateDynamicLPFee.snap index eccf7bcd..40100785 100644 --- a/.forge-snapshots/CLPoolManagerTest#testFuzzUpdateDynamicLPFee.snap +++ b/.forge-snapshots/CLPoolManagerTest#testFuzzUpdateDynamicLPFee.snap @@ -1 +1 @@ -32281 \ No newline at end of file +32293 \ No newline at end of file diff --git a/src/pool-cl/libraries/CLPool.sol b/src/pool-cl/libraries/CLPool.sol index 29f0eb8e..5f10defd 100644 --- a/src/pool-cl/libraries/CLPool.sol +++ b/src/pool-cl/libraries/CLPool.sol @@ -217,9 +217,8 @@ library CLPool { bool exactInput = params.amountSpecified > 0; { - uint16 protocolFee = params.zeroForOne - ? slot0Start.protocolFee.getZeroForOneFee() - : slot0Start.protocolFee.getOneForZeroFee(); + uint16 protocolFee = + zeroForOne ? slot0Start.protocolFee.getZeroForOneFee() : slot0Start.protocolFee.getOneForZeroFee(); state = SwapState({ amountSpecifiedRemaining: params.amountSpecified, @@ -228,7 +227,7 @@ library CLPool { tick: slot0Start.tick, swapFee: protocolFee == 0 ? slot0Start.lpFee : uint24(protocolFee).calculateSwapFee(slot0Start.lpFee), protocolFee: protocolFee, - feeGrowthGlobalX128: params.zeroForOne ? self.feeGrowthGlobal0X128 : self.feeGrowthGlobal1X128, + feeGrowthGlobalX128: zeroForOne ? self.feeGrowthGlobal0X128 : self.feeGrowthGlobal1X128, feeForProtocol: 0, liquidity: liquidityStart });