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