mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Merge pull request #5962 from ethereum/docs-modular-example
[DOCS] Create modular example
This commit is contained in:
		
						commit
						2f0926c368
					
				
							
								
								
									
										57
									
								
								docs/examples/modular.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								docs/examples/modular.rst
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,57 @@ | ||||
| .. index:: contract;modular, modular contract | ||||
| 
 | ||||
| ***************** | ||||
| Modular Contracts | ||||
| ***************** | ||||
| 
 | ||||
| A modular approach to building your contracts helps you prevent overflow risks | ||||
| and unexpected tokens. In the example below, the contract uses the ``move`` method | ||||
| of the ``Balances`` :ref:`library <libraries>` to check that balances sent between | ||||
| addresses match what you expect. | ||||
| 
 | ||||
| :: | ||||
| 
 | ||||
|     pragma solidity >=0.4.22 <0.6.0; | ||||
| 
 | ||||
|     library Balances { | ||||
|         function move(mapping(address => uint256) storage balances, address from, address to, uint amount) internal { | ||||
|             require(balances[from] >= amount); | ||||
|             require(balances[to] + amount >= balances[to]); | ||||
|             balances[from] -= amount; | ||||
|             balances[to] += amount; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     contract Token { | ||||
|         mapping(address => uint256) balances; | ||||
|         using Balances for *; | ||||
|         mapping(address => mapping (address => uint256)) allowed; | ||||
| 
 | ||||
|         event Transfer(address from, address to, uint amount); | ||||
|         event Approval(address owner, address spender, uint amount); | ||||
| 
 | ||||
|         function balanceOf(address tokenOwner) public view returns (uint balance) { | ||||
|             return balances[tokenOwner]; | ||||
|         } | ||||
|         function transfer(address to, uint amount) public returns (bool success) { | ||||
|             balances.move(msg.sender, to, amount); | ||||
|             emit Transfer(msg.sender, to, amount); | ||||
|             return true; | ||||
| 
 | ||||
|         } | ||||
| 
 | ||||
|         function transferFrom(address from, address to, uint amount) public returns (bool success) { | ||||
|             require(allowed[from][msg.sender] >= amount); | ||||
|             allowed[from][msg.sender] -= amount; | ||||
|             balances.move(from, to, amount); | ||||
|             emit Transfer(from, to, amount); | ||||
|             return true; | ||||
|         } | ||||
| 
 | ||||
|         function approve(address spender, uint tokens) public returns (bool success) { | ||||
|             require(allowed[msg.sender][spender] == 0, ""); | ||||
|             allowed[msg.sender][spender] = tokens; | ||||
|             emit Approval(msg.sender, spender, tokens); | ||||
|             return true; | ||||
|         } | ||||
|     } | ||||
| @ -3,8 +3,11 @@ Solidity by Example | ||||
| ################### | ||||
| 
 | ||||
| .. include:: examples/voting.rst | ||||
| 
 | ||||
| .. include:: examples/blind-auction.rst | ||||
| 
 | ||||
| .. include:: examples/safe-remote.rst | ||||
| 
 | ||||
| .. include:: examples/micropayment.rst | ||||
| .. include:: examples/micropayment.rst | ||||
| 
 | ||||
| .. include:: examples/modular.rst | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user