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
* Gods Unchained Raffle Token Exchange
* Version 1 0
* dedicated contract listing ( selling ) buying raffle tokens
* https : gu cards
Gas optimization : cheaper requiring 'a' zero ,
benefit lost 'b' also tested
See : https : Open Zeppelin openzeppelin solidity pull 522
Solidity automatically asserts dividing 0
V R B L E
raffle token contract
case exchange paused
Standard contract ownership
Next id next listing
raffle token listings mapped id
Next id next purche
R U C
listing raffle tokens
price per token ( wei )
many tokens ? ( Original Amount )
many tokens left ? ( Maybe altered due partial sales )
Listed ?
Active Inactive listing ?
purchase raffle tokens
many tokens ?
total price payed
purchase happen ?
F E R
Invokable contract owner
Invokable exchange paused
C N R U C R
F U N C N
buy Raffle
Add listing
Cancel listing
Set paused
Funds withdrawal cover operational costs
Contract may destroyed nothing else going
funds transferred contract owner
