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.
Files changed (55) hide show
  1. package/.travis.yml +5 -3
  2. package/README.md +10 -1
  3. package/dist/react.js +179 -145
  4. package/dist/react.min.js +1 -1
  5. package/doc/advanced.md +1 -1
  6. package/lib/base-task.js +16 -19
  7. package/lib/cb-task.js +5 -5
  8. package/lib/core.js +5 -5
  9. package/lib/dsl.js +29 -29
  10. package/lib/error.js +4 -4
  11. package/lib/event-collector.js +6 -6
  12. package/lib/event-manager.js +1 -1
  13. package/lib/eventemitter.js +3 -3
  14. package/lib/finalcb-first-task.js +4 -4
  15. package/lib/finalcb-task.js +4 -4
  16. package/lib/id.js +3 -3
  17. package/lib/input-parser.js +10 -10
  18. package/lib/log-events.js +1 -1
  19. package/lib/parse.js +3 -3
  20. package/lib/promise-resolve.js +4 -4
  21. package/lib/promise-task.js +4 -4
  22. package/lib/react.js +1 -1
  23. package/lib/ret-task.js +4 -4
  24. package/lib/sprintf.js +4 -4
  25. package/lib/status.js +3 -3
  26. package/lib/task.js +12 -12
  27. package/lib/track-tasks.js +4 -4
  28. package/lib/validate.js +8 -8
  29. package/lib/vcon.js +28 -5
  30. package/lib/when-task.js +7 -8
  31. package/package.json +7 -7
  32. package/test/ast.mocha.js +4 -4
  33. package/test/cb-task.mocha.js +17 -17
  34. package/test/core-deferred.mocha.js +8 -8
  35. package/test/core-when.mocha.js +7 -7
  36. package/test/core.mocha.js +52 -52
  37. package/test/dsl.mocha.js +14 -12
  38. package/test/event-manager.mocha.js +2 -2
  39. package/test/exec-options.mocha.js +4 -4
  40. package/test/finalcb-task.mocha.js +1 -1
  41. package/test/input-parser.mocha.js +1 -1
  42. package/test/log-events.mocha.js +1 -1
  43. package/test/module-use.mocha.js +24 -7
  44. package/test/promise-auto-resolve.mocha.js +4 -4
  45. package/test/ret-task.mocha.js +18 -18
  46. package/test/task.mocha.js +3 -3
  47. package/test/validate-cb-task.mocha.js +11 -11
  48. package/test/validate-ret-task.mocha.js +14 -14
  49. package/test/validate.mocha.js +57 -57
  50. package/test/vcon.mocha.js +13 -13
  51. package/vendor/chai/chai.js +3371 -1158
  52. package/vendor/requirejs/require.js +1447 -1455
  53. package/vendor/requirejs/require.min.js +31 -28
  54. package/vendor/mocha/mocha.css +0 -135
  55. package/vendor/mocha/mocha.js +0 -3589
@@ -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
- var OUTPUT_STYLES = {
16
- CALLBACK: 'cb',
17
- NONE: 'none'
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
- var args = inputArgs.filter(nonExecOptionsFilter);
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
+ });
@@ -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
- var PROMISE_SUFFIX = '__promise'; // added to param names that are promises
20
+ var PROMISE_SUFFIX = '__promise'; // added to param names that are promises
21
21
 
22
- var resolvingPromises = false;
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
+ });
@@ -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
+ });
@@ -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
- return errors;
76
+ return errors;
77
77
  }
78
78
 
79
79
  function validateTaskNamesUnique(tasks) {
80
- if (!Array.isArray(tasks)) return [];
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
- return nameAndProps.reduce(function (accObj, prop) {
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
+ });