added eth_serpent, contract separated to another file
This commit is contained in:
		
							
								
								
									
										14
									
								
								dist/ethereum.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								dist/ethereum.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										8
									
								
								dist/ethereum.js.map
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								dist/ethereum.js.map
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										2
									
								
								dist/ethereum.min.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								dist/ethereum.min.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										1
									
								
								index.js
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								index.js
									
									
									
									
									
								
							| @@ -3,5 +3,6 @@ web3.providers.WebSocketProvider = require('./lib/websocket'); | |||||||
| web3.providers.HttpRpcProvider = require('./lib/httprpc'); | web3.providers.HttpRpcProvider = require('./lib/httprpc'); | ||||||
| web3.providers.QtProvider = require('./lib/qt'); | web3.providers.QtProvider = require('./lib/qt'); | ||||||
| web3.providers.AutoProvider = require('./lib/autoprovider'); | web3.providers.AutoProvider = require('./lib/autoprovider'); | ||||||
|  | web3.contract = require('./lib/contract'); | ||||||
|  |  | ||||||
| module.exports = web3; | module.exports = web3; | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| var web3 = require('./lib/main'); | var web3 = require('./lib/main'); | ||||||
| web3.providers.QtProvider = require('./lib/qt'); | web3.providers.QtProvider = require('./lib/qt'); | ||||||
|  | web3.contract = require('./lib/contract'); | ||||||
|  |  | ||||||
| module.exports = web3; | module.exports = web3; | ||||||
|   | |||||||
							
								
								
									
										63
									
								
								lib/contract.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								lib/contract.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,63 @@ | |||||||
|  | /* | ||||||
|  |     This file is part of ethereum.js. | ||||||
|  |  | ||||||
|  |     ethereum.js is free software: you can redistribute it and/or modify | ||||||
|  |     it under the terms of the GNU Lesser General Public License as published by | ||||||
|  |     the Free Software Foundation, either version 3 of the License, or | ||||||
|  |     (at your option) any later version. | ||||||
|  |  | ||||||
|  |     ethereum.js is distributed in the hope that it will be useful, | ||||||
|  |     but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |     GNU Lesser General Public License for more details. | ||||||
|  |  | ||||||
|  |     You should have received a copy of the GNU Lesser General Public License | ||||||
|  |     along with ethereum.js.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  | */ | ||||||
|  | /** @file contract.js | ||||||
|  |  * @authors: | ||||||
|  |  *   Marek Kotewicz <marek@ethdev.com> | ||||||
|  |  * @date 2014 | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | if (process.env.NODE_ENV !== 'build') { | ||||||
|  |     var web3 = require('./web3'); // jshint ignore:line | ||||||
|  | } | ||||||
|  | var abi = require('./abi'); | ||||||
|  |  | ||||||
|  | var contract = function (address, desc) { | ||||||
|  |     var inputParser = abi.inputParser(desc); | ||||||
|  |     var outputParser = abi.outputParser(desc); | ||||||
|  |  | ||||||
|  |     var contract = {}; | ||||||
|  |  | ||||||
|  |     desc.forEach(function (method) { | ||||||
|  |         contract[method.name] = function () { | ||||||
|  |             var params = Array.prototype.slice.call(arguments); | ||||||
|  |             var parsed = inputParser[method.name].apply(null, params); | ||||||
|  |  | ||||||
|  |             var onSuccess = function (result) { | ||||||
|  |                 return outputParser[method.name](result); | ||||||
|  |             }; | ||||||
|  |  | ||||||
|  |             return { | ||||||
|  |                 call: function (extra) { | ||||||
|  |                     extra = extra || {}; | ||||||
|  |                     extra.to = address; | ||||||
|  |                     extra.data = parsed; | ||||||
|  |                     return web3.eth.call(extra).then(onSuccess); | ||||||
|  |                 }, | ||||||
|  |                 transact: function (extra) { | ||||||
|  |                     extra = extra || {}; | ||||||
|  |                     extra.to = address; | ||||||
|  |                     extra.data = parsed; | ||||||
|  |                     return web3.eth.transact(extra).then(onSuccess); | ||||||
|  |                 } | ||||||
|  |             }; | ||||||
|  |         }; | ||||||
|  |     }); | ||||||
|  |           | ||||||
|  |     return contract; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | module.exports = contract; | ||||||
							
								
								
									
										40
									
								
								lib/main.js
									
									
									
									
									
								
							
							
						
						
									
										40
									
								
								lib/main.js
									
									
									
									
									
								
							| @@ -22,8 +22,6 @@ | |||||||
|  * @date 2014 |  * @date 2014 | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| var abi = require('./abi'); |  | ||||||
|  |  | ||||||
| function flattenPromise (obj) { | function flattenPromise (obj) { | ||||||
|     if (obj instanceof Promise) { |     if (obj instanceof Promise) { | ||||||
|         return Promise.resolve(obj); |         return Promise.resolve(obj); | ||||||
| @@ -89,7 +87,8 @@ var ethMethods = function () { | |||||||
|     { name: 'uncle', call: uncleCall }, |     { name: 'uncle', call: uncleCall }, | ||||||
|     { name: 'compilers', call: 'eth_compilers' }, |     { name: 'compilers', call: 'eth_compilers' }, | ||||||
|     { name: 'lll', call: 'eth_lll' }, |     { name: 'lll', call: 'eth_lll' }, | ||||||
|     { name: 'solidity', call: 'eth_solidity' } |     { name: 'solidity', call: 'eth_solidity' }, | ||||||
|  |     { name: 'serpent', call: 'eth_serpent' } | ||||||
|     ]; |     ]; | ||||||
|     return methods; |     return methods; | ||||||
| }; | }; | ||||||
| @@ -455,40 +454,5 @@ function messageHandler(data) { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| web3.contract = function (address, desc) { |  | ||||||
|     var inputParser = abi.inputParser(desc); |  | ||||||
|     var outputParser = abi.outputParser(desc); |  | ||||||
|  |  | ||||||
|     var contract = {}; |  | ||||||
|  |  | ||||||
|     desc.forEach(function (method) { |  | ||||||
|         contract[method.name] = function () { |  | ||||||
|             var params = Array.prototype.slice.call(arguments); |  | ||||||
|             var parsed = inputParser[method.name].apply(null, params); |  | ||||||
|  |  | ||||||
|             var onSuccess = function (result) { |  | ||||||
|                 return outputParser[method.name](result); |  | ||||||
|             }; |  | ||||||
|  |  | ||||||
|             return { |  | ||||||
|                 call: function (extra) { |  | ||||||
|                     extra = extra || {}; |  | ||||||
|                     extra.to = address; |  | ||||||
|                     extra.data = parsed; |  | ||||||
|                     return web3.eth.call(extra).then(onSuccess); |  | ||||||
|                 }, |  | ||||||
|                 transact: function (extra) { |  | ||||||
|                     extra = extra || {}; |  | ||||||
|                     extra.to = address; |  | ||||||
|                     extra.data = parsed; |  | ||||||
|                     return web3.eth.transact(extra).then(onSuccess); |  | ||||||
|                 } |  | ||||||
|             }; |  | ||||||
|         }; |  | ||||||
|     }); |  | ||||||
|           |  | ||||||
|     return contract; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| module.exports = web3; | module.exports = web3; | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user