27	0	*	Wrappers Solidity's arithmetic operations added overflow
27	0	*	Arithmetic operations Solidity wrap overflow easily result
27	0	*	bugs , programmers usually assume overflow raises
27	0	*	error , standard behavior high level programming languages
27	0	*	`Safe Math` restores intuition reverting transaction
27	0	*	operation overflows
27	0	*	Using library instead unchecked operations eliminates entire
27	0	*	class bugs , recommended use always
27	0	*	Returns addition two unsigned integers , reverting
27	0	*	Counterpart Solidity's `+` operator
27	0	*	Requirements :
27	0	*	Addition cannot overflow
27	0	*	Returns subtraction two unsigned integers , reverting
27	0	*	overflow ( result negative )
27	0	*	Counterpart Solidity's ` ` operator
27	0	*	Requirements :
27	0	*	Subtraction cannot overflow
27	0	*	Returns multiplication two unsigned integers , reverting
27	0	*	Counterpart Solidity's `*` operator
27	0	*	Requirements :
27	0	*	Multiplication cannot overflow
27	0	*	Returns integer division two unsigned integers Reverts
27	0	*	division zero result rounded towards zero
27	0	*	Counterpart Solidity's ` ` operator Note : function uses
27	0	*	`revert` opcode ( leaves remaining gas untouched ) Solidity
27	0	*	uses invalid opcode revert ( consuming remaining gas )
27	0	*	Requirements :
27	0	*	divisor cannot zero
27	0	*	Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
27	0	*	Reverts dividing zero
27	0	*	Counterpart Solidity's `%` operator function uses `revert`
27	0	*	opcode ( leaves remaining gas untouched ) Solidity uses
27	0	*	invalid opcode revert ( consuming remaining gas )
27	0	*	Requirements :
27	0	*	divisor cannot zero
27	0	*	* Gods Unchained Raffle Token Exchange
27	0	*	* Version 1 0
27	0	*	* dedicated contract listing ( selling ) buying raffle tokens
27	0	*	* https : gu cards
27	0	*	Gas optimization : cheaper requiring 'a' zero ,
27	0	*	benefit lost 'b' also tested
27	0	*	See : https : Open Zeppelin openzeppelin solidity pull 522
27	0	*	Solidity automatically asserts dividing 0
27	0	*	V R B L E
27	0	*	raffle token contract
27	0	*	case exchange paused
27	0	*	Standard contract ownership
27	0	*	Next id next listing
27	0	*	raffle token listings mapped id
27	0	*	Next id next purche
27	0	*	R U C
27	0	*	listing raffle tokens
27	0	*	price per token ( wei )
27	0	*	many tokens ? ( Original Amount )
27	0	*	many tokens left ? ( Maybe altered due partial sales )
27	0	*	Listed ?
27	0	*	Active Inactive listing ?
27	0	*	purchase raffle tokens
27	0	*	many tokens ?
27	0	*	total price payed
27	0	*	purchase happen ?
27	0	*	F E R
27	0	*	Invokable contract owner
27	0	*	Invokable exchange paused
27	0	*	C N R U C R
27	0	*	F U N C N
27	0	*	buy Raffle
27	0	*	Add listing
27	0	*	Cancel listing
27	0	*	Set paused
27	0	*	Funds withdrawal cover operational costs
27	0	*	Contract may destroyed nothing else going
27	0	*	funds transferred contract owner
11	0	*	source : https : sigp solidity security blog
11	0	*	vulnerable lines : 20
11	0	*	sigp solidity security blog
11	0	*	collect ether
11	0	*	yes report ACCESS CONTROL
1	0	*	source : https : smartcontractsecurity SWC registry docs SWC 124 arbitrary location write simplesol
1	0	*	vulnerable lines : 27
1	0	*	smartcontractsecurity SWC registry docs SWC 124 arbitrary location write simplesol
1	0	*	yes report ACCESS CONTROL
1	0	*	condition always true since array lengths unsigned
1	0	*	underflow caused
1	0	*	write index less bonus Codes length
9	0	*	source : https : Smart Contract Security SWC registry blob master test cases solidity unprotected critical functions multiowned vulnerable multiowned vulnerable sol
9	0	*	vulnerable lines : 38
9	0	*	title Multi Ownable
9	0	*	Ownable constructor sets original `owner` contract sender
9	0	*	Throws called account owner
9	0	*	Adding new owners
9	0	*	Note "only Owner" modifier missing
9	0	*	Deleting owners
9	0	*	Smart Contract Security SWC registry blob master test cases solidity unprotected critical functions multiowned vulnerable multiowned vulnerable sol
9	0	*	owner = parent owner
9	0	*	yes report ACCESS CONTROL
25	0	*	fee whitelist
25	0	*	transfer amount zero
25	0	*	emit event stop execution
25	0	*	Calculate receiver balance
25	0	*	initial receive full value
25	0	*	Change sender balance
25	0	*	transaction whitelisted
25	0	*	calculate fees
25	0	*	Subtract fees receiver amount
25	0	*	Burn tokens
25	0	*	Transfer balance Dan Pan
25	0	*	Sanity checks
25	0	*	tokens created
25	0	*	Add tokens receiver
25	0	*	transfer amount zero
25	0	*	emit event stop execution
25	0	*	Calculate receiver balance
25	0	*	initial receive full value
25	0	*	Change sender balance
25	0	*	transaction whitelisted
25	0	*	calculate fees
25	0	*	Subtract fees receiver amount
25	0	*	Burn tokens
25	0	*	Transfer balance Dan Pan
25	0	*	Sanity checks
25	0	*	tokens created
25	0	*	Add tokens receiver
22	0	*	Wrappers Solidity's arithmetic operations added overflow
22	0	*	Arithmetic operations Solidity wrap overflow easily result
22	0	*	bugs , programmers usually assume overflow raises
22	0	*	error , standard behavior high level programming languages
22	0	*	`Safe Math` restores intuition reverting transaction
22	0	*	operation overflows
22	0	*	Using library instead unchecked operations eliminates entire
22	0	*	class bugs , recommended use always
22	0	*	Returns addition two unsigned integers , reverting
22	0	*	Counterpart Solidity's `+` operator
22	0	*	Requirements :
22	0	*	Addition cannot overflow
22	0	*	Returns subtraction two unsigned integers , reverting
22	0	*	overflow ( result negative )
22	0	*	Counterpart Solidity's ` ` operator
22	0	*	Requirements :
22	0	*	Subtraction cannot overflow
22	0	*	Returns subtraction two unsigned integers , reverting custom message
22	0	*	overflow ( result negative )
22	0	*	Counterpart Solidity's ` ` operator
22	0	*	Requirements :
22	0	*	Subtraction cannot overflow
22	0	*	NOTE : feature next version Open Zeppelin Contracts
22	0	*	Get via `npm install @openzeppelin contracts@next`
22	0	*	Returns multiplication two unsigned integers , reverting
22	0	*	Counterpart Solidity's `*` operator
22	0	*	Requirements :
22	0	*	Multiplication cannot overflow
22	0	*	Returns integer division two unsigned integers Reverts
22	0	*	division zero result rounded towards zero
22	0	*	Counterpart Solidity's ` ` operator Note : function uses
22	0	*	`revert` opcode ( leaves remaining gas untouched ) Solidity
22	0	*	uses invalid opcode revert ( consuming remaining gas )
22	0	*	Requirements :
22	0	*	divisor cannot zero
22	0	*	Returns integer division two unsigned integers Reverts custom message
22	0	*	division zero result rounded towards zero
22	0	*	Counterpart Solidity's ` ` operator Note : function uses
22	0	*	`revert` opcode ( leaves remaining gas untouched ) Solidity
22	0	*	uses invalid opcode revert ( consuming remaining gas )
22	0	*	Requirements :
22	0	*	divisor cannot zero
22	0	*	NOTE : feature next version Open Zeppelin Contracts
22	0	*	Get via `npm install @openzeppelin contracts@next`
22	0	*	Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
22	0	*	Reverts dividing zero
22	0	*	Counterpart Solidity's `%` operator function uses `revert`
22	0	*	opcode ( leaves remaining gas untouched ) Solidity uses
22	0	*	invalid opcode revert ( consuming remaining gas )
22	0	*	Requirements :
22	0	*	divisor cannot zero
22	0	*	Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
22	0	*	Reverts custom message dividing zero
22	0	*	Counterpart Solidity's `%` operator function uses `revert`
22	0	*	opcode ( leaves remaining gas untouched ) Solidity uses
22	0	*	invalid opcode revert ( consuming remaining gas )
22	0	*	Requirements :
22	0	*	divisor cannot zero
22	0	*	NOTE : feature next version Open Zeppelin Contracts
22	0	*	Get via `npm install @openzeppelin contracts@next`
22	0	*	sets 0 initials tokens , owner , supply Controller
22	0	*	serves constructor proxy compiles
22	0	*	memory model Implementation contract
22	0	*	constructor used ensure implementation
22	0	*	contract initialized uncontrolled implementation
22	0	*	contract might lead misleading state
22	0	*	users accidentally interact
22	0	*	Throws called account owner
22	0	*	Allows current owner transfer control contract new Owner
22	0	*	param new Owner address transfer ownership
22	0	*	Gas optimization : cheaper requiring 'a' zero ,
22	0	*	benefit lost 'b' also tested
22	0	*	See : https : Open Zeppelin openzeppelin contracts pull 522
22	0	*	Solidity automatically asserts dividing 0
22	0	*	INITIALIZATION DATA
22	0	*	OWNER DATA
22	0	*	INITIALIZATION FUNCTIONALITY
22	0	*	OWNER FUNCTIONALITY
13	0	*	Source Code first verified https : etherscan Friday , April 26 , 2019
13	0	*	etherscan Friday , April 26 , 2019
13	0	*	Total supply
13	0	*	Get token balance account `token Owner`
13	0	*	Transfer balance token owner's account `to` account
13	0	*	Owner's account must sufficient balance transfer
13	0	*	0 value transfers allowed
13	0	*	Token owner approve `spender` transfer ( ) `tokens`
13	0	*	token owner's account
13	0	*	https : ethereum EIPs blob master EIPS eip 20 token standard md
13	0	*	recommends checks approval double spend attack
13	0	*	implemented user interfaces
13	0	*	Transfer `tokens` `from` account `to` account
13	0	*	calling account must already sufficient tokens approve ( )
13	0	*	spending `from` account
13	0	*	account must sufficient balance transfer
13	0	*	Spender must sufficient allowance transfer
13	0	*	0 value transfers allowed
13	0	*	Returns amount tokens approved owner
13	0	*	transferred spender's account
13	0	*	Token owner approve `spender` transfer ( ) `tokens`
13	0	*	token owner's account `spender` contract function
13	0	*	`receive Approval ( ) ` executed
13	0	*	accept ETH
13	0	*	Owner transfer accidentally sent ERC20 tokens
5	0	*	source : https : trailofbits smart contracts blob master wrong constructor name incorrect constructor sol
5	0	*	vulnerable lines : 20
5	0	*	trailofbits smart contracts blob master wrong constructor name incorrect constructor sol
5	0	*	name constructor Missing
5	0	*	Anyone call Iam Missing contract deployed
5	0	*	yes report ACCESS CONTROL
28	0	*	Source Code first verified https : etherscan Tuesday , May 7 , 2019
28	0	*	etherscan Tuesday , May 7 , 2019
28	0	*	name , instance , "My test token"
28	0	*	Returns number decimals token uses set 3 , example , would support representation 0 001
28	0	*	Abbreviation token , like MTT
28	0	*	function sets Pause Status true , transfer transactions fail
28	0	*	Recording contract's owner
28	0	*	Set starting total
28	0	*	Set starting total
28	0	*	Subtract value number tokens account message sender
28	0	*	Transfer value number tokens recipient's account
28	0	*	Trigger coin transfer event
28	0	*	Trigger coin transfer event
28	0	*	Add value number tokens recipient's account
28	0	*	Deduct value number tokens payer's account ,
28	0	*	message sender reduce amount value transferred account
28	0	*	Trigger coin transfer event
28	0	*	Trigger coin transfer event
28	0	*	Allow spender take certain number tokens owner
28	0	*	following specific logic token protocol
28	0	*	Transfer ownership contract also hand tokens attached
28	0	*	Trigger contract ownership transfer event
28	0	*	Paused true , transactions paused
28	0	*	Amend contract name
24	0	*	Gas optimization : cheaper requiring 'a' zero ,
24	0	*	benefit lost 'b' also tested
24	0	*	See : https : Open Zeppelin openzeppelin solidity pull 522
24	0	*	Solidity automatically asserts dividing 0
38	0	*	require ( Valid Number ( result ) ) ;
7	0	*	source : https : smartcontractsecurity SWC registry docs SWC 118 incorrect constructor name2sol
7	0	*	vulnerable lines : 17
7	0	*	smartcontractsecurity SWC registry docs SWC 118 incorrect constructor name2sol
7	0	*	yes report ACCESS CONTROL
37	0	*	Wrappers Solidity's arithmetic operations added overflow
37	0	*	Arithmetic operations Solidity wrap overflow easily result
37	0	*	bugs , programmers usually assume overflow raises
37	0	*	error , standard behavior high level programming languages
37	0	*	`Safe Math` restores intuition reverting transaction
37	0	*	operation overflows
37	0	*	Using library instead unchecked operations eliminates entire
37	0	*	class bugs , recommended use always
37	0	*	Returns addition two unsigned integers , reverting
37	0	*	Counterpart Solidity's `+` operator
37	0	*	Requirements :
37	0	*	Addition cannot overflow
37	0	*	Returns subtraction two unsigned integers , reverting
37	0	*	overflow ( result negative )
37	0	*	Counterpart Solidity's ` ` operator
37	0	*	Requirements :
37	0	*	Subtraction cannot overflow
37	0	*	Returns multiplication two unsigned integers , reverting
37	0	*	Counterpart Solidity's `*` operator
37	0	*	Requirements :
37	0	*	Multiplication cannot overflow
37	0	*	Returns integer division two unsigned integers Reverts
37	0	*	division zero result rounded towards zero
37	0	*	Counterpart Solidity's ` ` operator Note : function uses
37	0	*	`revert` opcode ( leaves remaining gas untouched ) Solidity
37	0	*	uses invalid opcode revert ( consuming remaining gas )
37	0	*	Requirements :
37	0	*	divisor cannot zero
37	0	*	Returns remainder dividing two unsigned integers ( unsigned integer modulo ) ,
37	0	*	Reverts dividing zero
37	0	*	Counterpart Solidity's `%` operator function uses `revert`
37	0	*	opcode ( leaves remaining gas untouched ) Solidity uses
37	0	*	invalid opcode revert ( consuming remaining gas )
37	0	*	Requirements :
37	0	*	divisor cannot zero
37	0	*	Interface ERC20 standard defined EIP include
37	0	*	optional functions; access see `ERC20Detailed`
37	0	*	Returns amount tokens existence
37	0	*	Returns amount tokens owned `account`
37	0	*	Moves `amount` tokens caller's account `recipient`
37	0	*	Returns boolean value indicating whether operation succeeded
37	0	*	Emits `Transfer` event
37	0	*	Returns remaining number tokens `spender`
37	0	*	allowed spend behalf `owner` `transfer From`
37	0	*	zero default
37	0	*	value changes `approve` `transfer From` called
37	0	*	Sets `amount` allowance `spender` caller's tokens
37	0	*	Returns boolean value indicating whether operation succeeded
37	0	*	Beware changing allowance method brings risk
37	0	*	someone may use old new allowance unfortunate
37	0	*	transaction ordering One possible solution mitigate race
37	0	*	condition first reduce spender's allowance 0 set
37	0	*	desired value afterwards :
37	0	*	https : ethereum EIPs issues 20 issuecomment 263524729
37	0	*	Emits `Approval` event
37	0	*	Moves `amount` tokens `sender` `recipient` using
37	0	*	allowance mechanism `amount` deducted caller's
37	0	*	Returns boolean value indicating whether operation succeeded
37	0	*	Emits `Transfer` event
37	0	*	Emitted `value` tokens moved one account ( `from` )
37	0	*	another ( `to` )
37	0	*	Note `value` may zero
37	0	*	Emitted allowance `spender` `owner` set
37	0	*	call `approve` `value` new allowance
37	0	*	Implementation `IERC20` interface
37	0	*	implementation agnostic way tokens created means
37	0	*	supply mechanism added derived contract using ` mint`
37	0	*	generic mechanism see `ERC20Mintable`
37	0	*	detailed writeup see guide [How implement supply
37	0	*	mechanisms] ( https : forum zeppelin solutions implement erc20 supply mechanisms 226 )
37	0	*	followed general Open Zeppelin guidelines : functions revert instead
37	0	*	returning `false` failure behavior nonetheless conventional
37	0	*	conflict expectations ERC20 applications
37	0	*	Additionally , `Approval` event emitted calls `transfer From`
37	0	*	allows applications reconstruct allowance accounts
37	0	*	listening said events implementations EIP may emit
37	0	*	events , required specification
37	0	*	Finally , non standard `decrease Allowance` `increase Allowance`
37	0	*	functions added mitigate well known issues around setting
37	0	*	allowances See `IERC20 approve`
37	0	*	See `IERC20 total Supply`
37	0	*	See `IERC20 balance Of`
37	0	*	See `IERC20 transfer`
37	0	*	Requirements :
37	0	*	`recipient` cannot zero address
37	0	*	caller must balance least `amount`
37	0	*	See `IERC20 allowance`
37	0	*	See `IERC20 approve`
37	0	*	Requirements :
37	0	*	`spender` cannot zero address
37	0	*	See `IERC20 transfer From`
37	0	*	Emits `Approval` event indicating updated allowance
37	0	*	required EIP See note beginning `ERC20`;
37	0	*	Requirements :
37	0	*	`sender` `recipient` cannot zero address
37	0	*	`sender` must balance least `value`
37	0	*	caller must allowance `sender`'s tokens least
37	0	*	Atomically increases allowance granted `spender` caller
37	0	*	alternative `approve` used mitigation
37	0	*	problems described `IERC20 approve`
37	0	*	Emits `Approval` event indicating updated allowance
37	0	*	Requirements :
37	0	*	`spender` cannot zero address
37	0	*	Atomically decreases allowance granted `spender` caller
37	0	*	alternative `approve` used mitigation
37	0	*	problems described `IERC20 approve`
37	0	*	Emits `Approval` event indicating updated allowance
37	0	*	Requirements :
37	0	*	`spender` cannot zero address
37	0	*	`spender` must allowance caller least
37	0	*	`subtracted Value`
37	0	*	Moves tokens `amount` `sender` `recipient`
37	0	*	internal function equivalent `transfer` , used
37	0	*	e g implement automatic token fees , slashing mechanisms , etc
37	0	*	Emits `Transfer` event
37	0	*	Requirements :
37	0	*	`sender` cannot zero address
37	0	*	`recipient` cannot zero address
37	0	*	`sender` must balance least `amount`
37	0	*	Creates `amount` tokens assigns `account` , increasing
37	0	*	total supply
37	0	*	Emits `Transfer` event `from` set zero address
37	0	*	`to` cannot zero address
37	0	*	Destoys `amount` tokens `account` , reducing
37	0	*	total supply
37	0	*	Emits `Transfer` event `to` set zero address
37	0	*	`account` cannot zero address
37	0	*	`account` must least `amount` tokens
37	0	*	Sets `amount` allowance `spender` `owner`s tokens
37	0	*	internal function equivalent `approve` , used
37	0	*	e g set automatic allowances certain subsystems , etc
37	0	*	Emits `Approval` event
37	0	*	Requirements :
37	0	*	`owner` cannot zero address
37	0	*	`spender` cannot zero address
37	0	*	Destoys `amount` tokens `account` `amount` deducted
37	0	*	caller's allowance
37	0	*	See ` burn` ` approve`
37	0	*	Optional functions ERC20 standard
37	0	*	Sets values `name` , `symbol` , `decimals` three
37	0	*	values immutable : set
37	0	*	Returns name token
37	0	*	Returns symbol token , usually shorter version
37	0	*	Returns number decimals used get user representation
37	0	*	example , `decimals` equals `2` , balance `505` tokens
37	0	*	displayed user `5 , 05` ( `505 10 ** 2` )
37	0	*	Tokens usually opt value 18 , imitating relationship
37	0	*	Ether Wei
37	0	*	Note information used display purposes :
37	0	*	way affects arithmetic contract , including
37	0	*	`IERC20 balance Of` `IERC20 transfer`
37	0	*	Gas optimization : cheaper requiring 'a' zero ,
37	0	*	benefit lost 'b' also tested
37	0	*	See : https : Open Zeppelin openzeppelin contracts pull 522
37	0	*	Solidity automatically asserts dividing 0
37	0	*	ethereum EIPs issues 20 issuecomment 263524729
37	0	*	forum zeppelin solutions implement erc20 supply mechanisms 226 ) *
15	0	*	website : https : exclusiveplatform
15	0	*	title Safe Math
15	0	*	Multiplies two numbers , throws overflow
15	0	*	Integer division two numbers , truncating quotient
15	0	*	Subtracts two numbers , throws overflow ( e subtrahend greater minuend )
15	0	*	Adds two numbers , throws overflow
15	0	*	Ownable constructor sets original `owner` contract sender
15	0	*	Throws called account owner
15	0	*	Allows current owner transfer control contract new Owner
15	0	*	param new Owner address transfer ownership
15	0	*	20% bonus 5 eth
15	0	*	5% bonus 1 eth
15	0	*	mitigates ERC20 short address attack
15	0	*	suggested izqui9 @ : bit ly 2NMMCNv
15	0	*	@ actual transfer function token contract ,
15	0	*	called functions contract
15	0	*	@param address holding tokens transferred
15	0	*	@param address recipient
15	0	*	@param amount amount tokens transferred
15	0	*	@return True transfer successful
15	0	*	allow transfer 0x0 token contract
15	0	*	@return balance ` owner`
15	0	*	@notice `msg sender` approves ` spender` spend ` amount` tokens
15	0	*	behalf modified version ERC20 approve function
15	0	*	little bit safer
15	0	*	@param spender address account able transfer tokens
15	0	*	@param amount amount tokens approved transfer
15	0	*	@return True approval successful
15	0	*	change approve amount first reduce addresses`
15	0	*	allowance zero calling `approve ( spender , 0 ) `
15	0	*	already 0 mitigate race condition described :
15	0	*	https : ethereum EIPs issues 20 issuecomment 263524729
17	0	*	title Safe Math
17	0	*	Math operations safety checks throw error
17	0	*	Multiplies two numbers , throws overflow
17	0	*	Integer division two numbers , truncating quotient
17	0	*	Substracts two numbers , throws overflow ( e subtrahend greater minuend )
17	0	*	Adds two numbers , throws overflow
17	0	*	title owned
17	0	*	owned contract owner address , provides basic authorization
17	0	*	control functions , simplifies implementation "user permissions"
17	0	*	owned constructor sets original `owner` contract sender
17	0	*	Throws called account owner
17	0	*	Allows current owner transfer control contract new Owner
17	0	*	withdraws Contracts balance
17	0	*	functionhash 0x7ee20df8
17	0	*	team withdraw Contracts
17	0	*	either settled refunded funds transferred contract owner
17	0	*	team destruct
23	0	*	* whitebetting whitest football betting game based ethereum blockchain
23	0	*	Game information
23	0	*	game start time
23	0	*	game odds
23	0	*	Checking game status
23	0	*	Checking whether winning paid
23	0	*	Player betting infomation
23	0	*	betting type
23	0	*	Events issued make statistic recovery easier
23	0	*	Change game status
23	0	*	Refresh game odd
23	0	*	Save game information
23	0	*	Player make bet
23	0	*	Minium amount bet 0 001 ether
23	0	*	Check whether odds valid
23	0	*	Compare match mainnet odds submitted odds betting type
23	0	*	Betting possible game opening
23	0	*	Betting possible 10 min ago
23	0	*	Save betting information
23	0	*	Give prize money game result
23	0	*	Check game status whether opening
23	0	*	Check ever compensated
23	0	*	Check player betted
23	0	*	Give prize money !
23	0	*	Change game status
23	0	*	Standard modifier methods invokable contract owner
23	0	*	Get balance CA
23	0	*	Deposit owner CA
23	0	*	Change Owner
23	0	*	Fallback function
23	0	*	Withdraw CA owner
21	0	*	Source Code first verified https : etherscan Saturday , April 27 , 2019
21	0	*	title ERC20 interface
21	0	*	see https : eips ethereum org EIPS eip 20
21	0	*	title Safe Math
21	0	*	Unsigned math operations safety checks revert error
21	0	*	Multiplies two unsigned integers , reverts overflow
21	0	*	Integer division two unsigned integers truncating quotient , reverts division zero
21	0	*	Subtracts two unsigned integers , reverts overflow ( e subtrahend greater minuend )
21	0	*	Adds two unsigned integers , reverts overflow
21	0	*	Divides two unsigned integers returns remainder ( unsigned integer modulo ) ,
21	0	*	reverts dividing zero
21	0	*	title Standard ERC20 token
21	0	*	Implementation basic standard token
21	0	*	https : eips ethereum org EIPS eip 20
21	0	*	Originally based code First Blood :
21	0	*	https : Firstbloodio token blob master smart contract First Blood Token sol
21	0	*	implementation emits additional Approval events , allowing applications reconstruct allowance status
21	0	*	accounts listening said events Note required specification ,
21	0	*	compliant implementations may
21	0	*	Total number tokens existence
21	0	*	Gets balance specified address
21	0	*	param owner address query balance
21	0	*	return uint256 representing amount owned passed address
21	0	*	Function check amount tokens owner allowed spender
21	0	*	param owner address address owns funds
21	0	*	param spender address address spend funds
21	0	*	return uint256 specifying amount tokens still available spender
21	0	*	Transfer token specified address
21	0	*	param address transfer
21	0	*	param value amount transferred
21	0	*	Approve passed address spend specified amount tokens behalf msg sender
21	0	*	Beware changing allowance method brings risk someone may use old
21	0	*	new allowance unfortunate transaction ordering One possible solution mitigate
21	0	*	race condition first reduce spender's allowance 0 set desired value afterwards :
21	0	*	https : ethereum EIPs issues 20 issuecomment 263524729
21	0	*	param spender address spend funds
21	0	*	param value amount tokens spent
21	0	*	Transfer tokens one address another
21	0	*	Note function emits Approval event , required per specification ,
21	0	*	compliant implementations may emit event
21	0	*	param address address want send tokens
21	0	*	param address address want transfer
21	0	*	param value uint256 amount tokens transferred
21	0	*	Increase amount tokens owner allowed spender
21	0	*	approve called allowed[msg sender][spender] == 0 increment
21	0	*	allowed value better use function avoid 2 calls ( wait
21	0	*	first transaction mined )
21	0	*	Monolith DAO Token sol
21	0	*	Emits Approval event
21	0	*	param spender address spend funds
21	0	*	param added Value amount tokens increase allowance
21	0	*	Decrease amount tokens owner allowed spender
21	0	*	approve called allowed[msg sender][spender] == 0 decrement
21	0	*	allowed value better use function avoid 2 calls ( wait
21	0	*	first transaction mined )
21	0	*	Monolith DAO Token sol
21	0	*	Emits Approval event
21	0	*	param spender address spend funds
21	0	*	param subtracted Value amount tokens decrease allowance
21	0	*	Transfer token specified addresses
21	0	*	param address transfer
21	0	*	param address transfer
21	0	*	param value amount transferred
21	0	*	Internal function mints amount token assigns
21	0	*	account encapsulates modification balances
21	0	*	proper events emitted
21	0	*	param account account receive created tokens
21	0	*	param value amount created
21	0	*	Internal function burns amount token given
21	0	*	param account account whose tokens burnt
21	0	*	param value amount burnt
21	0	*	Approve address spend another addresses' tokens
21	0	*	param owner address owns tokens
21	0	*	param spender address spend tokens
21	0	*	param value number tokens spent
21	0	*	Internal function burns amount token given
21	0	*	account , deducting sender's allowance said account Uses
21	0	*	internal burn function
21	0	*	Emits Approval event ( reflecting reduced allowance )
21	0	*	param account account whose tokens burnt
21	0	*	param value amount burnt
21	0	*	title Burnable Token
21	0	*	Token irreversibly burned ( destroyed )
21	0	*	Burns specific amount tokens
21	0	*	param value amount token burned
21	0	*	Burns specific amount tokens target address decrements allowance
21	0	*	param address account whose tokens burned
21	0	*	param value uint256 amount token burned
21	0	*	title ERC20Detailed token
21	0	*	decimals visualization purposes
21	0	*	operations done using smallest indivisible token unit ,
21	0	*	Ethereum operations done wei
21	0	*	return name token
21	0	*	return symbol token
21	0	*	return number decimals token
21	0	*	etherscan Saturday , April 27 , 2019
21	0	*	eips ethereum org EIPS eip 20
21	0	*	Gas optimization : cheaper requiring 'a' zero ,
21	0	*	benefit lost 'b' also tested
21	0	*	See : https : Open Zeppelin openzeppelin solidity pull 522
21	0	*	Solidity automatically asserts dividing 0
21	0	*	eips ethereum org EIPS eip 20
21	0	*	Firstbloodio token blob master smart contract First Blood Token sol
21	0	*	ethereum EIPs issues 20 issuecomment 263524729
