react 0.6.3 → 0.7.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/.travis.yml +5 -3
- package/README.md +10 -1
- package/dist/react.js +179 -145
- package/dist/react.min.js +1 -1
- package/doc/advanced.md +1 -1
- package/lib/base-task.js +16 -19
- package/lib/cb-task.js +5 -5
- package/lib/core.js +5 -5
- package/lib/dsl.js +29 -29
- package/lib/error.js +4 -4
- package/lib/event-collector.js +6 -6
- package/lib/event-manager.js +1 -1
- package/lib/eventemitter.js +3 -3
- package/lib/finalcb-first-task.js +4 -4
- package/lib/finalcb-task.js +4 -4
- package/lib/id.js +3 -3
- package/lib/input-parser.js +10 -10
- package/lib/log-events.js +1 -1
- package/lib/parse.js +3 -3
- package/lib/promise-resolve.js +4 -4
- package/lib/promise-task.js +4 -4
- package/lib/react.js +1 -1
- package/lib/ret-task.js +4 -4
- package/lib/sprintf.js +4 -4
- package/lib/status.js +3 -3
- package/lib/task.js +12 -12
- package/lib/track-tasks.js +4 -4
- package/lib/validate.js +8 -8
- package/lib/vcon.js +28 -5
- package/lib/when-task.js +7 -8
- package/package.json +7 -7
- package/test/ast.mocha.js +4 -4
- package/test/cb-task.mocha.js +17 -17
- package/test/core-deferred.mocha.js +8 -8
- package/test/core-when.mocha.js +7 -7
- package/test/core.mocha.js +52 -52
- package/test/dsl.mocha.js +14 -12
- package/test/event-manager.mocha.js +2 -2
- package/test/exec-options.mocha.js +4 -4
- package/test/finalcb-task.mocha.js +1 -1
- package/test/input-parser.mocha.js +1 -1
- package/test/log-events.mocha.js +1 -1
- package/test/module-use.mocha.js +24 -7
- package/test/promise-auto-resolve.mocha.js +4 -4
- package/test/ret-task.mocha.js +18 -18
- package/test/task.mocha.js +3 -3
- package/test/validate-cb-task.mocha.js +11 -11
- package/test/validate-ret-task.mocha.js +14 -14
- package/test/validate.mocha.js +57 -57
- package/test/vcon.mocha.js +13 -13
- package/vendor/chai/chai.js +3371 -1158
- package/vendor/requirejs/require.js +1447 -1455
- package/vendor/requirejs/require.min.js +31 -28
- package/vendor/mocha/mocha.css +0 -135
- package/vendor/mocha/mocha.js +0 -3589
package/lib/input-parser.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -6,16 +5,17 @@ if (typeof define !== 'function') {
|
|
|
6
5
|
}
|
|
7
6
|
|
|
8
7
|
define(['./event-manager'], function (EventManager) {
|
|
8
|
+
'use strict';
|
|
9
9
|
|
|
10
10
|
var defaultExecOptions = {
|
|
11
11
|
reactExecOptions: true,
|
|
12
12
|
outputStyle: 'cb',
|
|
13
13
|
};
|
|
14
14
|
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
15
|
+
var OUTPUT_STYLES = {
|
|
16
|
+
CALLBACK: 'cb',
|
|
17
|
+
NONE: 'none'
|
|
18
|
+
};
|
|
19
19
|
|
|
20
20
|
function isExecOptions(x) { return (x && x.reactExecOptions); }
|
|
21
21
|
function execOptionsFilter(x) { return isExecOptions(x); }
|
|
@@ -31,16 +31,16 @@ define(['./event-manager'], function (EventManager) {
|
|
|
31
31
|
if (style === OUTPUT_STYLES.CALLBACK && args.length) result.cb = args.shift(); // next take the cb
|
|
32
32
|
result.extra = args; // these remaining were after the callback
|
|
33
33
|
return result;
|
|
34
|
-
|
|
35
|
-
|
|
34
|
+
}
|
|
35
|
+
|
|
36
36
|
function inputParser(inputArgs, ast) {
|
|
37
37
|
var parsedInput = { };
|
|
38
38
|
var execOptionsArr = inputArgs.filter(execOptionsFilter);
|
|
39
39
|
execOptionsArr.unshift(defaultExecOptions);
|
|
40
40
|
parsedInput.options = execOptionsArr.reduce(mergeExecOptions, {});
|
|
41
41
|
|
|
42
|
-
|
|
43
|
-
var splitResult = splitArgs(args, ast.inParams, parsedInput.options.outputStyle);
|
|
42
|
+
var args = inputArgs.filter(nonExecOptionsFilter);
|
|
43
|
+
var splitResult = splitArgs(args, ast.inParams, parsedInput.options.outputStyle);
|
|
44
44
|
parsedInput.args = splitResult.args;
|
|
45
45
|
parsedInput.cb = splitResult.cb;
|
|
46
46
|
if (splitResult.outputStyle) parsedInput.options.outputStyle = splitResult.outputStyle;
|
|
@@ -53,4 +53,4 @@ define(['./event-manager'], function (EventManager) {
|
|
|
53
53
|
inputParser.defaultExecOptions = defaultExecOptions;
|
|
54
54
|
return inputParser;
|
|
55
55
|
|
|
56
|
-
});
|
|
56
|
+
});
|
package/lib/log-events.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -6,6 +5,7 @@ if (typeof define !== 'function') {
|
|
|
6
5
|
}
|
|
7
6
|
|
|
8
7
|
define(['util'], function (util) { // TODO replace util.inspect with something portable to browser
|
|
8
|
+
'use strict';
|
|
9
9
|
|
|
10
10
|
var logEventsMod = { };
|
|
11
11
|
|
package/lib/parse.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -6,6 +5,7 @@ if (typeof define !== 'function') {
|
|
|
6
5
|
}
|
|
7
6
|
|
|
8
7
|
define(['./sprintf'], function (sprintf) {
|
|
8
|
+
'use strict';
|
|
9
9
|
|
|
10
10
|
function splitTrimFilterArgs(commaSepArgs) { //parse 'one, two' into ['one', 'two']
|
|
11
11
|
if (!commaSepArgs) return [];
|
|
@@ -30,7 +30,7 @@ define(['./sprintf'], function (sprintf) {
|
|
|
30
30
|
return result;
|
|
31
31
|
} else { // no match
|
|
32
32
|
throw new Error(sprintf(errStr, str));
|
|
33
|
-
}
|
|
33
|
+
}
|
|
34
34
|
}
|
|
35
35
|
|
|
36
36
|
return {
|
|
@@ -38,4 +38,4 @@ define(['./sprintf'], function (sprintf) {
|
|
|
38
38
|
parseStr: parseStr
|
|
39
39
|
};
|
|
40
40
|
|
|
41
|
-
});
|
|
41
|
+
});
|
package/lib/promise-resolve.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -6,6 +5,7 @@ if (typeof define !== 'function') {
|
|
|
6
5
|
}
|
|
7
6
|
|
|
8
7
|
define([], function () {
|
|
8
|
+
'use strict';
|
|
9
9
|
|
|
10
10
|
/**
|
|
11
11
|
Auto resolve promises passed in as arguments to the flow
|
|
@@ -17,9 +17,9 @@ define([], function () {
|
|
|
17
17
|
*/
|
|
18
18
|
|
|
19
19
|
|
|
20
|
-
|
|
20
|
+
var PROMISE_SUFFIX = '__promise'; // added to param names that are promises
|
|
21
21
|
|
|
22
|
-
|
|
22
|
+
var resolvingPromises = false;
|
|
23
23
|
|
|
24
24
|
function resolvePromises(react) {
|
|
25
25
|
if (resolvingPromises) return; // already resolving
|
|
@@ -47,4 +47,4 @@ define([], function () {
|
|
|
47
47
|
|
|
48
48
|
return resolvePromises;
|
|
49
49
|
|
|
50
|
-
});
|
|
50
|
+
});
|
package/lib/promise-task.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -6,6 +5,7 @@ if (typeof define !== 'function') {
|
|
|
6
5
|
}
|
|
7
6
|
|
|
8
7
|
define(['util', './sprintf', './base-task'], function (util, sprintf, BaseTask) {
|
|
8
|
+
'use strict';
|
|
9
9
|
|
|
10
10
|
/**
|
|
11
11
|
PromiseTask is a task which executes a fn that returns a promise
|
|
@@ -42,7 +42,7 @@ define(['util', './sprintf', './base-task'], function (util, sprintf, BaseTask)
|
|
|
42
42
|
taskDef.a.every(function (x) { return (typeof(x) === 'string'); }))) {
|
|
43
43
|
errors.push(format_error(A_REQ, taskDef));
|
|
44
44
|
}
|
|
45
|
-
if (! (Array.isArray(taskDef.out) && taskDef.out.length <= 1 &&
|
|
45
|
+
if (! (Array.isArray(taskDef.out) && taskDef.out.length <= 1 &&
|
|
46
46
|
taskDef.out.every(function (x) { return (typeof(x) === 'string'); }))) {
|
|
47
47
|
errors.push(format_error(OUT_REQ, taskDef));
|
|
48
48
|
}
|
|
@@ -85,9 +85,9 @@ define(['util', './sprintf', './base-task'], function (util, sprintf, BaseTask)
|
|
|
85
85
|
}
|
|
86
86
|
} catch (err) { //catch and handle the task error, calling final cb
|
|
87
87
|
handleError(this, err);
|
|
88
|
-
}
|
|
88
|
+
}
|
|
89
89
|
};
|
|
90
90
|
|
|
91
91
|
return PromiseTask;
|
|
92
92
|
|
|
93
|
-
});
|
|
93
|
+
});
|
package/lib/react.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -7,6 +6,7 @@ if (typeof define !== 'function') {
|
|
|
7
6
|
|
|
8
7
|
define(['./core', './dsl', './track-tasks', './log-events', './promise-resolve', './event-collector'],
|
|
9
8
|
function (core, dsl, trackTasksFn, logEventsMod, resolvePromisesFn, eventCollectorFactory) {
|
|
9
|
+
'use strict';
|
|
10
10
|
|
|
11
11
|
var react = dsl; // core + default dsl
|
|
12
12
|
|
package/lib/ret-task.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -6,7 +5,8 @@ if (typeof define !== 'function') {
|
|
|
6
5
|
}
|
|
7
6
|
|
|
8
7
|
define(['util', './sprintf', './base-task'], function (util, sprintf, BaseTask) {
|
|
9
|
-
|
|
8
|
+
'use strict';
|
|
9
|
+
|
|
10
10
|
function format_error(errmsg, obj) {
|
|
11
11
|
return sprintf('%s - %s', errmsg, util.inspect(obj));
|
|
12
12
|
}
|
|
@@ -50,7 +50,7 @@ define(['util', './sprintf', './base-task'], function (util, sprintf, BaseTask)
|
|
|
50
50
|
RetTask.prototype.exec = function exec(vCon, handleError, contExec) {
|
|
51
51
|
try {
|
|
52
52
|
var args = this.a.map(function (k) { return vCon.getVar(k); }); //get args from vCon
|
|
53
|
-
this.start(args); //note the start time, args
|
|
53
|
+
this.start(args); //note the start time, args
|
|
54
54
|
var func = this.f;
|
|
55
55
|
var bindObj = vCon.getVar('this'); //global space or the original this
|
|
56
56
|
if (this.isMethodCall()) { //if method call then reset func and bindObj
|
|
@@ -68,4 +68,4 @@ define(['util', './sprintf', './base-task'], function (util, sprintf, BaseTask)
|
|
|
68
68
|
|
|
69
69
|
return RetTask;
|
|
70
70
|
|
|
71
|
-
});
|
|
71
|
+
});
|
package/lib/sprintf.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true sprint:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -6,13 +5,14 @@ if (typeof define !== 'function') {
|
|
|
6
5
|
}
|
|
7
6
|
|
|
8
7
|
define(['util'], function (util) {
|
|
8
|
+
'use strict';
|
|
9
9
|
|
|
10
10
|
/**
|
|
11
11
|
Abstract the details of getting a sprintf function.
|
|
12
12
|
Currently using the simple format capabilities of node's util.format
|
|
13
13
|
*/
|
|
14
|
-
|
|
14
|
+
|
|
15
15
|
var sprintf = util.format;
|
|
16
16
|
return sprintf;
|
|
17
|
-
|
|
18
|
-
});
|
|
17
|
+
|
|
18
|
+
});
|
package/lib/status.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -6,9 +5,10 @@ if (typeof define !== 'function') {
|
|
|
6
5
|
}
|
|
7
6
|
|
|
8
7
|
define([], function () {
|
|
9
|
-
|
|
8
|
+
'use strict';
|
|
9
|
+
|
|
10
10
|
var STATUS = { READY: 'ready', RUNNING: 'running', ERRORED: 'errored', COMPLETE: 'complete' };
|
|
11
11
|
|
|
12
12
|
return STATUS;
|
|
13
13
|
|
|
14
|
-
});
|
|
14
|
+
});
|
package/lib/task.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -11,7 +10,8 @@ define(['util', './sprintf', 'ensure-array', './cb-task', './promise-task',
|
|
|
11
10
|
function (util, sprintf, array, CbTask, PromiseTask,
|
|
12
11
|
RetTask, WhenTask, FinalCbTask, FinalCbFirstSuccTask,
|
|
13
12
|
STATUS, error, VContext, EventManager) {
|
|
14
|
-
|
|
13
|
+
'use strict';
|
|
14
|
+
|
|
15
15
|
var TASK_TYPES = {
|
|
16
16
|
cb: CbTask,
|
|
17
17
|
ret: RetTask,
|
|
@@ -46,13 +46,13 @@ function (util, sprintf, array, CbTask, PromiseTask,
|
|
|
46
46
|
*/
|
|
47
47
|
function setMissingType(taskDef) {
|
|
48
48
|
if (taskDef.type) return taskDef; //already set, return
|
|
49
|
-
taskDef.type = 'cb';
|
|
49
|
+
taskDef.type = 'cb';
|
|
50
50
|
return taskDef;
|
|
51
51
|
}
|
|
52
52
|
|
|
53
53
|
function setMissingOutTaskType(taskDef) {
|
|
54
54
|
if (!taskDef.type) taskDef.type = Object.keys(OUT_TASK_TYPES)[0]; //use first outTask type as default
|
|
55
|
-
}
|
|
55
|
+
}
|
|
56
56
|
|
|
57
57
|
function ensureAfterArrStrings(taskDef) { // convert any fn to str, and make sure is array
|
|
58
58
|
if (!taskDef.after) return;
|
|
@@ -65,14 +65,14 @@ function (util, sprintf, array, CbTask, PromiseTask,
|
|
|
65
65
|
@returns array of errors for taskDef, could be empty
|
|
66
66
|
*/
|
|
67
67
|
function validate(taskDef) {
|
|
68
|
-
if (!taskDef || typeof(taskDef) !== 'object') {
|
|
68
|
+
if (!taskDef || typeof(taskDef) !== 'object') {
|
|
69
69
|
return [format_error(TASKDEF_IS_OBJECT, taskDef)];
|
|
70
70
|
}
|
|
71
71
|
setMissingType(taskDef);
|
|
72
72
|
ensureAfterArrStrings(taskDef);
|
|
73
73
|
var errors = [];
|
|
74
74
|
errors = errors.concat(validateTaskType(taskDef));
|
|
75
|
-
errors = errors.concat(validateTask(taskDef));
|
|
75
|
+
errors = errors.concat(validateTask(taskDef));
|
|
76
76
|
return errors;
|
|
77
77
|
}
|
|
78
78
|
|
|
@@ -99,13 +99,13 @@ function (util, sprintf, array, CbTask, PromiseTask,
|
|
|
99
99
|
setMissingOutTaskType(taskDef);
|
|
100
100
|
var taskCons = OUT_TASK_TYPES[taskDef.type];
|
|
101
101
|
errors = errors.concat(taskCons.validate(taskDef));
|
|
102
|
-
return errors;
|
|
102
|
+
return errors;
|
|
103
103
|
}
|
|
104
104
|
|
|
105
105
|
|
|
106
106
|
function validateLocalFunctions(inParams, taskDefs, locals) {
|
|
107
107
|
var errors = [];
|
|
108
|
-
function foo() { } //used to mock args as fns for validation check
|
|
108
|
+
function foo() { } //used to mock args as fns for validation check
|
|
109
109
|
var mock_args = inParams.map(function (p) { return foo; }); //mock args with fns
|
|
110
110
|
var vCon = VContext.create(mock_args, inParams, locals);
|
|
111
111
|
var tasks = taskDefs.map(create);
|
|
@@ -178,7 +178,7 @@ function (util, sprintf, array, CbTask, PromiseTask,
|
|
|
178
178
|
var TaskConstructor = outTaskOptions.TaskConstructor; // hook could have changed
|
|
179
179
|
return new TaskConstructor(outTaskOptions);
|
|
180
180
|
}
|
|
181
|
-
|
|
181
|
+
|
|
182
182
|
function createErrorHandler(vCon, outTask) {
|
|
183
183
|
return function handleError(task, err) {
|
|
184
184
|
task.status = STATUS.ERRORED;
|
|
@@ -196,7 +196,7 @@ function (util, sprintf, array, CbTask, PromiseTask,
|
|
|
196
196
|
|
|
197
197
|
function execTasks(tasksReady, vCon, handleError, contExec) {
|
|
198
198
|
tasksReady.forEach(function (t) { t.status = STATUS.READY; }); //set ready first, no double exec
|
|
199
|
-
tasksReady.forEach(function (t) { t.exec(vCon, handleError, contExec); });
|
|
199
|
+
tasksReady.forEach(function (t) { t.exec(vCon, handleError, contExec); });
|
|
200
200
|
}
|
|
201
201
|
|
|
202
202
|
/**
|
|
@@ -227,7 +227,7 @@ function (util, sprintf, array, CbTask, PromiseTask,
|
|
|
227
227
|
|
|
228
228
|
function serializeTasks(tasks) { // conveniently set after for each task idx > 0
|
|
229
229
|
nameTasks(tasks);
|
|
230
|
-
tasks.forEach(function (t, idx, arr) { if (idx !== 0) t.after = [arr[idx - 1].name]; });
|
|
230
|
+
tasks.forEach(function (t, idx, arr) { if (idx !== 0) t.after = [arr[idx - 1].name]; });
|
|
231
231
|
return tasks;
|
|
232
232
|
}
|
|
233
233
|
|
|
@@ -248,4 +248,4 @@ function (util, sprintf, array, CbTask, PromiseTask,
|
|
|
248
248
|
findReadyAndExec: findReadyAndExec
|
|
249
249
|
};
|
|
250
250
|
|
|
251
|
-
});
|
|
251
|
+
});
|
package/lib/track-tasks.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -6,7 +5,8 @@ if (typeof define !== 'function') {
|
|
|
6
5
|
}
|
|
7
6
|
|
|
8
7
|
define([], function () {
|
|
9
|
-
|
|
8
|
+
'use strict';
|
|
9
|
+
|
|
10
10
|
/**
|
|
11
11
|
Track the tasks, start, complete, args, results, elapsed time
|
|
12
12
|
Emits events that can be monitored
|
|
@@ -69,6 +69,6 @@ define([], function () {
|
|
|
69
69
|
|
|
70
70
|
}
|
|
71
71
|
|
|
72
|
-
return trackTasks;
|
|
72
|
+
return trackTasks;
|
|
73
73
|
|
|
74
|
-
});
|
|
74
|
+
});
|
package/lib/validate.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -6,8 +5,9 @@ if (typeof define !== 'function') {
|
|
|
6
5
|
}
|
|
7
6
|
|
|
8
7
|
define(['util', './sprintf', 'ensure-array', './task'], function (util, sprintf, array, taskUtil) {
|
|
8
|
+
'use strict';
|
|
9
9
|
/*jshint latedef:false */
|
|
10
|
-
|
|
10
|
+
|
|
11
11
|
var AST_IS_OBJECT = 'ast must be an object with inParams, tasks, and outTask';
|
|
12
12
|
var INPARAMS_ARR_STR = 'ast.inParams must be an array of strings';
|
|
13
13
|
var TASKS_ARR = 'ast.tasks must be an array of tasks';
|
|
@@ -17,7 +17,7 @@ define(['util', './sprintf', 'ensure-array', './task'], function (util, sprintf,
|
|
|
17
17
|
var MISSING_INPUTS = 'missing or mispelled variable referenced in flow definition: %s';
|
|
18
18
|
|
|
19
19
|
// match any of our literals true, false, int, float, quoted strings, or is property (has dot), match vcon.js
|
|
20
|
-
var LITERAL_OR_PROP_RE = /^(true|false|this|null|\-?[0-9\.]+)$|'|"|\./i;
|
|
20
|
+
var LITERAL_OR_PROP_RE = /^(true|false|this|null|\-?[0-9\.]+)$|'|"|\./i;
|
|
21
21
|
|
|
22
22
|
function format_error(errmsg, obj) {
|
|
23
23
|
return sprintf('%s - %s', errmsg, util.inspect(obj));
|
|
@@ -73,11 +73,11 @@ define(['util', './sprintf', 'ensure-array', './task'], function (util, sprintf,
|
|
|
73
73
|
tasks.forEach(function (t) {
|
|
74
74
|
errors = errors.concat(taskUtil.validate(t));
|
|
75
75
|
});
|
|
76
|
-
|
|
76
|
+
return errors;
|
|
77
77
|
}
|
|
78
78
|
|
|
79
79
|
function validateTaskNamesUnique(tasks) {
|
|
80
|
-
|
|
80
|
+
if (!Array.isArray(tasks)) return [];
|
|
81
81
|
var errors = [];
|
|
82
82
|
var namedTasks = tasks.filter(function (t) { return (t.name); });
|
|
83
83
|
var names = namedTasks.map(function (t) { return t.name; });
|
|
@@ -85,7 +85,7 @@ define(['util', './sprintf', 'ensure-array', './task'], function (util, sprintf,
|
|
|
85
85
|
if (accum[name]) errors.push(sprintf('%s %s', NAMES_UNIQUE, name));
|
|
86
86
|
else accum[name] = true;
|
|
87
87
|
return accum;
|
|
88
|
-
}, {});
|
|
88
|
+
}, {});
|
|
89
89
|
return errors;
|
|
90
90
|
}
|
|
91
91
|
|
|
@@ -151,9 +151,9 @@ define(['util', './sprintf', 'ensure-array', './task'], function (util, sprintf,
|
|
|
151
151
|
if (!isLiteralOrProp(p) && !names[p]) accum.push(sprintf(MISSING_INPUTS, p)); // add error if missing
|
|
152
152
|
return accum;
|
|
153
153
|
}, errors);
|
|
154
|
-
return errors;
|
|
154
|
+
return errors;
|
|
155
155
|
}
|
|
156
156
|
|
|
157
157
|
return validate;
|
|
158
158
|
|
|
159
|
-
});
|
|
159
|
+
});
|
package/lib/vcon.js
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
1
|
/*global define:true */
|
|
3
2
|
|
|
4
3
|
if (typeof define !== 'function') {
|
|
@@ -6,7 +5,8 @@ if (typeof define !== 'function') {
|
|
|
6
5
|
}
|
|
7
6
|
|
|
8
7
|
define([], function () {
|
|
9
|
-
|
|
8
|
+
'use strict';
|
|
9
|
+
|
|
10
10
|
var LAST_RESULTS_KEY = ':LAST_RESULTS';
|
|
11
11
|
|
|
12
12
|
function VContext() {
|
|
@@ -29,10 +29,23 @@ define([], function () {
|
|
|
29
29
|
var m = /^("|')([^\1]*)\1$/.exec(name); //check for quoted string " or '
|
|
30
30
|
if (m) return m[2]; // if is quoted str, return inside of the quotes
|
|
31
31
|
var nameAndProps = name.split('.');
|
|
32
|
-
|
|
32
|
+
var result = this.resolveNameArr(nameAndProps);
|
|
33
|
+
return result;
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
VContext.prototype.resolveNameArr = function (nameAndProps) {
|
|
37
|
+
var vConValues = this.values;
|
|
38
|
+
var result = nameAndProps.reduce(function (accObj, prop) {
|
|
33
39
|
if (accObj === undefined || accObj === null) return undefined; // prevent exception
|
|
34
40
|
return accObj[prop];
|
|
35
41
|
}, vConValues); // vCon['foo']['bar']
|
|
42
|
+
if (result === undefined && this.global !== undefined) { // see if matches any global
|
|
43
|
+
result = nameAndProps.reduce(function (accObj, prop) {
|
|
44
|
+
if (accObj === undefined || accObj === null) return undefined; // prevent exception
|
|
45
|
+
return accObj[prop];
|
|
46
|
+
}, this.global); // global['foo']['bar']
|
|
47
|
+
}
|
|
48
|
+
return result;
|
|
36
49
|
};
|
|
37
50
|
|
|
38
51
|
/**
|
|
@@ -62,7 +75,7 @@ define([], function () {
|
|
|
62
75
|
}, vConValues); // vCon['foo']['bar']
|
|
63
76
|
obj[lastProp] = value;
|
|
64
77
|
};
|
|
65
|
-
|
|
78
|
+
|
|
66
79
|
|
|
67
80
|
/**
|
|
68
81
|
Create Variable Context using arguments passed in.
|
|
@@ -72,6 +85,7 @@ define([], function () {
|
|
|
72
85
|
@param self used to pass 'this' context in
|
|
73
86
|
*/
|
|
74
87
|
VContext.create = function (args, inParams, locals, self) {
|
|
88
|
+
/*jshint validthis:true, evil:true */
|
|
75
89
|
var initValues = {};
|
|
76
90
|
if (self) initValues['this'] = self;
|
|
77
91
|
if (locals) Object.keys(locals).forEach(function (k) { initValues[k] = locals[k]; }); // copy over keys
|
|
@@ -81,10 +95,19 @@ define([], function () {
|
|
|
81
95
|
if (param) vcon[param] = (x !== undefined) ? x : null; // upgrade undefined to null
|
|
82
96
|
return vcon;
|
|
83
97
|
}, initValues);
|
|
98
|
+
|
|
99
|
+
// add in global
|
|
100
|
+
if (typeof global === 'object') { // node.js and modern browsers expose global
|
|
101
|
+
vContext.global = global;
|
|
102
|
+
} else { // try to access this using Function eval of this
|
|
103
|
+
// http://stackoverflow.com/questions/3277182/how-to-get-the-global-object-in-javascript
|
|
104
|
+
vContext.global = new Function('return this')();
|
|
105
|
+
}
|
|
106
|
+
|
|
84
107
|
return vContext;
|
|
85
108
|
};
|
|
86
109
|
|
|
87
110
|
|
|
88
111
|
return VContext;
|
|
89
112
|
|
|
90
|
-
});
|
|
113
|
+
});
|