react 0.0.1 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/.npmignore +6 -0
  2. package/Jakefile.js +8 -0
  3. package/README.md +233 -83
  4. package/examples/ast1.js +26 -0
  5. package/examples/chain-events1.js +34 -0
  6. package/examples/chain1.js +19 -0
  7. package/examples/default1.js +40 -0
  8. package/examples/fstr-events1.js +51 -0
  9. package/examples/fstr1.js +36 -0
  10. package/examples/pcode1.js +22 -0
  11. package/jake-tasks/jake-test.js +64 -0
  12. package/lib/base-task.js +115 -0
  13. package/lib/cb-task.js +67 -0
  14. package/lib/chain.js +148 -0
  15. package/lib/core.js +96 -0
  16. package/lib/dsl.js +122 -0
  17. package/lib/error.js +37 -0
  18. package/lib/event-manager.js +57 -0
  19. package/lib/finalcb-first-task.js +59 -0
  20. package/lib/finalcb-task.js +54 -0
  21. package/lib/fstr.js +110 -0
  22. package/lib/id.js +10 -0
  23. package/lib/input-parser.js +44 -0
  24. package/lib/parse.js +29 -0
  25. package/lib/pcode.js +164 -0
  26. package/lib/ret-task.js +67 -0
  27. package/lib/status.js +5 -0
  28. package/lib/task.js +234 -0
  29. package/lib/validate.js +102 -0
  30. package/lib/vcon.js +76 -0
  31. package/oldExamples/analyze.js +29 -0
  32. package/oldExamples/analyze2.js +29 -0
  33. package/oldExamples/example10-dsl.js +63 -0
  34. package/oldExamples/example11.js +62 -0
  35. package/oldExamples/example12.js +63 -0
  36. package/oldExamples/example13.js +63 -0
  37. package/oldExamples/example14.js +63 -0
  38. package/oldExamples/example15.js +75 -0
  39. package/{test → oldExamples}/example6-ast.js +4 -4
  40. package/{test → oldExamples}/example6-dsl.js +3 -2
  41. package/{test → oldExamples}/example8-ast.js +3 -2
  42. package/{test → oldExamples}/example8-dsl.js +3 -2
  43. package/oldExamples/example9-ast.js +58 -0
  44. package/oldExamples/example9-dsl.js +57 -0
  45. package/oldExamples/function-str-ex1.js +33 -0
  46. package/oldExamples/function-str-ex2.js +67 -0
  47. package/oldExamples/trait1.js +41 -0
  48. package/oldExamples/trait2.js +44 -0
  49. package/package.json +16 -6
  50. package/react.js +11 -1
  51. package/test/ast.test.js +69 -0
  52. package/test/cb-task.test.js +197 -0
  53. package/test/chain.test.js +239 -0
  54. package/test/core.test.js +519 -0
  55. package/test/dsl.test.js +237 -0
  56. package/test/event-manager.test.js +102 -0
  57. package/test/exec-options.test.js +32 -0
  58. package/test/finalcb-task.test.js +37 -0
  59. package/test/fstr.test.js +288 -0
  60. package/test/input-parser.test.js +62 -0
  61. package/test/module-use.test.js +317 -0
  62. package/test/pcode.test.js +321 -0
  63. package/test/ret-task.test.js +199 -0
  64. package/test/task.test.js +21 -0
  65. package/test/validate-cb-task.test.js +74 -0
  66. package/test/validate-ret-task.test.js +83 -0
  67. package/test/validate.test.js +218 -0
  68. package/test/vcon.test.js +160 -0
  69. package/lib/react.js +0 -228
@@ -0,0 +1,63 @@
1
+ 'use strict';
2
+
3
+ var react = require('react');
4
+
5
+ function loadUser(uid, cb) { setTimeout(cb, 100, null, "User" + uid); }
6
+ function loadFile(filename, cb) { setTimeout(cb, 100, null, 'Filedata' + filename); }
7
+ function markdown(filedata) { return 'html' + filedata; }
8
+ function prepareDirectory(outDirname, cb) { setTimeout(cb, 200, null, 'dircreated-' + outDirname); }
9
+ function writeOutput(html, user, cb) { setTimeout(cb, 300, null, html + '_bytesWritten'); }
10
+ function loadEmailTemplate(cb) { setTimeout(cb, 50, null, 'emailmd'); }
11
+ function customizeEmail(user, emailHtml, cb) { return 'cust-' + user + emailHtml; }
12
+ function deliverEmail(custEmailHtml, cb) { setTimeout(cb, 100, null, 'delivered-' + custEmailHtml); }
13
+
14
+ function useHtml(err, html, user, bytesWritten) {
15
+ if (err) {
16
+ console.log('***Error: %s', err);
17
+ return;
18
+ }
19
+ console.log('final result: %s, user: %s, written:%s', html, user, bytesWritten);
20
+ }
21
+
22
+
23
+
24
+ var fn = react(function (r, filename, uid, outDirname, cb) {
25
+ var err, user, html, bytesWritten;
26
+ r.sync(loadUser).in(uid).out(err, user)
27
+ .cb(err, html, user, bytesWritten);
28
+ });
29
+
30
+
31
+ /*
32
+ var r = react();
33
+ r.ast.inputNames = ['filename', 'uid', 'outDirname', 'cb'];
34
+ r.ast.taskDefs = [
35
+ { f:loadUser, a:['uid'], cb:['user'] },
36
+ { f:loadFile, a:['filename'], cb:['filedata'] },
37
+ { f:markdown, a:['filedata'], ret:['html'] },
38
+ { f:prepareDirectory, a:['outDirname'], cb:['dircreated'] },
39
+ { f:writeOutput, a:['html', 'user'], cb:['bytesWritten'], after:['prepareDirectory'] },
40
+ { f:loadEmailTemplate, a:[], cb:['emailmd'] },
41
+ { f:markdown, a:['emailmd'], ret:['emailHtml'] },
42
+ { f:customizeEmail, a:['user', 'emailHtml'], ret:['custEmailHtml'] },
43
+ { f:deliverEmail, a:['custEmailHtml'], cb:['deliveredEmail'], after:['writeOutput'] }
44
+ ];
45
+ r.ast.finalOutputNames = ['html', 'user', 'bytesWritten'];
46
+ */
47
+
48
+ var fn = react(function (filename, uid, outDirname, cb,
49
+ R, filedata, outDirName, dircreated, emailmd, emailHtml,
50
+ custEmailHtml, deliveredEmail, err, user, html, bytesWritten) {
51
+ R.async(loadUser, uid).cb(err, user)
52
+ .async(loadFile, filename).cb(err, filedata)
53
+ .sync(markdown, filedata).returns(filedata)
54
+ .async(prepareDirectory, outDirName).cb(dircreated)
55
+ .async(writeOutput, html, user).cb(err, bytesWritten).after(prepareDirectory)
56
+ .async(loadEmailTemplate).cb(err, emailmd)
57
+ .sync(markdown, emailmd).returns(emailHtml)
58
+ .sync(customizeEmail, user, emailHtml).returns(custEmailHtml)
59
+ .sync(deliverEmail, custEmailHtml).returns(deliveredEmail).after(writeOutput)
60
+ .finalCb(err, html, user, bytesWritten);
61
+ });
62
+
63
+
@@ -0,0 +1,75 @@
1
+ 'use strict';
2
+
3
+ var react = require('react');
4
+
5
+ function loadUser(uid, cb) { setTimeout(cb, 100, null, "User" + uid); }
6
+ function loadFile(filename, cb) { setTimeout(cb, 100, null, 'Filedata' + filename); }
7
+ function markdown(filedata) { return 'html' + filedata; }
8
+ function prepareDirectory(outDirname, cb) { setTimeout(cb, 200, null, 'dircreated-' + outDirname); }
9
+ function writeOutput(html, user, cb) { setTimeout(cb, 300, null, html + '_bytesWritten'); }
10
+ function loadEmailTemplate(cb) { setTimeout(cb, 50, null, 'emailmd'); }
11
+ function customizeEmail(user, emailHtml, cb) { return 'cust-' + user + emailHtml; }
12
+ function deliverEmail(custEmailHtml, cb) { setTimeout(cb, 100, null, 'delivered-' + custEmailHtml); }
13
+
14
+ function useHtml(err, html, user, bytesWritten) {
15
+ if (err) {
16
+ console.log('***Error: %s', err);
17
+ return;
18
+ }
19
+ console.log('final result: %s, user: %s, written:%s', html, user, bytesWritten);
20
+ }
21
+
22
+
23
+
24
+ var fn = react(function (r, filename, uid, outDirname, cb) {
25
+ var err, user, html, bytesWritten;
26
+ r.sync(loadUser).in(uid).out(err, user)
27
+ .cb(err, html, user, bytesWritten);
28
+ });
29
+
30
+
31
+ /*
32
+ var r = react();
33
+ r.ast.inputNames = ['filename', 'uid', 'outDirname', 'cb'];
34
+ r.ast.taskDefs = [
35
+ { f:loadUser, a:['uid'], cb:['user'] },
36
+ { f:loadFile, a:['filename'], cb:['filedata'] },
37
+ { f:markdown, a:['filedata'], ret:['html'] },
38
+ { f:prepareDirectory, a:['outDirname'], cb:['dircreated'] },
39
+ { f:writeOutput, a:['html', 'user'], cb:['bytesWritten'], after:['prepareDirectory'] },
40
+ { f:loadEmailTemplate, a:[], cb:['emailmd'] },
41
+ { f:markdown, a:['emailmd'], ret:['emailHtml'] },
42
+ { f:customizeEmail, a:['user', 'emailHtml'], ret:['custEmailHtml'] },
43
+ { f:deliverEmail, a:['custEmailHtml'], cb:['deliveredEmail'], after:['writeOutput'] }
44
+ ];
45
+ r.ast.finalOutputNames = ['html', 'user', 'bytesWritten'];
46
+ */
47
+
48
+ var fn = react(function (R, filename, uid, outDirname, cb) {
49
+
50
+ //local vars used
51
+ var filedata = R.var();
52
+ var outDirName = R.var();
53
+ var dircreated = R.var();
54
+ var emailmd = R.var();
55
+ var emailHtml = R.var();
56
+ var custEmailHtml = R.var();
57
+ var deliveredEmail = R.var();
58
+ var err = R.var();
59
+ var user = R.var();
60
+ var html = R.var();
61
+ var bytesWritten = R.var();
62
+
63
+ R.out(err, html, user, bytesWritten)
64
+ .async(loadUser, uid).cb(err, user)
65
+ .async(loadFile, filename).cb(err, filedata)
66
+ .sync(markdown, filedata).returns(filedata)
67
+ .async(prepareDirectory, outDirName).cb(dircreated)
68
+ .async(writeOutput, html, user).cb(err, bytesWritten).after(prepareDirectory)
69
+ .async(loadEmailTemplate).cb(err, emailmd)
70
+ .sync(markdown, emailmd).returns(emailHtml)
71
+ .sync(customizeEmail, user, emailHtml).returns(custEmailHtml)
72
+ .sync(deliverEmail, custEmailHtml).returns(deliveredEmail).after(writeOutput);
73
+ });
74
+
75
+
@@ -4,9 +4,9 @@
4
4
  Example setting the AST directly without using define
5
5
  */
6
6
 
7
- var react = require('../react.js').react;
8
- var reactOptions = require('react').reactOptions;
9
- reactOptions.debugOutput = true;
7
+ var reactMod = require(__dirname+'/../lib/react.js');
8
+ reactMod.reactOptions.debugOutput = true;
9
+ var react = reactMod.react;
10
10
 
11
11
  function loadUser(uid, cb){ setTimeout(cb, 100, null, "User"+uid); }
12
12
  function loadFile(filename, cb){ setTimeout(cb, 100, null, 'Filedata'+filename); }
@@ -25,7 +25,7 @@ function useHtml(err, html, user, bytesWritten) {
25
25
  console.log('final result: %s, user: %s, written:%s', html, user, bytesWritten);
26
26
  }
27
27
 
28
- var r = react();
28
+ var r = reactMod.react();
29
29
  r.ast.inputNames = ['filename', 'uid', 'outDirname', 'cb'];
30
30
  r.ast.taskDefs = [
31
31
  { f:loadUser, a:['uid'], cb:['user'] },
@@ -4,8 +4,9 @@
4
4
  Example using functions with the simple DSL
5
5
  */
6
6
 
7
- var react = require('../react.js').react;
8
- var reactOptions = require('react').reactOptions;
7
+ var reactMod = require(__dirname+'/../lib/react.js');
8
+ var react = reactMod.react;
9
+ var reactOptions = reactMod.reactOptions;
9
10
  reactOptions.debugOutput = true;
10
11
  reactOptions.stackTraceLimitMin = 20;
11
12
 
@@ -4,8 +4,9 @@
4
4
  AST directly without define, using object methods in addition to functions
5
5
  */
6
6
 
7
- var react = require('../react.js').react;
8
- var reactOptions = require('react').reactOptions;
7
+ var reactMod = require(__dirname+'/../lib/react.js');
8
+ var react = reactMod.react;
9
+ var reactOptions = reactMod.reactOptions;
9
10
  reactOptions.debugOutput = true;
10
11
 
11
12
 
@@ -4,8 +4,9 @@
4
4
  Using object methods in addition to functions with simple DSL
5
5
  */
6
6
 
7
- var react = require('../react.js').react;
8
- var reactOptions = require('react').reactOptions;
7
+ var reactMod = require(__dirname+'/../lib/react.js');
8
+ var react = reactMod.react;
9
+ var reactOptions = reactMod.reactOptions;
9
10
  reactOptions.debugOutput = true;
10
11
  reactOptions.stackTraceLimitMin = 20;
11
12
 
@@ -0,0 +1,58 @@
1
+ 'use strict';
2
+
3
+ /**
4
+ AST directly without define, using object methods in addition to functions
5
+ also passing in an options object and referring to the properties.
6
+ The dependency is on the object existing, if it exists, it expects the values
7
+ to be there.
8
+ */
9
+
10
+ var reactMod = require(__dirname+'/../lib/react.js');
11
+ var react = reactMod.react;
12
+ var reactOptions = reactMod.reactOptions;
13
+ reactOptions.debugOutput = true;
14
+
15
+
16
+ var UserMgr = function(){ };
17
+ UserMgr.prototype = {};
18
+ UserMgr.prototype.constructor = UserMgr;
19
+ UserMgr.prototype.loadUser = function loadUser(uid, cb){ setTimeout(cb, 100, null, "User"+uid); };
20
+
21
+ function loadFile(filename, cb){ setTimeout(cb, 100, null, 'Filedata'+filename); }
22
+ function markdown(filedata) { return 'html'+filedata; }
23
+ function prepareDirectory(outDirname, cb){ setTimeout(cb, 200, null, 'dircreated-'+outDirname); }
24
+ function writeOutput(html, user, cb){ setTimeout(cb, 300, null, html+'_bytesWritten'); }
25
+ function loadEmailTemplate(cb) { setTimeout(cb, 50, null, 'emailmd'); }
26
+ function customizeEmail(user, emailHtml, cb) { return 'cust-'+user+emailHtml; }
27
+ function deliverEmail(custEmailHtml, cb) { setTimeout(cb, 100, null, 'delivered-'+custEmailHtml); }
28
+
29
+ function useHtml(err, html, user, bytesWritten) {
30
+ if(err) {
31
+ console.log('***Error: %s', err);
32
+ return;
33
+ }
34
+ console.log('final result: %s, user: %s, written:%s', html, user, bytesWritten);
35
+ }
36
+
37
+ var r = react();
38
+ r.ast.inputNames = ['options', 'uid', 'anObj', 'cb'];
39
+ r.ast.taskDefs = [
40
+ { f:'anObj.loadUser', a:['uid'], cb:['user'] },
41
+ { f:loadFile, a:['options.filename'], cb:['filedata'] },
42
+ { f:markdown, a:['filedata'], ret:['html'] },
43
+ { f:prepareDirectory, a:['options.outDirname'],cb:['dircreated'] },
44
+ { f:writeOutput, a:['html', 'user'], cb:['bytesWritten'], after:['prepareDirectory'] },
45
+ { f:loadEmailTemplate, a:[], cb:['emailmd'] },
46
+ { f:markdown, a:['emailmd'], ret:['emailHtml'] },
47
+ { f:customizeEmail, a:['user', 'emailHtml'], ret:['custEmailHtml'] },
48
+ { f:deliverEmail, a:['custEmailHtml'], cb:['deliveredEmail'], after:['writeOutput'] }
49
+ ];
50
+ r.ast.finalOutputNames = ['html', 'user', 'bytesWritten'];
51
+
52
+ var myObj = new UserMgr();
53
+ r.exec({ filename: "hello.txt", outDirname: 'outHello' }, 100, myObj, useHtml);
54
+ r.exec({ filename: "small.txt", outDirname: 'outSmall' }, 200, myObj, useHtml);
55
+ r.exec({ filename: "world.txt", outDirname: 'outWorld' }, 300, myObj, useHtml);
56
+
57
+
58
+
@@ -0,0 +1,57 @@
1
+ 'use strict';
2
+
3
+ /**
4
+ Using object methods in addition to functions with simple DSL
5
+ also passing in an options object and referring to the properties.
6
+ The dependency is on the object existing, if it exists, it expects the values
7
+ to be there.
8
+ */
9
+
10
+ var reactMod = require(__dirname+'/../lib/react.js');
11
+ var react = reactMod.react;
12
+ var reactOptions = reactMod.reactOptions;
13
+ reactOptions.debugOutput = true;
14
+ reactOptions.stackTraceLimitMin = 20;
15
+
16
+ var UserMgr = function(){ };
17
+ UserMgr.prototype = {};
18
+ UserMgr.prototype.constructor = UserMgr;
19
+ UserMgr.prototype.loadUser = function loadUser(uid, cb){ setTimeout(cb, 100, null, "User"+uid); };
20
+
21
+ function loadFile(filename, cb){ setTimeout(cb, 100, null, 'Filedata'+filename); }
22
+ function markdown(filedata) { return 'html'+filedata; }
23
+ function prepareDirectory(outDirname, cb){ setTimeout(cb, 200, null, 'dircreated-'+outDirname); }
24
+ function writeOutput(html, user, cb){ setTimeout(cb, 300, null, html+'_bytesWritten'); }
25
+ function loadEmailTemplate(cb) { setTimeout(cb, 50, null, 'emailmd'); }
26
+ function customizeEmail(user, emailHtml, cb) { return 'cust-'+user+emailHtml; }
27
+ function deliverEmail(custEmailHtml, cb) { setTimeout(cb, 100, null, 'delivered-'+custEmailHtml); }
28
+
29
+ function useHtml(err, html, user, bytesWritten) {
30
+ if(err) {
31
+ console.log('***Error: %s', err);
32
+ return;
33
+ }
34
+ console.log('final result: %s, user: %s, written: %s', html, user, bytesWritten);
35
+ }
36
+
37
+ var r = react('options, uid, anObj, cb').define(
38
+ 'anObj.loadUser', 'uid -> err, user',
39
+ loadFile, 'options.filename -> err, filedata',
40
+ markdown, 'filedata -> returns html',
41
+ prepareDirectory, 'options.outDirname -> err, dircreated',
42
+ writeOutput, 'html, user -> err, bytesWritten', { after:prepareDirectory },
43
+ loadEmailTemplate,' -> err, emailmd',
44
+ markdown, 'emailmd -> returns emailHtml',
45
+ customizeEmail, 'user, emailHtml -> returns custEmailHtml',
46
+ deliverEmail, 'custEmailHtml -> err, deliveredEmail', { after: writeOutput }
47
+ ).callbackDef('err, html, user, bytesWritten');
48
+
49
+
50
+ //console.log(r.ast);
51
+
52
+ var myObj = new UserMgr();
53
+ r.exec({ filename: "hello.txt", outDirname: 'outHello' }, 100, myObj, useHtml);
54
+ r.exec({ filename: "small.txt", outDirname: 'outSmall' }, 200, myObj, useHtml);
55
+ r.exec({ filename: "world.txt", outDirname: 'outWorld' }, 300, myObj, useHtml);
56
+
57
+
@@ -0,0 +1,33 @@
1
+ 'use strict';
2
+
3
+ var react = require('react');
4
+ var CB = react.cb;
5
+ var CBV = react.cbv;
6
+
7
+ function loadMdFile(file, cb) {
8
+ var data = file + '-data';
9
+ setTimeout(function () { cb(null, data); }, 100); //similate file load
10
+ }
11
+
12
+ function mergeIntoHtml(data, cb) {
13
+ var html = data + '-html';
14
+ setTimeout(function () { cb(null, html); }, 100); //simulate templ load
15
+ }
16
+
17
+ function sendHtml(html, cb) {
18
+ var bytes = html.length;
19
+ setTimeout(function () { cb(null, bytes); }, 100); //simulate write
20
+ }
21
+
22
+ var loadAndSave = react(function defineFromSource(file, cb) {
23
+ loadMdFile(file, CB);
24
+ var data = CBV();
25
+
26
+ mergeIntoHtml(data, CB);
27
+ var html = CBV();
28
+
29
+ sendHtml(html, CB);
30
+ var bytes = CBV();
31
+
32
+ cb(null, file, bytes);
33
+ });
@@ -0,0 +1,67 @@
1
+ 'use strict';
2
+
3
+ var react = require('react');
4
+ var CB = react.cb;
5
+ var CBV = react.cbv;
6
+ var WAIT = react.wait;
7
+
8
+ function loadUser(uid, cb){ setTimeout(cb, 100, null, "User"+uid); }
9
+ function loadFile(filename, cb){ setTimeout(cb, 100, null, 'Filedata'+filename); }
10
+ function markdown(filedata) { return 'html'+filedata; }
11
+ function prepareDirectory(outDirname, cb){ setTimeout(cb, 200, null, 'dircreated-'+outDirname); }
12
+ function writeOutput(html, user, cb){ setTimeout(cb, 300, null, html+'_bytesWritten'); }
13
+ function loadEmailTemplate(cb) { setTimeout(cb, 50, null, 'emailmd'); }
14
+ function customizeEmail(user, emailHtml, cb) { return 'cust-'+user+emailHtml; }
15
+ function deliverEmail(custEmailHtml, cb) { setTimeout(cb, 100, null, 'delivered-'+custEmailHtml); }
16
+
17
+ function useHtml(err, html, user, bytesWritten) {
18
+ if(err) {
19
+ console.log('***Error: %s', err);
20
+ return;
21
+ }
22
+ console.log('final result: %s, user: %s, written: %s', html, user, bytesWritten);
23
+ }
24
+
25
+
26
+ var r = react('filename, uid, outDirname, cb').define(
27
+ loadUser, 'uid -> err, user',
28
+ loadFile, 'filename -> err, filedata',
29
+ markdown, 'filedata -> returns html',
30
+ prepareDirectory, 'outDirname -> err, dircreated',
31
+ writeOutput, 'html, user -> err, bytesWritten', { after:prepareDirectory },
32
+ loadEmailTemplate,' -> err, emailmd',
33
+ markdown, 'emailmd -> returns emailHtml',
34
+ customizeEmail, 'user, emailHtml -> returns custEmailHtml',
35
+ deliverEmail, 'custEmailHtml -> err, deliveredEmail', { after: writeOutput }
36
+ ).callbackDef('err, html, user, bytesWritten');
37
+
38
+ var loadAndDeliver = react(
39
+ function defineFromSource(filename, uid, outDirname, cb) {
40
+ loadUser(uid, CB);
41
+ var user = CBV();
42
+
43
+ loadFile(filename, CB);
44
+ var filedata = CBV();
45
+
46
+ var html = markdown(filedata);
47
+
48
+ prepareDirectory(outDirname, CB);
49
+ var dircreated = CBV();
50
+
51
+ WAIT(prepareDirectory);
52
+ writeOutput(html, user, CB);
53
+ var bytesWritten = CBV();
54
+
55
+ loadEmailTemplate(CB);
56
+ var emailmd = CBV();
57
+
58
+ var emailHtml = markdown(emailmd);
59
+
60
+ var custEmailHtml = customizeEmail(user, emailHtml);
61
+
62
+ deliverEmail(custEmailHtml, CB);
63
+ var deliveredEmail = CBV();
64
+
65
+ cb(null, html, user, bytesWritten);
66
+ }
67
+ );
@@ -0,0 +1,41 @@
1
+ 'use strict';
2
+
3
+ var trait = require('light-traits').Trait;
4
+
5
+ var tTaskMethods = trait({
6
+ ready: trait.required,
7
+ isReady: function(){ return this.ready; },
8
+ exec: function(){ console.log('exec'); },
9
+ toString: function(){ return 'taskMethods'; },
10
+ matches: function (taskDef) { return (/foo/.test(taskDef.name)) }
11
+ });
12
+
13
+ var tDebugOutput = trait({
14
+ isReady: trait.required,
15
+ //toStringTaskMethods: trait.required,
16
+ toString: function(){ return "trait: ready: "+this.isReady() /* +
17
+ ' taskMethods: '+this.toStringTaskMethods();*/
18
+ }
19
+ });
20
+
21
+ var tTask = trait.compose(
22
+ // tTaskMethods.resolve({ toString: 'toStringTaskMethods' }),
23
+ tTaskMethods.resolve({ toString: null }),
24
+ tDebugOutput
25
+ );
26
+
27
+ function taskFactory(ready){
28
+ return tTask.create({ ready: ready });
29
+ }
30
+
31
+ var t = taskFactory(true);
32
+ console.log(t.toString());
33
+
34
+ if (t.isReady()) {
35
+ t.exec();
36
+ }
37
+
38
+ console.log('foo', tTaskMethods.matches.value({ name: 'foo'}));
39
+ console.log('bar', tTaskMethods.matches.value({ name: 'bar'}));
40
+
41
+ console.log(tTask);