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 subtraction two unsigned integers , reverting custom message
overflow ( result negative )
Counterpart Solidity's ` ` operator
Requirements :
Subtraction cannot overflow
NOTE : feature next version Open Zeppelin Contracts
Get via `npm install @openzeppelin contracts@next`
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 integer division two unsigned integers Reverts custom message
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
NOTE : feature next version Open Zeppelin Contracts
Get via `npm install @openzeppelin contracts@next`
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
Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
Reverts custom message 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
NOTE : feature next version Open Zeppelin Contracts
Get via `npm install @openzeppelin contracts@next`
sets 0 initials tokens , owner , supply Controller
serves constructor proxy compiles
memory model Implementation contract
constructor used ensure implementation
contract initialized uncontrolled implementation
contract might lead misleading state
users accidentally interact
Throws called account owner
Allows current owner transfer control contract new Owner
param new Owner address transfer ownership
Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : Open Zeppelin openzeppelin contracts pull 522
Solidity automatically asserts dividing 0
INITIALIZATION DATA
OWNER DATA
INITIALIZATION FUNCTIONALITY
OWNER FUNCTIONALITY
