Skip to content

Commit

Permalink
Make proper use of the term spender...
Browse files Browse the repository at this point in the history
... in ERC20WithPermit.

Closes #15
  • Loading branch information
mhluongo committed Oct 25, 2024
1 parent c315b9d commit ab8ecd3
Showing 1 changed file with 15 additions and 15 deletions.
30 changes: 15 additions & 15 deletions contracts/token/ERC20WithPermit.sol
Original file line number Diff line number Diff line change
Expand Up @@ -73,29 +73,29 @@ contract ERC20WithPermit is IERC20WithPermit, Ownable {
return true;
}

/// @notice Moves `amount` tokens from `spender` to `recipient` using the
/// @notice Moves `amount` tokens from `owner` to `recipient` using the
/// allowance mechanism. `amount` is then deducted from the caller's
/// allowance unless the allowance was made for `type(uint256).max`.
/// @return True if the operation succeeded, reverts otherwise.
/// @dev Requirements:
/// - `spender` and `recipient` cannot be the zero address,
/// - `spender` must have a balance of at least `amount`,
/// - the caller must have allowance for `spender`'s tokens of at least
/// - `owner` and `recipient` cannot be the zero address,
/// - `owner` must have a balance of at least `amount`,
/// - the caller must have allowance for `owner`'s tokens of at least
/// `amount`.
function transferFrom(
address spender,
address owner,
address recipient,
uint256 amount
) external override returns (bool) {
uint256 currentAllowance = allowance[spender][msg.sender];
uint256 currentAllowance = allowance[owner][msg.sender];
if (currentAllowance != type(uint256).max) {
require(
currentAllowance >= amount,
"Transfer amount exceeds allowance"
);
_approve(spender, msg.sender, currentAllowance - amount);
_approve(owner, msg.sender, currentAllowance - amount);
}
_transfer(spender, recipient, amount);
_transfer(owner, recipient, amount);
return true;
}

Expand Down Expand Up @@ -289,21 +289,21 @@ contract ERC20WithPermit is IERC20WithPermit, Ownable {
}

function _transfer(
address spender,
address owner,
address recipient,
uint256 amount
) private {
require(spender != address(0), "Transfer from the zero address");
require(owner != address(0), "Transfer from the zero address");
require(recipient != address(0), "Transfer to the zero address");
require(recipient != address(this), "Transfer to the token address");

beforeTokenTransfer(spender, recipient, amount);
beforeTokenTransfer(owner, recipient, amount);

uint256 spenderBalance = balanceOf[spender];
require(spenderBalance >= amount, "Transfer amount exceeds balance");
balanceOf[spender] = spenderBalance - amount;
uint256 ownerBalance = balanceOf[owner];
require(ownerBalance >= amount, "Transfer amount exceeds balance");
balanceOf[owner] = ownerBalance - amount;
balanceOf[recipient] += amount;
emit Transfer(spender, recipient, amount);
emit Transfer(owner, recipient, amount);
}

function _approve(
Expand Down

0 comments on commit ab8ecd3

Please sign in to comment.