aboutsummaryrefslogtreecommitdiffstats
path: root/lib/contract.js
diff options
context:
space:
mode:
Diffstat (limited to 'lib/contract.js')
-rw-r--r--lib/contract.js57
1 files changed, 31 insertions, 26 deletions
diff --git a/lib/contract.js b/lib/contract.js
index eff16cca4..94a6d7dac 100644
--- a/lib/contract.js
+++ b/lib/contract.js
@@ -22,8 +22,18 @@
var web3 = require('./web3');
var abi = require('./abi');
+var utils = require('./utils');
var eventImpl = require('./event');
+var exportNatspecGlobals = function (vars) {
+ // it's used byt natspec.js
+ // TODO: figure out better way to solve this
+ web3._currentContractAbi = vars.abi;
+ web3._currentContractAddress = vars.address;
+ web3._currentContractMethodName = vars.method;
+ web3._currentContractMethodParams = vars.params;
+};
+
var addFunctionRelatedPropertiesToContract = function (contract) {
contract.call = function (options) {
@@ -53,14 +63,14 @@ var addFunctionsToContract = function (contract, desc, address) {
var outputParser = abi.outputParser(desc);
// create contract functions
- abi.filterFunctions(desc).forEach(function (method) {
+ utils.filterFunctions(desc).forEach(function (method) {
- var displayName = abi.methodDisplayName(method.name);
- var typeName = abi.methodTypeName(method.name);
+ var displayName = utils.extractDisplayName(method.name);
+ var typeName = utils.extractTypeName(method.name);
var impl = function () {
var params = Array.prototype.slice.call(arguments);
- var signature = abi.methodSignature(method.name);
+ var signature = abi.signatureFromAscii(method.name);
var parsed = inputParser[displayName][typeName].apply(null, params);
var options = contract._options || {};
@@ -75,12 +85,13 @@ var addFunctionsToContract = function (contract, desc, address) {
contract._isTransact = null;
if (isTransact) {
- // it's used byt natspec.js
- // TODO: figure out better way to solve this
- web3._currentContractAbi = desc;
- web3._currentContractAddress = address;
- web3._currentContractMethodName = method.name;
- web3._currentContractMethodParams = params;
+
+ exportNatspecGlobals({
+ abi: desc,
+ address: address,
+ method: method.name,
+ params: params
+ });
// transactions do not have any output, cause we do not know, when they will be processed
web3.eth.transact(options);
@@ -112,8 +123,8 @@ var addEventRelatedPropertiesToContract = function (contract, desc, address) {
Object.defineProperty(contract, 'topic', {
get: function() {
- return abi.filterEvents(desc).map(function (e) {
- return abi.methodSignature(e.name);
+ return utils.filterEvents(desc).map(function (e) {
+ return abi.signatureFromAscii(e.name);
});
}
});
@@ -122,27 +133,21 @@ var addEventRelatedPropertiesToContract = function (contract, desc, address) {
var addEventsToContract = function (contract, desc, address) {
// create contract events
- abi.filterEvents(desc).forEach(function (e) {
+ utils.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 signature = abi.signatureFromAscii(e.name);
+ var event = eventImpl(address, signature, e);
var o = event.apply(null, params);
return web3.eth.watch(o);
};
-
- impl.address = address;
-
- Object.defineProperty(impl, 'topic', {
- 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);
+ // this property should be used by eth.filter to check if object is an event
+ impl._isEvent = true;
+
+ var displayName = utils.extractDisplayName(e.name);
+ var typeName = utils.extractTypeName(e.name);
if (contract[displayName] === undefined) {
contract[displayName] = impl;