Merge branch 'cpp' into cpp2
Conflicts: example/balance.html
This commit is contained in:
		
						commit
						94e0e5ab7d
					
				
							
								
								
									
										287
									
								
								dist/ethereum.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										287
									
								
								dist/ethereum.js
									
									
									
									
										vendored
									
									
								
							| @ -66,6 +66,22 @@ var getMethodWithName = function (json, methodName) { | |||||||
|     return json[index]; |     return json[index]; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | /// Filters all function from input abi
 | ||||||
|  | /// @returns abi array with filtered objects of type 'function'
 | ||||||
|  | var filterFunctions = function (json) { | ||||||
|  |     return json.filter(function (current) { | ||||||
|  |         return current.type === 'function';  | ||||||
|  |     });  | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | /// Filters all events form input abi
 | ||||||
|  | /// @returns abi array with filtered objects of type 'event'
 | ||||||
|  | var filterEvents = function (json) { | ||||||
|  |     return json.filter(function (current) { | ||||||
|  |         return current.type === 'event'; | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| /// @param string string to be padded
 | /// @param string string to be padded
 | ||||||
| /// @param number of characters that result string should have
 | /// @param number of characters that result string should have
 | ||||||
| /// @param sign, by default 0
 | /// @param sign, by default 0
 | ||||||
| @ -212,6 +228,7 @@ var signedIsNegative = function (value) { | |||||||
| /// Formats input right-aligned input bytes to int
 | /// Formats input right-aligned input bytes to int
 | ||||||
| /// @returns right-aligned input bytes formatted to int
 | /// @returns right-aligned input bytes formatted to int
 | ||||||
| var formatOutputInt = function (value) { | var formatOutputInt = function (value) { | ||||||
|  |     value = value || "0"; | ||||||
|     // check if it's negative number
 |     // check if it's negative number
 | ||||||
|     // it it is, return two's complement
 |     // it it is, return two's complement
 | ||||||
|     if (signedIsNegative(value)) { |     if (signedIsNegative(value)) { | ||||||
| @ -223,6 +240,7 @@ var formatOutputInt = function (value) { | |||||||
| /// Formats big right-aligned input bytes to uint
 | /// Formats big right-aligned input bytes to uint
 | ||||||
| /// @returns right-aligned input bytes formatted to uint
 | /// @returns right-aligned input bytes formatted to uint
 | ||||||
| var formatOutputUInt = function (value) { | var formatOutputUInt = function (value) { | ||||||
|  |     value = value || "0"; | ||||||
|     return new BigNumber(value, 16); |     return new BigNumber(value, 16); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| @ -350,7 +368,7 @@ var methodTypeName = function (method) { | |||||||
| /// @returns input parser object for given json abi
 | /// @returns input parser object for given json abi
 | ||||||
| var inputParser = function (json) { | var inputParser = function (json) { | ||||||
|     var parser = {}; |     var parser = {}; | ||||||
|     json.forEach(function (method) { |     filterFunctions(json).forEach(function (method) { | ||||||
|         var displayName = methodDisplayName(method.name);  |         var displayName = methodDisplayName(method.name);  | ||||||
|         var typeName = methodTypeName(method.name); |         var typeName = methodTypeName(method.name); | ||||||
| 
 | 
 | ||||||
| @ -373,7 +391,7 @@ var inputParser = function (json) { | |||||||
| /// @returns output parser for given json abi
 | /// @returns output parser for given json abi
 | ||||||
| var outputParser = function (json) { | var outputParser = function (json) { | ||||||
|     var parser = {}; |     var parser = {}; | ||||||
|     json.forEach(function (method) { |     filterFunctions(json).forEach(function (method) { | ||||||
| 
 | 
 | ||||||
|         var displayName = methodDisplayName(method.name);  |         var displayName = methodDisplayName(method.name);  | ||||||
|         var typeName = methodTypeName(method.name); |         var typeName = methodTypeName(method.name); | ||||||
| @ -404,11 +422,13 @@ module.exports = { | |||||||
|     methodSignature: methodSignature, |     methodSignature: methodSignature, | ||||||
|     methodDisplayName: methodDisplayName, |     methodDisplayName: methodDisplayName, | ||||||
|     methodTypeName: methodTypeName, |     methodTypeName: methodTypeName, | ||||||
|     getMethodWithName: getMethodWithName |     getMethodWithName: getMethodWithName, | ||||||
|  |     filterFunctions: filterFunctions, | ||||||
|  |     filterEvents: filterEvents | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| },{"./web3":7}],2:[function(require,module,exports){ | },{"./web3":8}],2:[function(require,module,exports){ | ||||||
| /* | /* | ||||||
|     This file is part of ethereum.js. |     This file is part of ethereum.js. | ||||||
| 
 | 
 | ||||||
| @ -431,71 +451,40 @@ module.exports = { | |||||||
|  * @date 2014 |  * @date 2014 | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| var web3 = require('./web3'); // jshint ignore:line
 | var web3 = require('./web3');  | ||||||
| var abi = require('./abi'); | var abi = require('./abi'); | ||||||
|  | var eventImpl = require('./event'); | ||||||
| 
 | 
 | ||||||
| /** | var addFunctionRelatedPropertiesToContract = function (contract) { | ||||||
|  * This method should be called when we want to call / transact some solidity method from javascript |  | ||||||
|  * it returns an object which has same methods available as solidity contract description |  | ||||||
|  * usage example:  |  | ||||||
|  * |  | ||||||
|  * var abi = [{ |  | ||||||
|  *      name: 'myMethod', |  | ||||||
|  *      inputs: [{ name: 'a', type: 'string' }], |  | ||||||
|  *      outputs: [{name: 'd', type: 'string' }] |  | ||||||
|  * }];  // contract abi
 |  | ||||||
|  * |  | ||||||
|  * var myContract = web3.eth.contract('0x0123123121', abi); // creation of contract object
 |  | ||||||
|  * |  | ||||||
|  * myContract.myMethod('this is test string param for call'); // myMethod call (implicit, default)
 |  | ||||||
|  * myContract.call().myMethod('this is test string param for call'); // myMethod call (explicit)
 |  | ||||||
|  * myContract.transact().myMethod('this is test string param for transact'); // myMethod transact
 |  | ||||||
|  * |  | ||||||
|  * @param address - address of the contract, which should be called |  | ||||||
|  * @param desc - abi json description of the contract, which is being created |  | ||||||
|  * @returns contract object |  | ||||||
|  */ |  | ||||||
|      |      | ||||||
| var contract = function (address, desc) { |     contract.call = function (options) { | ||||||
|  |         contract._isTransact = false; | ||||||
|  |         contract._options = options; | ||||||
|  |         return contract; | ||||||
|  |     }; | ||||||
| 
 | 
 | ||||||
|     desc.forEach(function (method) { |     contract.transact = function (options) { | ||||||
|         // workaround for invalid assumption that method.name is the full anonymous prototype of the method.
 |         contract._isTransact = true; | ||||||
|         // it's not. it's just the name. the rest of the code assumes it's actually the anonymous
 |         contract._options = options; | ||||||
|         // prototype, so we make it so as a workaround.
 |         return contract; | ||||||
|         if (method.name.indexOf('(') === -1) { |     }; | ||||||
|             var displayName = method.name; | 
 | ||||||
|             var typeName = method.inputs.map(function(i){return i.type; }).join(); |     contract._options = {}; | ||||||
|             method.name = displayName + '(' + typeName + ')'; |     ['gas', 'gasPrice', 'value', 'from'].forEach(function(p) { | ||||||
|         } |         contract[p] = function (v) { | ||||||
|  |             contract._options[p] = v; | ||||||
|  |             return contract; | ||||||
|  |         }; | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | var addFunctionsToContract = function (contract, desc, address) { | ||||||
|     var inputParser = abi.inputParser(desc); |     var inputParser = abi.inputParser(desc); | ||||||
|     var outputParser = abi.outputParser(desc); |     var outputParser = abi.outputParser(desc); | ||||||
| 
 | 
 | ||||||
|     var result = {}; |     // create contract functions
 | ||||||
| 
 |     abi.filterFunctions(desc).forEach(function (method) { | ||||||
|     result.call = function (options) { |  | ||||||
|         result._isTransact = false; |  | ||||||
|         result._options = options; |  | ||||||
|         return result; |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     result.transact = function (options) { |  | ||||||
|         result._isTransact = true; |  | ||||||
|         result._options = options; |  | ||||||
|         return result; |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     result._options = {}; |  | ||||||
|     ['gas', 'gasPrice', 'value', 'from'].forEach(function(p) { |  | ||||||
|         result[p] = function (v) { |  | ||||||
|             result._options[p] = v; |  | ||||||
|             return result; |  | ||||||
|         }; |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|     desc.forEach(function (method) { |  | ||||||
| 
 | 
 | ||||||
|         var displayName = abi.methodDisplayName(method.name); |         var displayName = abi.methodDisplayName(method.name); | ||||||
|         var typeName = abi.methodTypeName(method.name); |         var typeName = abi.methodTypeName(method.name); | ||||||
| @ -505,16 +494,16 @@ var contract = function (address, desc) { | |||||||
|             var signature = abi.methodSignature(method.name); |             var signature = abi.methodSignature(method.name); | ||||||
|             var parsed = inputParser[displayName][typeName].apply(null, params); |             var parsed = inputParser[displayName][typeName].apply(null, params); | ||||||
| 
 | 
 | ||||||
|             var options = result._options || {}; |             var options = contract._options || {}; | ||||||
|             options.to = address; |             options.to = address; | ||||||
|             options.data = signature + parsed; |             options.data = signature + parsed; | ||||||
|              |              | ||||||
|             var isTransact = result._isTransact === true || (result._isTransact !== false && !method.constant); |             var isTransact = contract._isTransact === true || (contract._isTransact !== false && !method.constant); | ||||||
|             var collapse = options.collapse !== false; |             var collapse = options.collapse !== false; | ||||||
|              |              | ||||||
|             // reset
 |             // reset
 | ||||||
|             result._options = {}; |             contract._options = {}; | ||||||
|             result._isTransact = null; |             contract._isTransact = null; | ||||||
| 
 | 
 | ||||||
|             if (isTransact) { |             if (isTransact) { | ||||||
|                 // it's used byt natspec.js
 |                 // it's used byt natspec.js
 | ||||||
| @ -541,13 +530,102 @@ var contract = function (address, desc) { | |||||||
|             return ret; |             return ret; | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         if (result[displayName] === undefined) { |         if (contract[displayName] === undefined) { | ||||||
|             result[displayName] = impl; |             contract[displayName] = impl; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         result[displayName][typeName] = impl; |         contract[displayName][typeName] = impl; | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | var addEventRelatedPropertiesToContract = function (contract, desc, address) { | ||||||
|  |     contract.address = address; | ||||||
|  |      | ||||||
|  |     Object.defineProperty(contract, 'topics', { | ||||||
|  |         get: function() { | ||||||
|  |             return abi.filterEvents(desc).map(function (e) { | ||||||
|  |                 return abi.methodSignature(e.name); | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | var addEventsToContract = function (contract, desc, address) { | ||||||
|  |     // create contract events
 | ||||||
|  |     abi.filterEvents(desc).forEach(function (e) { | ||||||
|  | 
 | ||||||
|  |         var impl = function () { | ||||||
|  |             var params = Array.prototype.slice.call(arguments); | ||||||
|  |             var signature = abi.methodSignature(e.name); | ||||||
|  |             var event = eventImpl(address, signature); | ||||||
|  |             var o = event.apply(null, params); | ||||||
|  |             return web3.eth.watch(o);   | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         impl.address = address; | ||||||
|  | 
 | ||||||
|  |         Object.defineProperty(impl, 'topics', { | ||||||
|  |             get: function() { | ||||||
|  |                 return [abi.methodSignature(e.name)]; | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |          | ||||||
|  |         // TODO: rename these methods, cause they are used not only for methods
 | ||||||
|  |         var displayName = abi.methodDisplayName(e.name); | ||||||
|  |         var typeName = abi.methodTypeName(e.name); | ||||||
|  | 
 | ||||||
|  |         if (contract[displayName] === undefined) { | ||||||
|  |             contract[displayName] = impl; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         contract[displayName][typeName] = impl; | ||||||
| 
 | 
 | ||||||
|     }); |     }); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * This method should be called when we want to call / transact some solidity method from javascript | ||||||
|  |  * it returns an object which has same methods available as solidity contract description | ||||||
|  |  * usage example:  | ||||||
|  |  * | ||||||
|  |  * var abi = [{ | ||||||
|  |  *      name: 'myMethod', | ||||||
|  |  *      inputs: [{ name: 'a', type: 'string' }], | ||||||
|  |  *      outputs: [{name: 'd', type: 'string' }] | ||||||
|  |  * }];  // contract abi
 | ||||||
|  |  * | ||||||
|  |  * var myContract = web3.eth.contract('0x0123123121', abi); // creation of contract object
 | ||||||
|  |  * | ||||||
|  |  * myContract.myMethod('this is test string param for call'); // myMethod call (implicit, default)
 | ||||||
|  |  * myContract.call().myMethod('this is test string param for call'); // myMethod call (explicit)
 | ||||||
|  |  * myContract.transact().myMethod('this is test string param for transact'); // myMethod transact
 | ||||||
|  |  * | ||||||
|  |  * @param address - address of the contract, which should be called | ||||||
|  |  * @param desc - abi json description of the contract, which is being created | ||||||
|  |  * @returns contract object | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | var contract = function (address, desc) { | ||||||
|  | 
 | ||||||
|  |     // workaround for invalid assumption that method.name is the full anonymous prototype of the method.
 | ||||||
|  |     // it's not. it's just the name. the rest of the code assumes it's actually the anonymous
 | ||||||
|  |     // prototype, so we make it so as a workaround.
 | ||||||
|  |     // TODO: we may not want to modify input params, maybe use copy instead?
 | ||||||
|  |     desc.forEach(function (method) { | ||||||
|  |         if (method.name.indexOf('(') === -1) { | ||||||
|  |             var displayName = method.name; | ||||||
|  |             var typeName = method.inputs.map(function(i){return i.type; }).join(); | ||||||
|  |             method.name = displayName + '(' + typeName + ')'; | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     var result = {}; | ||||||
|  |     addFunctionRelatedPropertiesToContract(result); | ||||||
|  |     addFunctionsToContract(result, desc, address); | ||||||
|  |     addEventRelatedPropertiesToContract(result, desc, address); | ||||||
|  |     addEventsToContract(result, desc, address); | ||||||
| 
 | 
 | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
| @ -555,7 +633,44 @@ var contract = function (address, desc) { | |||||||
| module.exports = contract; | module.exports = contract; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| },{"./abi":1,"./web3":7}],3:[function(require,module,exports){ | },{"./abi":1,"./event":3,"./web3":8}],3:[function(require,module,exports){ | ||||||
|  | /* | ||||||
|  |     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 event.js | ||||||
|  |  * @authors: | ||||||
|  |  *   Marek Kotewicz <marek@ethdev.com> | ||||||
|  |  * @date 2014 | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | var implementationOfEvent = function (address, signature) { | ||||||
|  |      | ||||||
|  |     return function (options) { | ||||||
|  |         var o = options || {}; | ||||||
|  |         o.address = o.address || address; | ||||||
|  |         o.topics = o.topics || []; | ||||||
|  |         o.topics.push(signature); | ||||||
|  |         return o; | ||||||
|  |     }; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | module.exports = implementationOfEvent; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | },{}],4:[function(require,module,exports){ | ||||||
| /* | /* | ||||||
|     This file is part of ethereum.js. |     This file is part of ethereum.js. | ||||||
| 
 | 
 | ||||||
| @ -589,6 +704,19 @@ var Filter = function(options, impl) { | |||||||
|     this.impl = impl; |     this.impl = impl; | ||||||
|     this.callbacks = []; |     this.callbacks = []; | ||||||
| 
 | 
 | ||||||
|  |     if (typeof options !== "string") { | ||||||
|  |         // evaluate lazy properties
 | ||||||
|  |         options = { | ||||||
|  |             to: options.to, | ||||||
|  |             topics: options.topics, | ||||||
|  |             earliest: options.earliest, | ||||||
|  |             latest: options.latest, | ||||||
|  |             max: options.max, | ||||||
|  |             skip: options.skip, | ||||||
|  |             address: options.address | ||||||
|  |         }; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     this.id = impl.newFilter(options); |     this.id = impl.newFilter(options); | ||||||
|     web3.provider.startPolling({call: impl.changed, args: [this.id]}, this.id, this.trigger.bind(this)); |     web3.provider.startPolling({call: impl.changed, args: [this.id]}, this.id, this.trigger.bind(this)); | ||||||
| }; | }; | ||||||
| @ -606,7 +734,7 @@ Filter.prototype.changed = function(callback) { | |||||||
| /// trigger calling new message from people
 | /// trigger calling new message from people
 | ||||||
| Filter.prototype.trigger = function(messages) { | Filter.prototype.trigger = function(messages) { | ||||||
|     for (var i = 0; i < this.callbacks.length; i++) { |     for (var i = 0; i < this.callbacks.length; i++) { | ||||||
|         for (var j = 0; j < messages; j++) { |         for (var j = 0; j < messages.length; j++) { | ||||||
|             this.callbacks[i].call(this, messages[j]); |             this.callbacks[i].call(this, messages[j]); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @ -630,7 +758,7 @@ Filter.prototype.logs = function () { | |||||||
| 
 | 
 | ||||||
| module.exports = Filter; | module.exports = Filter; | ||||||
| 
 | 
 | ||||||
| },{"./web3":7}],4:[function(require,module,exports){ | },{"./web3":8}],5:[function(require,module,exports){ | ||||||
| /* | /* | ||||||
|     This file is part of ethereum.js. |     This file is part of ethereum.js. | ||||||
| 
 | 
 | ||||||
| @ -702,7 +830,7 @@ HttpSyncProvider.prototype.send = function (payload) { | |||||||
| module.exports = HttpSyncProvider; | module.exports = HttpSyncProvider; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| },{}],5:[function(require,module,exports){ | },{}],6:[function(require,module,exports){ | ||||||
| /* | /* | ||||||
|     This file is part of ethereum.js. |     This file is part of ethereum.js. | ||||||
| 
 | 
 | ||||||
| @ -781,6 +909,12 @@ ProviderManager.prototype.send = function(data) { | |||||||
|     //TODO: handle error here? 
 |     //TODO: handle error here? 
 | ||||||
|     var result = this.provider.send(data); |     var result = this.provider.send(data); | ||||||
|     result = JSON.parse(result); |     result = JSON.parse(result); | ||||||
|  | 
 | ||||||
|  |     if (result.error) { | ||||||
|  |         console.log(result.error); | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     return result.result; |     return result.result; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| @ -808,7 +942,7 @@ ProviderManager.prototype.stopPolling = function (pollId) { | |||||||
| module.exports = ProviderManager; | module.exports = ProviderManager; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| },{"./web3":7}],6:[function(require,module,exports){ | },{"./web3":8}],7:[function(require,module,exports){ | ||||||
| /* | /* | ||||||
|     This file is part of ethereum.js. |     This file is part of ethereum.js. | ||||||
| 
 | 
 | ||||||
| @ -842,7 +976,7 @@ QtSyncProvider.prototype.send = function (payload) { | |||||||
| module.exports = QtSyncProvider; | module.exports = QtSyncProvider; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| },{}],7:[function(require,module,exports){ | },{}],8:[function(require,module,exports){ | ||||||
| /* | /* | ||||||
|     This file is part of ethereum.js. |     This file is part of ethereum.js. | ||||||
| 
 | 
 | ||||||
| @ -943,7 +1077,6 @@ var ethProperties = function () { | |||||||
|     { name: 'listening', getter: 'eth_listening', setter: 'eth_setListening' }, |     { name: 'listening', getter: 'eth_listening', setter: 'eth_setListening' }, | ||||||
|     { name: 'mining', getter: 'eth_mining', setter: 'eth_setMining' }, |     { name: 'mining', getter: 'eth_mining', setter: 'eth_setMining' }, | ||||||
|     { name: 'gasPrice', getter: 'eth_gasPrice' }, |     { name: 'gasPrice', getter: 'eth_gasPrice' }, | ||||||
|     { name: 'account', getter: 'eth_account' }, |  | ||||||
|     { name: 'accounts', getter: 'eth_accounts' }, |     { name: 'accounts', getter: 'eth_accounts' }, | ||||||
|     { name: 'peerCount', getter: 'eth_peerCount' }, |     { name: 'peerCount', getter: 'eth_peerCount' }, | ||||||
|     { name: 'defaultBlock', getter: 'eth_defaultBlock', setter: 'eth_setDefaultBlock' }, |     { name: 'defaultBlock', getter: 'eth_defaultBlock', setter: 'eth_setDefaultBlock' }, | ||||||
| @ -1078,7 +1211,9 @@ var web3 = { | |||||||
| 
 | 
 | ||||||
|     /// @returns decimal representaton of hex value prefixed by 0x
 |     /// @returns decimal representaton of hex value prefixed by 0x
 | ||||||
|     toDecimal: function (val) { |     toDecimal: function (val) { | ||||||
|         return (new BigNumber(val.substring(2), 16).toString(10)); |         // remove 0x and place 0, if it's required
 | ||||||
|  |         val = val.length > 2 ? val.substring(2) : "0"; | ||||||
|  |         return (new BigNumber(val, 16).toString(10)); | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     /// @returns hex representation (prefixed by 0x) of decimal value
 |     /// @returns hex representation (prefixed by 0x) of decimal value
 | ||||||
| @ -1183,7 +1318,7 @@ web3.abi = require('./lib/abi'); | |||||||
| 
 | 
 | ||||||
| module.exports = web3; | module.exports = web3; | ||||||
| 
 | 
 | ||||||
| },{"./lib/abi":1,"./lib/contract":2,"./lib/filter":3,"./lib/httpsync":4,"./lib/providermanager":5,"./lib/qtsync":6,"./lib/web3":7}]},{},["web3"]) | },{"./lib/abi":1,"./lib/contract":2,"./lib/filter":4,"./lib/httpsync":5,"./lib/providermanager":6,"./lib/qtsync":7,"./lib/web3":8}]},{},["web3"]) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| //# sourceMappingURL=ethereum.js.map
 | //# sourceMappingURL=ethereum.js.map
 | ||||||
							
								
								
									
										14
									
								
								dist/ethereum.js.map
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								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
											
										
									
								
							| @ -20,6 +20,7 @@ | |||||||
|     // contract description, this will be autogenerated somehow |     // contract description, this will be autogenerated somehow | ||||||
|     var desc =  [{ |     var desc =  [{ | ||||||
|         "name": "multiply(uint256)", |         "name": "multiply(uint256)", | ||||||
|  |         "type": "function", | ||||||
|         "inputs": [ |         "inputs": [ | ||||||
|         { |         { | ||||||
|             "name": "a", |             "name": "a", | ||||||
|  | |||||||
							
								
								
									
										67
									
								
								example/event.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								example/event.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,67 @@ | |||||||
|  | <!doctype> | ||||||
|  | <html> | ||||||
|  |     <head> | ||||||
|  |     <script type="text/javascript" src="js/bignumber.js/bignumber.min.js"></script> | ||||||
|  |     <script type="text/javascript" src="../dist/ethereum.js"></script> | ||||||
|  |     <script type="text/javascript"> | ||||||
|  |         var web3 = require('web3'); | ||||||
|  |         web3.setProvider(new web3.providers.HttpSyncProvider('http://localhost:8080')); | ||||||
|  | 
 | ||||||
|  |         var desc = [{ | ||||||
|  |             "type":"event", | ||||||
|  |             "inputs": [{"name":"a","type":"uint256","indexed":true},{"name":"b","type":"hash256","indexed":false}], | ||||||
|  |             "name":"Event" | ||||||
|  |         }, { | ||||||
|  |             "type":"event", | ||||||
|  |             "inputs": [{"name":"a","type":"uint256","indexed":true},{"name":"b","type":"hash256","indexed":false}], | ||||||
|  |             "name":"Event2" | ||||||
|  |         }, { | ||||||
|  |             "type":"function", | ||||||
|  |             "inputs": [{"name":"a","type":"uint256"}], | ||||||
|  |             "name":"foo", | ||||||
|  |             "outputs": [] | ||||||
|  |         }]; | ||||||
|  | 
 | ||||||
|  |         var address = '0x01'; | ||||||
|  | 
 | ||||||
|  |         var contract = web3.eth.contract(address, desc);  | ||||||
|  | 
 | ||||||
|  |         function test1() { | ||||||
|  |             web3.eth.watch(contract).changed(function (res) { | ||||||
|  |                  | ||||||
|  |             }); | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         function test2() { | ||||||
|  |             web3.eth.watch(contract.Event).changed(function (res) { | ||||||
|  |                  | ||||||
|  |             }); | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         function test3() { | ||||||
|  |             contract.Event().changed(function (res) { | ||||||
|  |                  | ||||||
|  |             }); | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         // not valid | ||||||
|  |         // function test4() { | ||||||
|  |         //    web3.eth.watch([contract.Event, contract.Event2]).changed(function (res) { | ||||||
|  |         //    }); | ||||||
|  |         // }; | ||||||
|  | 
 | ||||||
|  |     </script> | ||||||
|  |     </head> | ||||||
|  | 
 | ||||||
|  |     <body> | ||||||
|  |         <div> | ||||||
|  |             <button type="button" onClick="test1();">test1</button> | ||||||
|  |         </div> | ||||||
|  |         <div> | ||||||
|  |             <button type="button" onClick="test2();">test2</button> | ||||||
|  |         </div> | ||||||
|  |         <div> | ||||||
|  |             <button type="button" onClick="test3();">test3</button> | ||||||
|  |         </div> | ||||||
|  |     </body> | ||||||
|  | </html> | ||||||
| @ -21,6 +21,7 @@ | |||||||
|     // contract description, this will be autogenerated somehow |     // contract description, this will be autogenerated somehow | ||||||
|     var desc =  [{ |     var desc =  [{ | ||||||
|         "name": "multiply(uint256)", |         "name": "multiply(uint256)", | ||||||
|  |         "type": "function", | ||||||
|         "inputs": [ |         "inputs": [ | ||||||
|         { |         { | ||||||
|             "name": "a", |             "name": "a", | ||||||
|  | |||||||
							
								
								
									
										26
									
								
								lib/abi.js
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								lib/abi.js
									
									
									
									
									
								
							| @ -65,6 +65,22 @@ var getMethodWithName = function (json, methodName) { | |||||||
|     return json[index]; |     return json[index]; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | /// Filters all function from input abi
 | ||||||
|  | /// @returns abi array with filtered objects of type 'function'
 | ||||||
|  | var filterFunctions = function (json) { | ||||||
|  |     return json.filter(function (current) { | ||||||
|  |         return current.type === 'function';  | ||||||
|  |     });  | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | /// Filters all events form input abi
 | ||||||
|  | /// @returns abi array with filtered objects of type 'event'
 | ||||||
|  | var filterEvents = function (json) { | ||||||
|  |     return json.filter(function (current) { | ||||||
|  |         return current.type === 'event'; | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| /// @param string string to be padded
 | /// @param string string to be padded
 | ||||||
| /// @param number of characters that result string should have
 | /// @param number of characters that result string should have
 | ||||||
| /// @param sign, by default 0
 | /// @param sign, by default 0
 | ||||||
| @ -211,6 +227,7 @@ var signedIsNegative = function (value) { | |||||||
| /// Formats input right-aligned input bytes to int
 | /// Formats input right-aligned input bytes to int
 | ||||||
| /// @returns right-aligned input bytes formatted to int
 | /// @returns right-aligned input bytes formatted to int
 | ||||||
| var formatOutputInt = function (value) { | var formatOutputInt = function (value) { | ||||||
|  |     value = value || "0"; | ||||||
|     // check if it's negative number
 |     // check if it's negative number
 | ||||||
|     // it it is, return two's complement
 |     // it it is, return two's complement
 | ||||||
|     if (signedIsNegative(value)) { |     if (signedIsNegative(value)) { | ||||||
| @ -222,6 +239,7 @@ var formatOutputInt = function (value) { | |||||||
| /// Formats big right-aligned input bytes to uint
 | /// Formats big right-aligned input bytes to uint
 | ||||||
| /// @returns right-aligned input bytes formatted to uint
 | /// @returns right-aligned input bytes formatted to uint
 | ||||||
| var formatOutputUInt = function (value) { | var formatOutputUInt = function (value) { | ||||||
|  |     value = value || "0"; | ||||||
|     return new BigNumber(value, 16); |     return new BigNumber(value, 16); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| @ -349,7 +367,7 @@ var methodTypeName = function (method) { | |||||||
| /// @returns input parser object for given json abi
 | /// @returns input parser object for given json abi
 | ||||||
| var inputParser = function (json) { | var inputParser = function (json) { | ||||||
|     var parser = {}; |     var parser = {}; | ||||||
|     json.forEach(function (method) { |     filterFunctions(json).forEach(function (method) { | ||||||
|         var displayName = methodDisplayName(method.name);  |         var displayName = methodDisplayName(method.name);  | ||||||
|         var typeName = methodTypeName(method.name); |         var typeName = methodTypeName(method.name); | ||||||
| 
 | 
 | ||||||
| @ -372,7 +390,7 @@ var inputParser = function (json) { | |||||||
| /// @returns output parser for given json abi
 | /// @returns output parser for given json abi
 | ||||||
| var outputParser = function (json) { | var outputParser = function (json) { | ||||||
|     var parser = {}; |     var parser = {}; | ||||||
|     json.forEach(function (method) { |     filterFunctions(json).forEach(function (method) { | ||||||
| 
 | 
 | ||||||
|         var displayName = methodDisplayName(method.name);  |         var displayName = methodDisplayName(method.name);  | ||||||
|         var typeName = methodTypeName(method.name); |         var typeName = methodTypeName(method.name); | ||||||
| @ -403,6 +421,8 @@ module.exports = { | |||||||
|     methodSignature: methodSignature, |     methodSignature: methodSignature, | ||||||
|     methodDisplayName: methodDisplayName, |     methodDisplayName: methodDisplayName, | ||||||
|     methodTypeName: methodTypeName, |     methodTypeName: methodTypeName, | ||||||
|     getMethodWithName: getMethodWithName |     getMethodWithName: getMethodWithName, | ||||||
|  |     filterFunctions: filterFunctions, | ||||||
|  |     filterEvents: filterEvents | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										184
									
								
								lib/contract.js
									
									
									
									
									
								
							
							
						
						
									
										184
									
								
								lib/contract.js
									
									
									
									
									
								
							| @ -20,71 +20,40 @@ | |||||||
|  * @date 2014 |  * @date 2014 | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| var web3 = require('./web3'); // jshint ignore:line
 | var web3 = require('./web3');  | ||||||
| var abi = require('./abi'); | var abi = require('./abi'); | ||||||
|  | var eventImpl = require('./event'); | ||||||
| 
 | 
 | ||||||
| /** | var addFunctionRelatedPropertiesToContract = function (contract) { | ||||||
|  * This method should be called when we want to call / transact some solidity method from javascript |  | ||||||
|  * it returns an object which has same methods available as solidity contract description |  | ||||||
|  * usage example:  |  | ||||||
|  * |  | ||||||
|  * var abi = [{ |  | ||||||
|  *      name: 'myMethod', |  | ||||||
|  *      inputs: [{ name: 'a', type: 'string' }], |  | ||||||
|  *      outputs: [{name: 'd', type: 'string' }] |  | ||||||
|  * }];  // contract abi
 |  | ||||||
|  * |  | ||||||
|  * var myContract = web3.eth.contract('0x0123123121', abi); // creation of contract object
 |  | ||||||
|  * |  | ||||||
|  * myContract.myMethod('this is test string param for call'); // myMethod call (implicit, default)
 |  | ||||||
|  * myContract.call().myMethod('this is test string param for call'); // myMethod call (explicit)
 |  | ||||||
|  * myContract.transact().myMethod('this is test string param for transact'); // myMethod transact
 |  | ||||||
|  * |  | ||||||
|  * @param address - address of the contract, which should be called |  | ||||||
|  * @param desc - abi json description of the contract, which is being created |  | ||||||
|  * @returns contract object |  | ||||||
|  */ |  | ||||||
|      |      | ||||||
| var contract = function (address, desc) { |     contract.call = function (options) { | ||||||
|  |         contract._isTransact = false; | ||||||
|  |         contract._options = options; | ||||||
|  |         return contract; | ||||||
|  |     }; | ||||||
| 
 | 
 | ||||||
|     desc.forEach(function (method) { |     contract.transact = function (options) { | ||||||
|         // workaround for invalid assumption that method.name is the full anonymous prototype of the method.
 |         contract._isTransact = true; | ||||||
|         // it's not. it's just the name. the rest of the code assumes it's actually the anonymous
 |         contract._options = options; | ||||||
|         // prototype, so we make it so as a workaround.
 |         return contract; | ||||||
|         if (method.name.indexOf('(') === -1) { |     }; | ||||||
|             var displayName = method.name; | 
 | ||||||
|             var typeName = method.inputs.map(function(i){return i.type; }).join(); |     contract._options = {}; | ||||||
|             method.name = displayName + '(' + typeName + ')'; |     ['gas', 'gasPrice', 'value', 'from'].forEach(function(p) { | ||||||
|         } |         contract[p] = function (v) { | ||||||
|  |             contract._options[p] = v; | ||||||
|  |             return contract; | ||||||
|  |         }; | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | var addFunctionsToContract = function (contract, desc, address) { | ||||||
|     var inputParser = abi.inputParser(desc); |     var inputParser = abi.inputParser(desc); | ||||||
|     var outputParser = abi.outputParser(desc); |     var outputParser = abi.outputParser(desc); | ||||||
| 
 | 
 | ||||||
|     var result = {}; |     // create contract functions
 | ||||||
| 
 |     abi.filterFunctions(desc).forEach(function (method) { | ||||||
|     result.call = function (options) { |  | ||||||
|         result._isTransact = false; |  | ||||||
|         result._options = options; |  | ||||||
|         return result; |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     result.transact = function (options) { |  | ||||||
|         result._isTransact = true; |  | ||||||
|         result._options = options; |  | ||||||
|         return result; |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     result._options = {}; |  | ||||||
|     ['gas', 'gasPrice', 'value', 'from'].forEach(function(p) { |  | ||||||
|         result[p] = function (v) { |  | ||||||
|             result._options[p] = v; |  | ||||||
|             return result; |  | ||||||
|         }; |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|     desc.forEach(function (method) { |  | ||||||
| 
 | 
 | ||||||
|         var displayName = abi.methodDisplayName(method.name); |         var displayName = abi.methodDisplayName(method.name); | ||||||
|         var typeName = abi.methodTypeName(method.name); |         var typeName = abi.methodTypeName(method.name); | ||||||
| @ -94,16 +63,16 @@ var contract = function (address, desc) { | |||||||
|             var signature = abi.methodSignature(method.name); |             var signature = abi.methodSignature(method.name); | ||||||
|             var parsed = inputParser[displayName][typeName].apply(null, params); |             var parsed = inputParser[displayName][typeName].apply(null, params); | ||||||
| 
 | 
 | ||||||
|             var options = result._options || {}; |             var options = contract._options || {}; | ||||||
|             options.to = address; |             options.to = address; | ||||||
|             options.data = signature + parsed; |             options.data = signature + parsed; | ||||||
|              |              | ||||||
|             var isTransact = result._isTransact === true || (result._isTransact !== false && !method.constant); |             var isTransact = contract._isTransact === true || (contract._isTransact !== false && !method.constant); | ||||||
|             var collapse = options.collapse !== false; |             var collapse = options.collapse !== false; | ||||||
|              |              | ||||||
|             // reset
 |             // reset
 | ||||||
|             result._options = {}; |             contract._options = {}; | ||||||
|             result._isTransact = null; |             contract._isTransact = null; | ||||||
| 
 | 
 | ||||||
|             if (isTransact) { |             if (isTransact) { | ||||||
|                 // it's used byt natspec.js
 |                 // it's used byt natspec.js
 | ||||||
| @ -130,13 +99,102 @@ var contract = function (address, desc) { | |||||||
|             return ret; |             return ret; | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         if (result[displayName] === undefined) { |         if (contract[displayName] === undefined) { | ||||||
|             result[displayName] = impl; |             contract[displayName] = impl; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         result[displayName][typeName] = impl; |         contract[displayName][typeName] = impl; | ||||||
|  |     }); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | var addEventRelatedPropertiesToContract = function (contract, desc, address) { | ||||||
|  |     contract.address = address; | ||||||
|  |      | ||||||
|  |     Object.defineProperty(contract, 'topics', { | ||||||
|  |         get: function() { | ||||||
|  |             return abi.filterEvents(desc).map(function (e) { | ||||||
|  |                 return abi.methodSignature(e.name); | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | var addEventsToContract = function (contract, desc, address) { | ||||||
|  |     // create contract events
 | ||||||
|  |     abi.filterEvents(desc).forEach(function (e) { | ||||||
|  | 
 | ||||||
|  |         var impl = function () { | ||||||
|  |             var params = Array.prototype.slice.call(arguments); | ||||||
|  |             var signature = abi.methodSignature(e.name); | ||||||
|  |             var event = eventImpl(address, signature); | ||||||
|  |             var o = event.apply(null, params); | ||||||
|  |             return web3.eth.watch(o);   | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         impl.address = address; | ||||||
|  | 
 | ||||||
|  |         Object.defineProperty(impl, 'topics', { | ||||||
|  |             get: function() { | ||||||
|  |                 return [abi.methodSignature(e.name)]; | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |          | ||||||
|  |         // TODO: rename these methods, cause they are used not only for methods
 | ||||||
|  |         var displayName = abi.methodDisplayName(e.name); | ||||||
|  |         var typeName = abi.methodTypeName(e.name); | ||||||
|  | 
 | ||||||
|  |         if (contract[displayName] === undefined) { | ||||||
|  |             contract[displayName] = impl; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         contract[displayName][typeName] = impl; | ||||||
| 
 | 
 | ||||||
|     }); |     }); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * This method should be called when we want to call / transact some solidity method from javascript | ||||||
|  |  * it returns an object which has same methods available as solidity contract description | ||||||
|  |  * usage example:  | ||||||
|  |  * | ||||||
|  |  * var abi = [{ | ||||||
|  |  *      name: 'myMethod', | ||||||
|  |  *      inputs: [{ name: 'a', type: 'string' }], | ||||||
|  |  *      outputs: [{name: 'd', type: 'string' }] | ||||||
|  |  * }];  // contract abi
 | ||||||
|  |  * | ||||||
|  |  * var myContract = web3.eth.contract('0x0123123121', abi); // creation of contract object
 | ||||||
|  |  * | ||||||
|  |  * myContract.myMethod('this is test string param for call'); // myMethod call (implicit, default)
 | ||||||
|  |  * myContract.call().myMethod('this is test string param for call'); // myMethod call (explicit)
 | ||||||
|  |  * myContract.transact().myMethod('this is test string param for transact'); // myMethod transact
 | ||||||
|  |  * | ||||||
|  |  * @param address - address of the contract, which should be called | ||||||
|  |  * @param desc - abi json description of the contract, which is being created | ||||||
|  |  * @returns contract object | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | var contract = function (address, desc) { | ||||||
|  | 
 | ||||||
|  |     // workaround for invalid assumption that method.name is the full anonymous prototype of the method.
 | ||||||
|  |     // it's not. it's just the name. the rest of the code assumes it's actually the anonymous
 | ||||||
|  |     // prototype, so we make it so as a workaround.
 | ||||||
|  |     // TODO: we may not want to modify input params, maybe use copy instead?
 | ||||||
|  |     desc.forEach(function (method) { | ||||||
|  |         if (method.name.indexOf('(') === -1) { | ||||||
|  |             var displayName = method.name; | ||||||
|  |             var typeName = method.inputs.map(function(i){return i.type; }).join(); | ||||||
|  |             method.name = displayName + '(' + typeName + ')'; | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     var result = {}; | ||||||
|  |     addFunctionRelatedPropertiesToContract(result); | ||||||
|  |     addFunctionsToContract(result, desc, address); | ||||||
|  |     addEventRelatedPropertiesToContract(result, desc, address); | ||||||
|  |     addEventsToContract(result, desc, address); | ||||||
| 
 | 
 | ||||||
|     return result; |     return result; | ||||||
| }; | }; | ||||||
|  | |||||||
							
								
								
									
										35
									
								
								lib/event.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								lib/event.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,35 @@ | |||||||
|  | /* | ||||||
|  |     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 event.js | ||||||
|  |  * @authors: | ||||||
|  |  *   Marek Kotewicz <marek@ethdev.com> | ||||||
|  |  * @date 2014 | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | var implementationOfEvent = function (address, signature) { | ||||||
|  |      | ||||||
|  |     return function (options) { | ||||||
|  |         var o = options || {}; | ||||||
|  |         o.address = o.address || address; | ||||||
|  |         o.topics = o.topics || []; | ||||||
|  |         o.topics.push(signature); | ||||||
|  |         return o; | ||||||
|  |     }; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | module.exports = implementationOfEvent; | ||||||
|  | 
 | ||||||
| @ -31,6 +31,19 @@ var Filter = function(options, impl) { | |||||||
|     this.impl = impl; |     this.impl = impl; | ||||||
|     this.callbacks = []; |     this.callbacks = []; | ||||||
| 
 | 
 | ||||||
|  |     if (typeof options !== "string") { | ||||||
|  |         // evaluate lazy properties
 | ||||||
|  |         options = { | ||||||
|  |             to: options.to, | ||||||
|  |             topics: options.topics, | ||||||
|  |             earliest: options.earliest, | ||||||
|  |             latest: options.latest, | ||||||
|  |             max: options.max, | ||||||
|  |             skip: options.skip, | ||||||
|  |             address: options.address | ||||||
|  |         }; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     this.id = impl.newFilter(options); |     this.id = impl.newFilter(options); | ||||||
|     web3.provider.startPolling({call: impl.changed, args: [this.id]}, this.id, this.trigger.bind(this)); |     web3.provider.startPolling({call: impl.changed, args: [this.id]}, this.id, this.trigger.bind(this)); | ||||||
| }; | }; | ||||||
| @ -48,7 +61,7 @@ Filter.prototype.changed = function(callback) { | |||||||
| /// trigger calling new message from people
 | /// trigger calling new message from people
 | ||||||
| Filter.prototype.trigger = function(messages) { | Filter.prototype.trigger = function(messages) { | ||||||
|     for (var i = 0; i < this.callbacks.length; i++) { |     for (var i = 0; i < this.callbacks.length; i++) { | ||||||
|         for (var j = 0; j < messages; j++) { |         for (var j = 0; j < messages.length; j++) { | ||||||
|             this.callbacks[i].call(this, messages[j]); |             this.callbacks[i].call(this, messages[j]); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -76,6 +76,12 @@ ProviderManager.prototype.send = function(data) { | |||||||
|     //TODO: handle error here? 
 |     //TODO: handle error here? 
 | ||||||
|     var result = this.provider.send(data); |     var result = this.provider.send(data); | ||||||
|     result = JSON.parse(result); |     result = JSON.parse(result); | ||||||
|  | 
 | ||||||
|  |     if (result.error) { | ||||||
|  |         console.log(result.error); | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     return result.result; |     return result.result; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -98,7 +98,6 @@ var ethProperties = function () { | |||||||
|     { name: 'listening', getter: 'eth_listening', setter: 'eth_setListening' }, |     { name: 'listening', getter: 'eth_listening', setter: 'eth_setListening' }, | ||||||
|     { name: 'mining', getter: 'eth_mining', setter: 'eth_setMining' }, |     { name: 'mining', getter: 'eth_mining', setter: 'eth_setMining' }, | ||||||
|     { name: 'gasPrice', getter: 'eth_gasPrice' }, |     { name: 'gasPrice', getter: 'eth_gasPrice' }, | ||||||
|     { name: 'account', getter: 'eth_account' }, |  | ||||||
|     { name: 'accounts', getter: 'eth_accounts' }, |     { name: 'accounts', getter: 'eth_accounts' }, | ||||||
|     { name: 'peerCount', getter: 'eth_peerCount' }, |     { name: 'peerCount', getter: 'eth_peerCount' }, | ||||||
|     { name: 'defaultBlock', getter: 'eth_defaultBlock', setter: 'eth_setDefaultBlock' }, |     { name: 'defaultBlock', getter: 'eth_defaultBlock', setter: 'eth_setDefaultBlock' }, | ||||||
| @ -233,7 +232,9 @@ var web3 = { | |||||||
| 
 | 
 | ||||||
|     /// @returns decimal representaton of hex value prefixed by 0x
 |     /// @returns decimal representaton of hex value prefixed by 0x
 | ||||||
|     toDecimal: function (val) { |     toDecimal: function (val) { | ||||||
|         return (new BigNumber(val.substring(2), 16).toString(10)); |         // remove 0x and place 0, if it's required
 | ||||||
|  |         val = val.length > 2 ? val.substring(2) : "0"; | ||||||
|  |         return (new BigNumber(val, 16).toString(10)); | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     /// @returns hex representation (prefixed by 0x) of decimal value
 |     /// @returns hex representation (prefixed by 0x) of decimal value
 | ||||||
|  | |||||||
							
								
								
									
										49
									
								
								test/abi.filters.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								test/abi.filters.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,49 @@ | |||||||
|  | var assert = require('assert'); | ||||||
|  | var abi = require('../lib/abi.js'); | ||||||
|  | 
 | ||||||
|  | describe('abi', function() { | ||||||
|  |     it('should filter functions and events from input array properly', function () { | ||||||
|  | 
 | ||||||
|  |         // given
 | ||||||
|  |         var description = [{ | ||||||
|  |             "name": "test", | ||||||
|  |             "type": "function", | ||||||
|  |             "inputs": [{ | ||||||
|  |                 "name": "a", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |             "outputs": [ | ||||||
|  |             { | ||||||
|  |                 "name": "d", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |         }, { | ||||||
|  |             "name": "test2", | ||||||
|  |             "type": "event", | ||||||
|  |             "inputs": [{ | ||||||
|  |                 "name": "a", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |             "outputs": [ | ||||||
|  |             { | ||||||
|  |                 "name": "d", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ] | ||||||
|  |         }]; | ||||||
|  |          | ||||||
|  |         // when
 | ||||||
|  |         var events = abi.filterEvents(description); | ||||||
|  |         var functions = abi.filterFunctions(description); | ||||||
|  | 
 | ||||||
|  |         // then
 | ||||||
|  |         assert.equal(events.length, 1); | ||||||
|  |         assert.equal(events[0].name, 'test2'); | ||||||
|  |         assert.equal(functions.length, 1); | ||||||
|  |         assert.equal(functions[0].name, 'test'); | ||||||
|  |          | ||||||
|  |     }); | ||||||
|  | }); | ||||||
| @ -5,6 +5,7 @@ var clone = function (object) { return JSON.parse(JSON.stringify(object)); }; | |||||||
| 
 | 
 | ||||||
| var description =  [{ | var description =  [{ | ||||||
|     "name": "test", |     "name": "test", | ||||||
|  |     "type": "function", | ||||||
|     "inputs": [{ |     "inputs": [{ | ||||||
|         "name": "a", |         "name": "a", | ||||||
|         "type": "uint256" |         "type": "uint256" | ||||||
| @ -339,10 +340,12 @@ describe('abi', function() { | |||||||
|             // given
 |             // given
 | ||||||
|             var d =  [{ |             var d =  [{ | ||||||
|                 name: "test", |                 name: "test", | ||||||
|  |                 type: "function", | ||||||
|                 inputs: [{ type: "int" }], |                 inputs: [{ type: "int" }], | ||||||
|                 outputs: [{ type: "int" }] |                 outputs: [{ type: "int" }] | ||||||
|             },{ |             },{ | ||||||
|                 name: "test2", |                 name: "test2", | ||||||
|  |                 type: "function", | ||||||
|                 inputs: [{ type: "string" }], |                 inputs: [{ type: "string" }], | ||||||
|                 outputs: [{ type: "string" }] |                 outputs: [{ type: "string" }] | ||||||
|             }]; |             }]; | ||||||
| @ -775,10 +778,12 @@ describe('abi', function() { | |||||||
|             // given
 |             // given
 | ||||||
|             var d =  [{ |             var d =  [{ | ||||||
|                 name: "test", |                 name: "test", | ||||||
|  |                 type: "function", | ||||||
|                 inputs: [{ type: "int" }], |                 inputs: [{ type: "int" }], | ||||||
|                 outputs: [{ type: "int" }] |                 outputs: [{ type: "int" }] | ||||||
|             },{ |             },{ | ||||||
|                 name: "test2", |                 name: "test2", | ||||||
|  |                 type: "function", | ||||||
|                 inputs: [{ type: "string" }], |                 inputs: [{ type: "string" }], | ||||||
|                 outputs: [{ type: "string" }] |                 outputs: [{ type: "string" }] | ||||||
|             }]; |             }]; | ||||||
| @ -823,6 +828,38 @@ describe('abi', function() { | |||||||
| 
 | 
 | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|  |         it('should parse 0x value', function () { | ||||||
|  |          | ||||||
|  |             // given
 | ||||||
|  |             var d = clone(description); | ||||||
|  |             d[0].outputs = [ | ||||||
|  |                 { type: 'int' } | ||||||
|  |             ]; | ||||||
|  | 
 | ||||||
|  |             // when
 | ||||||
|  |             var parser = abi.outputParser(d); | ||||||
|  | 
 | ||||||
|  |             // then
 | ||||||
|  |             assert.equal(parser.test("0x")[0], 0); | ||||||
|  | 
 | ||||||
|  |         }); | ||||||
|  |          | ||||||
|  |         it('should parse 0x value', function () { | ||||||
|  |          | ||||||
|  |             // given
 | ||||||
|  |             var d = clone(description); | ||||||
|  |             d[0].outputs = [ | ||||||
|  |                 { type: 'uint' } | ||||||
|  |             ]; | ||||||
|  | 
 | ||||||
|  |             // when
 | ||||||
|  |             var parser = abi.outputParser(d); | ||||||
|  | 
 | ||||||
|  |             // then
 | ||||||
|  |             assert.equal(parser.test("0x")[0], 0); | ||||||
|  | 
 | ||||||
|  |         }); | ||||||
|  | 
 | ||||||
|     }); |     }); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										201
									
								
								test/eth.contract.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										201
									
								
								test/eth.contract.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,201 @@ | |||||||
|  | var assert = require('assert'); | ||||||
|  | var contract = require('../lib/contract.js'); | ||||||
|  | 
 | ||||||
|  | describe('contract', function() { | ||||||
|  |     it('should create simple contract with one method from abi with explicit type name', function () { | ||||||
|  |          | ||||||
|  |         // given
 | ||||||
|  |         var description =  [{ | ||||||
|  |             "name": "test(uint256)", | ||||||
|  |             "type": "function", | ||||||
|  |             "inputs": [{ | ||||||
|  |                 "name": "a", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |             "outputs": [ | ||||||
|  |             { | ||||||
|  |                 "name": "d", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ] | ||||||
|  |         }]; | ||||||
|  |      | ||||||
|  |         // when
 | ||||||
|  |         var con = contract(null, description); | ||||||
|  | 
 | ||||||
|  |         // then
 | ||||||
|  |         assert.equal('function', typeof con.test);  | ||||||
|  |         assert.equal('function', typeof con.test['uint256']); | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     it('should create simple contract with one method from abi with implicit type name', function () { | ||||||
|  |      | ||||||
|  |         // given
 | ||||||
|  |         var description =  [{ | ||||||
|  |             "name": "test", | ||||||
|  |             "type": "function", | ||||||
|  |             "inputs": [{ | ||||||
|  |                 "name": "a", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |             "outputs": [ | ||||||
|  |             { | ||||||
|  |                 "name": "d", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ] | ||||||
|  |         }]; | ||||||
|  | 
 | ||||||
|  |         // when
 | ||||||
|  |         var con = contract(null, description); | ||||||
|  | 
 | ||||||
|  |         // then
 | ||||||
|  |         assert.equal('function', typeof con.test);  | ||||||
|  |         assert.equal('function', typeof con.test['uint256']); | ||||||
|  |     });  | ||||||
|  | 
 | ||||||
|  |     it('should create contract with multiple methods', function () { | ||||||
|  |          | ||||||
|  |         // given
 | ||||||
|  |         var description = [{ | ||||||
|  |             "name": "test", | ||||||
|  |             "type": "function", | ||||||
|  |             "inputs": [{ | ||||||
|  |                 "name": "a", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |             "outputs": [ | ||||||
|  |             { | ||||||
|  |                 "name": "d", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |         }, { | ||||||
|  |             "name": "test2", | ||||||
|  |             "type": "function", | ||||||
|  |             "inputs": [{ | ||||||
|  |                 "name": "a", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |             "outputs": [ | ||||||
|  |             { | ||||||
|  |                 "name": "d", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ] | ||||||
|  |         }]; | ||||||
|  |          | ||||||
|  |         // when
 | ||||||
|  |         var con = contract(null, description); | ||||||
|  | 
 | ||||||
|  |         // then
 | ||||||
|  |         assert.equal('function', typeof con.test);  | ||||||
|  |         assert.equal('function', typeof con.test['uint256']); | ||||||
|  |         assert.equal('function', typeof con.test2);  | ||||||
|  |         assert.equal('function', typeof con.test2['uint256']); | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     it('should create contract with overloaded methods', function () { | ||||||
|  |      | ||||||
|  |         // given
 | ||||||
|  |         var description = [{ | ||||||
|  |             "name": "test", | ||||||
|  |             "type": "function", | ||||||
|  |             "inputs": [{ | ||||||
|  |                 "name": "a", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |             "outputs": [ | ||||||
|  |             { | ||||||
|  |                 "name": "d", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |         }, { | ||||||
|  |             "name": "test", | ||||||
|  |             "type": "function", | ||||||
|  |             "inputs": [{ | ||||||
|  |                 "name": "a", | ||||||
|  |                 "type": "string" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |             "outputs": [ | ||||||
|  |             { | ||||||
|  |                 "name": "d", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ] | ||||||
|  |         }]; | ||||||
|  |          | ||||||
|  |         // when
 | ||||||
|  |         var con = contract(null, description); | ||||||
|  | 
 | ||||||
|  |         // then
 | ||||||
|  |         assert.equal('function', typeof con.test);  | ||||||
|  |         assert.equal('function', typeof con.test['uint256']); | ||||||
|  |         assert.equal('function', typeof con.test['string']);  | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     it('should create contract with no methods', function () { | ||||||
|  |          | ||||||
|  |         // given
 | ||||||
|  |         var description =  [{ | ||||||
|  |             "name": "test(uint256)", | ||||||
|  |             "inputs": [{ | ||||||
|  |                 "name": "a", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |             "outputs": [ | ||||||
|  |             { | ||||||
|  |                 "name": "d", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ] | ||||||
|  |         }]; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         // when
 | ||||||
|  |         var con = contract(null, description); | ||||||
|  | 
 | ||||||
|  |         // then
 | ||||||
|  |         assert.equal('undefined', typeof con.test);  | ||||||
|  | 
 | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     it('should create contract with one event', function () { | ||||||
|  |          | ||||||
|  |         // given
 | ||||||
|  |         var description =  [{ | ||||||
|  |             "name": "test", | ||||||
|  |             "type": "event", | ||||||
|  |             "inputs": [{ | ||||||
|  |                 "name": "a", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ], | ||||||
|  |             "outputs": [ | ||||||
|  |             { | ||||||
|  |                 "name": "d", | ||||||
|  |                 "type": "uint256" | ||||||
|  |             } | ||||||
|  |             ] | ||||||
|  |         }]; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         // when
 | ||||||
|  |         var con = contract(null, description); | ||||||
|  | 
 | ||||||
|  |         // then
 | ||||||
|  |         assert.equal('function', typeof con.test);  | ||||||
|  |         assert.equal('function', typeof con.test['uint256']);  | ||||||
|  | 
 | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  | }); | ||||||
|  | 
 | ||||||
| @ -24,7 +24,6 @@ describe('web3', function() { | |||||||
|         u.propertyExists(web3.eth, 'listening'); |         u.propertyExists(web3.eth, 'listening'); | ||||||
|         u.propertyExists(web3.eth, 'mining'); |         u.propertyExists(web3.eth, 'mining'); | ||||||
|         u.propertyExists(web3.eth, 'gasPrice'); |         u.propertyExists(web3.eth, 'gasPrice'); | ||||||
|         u.propertyExists(web3.eth, 'account'); |  | ||||||
|         u.propertyExists(web3.eth, 'accounts'); |         u.propertyExists(web3.eth, 'accounts'); | ||||||
|         u.propertyExists(web3.eth, 'peerCount'); |         u.propertyExists(web3.eth, 'peerCount'); | ||||||
|         u.propertyExists(web3.eth, 'defaultBlock'); |         u.propertyExists(web3.eth, 'defaultBlock'); | ||||||
|  | |||||||
							
								
								
									
										22
									
								
								test/event.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								test/event.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,22 @@ | |||||||
|  | var assert = require('assert'); | ||||||
|  | var event = require('../lib/event.js'); | ||||||
|  | 
 | ||||||
|  | describe('event', function () { | ||||||
|  |     it('should create filter input object from given', function () { | ||||||
|  |          | ||||||
|  |         // given
 | ||||||
|  |         var address = '0x012345';  | ||||||
|  |         var signature = '0x987654'; | ||||||
|  | 
 | ||||||
|  |         // when
 | ||||||
|  |         var impl = event(address, signature); | ||||||
|  |         var result = impl(); | ||||||
|  | 
 | ||||||
|  |         // then
 | ||||||
|  |         assert.equal(result.address, address);  | ||||||
|  |         assert.equal(result.topics.length, 1); | ||||||
|  |         assert.equal(result.topics[0], signature); | ||||||
|  | 
 | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
| @ -6,8 +6,5 @@ describe('web3', function() { | |||||||
|     u.methodExists(web3, 'sha3'); |     u.methodExists(web3, 'sha3'); | ||||||
|     u.methodExists(web3, 'toAscii'); |     u.methodExists(web3, 'toAscii'); | ||||||
|     u.methodExists(web3, 'fromAscii'); |     u.methodExists(web3, 'fromAscii'); | ||||||
|     u.methodExists(web3, 'toFixed'); |  | ||||||
|     u.methodExists(web3, 'fromFixed'); |  | ||||||
|     u.methodExists(web3, 'offset'); |  | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user