Wrappers Solidity's arithmetic operations added overflow
Arithmetic operations Solidity wrap overflow easily result
bugs , programmers usually assume overflow raises
error , standard behavior high level programming languages
`Safe Math` restores intuition reverting transaction
operation overflows
Using library instead unchecked operations eliminates entire
class bugs , recommended use always
Returns addition two unsigned integers , reverting
Counterpart Solidity's `+` operator
Requirements :
Addition cannot overflow
Returns subtraction two unsigned integers , reverting
overflow ( result negative )
Counterpart Solidity's ` ` operator
Requirements :
Subtraction cannot overflow
Returns multiplication two unsigned integers , reverting
Counterpart Solidity's `*` operator
Requirements :
Multiplication cannot overflow
Returns integer division two unsigned integers Reverts
division zero result rounded towards zero
Counterpart Solidity's ` ` operator Note : function uses
`revert` opcode ( leaves remaining gas untouched ) Solidity
uses invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
Reverts dividing zero
Counterpart Solidity's `%` operator function uses `revert`
opcode ( leaves remaining gas untouched ) Solidity uses
invalid opcode revert ( consuming remaining gas )
Requirements :
divisor cannot zero
Interface ERC20 standard defined EIP include
optional functions; access see `ERC20Detailed`
Returns amount tokens existence
Returns amount tokens owned `account`
Moves `amount` tokens caller's account `recipient`
Returns boolean value indicating whether operation succeeded
Emits `Transfer` event
Returns remaining number tokens `spender`
allowed spend behalf `owner` `transfer From`
zero default
value changes `approve` `transfer From` called
Sets `amount` allowance `spender` caller's tokens
Returns boolean value indicating whether operation succeeded
Beware changing allowance method brings risk
someone may use old new allowance unfortunate
transaction ordering One possible solution mitigate race
condition first reduce spender's allowance 0 set
desired value afterwards :
https : ethereum EIPs issues 20 issuecomment 263524729
Emits `Approval` event
Moves `amount` tokens `sender` `recipient` using
allowance mechanism `amount` deducted caller's
Returns boolean value indicating whether operation succeeded
Emits `Transfer` event
Emitted `value` tokens moved one account ( `from` )
another ( `to` )
Note `value` may zero
Emitted allowance `spender` `owner` set
call `approve` `value` new allowance
Implementation `IERC20` interface
implementation agnostic way tokens created means
supply mechanism added derived contract using ` mint`
generic mechanism see `ERC20Mintable`
detailed writeup see guide [How implement supply
mechanisms] ( https : forum zeppelin solutions implement erc20 supply mechanisms 226 )
followed general Open Zeppelin guidelines : functions revert instead
returning `false` failure behavior nonetheless conventional
conflict expectations ERC20 applications
Additionally , `Approval` event emitted calls `transfer From`
allows applications reconstruct allowance accounts
listening said events implementations EIP may emit
events , required specification
Finally , non standard `decrease Allowance` `increase Allowance`
functions added mitigate well known issues around setting
allowances See `IERC20 approve`
See `IERC20 total Supply`
See `IERC20 balance Of`
See `IERC20 transfer`
Requirements :
`recipient` cannot zero address
caller must balance least `amount`
See `IERC20 allowance`
See `IERC20 approve`
Requirements :
`spender` cannot zero address
See `IERC20 transfer From`
Emits `Approval` event indicating updated allowance
required EIP See note beginning `ERC20`;
Requirements :
`sender` `recipient` cannot zero address
`sender` must balance least `value`
caller must allowance `sender`'s tokens least
Atomically increases allowance granted `spender` caller
alternative `approve` used mitigation
problems described `IERC20 approve`
Emits `Approval` event indicating updated allowance
Requirements :
`spender` cannot zero address
Atomically decreases allowance granted `spender` caller
alternative `approve` used mitigation
problems described `IERC20 approve`
Emits `Approval` event indicating updated allowance
Requirements :
`spender` cannot zero address
`spender` must allowance caller least
`subtracted Value`
Moves tokens `amount` `sender` `recipient`
internal function equivalent `transfer` , used
e g implement automatic token fees , slashing mechanisms , etc
Emits `Transfer` event
Requirements :
`sender` cannot zero address
`recipient` cannot zero address
`sender` must balance least `amount`
Creates `amount` tokens assigns `account` , increasing
total supply
Emits `Transfer` event `from` set zero address
`to` cannot zero address
Destoys `amount` tokens `account` , reducing
total supply
Emits `Transfer` event `to` set zero address
`account` cannot zero address
`account` must least `amount` tokens
Sets `amount` allowance `spender` `owner`s tokens
internal function equivalent `approve` , used
e g set automatic allowances certain subsystems , etc
Emits `Approval` event
Requirements :
`owner` cannot zero address
`spender` cannot zero address
Destoys `amount` tokens `account` `amount` deducted
caller's allowance
See ` burn` ` approve`
Optional functions ERC20 standard
Sets values `name` , `symbol` , `decimals` three
values immutable : set
Returns name token
Returns symbol token , usually shorter version
Returns number decimals used get user representation
example , `decimals` equals `2` , balance `505` tokens
displayed user `5 , 05` ( `505 10 ** 2` )
Tokens usually opt value 18 , imitating relationship
Ether Wei
Note information used display purposes :
way affects arithmetic contract , including
`IERC20 balance Of` `IERC20 transfer`
Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : Open Zeppelin openzeppelin contracts pull 522
Solidity automatically asserts dividing 0
ethereum EIPs issues 20 issuecomment 263524729
forum zeppelin solutions implement erc20 supply mechanisms 226 ) *
