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
package/lib/dsl.js CHANGED
@@ -6,9 +6,13 @@ var core = require('./core.js');
6
6
  var parse = require('./parse.js');
7
7
  var tutil = require('./task.js');
8
8
 
9
- var INOUT_PARAMS_NO_MATCH = 'params in wrong format, wanted "foo, bar cb -> err, baz" - found: %s';
9
+ var MISSING_NAME = 'first flow parameter should be the flow name, but found in/out def: %s';
10
+ var INOUT_PARAMS_NO_MATCH = 'params in wrong format, wanted "foo, bar, cb -> err, baz" - found: %s';
11
+ var MISSING_ERR = 'callback specified, but first out param was not "err", use for clarity. Found in/out def: %s';
12
+ var MISSING_CB = 'found err param, but cb/callback is not specified, is this cb-style async or sync function? Found in/out def: %s';
10
13
  var EXTRA_TASKARG = 'extra unmatched task arg: %s';
11
14
 
15
+ var INOUT_RE = /\->/; // used to detect missing name, in/out as first arg
12
16
  var CB_NAMES_RE = /^cb|callback$/i; //cb, Cb, CB, callback, Callback
13
17
  var ERR_NAMES_RE = /^err$/i; // err, ERR, Err, ...
14
18
 
@@ -23,12 +27,18 @@ function filterOutLeadingErrParam(args) { // if leading err param, filter it out
23
27
  }
24
28
 
25
29
  var inOutDefParse = {
26
- regex: /^([^\-]*)(->\s*(.*))?$/i,
27
- fn: function (m) {
28
- var inParams = parse.splitTrimFilterArgs(m[1]);
30
+ splitStr: '->',
31
+ fn: function (m, origStr) {
32
+ var inParams = parse.splitTrimFilterArgs(m[0]);
29
33
  var lastParam = inParams[inParams.length - 1];
30
34
  var type = (lastParam && CB_NAMES_RE.test(lastParam)) ? 'cb' : 'ret';
31
- var outParams = parse.splitTrimFilterArgs(m[3]);
35
+ var outParams = parse.splitTrimFilterArgs(m[1]);
36
+ var firstOutParam = outParams[0];
37
+ if (type === 'cb' && (!firstOutParam || !ERR_NAMES_RE.test(firstOutParam))) {
38
+ throw new Error(sprintf(MISSING_ERR, origStr)); // found cb, but no err param
39
+ } else if (type === 'ret' && firstOutParam && ERR_NAMES_RE.test(firstOutParam)) {
40
+ throw new Error(sprintf(MISSING_CB, origStr)); // found err but not cb param
41
+ }
32
42
  return {
33
43
  type: type,
34
44
  inDef: filterOutTrailingCbParam(inParams),
@@ -81,6 +91,7 @@ function parseVargs(vargs) {
81
91
 
82
92
  function dslDefine(name, arg1, arg2, argN) {
83
93
  var reactFn = core();
94
+ if (name && INOUT_RE.test(name)) throw new Error(sprintf(MISSING_NAME, name));
84
95
  var defObj = parseVargs(Array.prototype.slice.call(arguments, 1)); // name, already used
85
96
  var inOutDef = parseInOutParams(defObj.inOutParamStr);
86
97
  var ast = {
@@ -3,12 +3,20 @@
3
3
  var EventEmitter2 = require('eventemitter2').EventEmitter2;
4
4
 
5
5
  var EVENT_EMITTER2_CONFIG = {
6
- wildcard: true
6
+ wildcard: true, // should the event emitter use wildcards.
7
+ delimiter: '.', // the delimiter used to segment namespaces, defaults to `.`.
8
+ maxListeners: 30 // the max number of listeners that can be assigned to an event, defaults to 10.
7
9
  };
8
10
 
9
11
  var TYPES = {
10
- TASK_BEGIN: 'task.begin',
11
- TASK_COMPLETE: 'task.complete'
12
+ // Flow monitoring events and their params
13
+ TASK_BEGIN: 'task.begin', // task
14
+ TASK_COMPLETE: 'task.complete', // task
15
+
16
+ // Internal Hooks
17
+ EXEC_INPUT_PREPROCESS: 'exec.input.preprocess', // parsedInput
18
+ EXEC_TASKS_PRECREATE: 'exec.tasks.precreate', // taskEnv
19
+ EXEC_OUTTASK_CREATE: 'exec.outTask.create' // outTaskOptions
12
20
  };
13
21
 
14
22
  /**
@@ -21,6 +29,9 @@ function EventManager() {
21
29
 
22
30
  EventManager.create = function () { return new EventManager(); };
23
31
 
32
+ EventManager.TYPES = TYPES;
33
+ EventManager.prototype.TYPES = TYPES;
34
+
24
35
  EventManager.prototype.isEnabled = function () { // if has listener or an ancestor has listener
25
36
  return (this.emitter || (this.parent && this.parent.isEnabled()));
26
37
  };
@@ -36,6 +47,7 @@ EventManager.prototype.on = function (event, listener) {
36
47
  };
37
48
 
38
49
  EventManager.prototype.emit = function (event, arg1, arg2, argN) {
50
+ if (event === undefined) throw new Error('event is undefined');
39
51
  if (this.emitter) this.emitter.emit.apply(this.emitter, arguments);
40
52
  if (this.parent && this.parent.isEnabled()) this.parent.emit.apply(this.parent, arguments);
41
53
  };
@@ -54,4 +66,4 @@ EventManager.prototype.emitObject = function (event, object) {
54
66
  };
55
67
 
56
68
  module.exports = EventManager;
57
- module.exports.TYPES = TYPES;
69
+ module.exports.global = EventManager.create(); // create one top level emitter
@@ -8,12 +8,20 @@ var VContext = require('./vcon.js');
8
8
 
9
9
  var OUTTASK_A_REQ = 'ast.outTask.a should be an array of string param names';
10
10
 
11
- function FinalCbFirstSuccTask(taskDef, cbFunc, tasks, vCon) {
11
+ function FinalCbFirstSuccTask(outTaskOptions) {
12
+ var taskDef = outTaskOptions.taskDef;
13
+ var cbFunc = outTaskOptions.cbFunc;
14
+ var tasks = outTaskOptions.tasks;
15
+ var vCon = outTaskOptions.vCon;
16
+ var execOptions = outTaskOptions.execOptions;
17
+ var retValue = outTaskOptions.retValue;
18
+ if (typeof(cbFunc) !== 'function') throw new Error('callback is not a function');
12
19
  var self = this;
13
20
  Object.keys(taskDef).forEach(function (k) { self[k] = taskDef[k]; });
14
21
  this.f = cbFunc;
15
22
  this.tasks = tasks;
16
23
  this.vCon = vCon;
24
+ this.retValue = retValue;
17
25
  }
18
26
 
19
27
  function format_error(errmsg, obj) {
@@ -27,11 +35,6 @@ FinalCbFirstSuccTask.validate = function (taskDef) {
27
35
  errors.push(format_error(OUTTASK_A_REQ, taskDef));
28
36
  }
29
37
  return errors;
30
- }
31
-
32
- FinalCbFirstSuccTask.create = function (taskDef, cbFunc, tasks, vCon) {
33
- if (!(cbFunc && cbFunc instanceof Function)) throw new Error('callback is not a function');
34
- return new FinalCbFirstSuccTask(taskDef, cbFunc, tasks, vCon);
35
38
  };
36
39
 
37
40
  /**
@@ -7,12 +7,20 @@ var STATUS = require('./status.js');
7
7
 
8
8
  var OUTTASK_A_REQ = 'ast.outTask.a should be an array of string param names';
9
9
 
10
- function FinalCbTask(taskDef, cbFunc, tasks, vCon) {
10
+ function FinalCbTask(outTaskOptions) {
11
+ var taskDef = outTaskOptions.taskDef;
12
+ var cbFunc = outTaskOptions.cbFunc;
13
+ var tasks = outTaskOptions.tasks;
14
+ var vCon = outTaskOptions.vCon;
15
+ var execOptions = outTaskOptions.execOptions;
16
+ var retValue = outTaskOptions.retValue;
17
+ if (typeof(cbFunc) !== 'function') throw new Error('callback is not a function');
11
18
  var self = this;
12
19
  Object.keys(taskDef).forEach(function (k) { self[k] = taskDef[k]; });
13
20
  this.f = cbFunc;
14
21
  this.tasks = tasks;
15
22
  this.vCon = vCon;
23
+ this.retValue = retValue;
16
24
  }
17
25
 
18
26
  function format_error(errmsg, obj) {
@@ -29,11 +37,6 @@ FinalCbTask.validate = function (taskDef) {
29
37
  return errors;
30
38
  };
31
39
 
32
- FinalCbTask.create = function (taskDef, cbFunc, tasks, vCon) {
33
- if (!(cbFunc && cbFunc instanceof Function)) throw new Error('callback is not a function');
34
- return new FinalCbTask(taskDef, cbFunc, tasks, vCon);
35
- };
36
-
37
40
  FinalCbTask.prototype.isReady = function () {
38
41
  return (this.tasks.every(function (t) { return (t.status === STATUS.COMPLETE); }));
39
42
  };
@@ -1,12 +1,14 @@
1
1
  'use strict';
2
2
 
3
+ var EventManager = require('./event-manager.js');
4
+
3
5
  var defaultExecOptions = {
4
6
  reactExecOptions: true,
5
- outputStyle: 'callback',
7
+ outputStyle: 'cb',
6
8
  };
7
9
 
8
10
  var OUTPUT_STYLES = {
9
- CALLBACK: 'callback',
11
+ CALLBACK: 'cb',
10
12
  NONE: 'none'
11
13
  };
12
14
 
@@ -36,7 +38,9 @@ function inputParser(inputArgs, ast) {
36
38
  var splitResult = splitArgs(args, ast.inParams, parsedInput.options.outputStyle);
37
39
  parsedInput.args = splitResult.args;
38
40
  parsedInput.cb = splitResult.cb;
39
- if (splitResult.extra) parsedInput.extraArgs = splitResult.extra;
41
+ if (splitResult.outputStyle) parsedInput.options.outputStyle = splitResult.outputStyle;
42
+ if (splitResult.extra) parsedInput.extraArgs = splitResult.extra;
43
+ EventManager.global.emit(EventManager.TYPES.EXEC_INPUT_PREPROCESS, parsedInput); // hook
40
44
  return parsedInput;
41
45
  }
42
46
 
package/lib/parse.js CHANGED
@@ -9,10 +9,13 @@ function splitTrimFilterArgs(commaSepArgs) { //parse 'one, two' into ['one', 'tw
9
9
  .filter(function (s) { return (s); }); //filter out empty strings
10
10
  }
11
11
 
12
- function parseReduce(accum, regexFn) {
12
+ /**
13
+ @param patternFn regex + fn or splitStr + fn
14
+ */
15
+ function parseReduce(accum, patternFn) {
13
16
  if (typeof(accum) !== 'string') return accum; // already matched
14
- var m = regexFn.regex.exec(accum);
15
- if (m) return regexFn.fn(m); // return result obj
17
+ var m = (patternFn.regex) ? patternFn.regex.exec(accum) : accum.split(patternFn.splitStr);
18
+ if (m) return patternFn.fn(m, accum); // pass in matches and origStr, return result obj
16
19
  return accum; // no match, return str, will try next matcher
17
20
  }
18
21
 
@@ -0,0 +1,89 @@
1
+ 'use strict';
2
+
3
+ /**
4
+ PromiseTask is a task which executes a fn that returns a promise
5
+ and when it completes it sets the values in vCon
6
+ */
7
+
8
+ var util = require('util');
9
+ var sprintf = require('sprintf').sprintf;
10
+
11
+ var BaseTask = require('./base-task.js');
12
+
13
+ function format_error(errmsg, obj) {
14
+ return sprintf('%s - %s', errmsg, util.inspect(obj));
15
+ }
16
+
17
+ var REQ = 'promiseTask requires f, a, out';
18
+ var FN_REQ = 'promiseTask requires f to be a function or string';
19
+ var A_REQ = 'promiseTask requires a to be an array of string param names';
20
+ var OUT_REQ = 'promiseTask requires out to be an array[1] of string param names';
21
+
22
+ function PromiseTask(taskDef) {
23
+ var self = this;
24
+ Object.keys(taskDef).forEach(function (k) { self[k] = taskDef[k]; });
25
+ }
26
+
27
+ PromiseTask.prototype = new BaseTask();
28
+ PromiseTask.prototype.constructor = PromiseTask;
29
+
30
+ PromiseTask.validate = function (taskDef) {
31
+ var errors = [];
32
+ if (!taskDef.f || !taskDef.a || !taskDef.out) {
33
+ errors.push(format_error(REQ, taskDef));
34
+ } else {
35
+ var ftype = typeof(taskDef.f);
36
+ if (! ((taskDef.f instanceof Function) || (ftype === 'string'))) {
37
+ errors.push(format_error(FN_REQ, taskDef));
38
+ }
39
+ if (! (Array.isArray(taskDef.a) &&
40
+ taskDef.a.every(function (x) { return (typeof(x) === 'string'); }))) {
41
+ errors.push(format_error(A_REQ, taskDef));
42
+ }
43
+ if (! (Array.isArray(taskDef.out) && taskDef.out.length <= 1 &&
44
+ taskDef.out.every(function (x) { return (typeof(x) === 'string'); }))) {
45
+ errors.push(format_error(OUT_REQ, taskDef));
46
+ }
47
+ }
48
+ return errors;
49
+ };
50
+
51
+ PromiseTask.prototype.prepare = function prepare(handleTaskError, vCon, contExec) {
52
+ var self = this;
53
+ this.nextFn = function (arg) {
54
+ var args = Array.prototype.slice.call(arguments);
55
+ vCon.saveResults(self.out, args);
56
+ self.complete(args);
57
+ contExec();
58
+ };
59
+ this.failFn = function (err) {
60
+ handleTaskError(self, err);
61
+ };
62
+ };
63
+
64
+ PromiseTask.prototype.exec = function exec(vCon, handleError, contExec) {
65
+ try {
66
+ var args = this.a.map(function (k) { return vCon.getVar(k); }); //get args from vCon
67
+ //console.error('PromiseTask.exec.args=', args);
68
+ //console.error('PromiseTask.exec.vCon=', vCon);
69
+ this.start(args); //note the start time, args
70
+ var func = this.f;
71
+ var bindObj = vCon.getVar('this'); //global space or the original this
72
+ if (this.isMethodCall()) { //if method call then reset func and bindObj
73
+ func = vCon.getVar(this.f);
74
+ bindObj = this.getMethodObj(vCon);
75
+ } else if (typeof(func) === 'string') {
76
+ func = vCon.getVar(func); // we want the actual fn from this string
77
+ }
78
+ var retValue = func.apply(bindObj, args);
79
+ if (retValue && typeof(retValue.then) === 'function') { // is a promise
80
+ retValue.then(this.nextFn, this.failFn);
81
+ } else { // just a value, proceed now
82
+ this.nextFn(retValue);
83
+ }
84
+ } catch (err) { //catch and handle the task error, calling final cb
85
+ handleError(this, err);
86
+ }
87
+ };
88
+
89
+ module.exports = PromiseTask;
package/lib/ret-task.js CHANGED
@@ -50,7 +50,7 @@ RetTask.prototype.exec = function exec(vCon, handleError, contExec) {
50
50
  var args = this.a.map(function (k) { return vCon.getVar(k); }); //get args from vCon
51
51
  this.start(args); //note the start time, args
52
52
  var func = this.f;
53
- var bindObj = null; //global space
53
+ var bindObj = vCon.getVar('this'); //global space or the original this
54
54
  if (this.isMethodCall()) { //if method call then reset func and bindObj
55
55
  func = vCon.getVar(this.f);
56
56
  bindObj = this.getMethodObj(vCon);
package/lib/task.js CHANGED
@@ -4,16 +4,21 @@ var util = require('util');
4
4
  var sprintf = require('sprintf').sprintf;
5
5
  var array = require('ensure-array');
6
6
  var CbTask = require('./cb-task.js');
7
+ var PromiseTask = require('./promise-task.js');
7
8
  var RetTask = require('./ret-task.js');
9
+ var WhenTask = require('./when-task.js');
8
10
  var FinalCbTask = require('./finalcb-task.js');
9
11
  var FinalCbFirstSuccTask = require('./finalcb-first-task.js');
10
12
  var STATUS = require('./status.js');
11
13
  var error = require('./error.js');
12
14
  var VContext = require('./vcon.js');
15
+ var EventManager = require('./event-manager.js');
13
16
 
14
17
  var TASK_TYPES = {
15
18
  cb: CbTask,
16
- ret: RetTask
19
+ ret: RetTask,
20
+ promise: PromiseTask,
21
+ when: WhenTask
17
22
  };
18
23
  function taskTypeKeys() { return Object.keys(TASK_TYPES); }
19
24
 
@@ -106,7 +111,8 @@ function validateLocalFunctions(inParams, taskDefs, locals) {
106
111
  var mock_args = inParams.map(function (p) { return foo; }); //mock args with fns
107
112
  var vCon = VContext.create(mock_args, inParams, locals);
108
113
  var tasks = taskDefs.map(create);
109
- tasks.forEach(function (t, idx) {
114
+ var tasksWFunctions = tasks.filter(function (t) { return (t.type !== 'when'); }); // non-when tasks need f
115
+ tasksWFunctions.forEach(function (t, idx) {
110
116
  if (!t.functionExists(vCon)) { // error if function doesnt exist AND
111
117
  if (!t.isMethodCall()) errors.push(sprintf(LOCAL_FN_MISSING, t.f, idx)); // not method OR
112
118
  else {
@@ -121,7 +127,9 @@ function validateLocalFunctions(inParams, taskDefs, locals) {
121
127
  }
122
128
 
123
129
  function fName(fn) {
124
- return (typeof(fn) === 'string') ? fn : fn.name;
130
+ return (fn) ?
131
+ ((fn.name) ? fn.name : fn) : // if defined, try name, otherwise toString()
132
+ 'undefined'; // not defined, use undefined
125
133
  }
126
134
 
127
135
  /**
@@ -155,24 +163,21 @@ function create(taskDef) {
155
163
  return new TaskConstructor(taskDef);
156
164
  }
157
165
 
158
- function createOutTask(taskDef, cbFinal, tasks, vCon) {
166
+ function createOutTask(taskDef, cbFunc, tasks, vCon, execOptions) {
159
167
  setMissingOutTaskType(taskDef);
160
- var TaskConstructor = OUT_TASK_TYPES[taskDef.type];
161
- return new TaskConstructor(taskDef, cbFinal, tasks, vCon);
162
- }
163
-
164
- function createCallback(task, handleTaskError, vCon, contExec) {
165
- return function (err, arg0, arg1, argn) {
166
- var args = Array.prototype.slice.call(arguments, 1);
167
- if (err) { handleTaskError(task, err); return; } //handle error and return, we are done
168
-
169
- //no error, save callback args to vCon context, then continue execution
170
- vCon.saveResults(task.out, args);
171
- task.complete(args);
172
- contExec();
168
+ var outTaskOptions = {
169
+ taskDef: taskDef,
170
+ cbFunc: cbFunc,
171
+ tasks: tasks,
172
+ vCon: vCon,
173
+ execOptions: execOptions,
174
+ TaskConstructor: OUT_TASK_TYPES[taskDef.type]
173
175
  };
176
+ EventManager.global.emit(EventManager.TYPES.EXEC_OUTTASK_CREATE, outTaskOptions); // hook
177
+ var TaskConstructor = outTaskOptions.TaskConstructor; // hook could have changed
178
+ return new TaskConstructor(outTaskOptions);
174
179
  }
175
-
180
+
176
181
  function createErrorHandler(vCon, outTask) {
177
182
  return function handleError(task, err) {
178
183
  task.status = STATUS.ERRORED;
@@ -234,6 +239,5 @@ exports.validateLocalFunctions = validateLocalFunctions;
234
239
  exports.nameTasks = nameTasks;
235
240
  exports.create = create;
236
241
  exports.createOutTask = createOutTask;
237
- exports.createCallback = createCallback;
238
242
  exports.createErrorHandler = createErrorHandler;
239
243
  exports.findReadyAndExec = findReadyAndExec;
package/lib/validate.js CHANGED
@@ -13,6 +13,9 @@ var LOCALS_NOTNULL = 'ast.locals should not be null';
13
13
  var DUP_OUTPUTS = 'multiple tasks output the same param, must be unique. param';
14
14
  var MISSING_INPUTS = 'missing or mispelled variable referenced in flow definition: %s';
15
15
 
16
+ // match any of our literals true, false, int, float, quoted strings, or is property (has dot), match vcon.js
17
+ var LITERAL_OR_PROP_RE = /^(true|false|this|null|\-?[0-9\.]+)$|'|"|\./i;
18
+
16
19
  var validateInParams, validateTasks, validateOutTask, validateTaskNamesUnique;
17
20
  var validateLocals, validateOuputsUnique, validateNoMissingNames;
18
21
 
@@ -20,10 +23,15 @@ function format_error(errmsg, obj) {
20
23
  return sprintf('%s - %s', errmsg, util.inspect(obj));
21
24
  }
22
25
 
23
- function isProp(str) { // true if is a property name (contains a dot)
24
- return (str.indexOf('.') !== -1);
26
+ /**
27
+ true if is a literal name
28
+ */
29
+ function isLiteralOrProp(name) { // need to match what is in vcon.js, TODO consolidate?
30
+ return LITERAL_OR_PROP_RE.test(name);
25
31
  }
26
32
 
33
+
34
+
27
35
  /**
28
36
  validate the AST return Errors
29
37
  @example
@@ -105,6 +113,7 @@ function validateOuputsUnique(taskDefs) {
105
113
  return errors;
106
114
  }
107
115
 
116
+
108
117
  /**
109
118
  validate there are no missing or mispelled param names in any task inputs
110
119
  or the final task output
@@ -134,17 +143,17 @@ function validateNoMissingNames(ast) {
134
143
  // now we have all possible provided vars, check task inputs are accounted for
135
144
  ast.tasks.reduce(function (accum, t) { // for all tasks
136
145
  return t.a.reduce(function (innerAccum, p) { // for all in params, except property
137
- if (!isProp(p) && !names[p]) innerAccum.push(sprintf(MISSING_INPUTS, p)); // add error if missing
146
+ if (!isLiteralOrProp(p) && !names[p]) innerAccum.push(sprintf(MISSING_INPUTS, p)); // add error if missing
138
147
  return innerAccum;
139
148
  }, accum);
140
149
  }, errors);
141
150
 
142
151
  // now check the final task outputs
143
152
  ast.outTask.a.reduce(function (accum, p) { // for final task out params
144
- if (!isProp(p) && !names[p]) accum.push(sprintf(MISSING_INPUTS, p)); // add error if missing
153
+ if (!isLiteralOrProp(p) && !names[p]) accum.push(sprintf(MISSING_INPUTS, p)); // add error if missing
145
154
  return accum;
146
155
  }, errors);
147
- return errors;
156
+ return errors;
148
157
  }
149
158
 
150
159
  module.exports = validate;