Skip to content

Commit

Permalink
G-04. ExtensibleBase._setSafeMethod(): storage access optimization
Browse files Browse the repository at this point in the history
  • Loading branch information
remedcu committed Jan 9, 2025
1 parent 77bab0d commit 2113e23
Showing 1 changed file with 4 additions and 3 deletions.
7 changes: 4 additions & 3 deletions contracts/handler/extensible/ExtensibleBase.sol
Original file line number Diff line number Diff line change
Expand Up @@ -46,14 +46,15 @@ abstract contract ExtensibleBase is HandlerContext {

function _setSafeMethod(ISafe safe, bytes4 selector, bytes32 newMethod) internal {
(, address newHandler) = MarshalLib.decode(newMethod);
bytes32 oldMethod = safeMethods[safe][selector];
mapping(bytes4 => bytes32) storage safeMethod = safeMethods[safe];
bytes32 oldMethod = safeMethod[selector];
(, address oldHandler) = MarshalLib.decode(oldMethod);

if (address(newHandler) == address(0) && address(oldHandler) != address(0)) {
delete safeMethods[safe][selector];
delete safeMethod[selector];
emit RemovedSafeMethod(safe, selector);
} else {
safeMethods[safe][selector] = newMethod;
safeMethod[selector] = newMethod;
if (address(oldHandler) == address(0)) {
emit AddedSafeMethod(safe, selector, newMethod);
} else {
Expand Down

0 comments on commit 2113e23

Please sign in to comment.