react 0.2.3 → 0.3.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 (61) hide show
  1. package/README.md +15 -13
  2. package/{lib → dsl}/chain.js +5 -3
  3. package/{lib → dsl}/fstr.js +17 -6
  4. package/{lib → dsl}/pcode.js +19 -8
  5. package/examples/chain-events1.js +3 -3
  6. package/examples/chain1.js +2 -2
  7. package/examples/default-events1.js +2 -2
  8. package/examples/fstr-events1.js +4 -3
  9. package/examples/fstr1.js +3 -2
  10. package/examples/pcode1.js +2 -2
  11. package/lib/base-task.js +1 -0
  12. package/lib/cb-task.js +14 -1
  13. package/lib/core.js +36 -12
  14. package/lib/dsl.js +16 -5
  15. package/lib/event-manager.js +16 -4
  16. package/lib/finalcb-first-task.js +9 -6
  17. package/lib/finalcb-task.js +9 -6
  18. package/lib/input-parser.js +7 -3
  19. package/lib/parse.js +6 -3
  20. package/lib/promise-task.js +89 -0
  21. package/lib/ret-task.js +1 -1
  22. package/lib/task.js +23 -19
  23. package/lib/validate.js +14 -5
  24. package/lib/vcon.js +8 -3
  25. package/lib/when-task.js +81 -0
  26. package/package.json +4 -2
  27. package/promise-resolve.js +35 -0
  28. package/react.js +0 -4
  29. package/test/core-deferred.test.js +134 -0
  30. package/test/core-promised.test.js +132 -0
  31. package/test/core-when.test.js +84 -0
  32. package/test/core.test.js +63 -4
  33. package/test/dsl.test.js +70 -5
  34. package/test/{chain.test.js → dsl/chain.test.js} +84 -1
  35. package/test/{fstr.test.js → dsl/fstr.test.js} +13 -1
  36. package/test/{pcode.test.js → dsl/pcode.test.js} +136 -1
  37. package/test/exec-options.test.js +2 -1
  38. package/test/finalcb-task.test.js +6 -5
  39. package/test/input-parser.test.js +10 -6
  40. package/test/module-use.test.js +2 -190
  41. package/test/promise-auto-resolve.test.js +51 -0
  42. package/test/validate.test.js +30 -1
  43. package/test/vcon.test.js +13 -0
  44. package/oldExamples/analyze.js +0 -29
  45. package/oldExamples/analyze2.js +0 -29
  46. package/oldExamples/example10-dsl.js +0 -63
  47. package/oldExamples/example11.js +0 -62
  48. package/oldExamples/example12.js +0 -63
  49. package/oldExamples/example13.js +0 -63
  50. package/oldExamples/example14.js +0 -63
  51. package/oldExamples/example15.js +0 -75
  52. package/oldExamples/example6-ast.js +0 -47
  53. package/oldExamples/example6-dsl.js +0 -49
  54. package/oldExamples/example8-ast.js +0 -55
  55. package/oldExamples/example8-dsl.js +0 -53
  56. package/oldExamples/example9-ast.js +0 -58
  57. package/oldExamples/example9-dsl.js +0 -57
  58. package/oldExamples/function-str-ex1.js +0 -33
  59. package/oldExamples/function-str-ex2.js +0 -67
  60. package/oldExamples/trait1.js +0 -41
  61. package/oldExamples/trait2.js +0 -44
@@ -1,49 +0,0 @@
1
- 'use strict';
2
-
3
- /**
4
- Example using functions with the simple DSL
5
- */
6
-
7
- var reactMod = require(__dirname+'/../lib/react.js');
8
- var react = reactMod.react;
9
- var reactOptions = reactMod.reactOptions;
10
- reactOptions.debugOutput = true;
11
- reactOptions.stackTraceLimitMin = 20;
12
-
13
- function loadUser(uid, cb){ setTimeout(cb, 100, null, "User"+uid); }
14
- function loadFile(filename, cb){ setTimeout(cb, 100, null, 'Filedata'+filename); }
15
- function markdown(filedata) { return 'html'+filedata; }
16
- function prepareDirectory(outDirname, cb){ setTimeout(cb, 200, null, 'dircreated-'+outDirname); }
17
- function writeOutput(html, user, cb){ setTimeout(cb, 300, null, html+'_bytesWritten'); }
18
- function loadEmailTemplate(cb) { setTimeout(cb, 50, null, 'emailmd'); }
19
- function customizeEmail(user, emailHtml, cb) { return 'cust-'+user+emailHtml; }
20
- function deliverEmail(custEmailHtml, cb) { setTimeout(cb, 100, null, 'delivered-'+custEmailHtml); }
21
-
22
- function useHtml(err, html, user, bytesWritten) {
23
- if(err) {
24
- console.log('***Error: %s', err);
25
- return;
26
- }
27
- console.log('final result: %s, user: %s, written: %s', html, user, bytesWritten);
28
- }
29
-
30
- var r = react('filename, uid, outDirname, cb').define(
31
- loadUser, 'uid -> err, user',
32
- loadFile, 'filename -> err, filedata',
33
- markdown, 'filedata -> returns html',
34
- prepareDirectory, 'outDirname -> err, dircreated',
35
- writeOutput, 'html, user -> err, bytesWritten', { after:prepareDirectory },
36
- loadEmailTemplate,' -> err, emailmd',
37
- markdown, 'emailmd -> returns emailHtml',
38
- customizeEmail, 'user, emailHtml -> returns custEmailHtml',
39
- deliverEmail, 'custEmailHtml -> err, deliveredEmail', { after: writeOutput }
40
- ).callbackDef('err, html, user, bytesWritten');
41
-
42
-
43
- //console.log(r.ast);
44
-
45
-
46
- r.exec("hello.txt", 100, 'outHello', useHtml);
47
- r.exec("small.txt", 200, 'outSmall', useHtml);
48
- r.exec("world.txt", 300, 'outWorld', useHtml);
49
-
@@ -1,55 +0,0 @@
1
- 'use strict';
2
-
3
- /**
4
- AST directly without define, using object methods in addition to functions
5
- */
6
-
7
- var reactMod = require(__dirname+'/../lib/react.js');
8
- var react = reactMod.react;
9
- var reactOptions = reactMod.reactOptions;
10
- reactOptions.debugOutput = true;
11
-
12
-
13
- var UserMgr = function(){ };
14
- UserMgr.prototype = {};
15
- UserMgr.prototype.constructor = UserMgr;
16
- UserMgr.prototype.loadUser = function loadUser(uid, cb){ setTimeout(cb, 100, null, "User"+uid); };
17
-
18
- function loadFile(filename, cb){ setTimeout(cb, 100, null, 'Filedata'+filename); }
19
- function markdown(filedata) { return 'html'+filedata; }
20
- function prepareDirectory(outDirname, cb){ setTimeout(cb, 200, null, 'dircreated-'+outDirname); }
21
- function writeOutput(html, user, cb){ setTimeout(cb, 300, null, html+'_bytesWritten'); }
22
- function loadEmailTemplate(cb) { setTimeout(cb, 50, null, 'emailmd'); }
23
- function customizeEmail(user, emailHtml, cb) { return 'cust-'+user+emailHtml; }
24
- function deliverEmail(custEmailHtml, cb) { setTimeout(cb, 100, null, 'delivered-'+custEmailHtml); }
25
-
26
- function useHtml(err, html, user, bytesWritten) {
27
- if(err) {
28
- console.log('***Error: %s', err);
29
- return;
30
- }
31
- console.log('final result: %s, user: %s, written:%s', html, user, bytesWritten);
32
- }
33
-
34
- var r = react();
35
- r.ast.inputNames = ['filename', 'uid', 'outDirname', 'anObj', 'cb'];
36
- r.ast.taskDefs = [
37
- { f:'anObj.loadUser', a:['uid'], cb:['user'] },
38
- { f:loadFile, a:['filename'], cb:['filedata'] },
39
- { f:markdown, a:['filedata'], ret:['html'] },
40
- { f:prepareDirectory, a:['outDirname'], cb:['dircreated'] },
41
- { f:writeOutput, a:['html', 'user'], cb:['bytesWritten'], after:['prepareDirectory'] },
42
- { f:loadEmailTemplate, a:[], cb:['emailmd'] },
43
- { f:markdown, a:['emailmd'], ret:['emailHtml'] },
44
- { f:customizeEmail, a:['user', 'emailHtml'], ret:['custEmailHtml'] },
45
- { f:deliverEmail, a:['custEmailHtml'], cb:['deliveredEmail'], after:['writeOutput'] }
46
- ];
47
- r.ast.finalOutputNames = ['html', 'user', 'bytesWritten'];
48
-
49
- var myObj = new UserMgr();
50
- r.exec("hello.txt", 100, 'outHello', myObj, useHtml);
51
- r.exec("small.txt", 200, 'outSmall', myObj, useHtml);
52
- r.exec("world.txt", 300, 'outWorld', myObj, useHtml);
53
-
54
-
55
-
@@ -1,53 +0,0 @@
1
- 'use strict';
2
-
3
- /**
4
- Using object methods in addition to functions with simple DSL
5
- */
6
-
7
- var reactMod = require(__dirname+'/../lib/react.js');
8
- var react = reactMod.react;
9
- var reactOptions = reactMod.reactOptions;
10
- reactOptions.debugOutput = true;
11
- reactOptions.stackTraceLimitMin = 20;
12
-
13
- var UserMgr = function(){ };
14
- UserMgr.prototype = {};
15
- UserMgr.prototype.constructor = UserMgr;
16
- UserMgr.prototype.loadUser = function loadUser(uid, cb){ setTimeout(cb, 100, null, "User"+uid); };
17
-
18
- function loadFile(filename, cb){ setTimeout(cb, 100, null, 'Filedata'+filename); }
19
- function markdown(filedata) { return 'html'+filedata; }
20
- function prepareDirectory(outDirname, cb){ setTimeout(cb, 200, null, 'dircreated-'+outDirname); }
21
- function writeOutput(html, user, cb){ setTimeout(cb, 300, null, html+'_bytesWritten'); }
22
- function loadEmailTemplate(cb) { setTimeout(cb, 50, null, 'emailmd'); }
23
- function customizeEmail(user, emailHtml, cb) { return 'cust-'+user+emailHtml; }
24
- function deliverEmail(custEmailHtml, cb) { setTimeout(cb, 100, null, 'delivered-'+custEmailHtml); }
25
-
26
- function useHtml(err, html, user, bytesWritten) {
27
- if(err) {
28
- console.log('***Error: %s', err);
29
- return;
30
- }
31
- console.log('final result: %s, user: %s, written: %s', html, user, bytesWritten);
32
- }
33
-
34
- var r = react('filename, uid, outDirname, anObj, cb').define(
35
- 'anObj.loadUser', 'uid -> err, user',
36
- loadFile, 'filename -> err, filedata',
37
- markdown, 'filedata -> returns html',
38
- prepareDirectory, 'outDirname -> err, dircreated',
39
- writeOutput, 'html, user -> err, bytesWritten', { after:prepareDirectory },
40
- loadEmailTemplate,' -> err, emailmd',
41
- markdown, 'emailmd -> returns emailHtml',
42
- customizeEmail, 'user, emailHtml -> returns custEmailHtml',
43
- deliverEmail, 'custEmailHtml -> err, deliveredEmail', { after: writeOutput }
44
- ).callbackDef('err, html, user, bytesWritten');
45
-
46
-
47
- //console.log(r.ast);
48
-
49
- var myObj = new UserMgr();
50
- r.exec("hello.txt", 100, 'outHello', myObj, useHtml);
51
- r.exec("small.txt", 200, 'outSmall', myObj, useHtml);
52
- r.exec("world.txt", 300, 'outWorld', myObj, useHtml);
53
-
@@ -1,58 +0,0 @@
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
-
@@ -1,57 +0,0 @@
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
-
@@ -1,33 +0,0 @@
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
- });
@@ -1,67 +0,0 @@
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
- );
@@ -1,41 +0,0 @@
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);
@@ -1,44 +0,0 @@
1
- 'use strict';
2
-
3
- var trait = require('traits').Trait;
4
-
5
-
6
-
7
-
8
- var tTaskMethods = trait({
9
- ready: trait.required,
10
- isReady: function(){ return this.ready; },
11
- exec: function(){ console.log('exec'); },
12
- toString: function(){ return 'taskMethods'; }
13
- });
14
-
15
- var tDebugOutput = trait({
16
- isReady: trait.required,
17
- toString: function(){ return "trait: ready: "+this.isReady(); }
18
- });
19
-
20
- function Foo() {
21
- }
22
-
23
- Foo.prototype = { };
24
- Foo.prototype.constructor = Foo;
25
- Foo.prototype.greet = function(){ console.log('hello'); };
26
-
27
- function taskFactory(ready){
28
- return Object.create(Foo.prototype, trait.compose(
29
- tTaskMethods,
30
- tDebugOutput,
31
- trait({ ready: ready })
32
- ));
33
- }
34
-
35
-
36
-
37
- var t = taskFactory(true);
38
- console.log(t.toString());
39
-
40
- if (t.isReady()) {
41
- t.exec();
42
- }
43
-
44
- t.greet();