react 0.2.4 → 0.3.4
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 +146 -94
- package/doc/alternate-dsls.md +103 -0
- package/{lib → dsl}/chain.js +5 -3
- package/{lib → dsl}/fstr.js +17 -6
- package/{lib → dsl}/pcode.js +19 -8
- package/examples/chain-events1.js +28 -7
- package/examples/chain1.js +2 -2
- package/examples/default-events1.js +33 -6
- package/examples/default-log-events.js +43 -0
- package/examples/fstr-events1.js +4 -17
- package/examples/fstr1.js +3 -2
- package/examples/pcode1.js +2 -2
- package/lib/base-task.js +8 -6
- package/lib/cb-task.js +14 -1
- package/lib/core.js +46 -15
- package/lib/dsl.js +14 -6
- package/lib/event-manager.js +29 -15
- package/lib/finalcb-first-task.js +16 -10
- package/lib/finalcb-task.js +17 -10
- package/lib/input-parser.js +7 -3
- package/lib/log-events.js +71 -0
- package/lib/parse.js +6 -3
- package/lib/promise-task.js +89 -0
- package/lib/ret-task.js +1 -1
- package/lib/task.js +32 -23
- package/lib/track-tasks.js +117 -0
- package/lib/validate.js +14 -5
- package/lib/vcon.js +8 -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 +108 -60
- package/test/dsl.test.js +58 -6
- package/test/{chain.test.js → dsl/chain.test.js} +85 -1
- package/test/{fstr.test.js → dsl/fstr.test.js} +13 -1
- package/test/{pcode.test.js → dsl/pcode.test.js} +128 -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 +13 -199
- package/test/promise-auto-resolve.test.js +51 -0
- package/test/validate.test.js +30 -1
- 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/example11.js
DELETED
|
@@ -1,62 +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
|
-
var filedata, outDirName, dircreated, emailmd, emailHtml, custEmailHtml, deliveredEmail;
|
|
50
|
-
var err, user, html, bytesWritten;
|
|
51
|
-
|
|
52
|
-
r.async(loadUser).in(uid).out(err, user)
|
|
53
|
-
.async(loadFile).in(filename).out(filedata)
|
|
54
|
-
.sync(markdown).in(filedata).out(html)
|
|
55
|
-
.async(prepareDirectory).in(outDirName).out(dircreated)
|
|
56
|
-
.async(writeOutput).in(html, user).out(bytesWritten).after(prepareDirectory)
|
|
57
|
-
.async(loadEmailTemplate).out(emailmd)
|
|
58
|
-
.sync(markdown).in(emailmd).out(emailHtml)
|
|
59
|
-
.sync(customizeEmail).in(user, emailHtml).out(custEmailHtml)
|
|
60
|
-
.async(deliveredEmail).in(custEmailHtml).out(deliveredEmail).after(writeOutput)
|
|
61
|
-
.cb(err, html, user, bytesWritten);
|
|
62
|
-
});
|
package/oldExamples/example12.js
DELETED
|
@@ -1,63 +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
|
-
filedata, outDirName, dircreated, emailmd, emailHtml,
|
|
50
|
-
custEmailHtml, deliveredEmail,
|
|
51
|
-
err, user, html, bytesWritten) {
|
|
52
|
-
|
|
53
|
-
r.async(loadUser, [uid], [err, user])
|
|
54
|
-
.async(loadFile, [filename], [filedata])
|
|
55
|
-
.sync(markdown, [filedata], filedata)
|
|
56
|
-
.async(prepareDirectory, [outDirName], [dircreated])
|
|
57
|
-
.async(writeOutput, [html, user], [err, bytesWritten], { after: prepareDirectory })
|
|
58
|
-
.async(loadEmailTemplate, [], [emailmd])
|
|
59
|
-
.sync(markdown, [emailmd], emailHtml)
|
|
60
|
-
.sync(customizeEmail, [user, emailHtml], custEmailHtml)
|
|
61
|
-
.sync(deliverEmail, [custEmailHtml], [deliveredEmail], { after: writeOutput })
|
|
62
|
-
.cb(err, html, user, bytesWritten);
|
|
63
|
-
});
|
package/oldExamples/example13.js
DELETED
|
@@ -1,63 +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
|
-
filedata, outDirName, dircreated, emailmd, emailHtml,
|
|
50
|
-
custEmailHtml, deliveredEmail,
|
|
51
|
-
err, user, html, bytesWritten) {
|
|
52
|
-
|
|
53
|
-
r.async(loadUser, uid).cb(err, user)
|
|
54
|
-
.async(loadFile, filename).cb(err, filedata)
|
|
55
|
-
.sync(markdown, filedata).returns(filedata)
|
|
56
|
-
.async(prepareDirectory, outDirName).cb(dircreated)
|
|
57
|
-
.async(writeOutput, html, user).cb(err, bytesWritten).after(prepareDirectory)
|
|
58
|
-
.async(loadEmailTemplate).cb(err, emailmd)
|
|
59
|
-
.sync(markdown, emailmd).returns(emailHtml)
|
|
60
|
-
.sync(customizeEmail, user, emailHtml).returns(custEmailHtml)
|
|
61
|
-
.sync(deliverEmail, custEmailHtml).returns(deliveredEmail).after(writeOutput)
|
|
62
|
-
.finalCb(err, html, user, bytesWritten);
|
|
63
|
-
});
|
package/oldExamples/example14.js
DELETED
|
@@ -1,63 +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 (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
|
-
|
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
|
-
|