react 0.6.3 → 0.9.0-rc1

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 (218) hide show
  1. package/README.md +10 -222
  2. package/addons.js +1 -0
  3. package/lib/AutoFocusMixin.js +30 -0
  4. package/lib/CSSCore.js +115 -0
  5. package/lib/CSSProperty.js +121 -0
  6. package/lib/CSSPropertyOperations.js +97 -0
  7. package/lib/ChangeEventPlugin.js +387 -0
  8. package/lib/ClientReactRootIndex.js +30 -0
  9. package/lib/CompositionEventPlugin.js +260 -0
  10. package/lib/DOMChildrenOperations.js +165 -0
  11. package/lib/DOMProperty.js +268 -0
  12. package/lib/DOMPropertyOperations.js +181 -0
  13. package/lib/Danger.js +187 -0
  14. package/lib/DefaultDOMPropertyConfig.js +197 -0
  15. package/lib/DefaultEventPluginOrder.js +44 -0
  16. package/lib/EnterLeaveEventPlugin.js +145 -0
  17. package/lib/EventConstants.js +76 -0
  18. package/lib/EventListener.js +69 -0
  19. package/lib/EventPluginHub.js +291 -0
  20. package/lib/EventPluginRegistry.js +260 -0
  21. package/lib/EventPluginUtils.js +214 -0
  22. package/lib/EventPropagators.js +143 -0
  23. package/lib/ExecutionEnvironment.js +44 -0
  24. package/lib/LinkedStateMixin.js +46 -0
  25. package/lib/LinkedValueUtils.js +161 -0
  26. package/lib/MobileSafariClickEventPlugin.js +63 -0
  27. package/lib/PooledClass.js +119 -0
  28. package/lib/React.js +95 -0
  29. package/lib/ReactCSSTransitionGroup.js +65 -0
  30. package/lib/ReactCSSTransitionGroupChild.js +138 -0
  31. package/lib/ReactChildren.js +132 -0
  32. package/lib/ReactComponent.js +550 -0
  33. package/lib/ReactComponentBrowserEnvironment.js +158 -0
  34. package/lib/ReactComponentEnvironment.js +26 -0
  35. package/lib/ReactCompositeComponent.js +1455 -0
  36. package/lib/ReactContext.js +67 -0
  37. package/lib/ReactCurrentOwner.js +39 -0
  38. package/lib/ReactDOM.js +207 -0
  39. package/lib/ReactDOMButton.js +68 -0
  40. package/lib/ReactDOMComponent.js +399 -0
  41. package/lib/ReactDOMForm.js +59 -0
  42. package/lib/ReactDOMIDOperations.js +218 -0
  43. package/lib/ReactDOMImg.js +58 -0
  44. package/lib/ReactDOMInput.js +181 -0
  45. package/lib/ReactDOMOption.js +51 -0
  46. package/lib/ReactDOMSelect.js +179 -0
  47. package/lib/ReactDOMSelection.js +189 -0
  48. package/lib/ReactDOMTextarea.js +140 -0
  49. package/lib/ReactDefaultBatchingStrategy.js +75 -0
  50. package/lib/ReactDefaultInjection.js +115 -0
  51. package/lib/ReactDefaultPerf.js +244 -0
  52. package/lib/ReactDefaultPerfAnalysis.js +199 -0
  53. package/lib/ReactErrorUtils.js +37 -0
  54. package/lib/ReactEventEmitter.js +337 -0
  55. package/lib/ReactEventEmitterMixin.js +57 -0
  56. package/lib/ReactEventTopLevelCallback.js +109 -0
  57. package/lib/ReactInjection.js +39 -0
  58. package/lib/ReactInputSelection.js +140 -0
  59. package/lib/ReactInstanceHandles.js +338 -0
  60. package/lib/ReactLink.js +54 -0
  61. package/lib/ReactMarkupChecksum.js +53 -0
  62. package/lib/ReactMount.js +641 -0
  63. package/lib/ReactMountReady.js +95 -0
  64. package/lib/ReactMultiChild.js +425 -0
  65. package/lib/ReactMultiChildUpdateTypes.js +38 -0
  66. package/lib/ReactOwner.js +154 -0
  67. package/lib/ReactPerf.js +85 -0
  68. package/lib/ReactPropTransferer.js +147 -0
  69. package/lib/ReactPropTypeLocationNames.js +31 -0
  70. package/lib/ReactPropTypeLocations.js +29 -0
  71. package/lib/ReactPropTypes.js +359 -0
  72. package/lib/ReactPutListenerQueue.js +61 -0
  73. package/lib/ReactReconcileTransaction.js +181 -0
  74. package/lib/ReactRootIndex.js +36 -0
  75. package/lib/ReactServerRendering.js +59 -0
  76. package/lib/ReactStateSetters.js +111 -0
  77. package/lib/ReactTextComponent.js +99 -0
  78. package/lib/ReactTransitionChildMapping.js +106 -0
  79. package/lib/ReactTransitionEvents.js +97 -0
  80. package/lib/ReactTransitionGroup.js +187 -0
  81. package/lib/ReactUpdates.js +148 -0
  82. package/lib/ReactWithAddons.js +46 -0
  83. package/lib/SelectEventPlugin.js +200 -0
  84. package/lib/ServerReactRootIndex.js +36 -0
  85. package/lib/SimpleEventPlugin.js +413 -0
  86. package/lib/SyntheticClipboardEvent.js +51 -0
  87. package/lib/SyntheticCompositionEvent.js +51 -0
  88. package/lib/SyntheticDragEvent.js +44 -0
  89. package/lib/SyntheticEvent.js +164 -0
  90. package/lib/SyntheticFocusEvent.js +44 -0
  91. package/lib/SyntheticKeyboardEvent.js +58 -0
  92. package/lib/SyntheticMouseEvent.js +85 -0
  93. package/lib/SyntheticTouchEvent.js +50 -0
  94. package/lib/SyntheticUIEvent.js +45 -0
  95. package/lib/SyntheticWheelEvent.js +66 -0
  96. package/lib/Transaction.js +276 -0
  97. package/lib/ViewportMetrics.js +37 -0
  98. package/lib/accumulate.js +54 -0
  99. package/lib/adler32.js +39 -0
  100. package/lib/cloneWithProps.js +59 -0
  101. package/lib/containsNode.js +49 -0
  102. package/lib/copyProperties.js +54 -0
  103. package/lib/createArrayFrom.js +91 -0
  104. package/lib/createFullPageComponent.js +63 -0
  105. package/lib/createNodesFromMarkup.js +93 -0
  106. package/lib/createObjectFrom.js +61 -0
  107. package/lib/cx.js +44 -0
  108. package/lib/dangerousStyleValue.js +57 -0
  109. package/lib/emptyFunction.js +43 -0
  110. package/lib/escapeTextForBrowser.js +47 -0
  111. package/lib/flattenChildren.js +57 -0
  112. package/lib/forEachAccumulated.js +36 -0
  113. package/lib/getActiveElement.js +34 -0
  114. package/lib/getEventKey.js +85 -0
  115. package/lib/getEventTarget.js +36 -0
  116. package/lib/getMarkupWrap.js +118 -0
  117. package/lib/getNodeForCharacterOffset.js +80 -0
  118. package/lib/getReactRootElementInContainer.js +40 -0
  119. package/lib/getTextContentAccessor.js +42 -0
  120. package/lib/getUnboundedScrollPosition.js +45 -0
  121. package/lib/hyphenate.js +35 -0
  122. package/lib/invariant.js +62 -0
  123. package/lib/isEventSupported.js +70 -0
  124. package/lib/isNode.js +33 -0
  125. package/lib/isTextInputElement.js +49 -0
  126. package/lib/isTextNode.js +30 -0
  127. package/lib/joinClasses.js +44 -0
  128. package/lib/keyMirror.js +58 -0
  129. package/lib/keyOf.js +41 -0
  130. package/lib/memoizeStringOnly.js +39 -0
  131. package/lib/merge.js +37 -0
  132. package/lib/mergeHelpers.js +136 -0
  133. package/lib/mergeInto.js +45 -0
  134. package/lib/mixInto.js +34 -0
  135. package/lib/objMap.js +47 -0
  136. package/lib/objMapKeyVal.js +47 -0
  137. package/lib/onlyChild.js +43 -0
  138. package/lib/performanceNow.js +42 -0
  139. package/lib/shallowEqual.js +49 -0
  140. package/lib/shouldUpdateReactComponent.js +58 -0
  141. package/lib/toArray.js +75 -0
  142. package/lib/traverseAllChildren.js +189 -0
  143. package/lib/warning.js +40 -0
  144. package/package.json +32 -21
  145. package/react.js +1 -0
  146. package/.npmignore +0 -7
  147. package/.travis.yml +0 -5
  148. package/Jakefile.js +0 -39
  149. package/LICENSE +0 -19
  150. package/browser-test/dist.html +0 -90
  151. package/browser-test/index.html +0 -86
  152. package/browser-test/min.html +0 -90
  153. package/dist/react.js +0 -3107
  154. package/dist/react.min.js +0 -22
  155. package/doc/advanced.md +0 -174
  156. package/doc/color-def.graffle +0 -938
  157. package/doc/color-def.png +0 -0
  158. package/doc/simple.dot +0 -25
  159. package/doc/simple.png +0 -0
  160. package/examples/longer-example.js +0 -41
  161. package/examples/simple.js +0 -45
  162. package/examples/using-ast-directly.js +0 -30
  163. package/examples/using-events1.js +0 -79
  164. package/examples/using-log-events.js +0 -43
  165. package/lib/base-task.js +0 -123
  166. package/lib/cb-task.js +0 -84
  167. package/lib/core.js +0 -138
  168. package/lib/dsl.js +0 -138
  169. package/lib/error.js +0 -55
  170. package/lib/event-collector.js +0 -81
  171. package/lib/event-manager.js +0 -89
  172. package/lib/eventemitter.js +0 -20
  173. package/lib/finalcb-first-task.js +0 -68
  174. package/lib/finalcb-task.js +0 -65
  175. package/lib/id.js +0 -22
  176. package/lib/input-parser.js +0 -56
  177. package/lib/log-events.js +0 -101
  178. package/lib/parse.js +0 -41
  179. package/lib/promise-resolve.js +0 -50
  180. package/lib/promise-task.js +0 -93
  181. package/lib/react.js +0 -59
  182. package/lib/ret-task.js +0 -71
  183. package/lib/sprintf.js +0 -18
  184. package/lib/status.js +0 -14
  185. package/lib/task.js +0 -251
  186. package/lib/track-tasks.js +0 -74
  187. package/lib/validate.js +0 -159
  188. package/lib/vcon.js +0 -90
  189. package/lib/when-task.js +0 -85
  190. package/src/dist.build.requirejs +0 -20
  191. package/test/ast.mocha.js +0 -136
  192. package/test/cb-task.mocha.js +0 -220
  193. package/test/core-deferred.mocha.js +0 -143
  194. package/test/core-when.mocha.js +0 -96
  195. package/test/core.mocha.js +0 -589
  196. package/test/dsl.mocha.js +0 -350
  197. package/test/event-manager.mocha.js +0 -119
  198. package/test/exec-options.mocha.js +0 -48
  199. package/test/finalcb-task.mocha.js +0 -58
  200. package/test/input-parser.mocha.js +0 -86
  201. package/test/log-events.mocha.js +0 -88
  202. package/test/mocha.opts +0 -2
  203. package/test/module-use.mocha.js +0 -147
  204. package/test/promise-auto-resolve.mocha.js +0 -68
  205. package/test/ret-task.mocha.js +0 -220
  206. package/test/task.mocha.js +0 -42
  207. package/test/validate-cb-task.mocha.js +0 -100
  208. package/test/validate-ret-task.mocha.js +0 -110
  209. package/test/validate.mocha.js +0 -324
  210. package/test/vcon.mocha.js +0 -193
  211. package/vendor/chai/chai.js +0 -2038
  212. package/vendor/jquery/jquery-1.7.1.js +0 -9266
  213. package/vendor/jquery/jquery-1.7.1.min.js +0 -4
  214. package/vendor/mocha/mocha.css +0 -135
  215. package/vendor/mocha/mocha.js +0 -3589
  216. package/vendor/node/util.js +0 -531
  217. package/vendor/requirejs/require.js +0 -2053
  218. package/vendor/requirejs/require.min.js +0 -33
@@ -1,86 +0,0 @@
1
- <html>
2
- <head>
3
- <meta charset="utf-8">
4
- <title>Mocha Tests</title>
5
- <link rel="stylesheet" href="../vendor/mocha/mocha.css" />
6
- <script type="text/javascript" src="../vendor/jquery/jquery-1.7.1.js"></script>
7
- <script type="text/javascript" src="../vendor/chai/chai.js"></script>
8
- <script type="text/javascript" src="../vendor/mocha/mocha.js"></script>
9
- <script>mocha.setup('qunit')</script>
10
- <script src="../vendor/requirejs/require.min.js"></script>
11
- <script type="text/javascript">
12
- require.config({
13
- baseUrl: "..",
14
- packages: [
15
- {
16
- name: "react",
17
- location: "lib",
18
- main: "react"
19
- }
20
- ],
21
- paths: {
22
- jquery: "vendor/jquery/jquery-1.7.1",
23
- eventemitter2: "node_modules/eventemitter2/lib/eventemitter2",
24
- util: "vendor/node/util",
25
- "ensure-array": "node_modules/ensure-array/ensure-array",
26
- test: "test"
27
- }
28
- });
29
-
30
- require(["react", "react/sprintf", "util", "react/validate", "react/task",
31
- "react/cb-task", "react/vcon", "react/event-manager", "react/input-parser",
32
- "react/base-task", "react/ret-task", "react/validate", "jquery"],
33
- function (react, sprintf, util, validate, taskUtil,
34
- CbTask, VContext, EventManager, inputParser,
35
- BaseTask, RetTask, validate, jquery) {
36
- // save refs on window for these
37
- window.react = react;
38
- window.sprintf = sprintf;
39
- window.util = util;
40
- window.validate = validate;
41
- window.taskUtil = taskUtil;
42
- window.CbTask = CbTask;
43
- window.VContext = VContext;
44
- window.EventManager = EventManager;
45
- window.inputParser = inputParser;
46
- window.BaseTask = BaseTask;
47
- window.RetTask = RetTask;
48
- window.validate = validate;
49
- window.Deferred = jQuery.Deferred;
50
- window.Deferred.when = jQuery.when;
51
- var testFiles = [
52
- "test/ast.mocha",
53
- "test/cb-task.mocha",
54
- "test/core-deferred.mocha",
55
- "test/core-when.mocha",
56
- "test/core.mocha",
57
- "test/dsl.mocha",
58
- "test/event-manager.mocha",
59
- "test/exec-options.mocha",
60
- "test/finalcb-task.mocha",
61
- "test/input-parser.mocha",
62
- "test/log-events.mocha",
63
- "test/module-use.mocha",
64
- "test/promise-auto-resolve.mocha",
65
- "test/ret-task.mocha",
66
- "test/task.mocha",
67
- "test/validate-cb-task.mocha",
68
- "test/validate-ret-task.mocha",
69
- "test/validate.mocha",
70
- "test/vcon.mocha"
71
- ];
72
- require(testFiles, function () {
73
- var runner = mocha.run().on('end', function () {
74
- console.log('mocha finished');
75
- jQuery("#mocha-result").text('completed');
76
- });
77
- //mocha.reporters.TAP(runner);
78
- });
79
- });
80
- </script>
81
- </head>
82
- <body>
83
- <div id="mocha"></div>
84
- <div id="mocha-result"></div>
85
- </body>
86
- </html>
@@ -1,90 +0,0 @@
1
- <html>
2
- <head>
3
- <meta charset="utf-8">
4
- <title>Mocha Tests</title>
5
- <link rel="stylesheet" href="../vendor/mocha/mocha.css" />
6
- <script type="text/javascript" src="../vendor/jquery/jquery-1.7.1.js"></script>
7
- <script type="text/javascript" src="../vendor/chai/chai.js"></script>
8
- <script type="text/javascript" src="../vendor/mocha/mocha.js"></script>
9
- <script>mocha.setup('qunit')</script>
10
- <script src="../vendor/requirejs/require.min.js"></script>
11
- <script type="text/javascript">
12
- require.config({
13
- baseUrl: "..",
14
- packages: [
15
- {
16
- name: "react",
17
- location: "dist",
18
- main: "react.min"
19
- }
20
- ],
21
- paths: {
22
- jQuery: "vendor/jquery/jquery-1.7.1.min",
23
- eventemitter2: "dist/react.min",
24
- util: "dist/react.min",
25
- "ensure-array": "dist/react.min",
26
- test: "test"
27
- }
28
- });
29
-
30
- require(["react", "jQuery"],
31
- function (react, jquery) {
32
-
33
- require(["react/sprintf", "react/validate", "react/task", "react/cb-task",
34
- "react/vcon", "react/event-manager", "react/input-parser",
35
- "react/base-task", "react/ret-task", "util"],
36
- function (sprintf, validate, taskUtil, CbTask,
37
- VContext, EventManager, inputParser,
38
- BaseTask, RetTask, util) {
39
- // save refs on window for these
40
- window.react = react;
41
- window.sprintf = sprintf;
42
- window.util = util;
43
- window.validate = validate;
44
- window.taskUtil = taskUtil;
45
- window.CbTask = CbTask;
46
- window.VContext = VContext;
47
- window.EventManager = EventManager;
48
- window.inputParser = inputParser;
49
- window.BaseTask = BaseTask;
50
- window.RetTask = RetTask;
51
- window.validate = validate;
52
- window.Deferred = jQuery.Deferred;
53
- window.Deferred.when = jQuery.when;
54
- var testFiles = [
55
- "test/ast.mocha",
56
- "test/cb-task.mocha",
57
- "test/core-deferred.mocha",
58
- "test/core-when.mocha",
59
- "test/core.mocha",
60
- "test/dsl.mocha",
61
- "test/event-manager.mocha",
62
- "test/exec-options.mocha",
63
- "test/finalcb-task.mocha",
64
- "test/input-parser.mocha",
65
- "test/log-events.mocha",
66
- "test/module-use.mocha",
67
- "test/promise-auto-resolve.mocha",
68
- "test/ret-task.mocha",
69
- "test/task.mocha",
70
- "test/validate-cb-task.mocha",
71
- "test/validate-ret-task.mocha",
72
- "test/validate.mocha",
73
- "test/vcon.mocha"
74
- ];
75
- require(testFiles, function () {
76
- var runner = mocha.run().on('end', function () {
77
- console.log('mocha finished');
78
- jQuery("#mocha-result").text('completed');
79
- });
80
- //mocha.reporters.TAP(runner);
81
- });
82
- });
83
- });
84
- </script>
85
- </head>
86
- <body>
87
- <div id="mocha"></div>
88
- <div id="mocha-result"></div>
89
- </body>
90
- </html>
package/dist/react.js DELETED
@@ -1,3107 +0,0 @@
1
-
2
- ;!function(exports, undefined) {
3
-
4
- var isArray = Array.isArray ? Array.isArray : function _isArray(obj) {
5
- return Object.prototype.toString.call(obj) === "[object Array]";
6
- };
7
- var defaultMaxListeners = 10;
8
-
9
- function init() {
10
- this._events = new Object;
11
- }
12
-
13
- function configure(conf) {
14
- if (conf) {
15
- conf.delimiter && (this.delimiter = conf.delimiter);
16
- conf.wildcard && (this.wildcard = conf.wildcard);
17
- if (this.wildcard) {
18
- this.listenerTree = new Object;
19
- }
20
- }
21
- }
22
-
23
- function EventEmitter(conf) {
24
- this._events = new Object;
25
- configure.call(this, conf);
26
- }
27
-
28
- //
29
- // Attention, function return type now is array, always !
30
- // It has zero elements if no any matches found and one or more
31
- // elements (leafs) if there are matches
32
- //
33
- function searchListenerTree(handlers, type, tree, i) {
34
- if (!tree) {
35
- return [];
36
- }
37
- var listeners=[], leaf, len, branch, xTree, xxTree, isolatedBranch, endReached,
38
- typeLength = type.length, currentType = type[i], nextType = type[i+1];
39
- if (i === typeLength && tree._listeners) {
40
- //
41
- // If at the end of the event(s) list and the tree has listeners
42
- // invoke those listeners.
43
- //
44
- if (typeof tree._listeners === 'function') {
45
- handlers && handlers.push(tree._listeners);
46
- return [tree];
47
- } else {
48
- for (leaf = 0, len = tree._listeners.length; leaf < len; leaf++) {
49
- handlers && handlers.push(tree._listeners[leaf]);
50
- }
51
- return [tree];
52
- }
53
- }
54
-
55
- if ((currentType === '*' || currentType === '**') || tree[currentType]) {
56
- //
57
- // If the event emitted is '*' at this part
58
- // or there is a concrete match at this patch
59
- //
60
- if (currentType === '*') {
61
- for (branch in tree) {
62
- if (branch !== '_listeners' && tree.hasOwnProperty(branch)) {
63
- listeners = listeners.concat(searchListenerTree(handlers, type, tree[branch], i+1));
64
- }
65
- }
66
- return listeners;
67
- } else if(currentType === '**') {
68
- endReached = (i+1 === typeLength || (i+2 === typeLength && nextType === '*'));
69
- if(endReached && tree._listeners) {
70
- // The next element has a _listeners, add it to the handlers.
71
- listeners = listeners.concat(searchListenerTree(handlers, type, tree, typeLength));
72
- }
73
-
74
- for (branch in tree) {
75
- if (branch !== '_listeners' && tree.hasOwnProperty(branch)) {
76
- if(branch === '*' || branch === '**') {
77
- if(tree[branch]._listeners && !endReached) {
78
- listeners = listeners.concat(searchListenerTree(handlers, type, tree[branch], typeLength));
79
- }
80
- listeners = listeners.concat(searchListenerTree(handlers, type, tree[branch], i));
81
- } else if(branch === nextType) {
82
- listeners = listeners.concat(searchListenerTree(handlers, type, tree[branch], i+2));
83
- } else {
84
- // No match on this one, shift into the tree but not in the type array.
85
- listeners = listeners.concat(searchListenerTree(handlers, type, tree[branch], i));
86
- }
87
- }
88
- }
89
- return listeners;
90
- }
91
-
92
- listeners = listeners.concat(searchListenerTree(handlers, type, tree[currentType], i+1));
93
- }
94
-
95
- xTree = tree['*'];
96
- if (xTree) {
97
- //
98
- // If the listener tree will allow any match for this part,
99
- // then recursively explore all branches of the tree
100
- //
101
- searchListenerTree(handlers, type, xTree, i+1);
102
- }
103
-
104
- xxTree = tree['**'];
105
- if(xxTree) {
106
- if(i < typeLength) {
107
- if(xxTree._listeners) {
108
- // If we have a listener on a '**', it will catch all, so add its handler.
109
- searchListenerTree(handlers, type, xxTree, typeLength);
110
- }
111
-
112
- // Build arrays of matching next branches and others.
113
- for(branch in xxTree) {
114
- if(branch !== '_listeners' && xxTree.hasOwnProperty(branch)) {
115
- if(branch === nextType) {
116
- // We know the next element will match, so jump twice.
117
- searchListenerTree(handlers, type, xxTree[branch], i+2);
118
- } else if(branch === currentType) {
119
- // Current node matches, move into the tree.
120
- searchListenerTree(handlers, type, xxTree[branch], i+1);
121
- } else {
122
- isolatedBranch = {};
123
- isolatedBranch[branch] = xxTree[branch];
124
- searchListenerTree(handlers, type, { '**': isolatedBranch }, i+1);
125
- }
126
- }
127
- }
128
- } else if(xxTree._listeners) {
129
- // We have reached the end and still on a '**'
130
- searchListenerTree(handlers, type, xxTree, typeLength);
131
- } else if(xxTree['*'] && xxTree['*']._listeners) {
132
- searchListenerTree(handlers, type, xxTree['*'], typeLength);
133
- }
134
- }
135
-
136
- return listeners;
137
- }
138
-
139
- function growListenerTree(type, listener) {
140
-
141
- type = typeof type === 'string' ? type.split(this.delimiter) : type.slice();
142
-
143
- //
144
- // Looks for two consecutive '**', if so, don't add the event at all.
145
- //
146
- for(var i = 0, len = type.length; i+1 < len; i++) {
147
- if(type[i] === '**' && type[i+1] === '**') {
148
- return;
149
- }
150
- }
151
-
152
- var tree = this.listenerTree;
153
- var name = type.shift();
154
-
155
- while (name) {
156
-
157
- if (!tree[name]) {
158
- tree[name] = new Object;
159
- }
160
-
161
- tree = tree[name];
162
-
163
- if (type.length === 0) {
164
-
165
- if (!tree._listeners) {
166
- tree._listeners = listener;
167
- }
168
- else if(typeof tree._listeners === 'function') {
169
- tree._listeners = [tree._listeners, listener];
170
- }
171
- else if (isArray(tree._listeners)) {
172
-
173
- tree._listeners.push(listener);
174
-
175
- if (!tree._listeners.warned) {
176
-
177
- var m = defaultMaxListeners;
178
-
179
- if (typeof this._events.maxListeners !== 'undefined') {
180
- m = this._events.maxListeners;
181
- }
182
-
183
- if (m > 0 && tree._listeners.length > m) {
184
-
185
- tree._listeners.warned = true;
186
- console.error('(node) warning: possible EventEmitter memory ' +
187
- 'leak detected. %d listeners added. ' +
188
- 'Use emitter.setMaxListeners() to increase limit.',
189
- tree._listeners.length);
190
- console.trace();
191
- }
192
- }
193
- }
194
- return true;
195
- }
196
- name = type.shift();
197
- }
198
- return true;
199
- };
200
-
201
- // By default EventEmitters will print a warning if more than
202
- // 10 listeners are added to it. This is a useful default which
203
- // helps finding memory leaks.
204
- //
205
- // Obviously not all Emitters should be limited to 10. This function allows
206
- // that to be increased. Set to zero for unlimited.
207
-
208
- EventEmitter.prototype.delimiter = '.';
209
-
210
- EventEmitter.prototype.setMaxListeners = function(n) {
211
- this._events || init.call(this);
212
- this._events.maxListeners = n;
213
- };
214
-
215
- EventEmitter.prototype.event = '';
216
-
217
- EventEmitter.prototype.once = function(event, fn) {
218
- this.many(event, 1, fn);
219
- return this;
220
- };
221
-
222
- EventEmitter.prototype.many = function(event, ttl, fn) {
223
- var self = this;
224
-
225
- if (typeof fn !== 'function') {
226
- throw new Error('many only accepts instances of Function');
227
- }
228
-
229
- function listener() {
230
- if (--ttl === 0) {
231
- self.off(event, listener);
232
- }
233
- fn.apply(this, arguments);
234
- };
235
-
236
- listener._origin = fn;
237
-
238
- this.on(event, listener);
239
-
240
- return self;
241
- };
242
-
243
- EventEmitter.prototype.emit = function() {
244
- this._events || init.call(this);
245
-
246
- var type = arguments[0];
247
-
248
- if (type === 'newListener') {
249
- if (!this._events.newListener) { return false; }
250
- }
251
-
252
- // Loop through the *_all* functions and invoke them.
253
- if (this._all) {
254
- var l = arguments.length;
255
- var args = new Array(l - 1);
256
- for (var i = 1; i < l; i++) args[i - 1] = arguments[i];
257
- for (i = 0, l = this._all.length; i < l; i++) {
258
- this.event = type;
259
- this._all[i].apply(this, args);
260
- }
261
- }
262
-
263
- // If there is no 'error' event listener then throw.
264
- if (type === 'error') {
265
-
266
- if (!this._all &&
267
- !this._events.error &&
268
- !(this.wildcard && this.listenerTree.error)) {
269
-
270
- if (arguments[1] instanceof Error) {
271
- throw arguments[1]; // Unhandled 'error' event
272
- } else {
273
- throw new Error("Uncaught, unspecified 'error' event.");
274
- }
275
- return false;
276
- }
277
- }
278
-
279
- var handler;
280
-
281
- if(this.wildcard) {
282
- handler = [];
283
- var ns = typeof type === 'string' ? type.split(this.delimiter) : type.slice();
284
- searchListenerTree.call(this, handler, ns, this.listenerTree, 0);
285
- }
286
- else {
287
- handler = this._events[type];
288
- }
289
-
290
- if (typeof handler === 'function') {
291
- this.event = type;
292
- if (arguments.length === 1) {
293
- handler.call(this);
294
- }
295
- else if (arguments.length > 1)
296
- switch (arguments.length) {
297
- case 2:
298
- handler.call(this, arguments[1]);
299
- break;
300
- case 3:
301
- handler.call(this, arguments[1], arguments[2]);
302
- break;
303
- // slower
304
- default:
305
- var l = arguments.length;
306
- var args = new Array(l - 1);
307
- for (var i = 1; i < l; i++) args[i - 1] = arguments[i];
308
- handler.apply(this, args);
309
- }
310
- return true;
311
- }
312
- else if (handler) {
313
- var l = arguments.length;
314
- var args = new Array(l - 1);
315
- for (var i = 1; i < l; i++) args[i - 1] = arguments[i];
316
-
317
- var listeners = handler.slice();
318
- for (var i = 0, l = listeners.length; i < l; i++) {
319
- this.event = type;
320
- listeners[i].apply(this, args);
321
- }
322
- return (listeners.length > 0) || this._all;
323
- }
324
- else {
325
- return this._all;
326
- }
327
-
328
- };
329
-
330
- EventEmitter.prototype.on = function(type, listener) {
331
-
332
- if (typeof type === 'function') {
333
- this.onAny(type);
334
- return this;
335
- }
336
-
337
- if (typeof listener !== 'function') {
338
- throw new Error('on only accepts instances of Function');
339
- }
340
- this._events || init.call(this);
341
-
342
- // To avoid recursion in the case that type == "newListeners"! Before
343
- // adding it to the listeners, first emit "newListeners".
344
- this.emit('newListener', type, listener);
345
-
346
- if(this.wildcard) {
347
- growListenerTree.call(this, type, listener);
348
- return this;
349
- }
350
-
351
- if (!this._events[type]) {
352
- // Optimize the case of one listener. Don't need the extra array object.
353
- this._events[type] = listener;
354
- }
355
- else if(typeof this._events[type] === 'function') {
356
- // Adding the second element, need to change to array.
357
- this._events[type] = [this._events[type], listener];
358
- }
359
- else if (isArray(this._events[type])) {
360
- // If we've already got an array, just append.
361
- this._events[type].push(listener);
362
-
363
- // Check for listener leak
364
- if (!this._events[type].warned) {
365
-
366
- var m = defaultMaxListeners;
367
-
368
- if (typeof this._events.maxListeners !== 'undefined') {
369
- m = this._events.maxListeners;
370
- }
371
-
372
- if (m > 0 && this._events[type].length > m) {
373
-
374
- this._events[type].warned = true;
375
- console.error('(node) warning: possible EventEmitter memory ' +
376
- 'leak detected. %d listeners added. ' +
377
- 'Use emitter.setMaxListeners() to increase limit.',
378
- this._events[type].length);
379
- console.trace();
380
- }
381
- }
382
- }
383
- return this;
384
- };
385
-
386
- EventEmitter.prototype.onAny = function(fn) {
387
-
388
- if(!this._all) {
389
- this._all = [];
390
- }
391
-
392
- if (typeof fn !== 'function') {
393
- throw new Error('onAny only accepts instances of Function');
394
- }
395
-
396
- // Add the function to the event listener collection.
397
- this._all.push(fn);
398
- return this;
399
- };
400
-
401
- EventEmitter.prototype.addListener = EventEmitter.prototype.on;
402
-
403
- EventEmitter.prototype.off = function(type, listener) {
404
- if (typeof listener !== 'function') {
405
- throw new Error('removeListener only takes instances of Function');
406
- }
407
-
408
- var handlers,leafs=[];
409
-
410
- if(this.wildcard) {
411
- var ns = typeof type === 'string' ? type.split(this.delimiter) : type.slice();
412
- leafs = searchListenerTree.call(this, null, ns, this.listenerTree, 0);
413
- }
414
- else {
415
- // does not use listeners(), so no side effect of creating _events[type]
416
- if (!this._events[type]) return this;
417
- handlers = this._events[type];
418
- leafs.push({_listeners:handlers});
419
- }
420
-
421
- for (var iLeaf=0; iLeaf<leafs.length; iLeaf++) {
422
- var leaf = leafs[iLeaf];
423
- handlers = leaf._listeners;
424
- if (isArray(handlers)) {
425
-
426
- var position = -1;
427
-
428
- for (var i = 0, length = handlers.length; i < length; i++) {
429
- if (handlers[i] === listener ||
430
- (handlers[i].listener && handlers[i].listener === listener) ||
431
- (handlers[i]._origin && handlers[i]._origin === listener)) {
432
- position = i;
433
- break;
434
- }
435
- }
436
-
437
- if (position < 0) {
438
- return this;
439
- }
440
-
441
- if(this.wildcard) {
442
- leaf._listeners.splice(position, 1)
443
- }
444
- else {
445
- this._events[type].splice(position, 1);
446
- }
447
-
448
- if (handlers.length === 0) {
449
- if(this.wildcard) {
450
- delete leaf._listeners;
451
- }
452
- else {
453
- delete this._events[type];
454
- }
455
- }
456
- }
457
- else if (handlers === listener ||
458
- (handlers.listener && handlers.listener === listener) ||
459
- (handlers._origin && handlers._origin === listener)) {
460
- if(this.wildcard) {
461
- delete leaf._listeners;
462
- }
463
- else {
464
- delete this._events[type];
465
- }
466
- }
467
- }
468
-
469
- return this;
470
- };
471
-
472
- EventEmitter.prototype.offAny = function(fn) {
473
- var i = 0, l = 0, fns;
474
- if (fn && this._all && this._all.length > 0) {
475
- fns = this._all;
476
- for(i = 0, l = fns.length; i < l; i++) {
477
- if(fn === fns[i]) {
478
- fns.splice(i, 1);
479
- return this;
480
- }
481
- }
482
- } else {
483
- this._all = [];
484
- }
485
- return this;
486
- };
487
-
488
- EventEmitter.prototype.removeListener = EventEmitter.prototype.off;
489
-
490
- EventEmitter.prototype.removeAllListeners = function(type) {
491
- if (arguments.length === 0) {
492
- !this._events || init.call(this);
493
- return this;
494
- }
495
-
496
- if(this.wildcard) {
497
- var ns = typeof type === 'string' ? type.split(this.delimiter) : type.slice();
498
- var leafs = searchListenerTree.call(this, null, ns, this.listenerTree, 0);
499
-
500
- for (var iLeaf=0; iLeaf<leafs.length; iLeaf++) {
501
- var leaf = leafs[iLeaf];
502
- leaf._listeners = null;
503
- }
504
- }
505
- else {
506
- if (!this._events[type]) return this;
507
- this._events[type] = null;
508
- }
509
- return this;
510
- };
511
-
512
- EventEmitter.prototype.listeners = function(type) {
513
- if(this.wildcard) {
514
- var handlers = [];
515
- var ns = typeof type === 'string' ? type.split(this.delimiter) : type.slice();
516
- searchListenerTree.call(this, handlers, ns, this.listenerTree, 0);
517
- return handlers;
518
- }
519
-
520
- this._events || init.call(this);
521
-
522
- if (!this._events[type]) this._events[type] = [];
523
- if (!isArray(this._events[type])) {
524
- this._events[type] = [this._events[type]];
525
- }
526
- return this._events[type];
527
- };
528
-
529
- EventEmitter.prototype.listenersAny = function() {
530
-
531
- if(this._all) {
532
- return this._all;
533
- }
534
- else {
535
- return [];
536
- }
537
-
538
- };
539
-
540
- if (typeof define === 'function' && define.amd) {
541
- define('eventemitter2',[],function() {
542
- return EventEmitter;
543
- });
544
- } else {
545
- exports.EventEmitter2 = EventEmitter;
546
- }
547
-
548
- }(typeof process !== 'undefined' && typeof process.title !== 'undefined' && typeof exports !== 'undefined' ? exports : window);
549
-
550
-
551
- /*global define:true EventEmitter2:true */
552
-
553
-
554
-
555
- define('react/eventemitter',['eventemitter2'], function (EventEmitterMod) {
556
-
557
- /**
558
- Abstract the details of getting an EventEmitter
559
- */
560
-
561
- // EventEmitter doesn't return itself in browser so need to get the global
562
- // EventEmitter api changed, so accomodate which ever version is available
563
- var EventEmitter = (EventEmitterMod) ?
564
- ((EventEmitterMod.EventEmitter2) ? EventEmitterMod.EventEmitter2 : EventEmitterMod) : EventEmitter2;
565
- return EventEmitter;
566
-
567
- });
568
- /*global define:true */
569
-
570
-
571
-
572
- // Copyright Joyent, Inc. and other Node contributors.
573
- //
574
- // Permission is hereby granted, free of charge, to any person obtaining a
575
- // copy of this software and associated documentation files (the
576
- // "Software"), to deal in the Software without restriction, including
577
- // without limitation the rights to use, copy, modify, merge, publish,
578
- // distribute, sublicense, and/or sell copies of the Software, and to permit
579
- // persons to whom the Software is furnished to do so, subject to the
580
- // following conditions:
581
- //
582
- // The above copyright notice and this permission notice shall be included
583
- // in all copies or substantial portions of the Software.
584
- //
585
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
586
- // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
587
- // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
588
- // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
589
- // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
590
- // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
591
- // USE OR OTHER DEALINGS IN THE SOFTWARE.
592
-
593
- define('util',['require','exports','module'],function (require, exports, module) {
594
- /*jshint white:false */
595
-
596
- var formatRegExp = /%[sdj%]/g;
597
- exports.format = function(f) {
598
- if (typeof f !== 'string') {
599
- var objects = [];
600
- for (var j = 0; j < arguments.length; j++) {
601
- objects.push(inspect(arguments[j]));
602
- }
603
- return objects.join(' ');
604
- }
605
-
606
- var i = 1;
607
- var args = arguments;
608
- var len = args.length;
609
- var str = String(f).replace(formatRegExp, function(x) {
610
- if (x === '%%') return '%';
611
- if (i >= len) return x;
612
- switch (x) {
613
- case '%s': return String(args[i++]);
614
- case '%d': return Number(args[i++]);
615
- case '%j': return JSON.stringify(args[i++]);
616
- default:
617
- return x;
618
- }
619
- });
620
- for (var x = args[i]; i < len; x = args[++i]) {
621
- if (x === null || typeof x !== 'object') {
622
- str += ' ' + x;
623
- } else {
624
- str += ' ' + inspect(x);
625
- }
626
- }
627
- return str;
628
- };
629
-
630
-
631
- exports.print = function() {
632
- for (var i = 0, len = arguments.length; i < len; ++i) {
633
- process.stdout.write(String(arguments[i]));
634
- }
635
- };
636
-
637
-
638
- exports.puts = function() {
639
- for (var i = 0, len = arguments.length; i < len; ++i) {
640
- process.stdout.write(arguments[i] + '\n');
641
- }
642
- };
643
-
644
-
645
- exports.debug = function(x) {
646
- process.stderr.write('DEBUG: ' + x + '\n');
647
- };
648
-
649
-
650
- var error = exports.error = function(x) {
651
- for (var i = 0, len = arguments.length; i < len; ++i) {
652
- process.stderr.write(arguments[i] + '\n');
653
- }
654
- };
655
-
656
-
657
- /**
658
- * Echos the value of a value. Trys to print the value out
659
- * in the best way possible given the different types.
660
- *
661
- * @param {Object} obj The object to print out.
662
- * @param {Boolean} showHidden Flag that shows hidden (not enumerable)
663
- * properties of objects.
664
- * @param {Number} depth Depth in which to descend in object. Default is 2.
665
- * @param {Boolean} colors Flag to turn on ANSI escape codes to color the
666
- * output. Default is false (no coloring).
667
- */
668
- function inspect(obj, showHidden, depth, colors) {
669
- var ctx = {
670
- showHidden: showHidden,
671
- seen: [],
672
- stylize: colors ? stylizeWithColor : stylizeNoColor
673
- };
674
- return formatValue(ctx, obj, (typeof depth === 'undefined' ? 2 : depth));
675
- }
676
- exports.inspect = inspect;
677
-
678
-
679
- // http://en.wikipedia.org/wiki/ANSI_escape_code#graphics
680
- var colors = {
681
- 'bold' : [1, 22],
682
- 'italic' : [3, 23],
683
- 'underline' : [4, 24],
684
- 'inverse' : [7, 27],
685
- 'white' : [37, 39],
686
- 'grey' : [90, 39],
687
- 'black' : [30, 39],
688
- 'blue' : [34, 39],
689
- 'cyan' : [36, 39],
690
- 'green' : [32, 39],
691
- 'magenta' : [35, 39],
692
- 'red' : [31, 39],
693
- 'yellow' : [33, 39]
694
- };
695
-
696
- // Don't use 'blue' not visible on cmd.exe
697
- var styles = {
698
- 'special': 'cyan',
699
- 'number': 'yellow',
700
- 'boolean': 'yellow',
701
- 'undefined': 'grey',
702
- 'null': 'bold',
703
- 'string': 'green',
704
- 'date': 'magenta',
705
- // "name": intentionally not styling
706
- 'regexp': 'red'
707
- };
708
-
709
-
710
- function stylizeWithColor(str, styleType) {
711
- var style = styles[styleType];
712
-
713
- if (style) {
714
- return '\033[' + colors[style][0] + 'm' + str +
715
- '\033[' + colors[style][1] + 'm';
716
- } else {
717
- return str;
718
- }
719
- }
720
-
721
-
722
- function stylizeNoColor(str, styleType) {
723
- return str;
724
- }
725
-
726
-
727
- function formatValue(ctx, value, recurseTimes) {
728
- // Provide a hook for user-specified inspect functions.
729
- // Check that value is an object with an inspect function on it
730
- if (value && typeof value.inspect === 'function' &&
731
- // Filter out the util module, it's inspect function is special
732
- value.inspect !== exports.inspect &&
733
- // Also filter out any prototype objects using the circular check.
734
- !(value.constructor && value.constructor.prototype === value)) {
735
- return value.inspect(recurseTimes);
736
- }
737
-
738
- // Primitive types cannot have properties
739
- var primitive = formatPrimitive(ctx, value);
740
- if (primitive) {
741
- return primitive;
742
- }
743
-
744
- // Look up the keys of the object.
745
- var visibleKeys = Object.keys(value);
746
- var keys = ctx.showHidden ? Object.getOwnPropertyNames(value) : visibleKeys;
747
-
748
- // Some type of object without properties can be shortcutted.
749
- if (keys.length === 0) {
750
- if (typeof value === 'function') {
751
- var name = value.name ? ': ' + value.name : '';
752
- return ctx.stylize('[Function' + name + ']', 'special');
753
- }
754
- if (isRegExp(value)) {
755
- return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');
756
- }
757
- if (isDate(value)) {
758
- return ctx.stylize(Date.prototype.toString.call(value), 'date');
759
- }
760
- if (isError(value)) {
761
- return formatError(value);
762
- }
763
- }
764
-
765
- var base = '', array = false, braces = ['{', '}'];
766
-
767
- // Make Array say that they are Array
768
- if (isArray(value)) {
769
- array = true;
770
- braces = ['[', ']'];
771
- }
772
-
773
- // Make functions say that they are functions
774
- if (typeof value === 'function') {
775
- var n = value.name ? ': ' + value.name : '';
776
- base = ' [Function' + n + ']';
777
- }
778
-
779
- // Make RegExps say that they are RegExps
780
- if (isRegExp(value)) {
781
- base = ' ' + RegExp.prototype.toString.call(value);
782
- }
783
-
784
- // Make dates with properties first say the date
785
- if (isDate(value)) {
786
- base = ' ' + Date.prototype.toUTCString.call(value);
787
- }
788
-
789
- // Make error with message first say the error
790
- if (isError(value)) {
791
- base = ' ' + formatError(value);
792
- }
793
-
794
- if (keys.length === 0 && (!array || value.length === 0)) {
795
- return braces[0] + base + braces[1];
796
- }
797
-
798
- if (recurseTimes < 0) {
799
- if (isRegExp(value)) {
800
- return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');
801
- } else {
802
- return ctx.stylize('[Object]', 'special');
803
- }
804
- }
805
-
806
- ctx.seen.push(value);
807
-
808
- var output;
809
- if (array) {
810
- output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);
811
- } else {
812
- output = keys.map(function(key) {
813
- return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);
814
- });
815
- }
816
-
817
- ctx.seen.pop();
818
-
819
- return reduceToSingleString(output, base, braces);
820
- }
821
-
822
-
823
- function formatPrimitive(ctx, value) {
824
- switch (typeof value) {
825
- case 'undefined':
826
- return ctx.stylize('undefined', 'undefined');
827
-
828
- case 'string':
829
- var simple = '\'' + JSON.stringify(value).replace(/^"|"$/g, '')
830
- .replace(/'/g, "\\'")
831
- .replace(/\\"/g, '"') + '\'';
832
- return ctx.stylize(simple, 'string');
833
-
834
- case 'number':
835
- return ctx.stylize('' + value, 'number');
836
-
837
- case 'boolean':
838
- return ctx.stylize('' + value, 'boolean');
839
- }
840
- // For some reason typeof null is "object", so special case here.
841
- if (value === null) {
842
- return ctx.stylize('null', 'null');
843
- }
844
- }
845
-
846
-
847
- function formatError(value) {
848
- return '[' + Error.prototype.toString.call(value) + ']';
849
- }
850
-
851
-
852
- function formatArray(ctx, value, recurseTimes, visibleKeys, keys) {
853
- var output = [];
854
- for (var i = 0, l = value.length; i < l; ++i) {
855
- if (Object.prototype.hasOwnProperty.call(value, String(i))) {
856
- output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,
857
- String(i), true));
858
- } else {
859
- output.push('');
860
- }
861
- }
862
- keys.forEach(function(key) {
863
- if (!key.match(/^\d+$/)) {
864
- output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,
865
- key, true));
866
- }
867
- });
868
- return output;
869
- }
870
-
871
-
872
- function formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {
873
- var name, str, desc;
874
- desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };
875
- if (desc.get) {
876
- if (desc.set) {
877
- str = ctx.stylize('[Getter/Setter]', 'special');
878
- } else {
879
- str = ctx.stylize('[Getter]', 'special');
880
- }
881
- } else {
882
- if (desc.set) {
883
- str = ctx.stylize('[Setter]', 'special');
884
- }
885
- }
886
- if (visibleKeys.indexOf(key) < 0) {
887
- name = '[' + key + ']';
888
- }
889
- if (!str) {
890
- if (ctx.seen.indexOf(desc.value) < 0) {
891
- if (recurseTimes === null) {
892
- str = formatValue(ctx, desc.value, null);
893
- } else {
894
- str = formatValue(ctx, desc.value, recurseTimes - 1);
895
- }
896
- if (str.indexOf('\n') > -1) {
897
- if (array) {
898
- str = str.split('\n').map(function(line) {
899
- return ' ' + line;
900
- }).join('\n').substr(2);
901
- } else {
902
- str = '\n' + str.split('\n').map(function(line) {
903
- return ' ' + line;
904
- }).join('\n');
905
- }
906
- }
907
- } else {
908
- str = ctx.stylize('[Circular]', 'special');
909
- }
910
- }
911
- if (typeof name === 'undefined') {
912
- if (array && key.match(/^\d+$/)) {
913
- return str;
914
- }
915
- name = JSON.stringify('' + key);
916
- if (name.match(/^"([a-zA-Z_][a-zA-Z_0-9]*)"$/)) {
917
- name = name.substr(1, name.length - 2);
918
- name = ctx.stylize(name, 'name');
919
- } else {
920
- name = name.replace(/'/g, "\\'")
921
- .replace(/\\"/g, '"')
922
- .replace(/(^"|"$)/g, "'");
923
- name = ctx.stylize(name, 'string');
924
- }
925
- }
926
-
927
- return name + ': ' + str;
928
- }
929
-
930
-
931
- function reduceToSingleString(output, base, braces) {
932
- var numLinesEst = 0;
933
- var length = output.reduce(function(prev, cur) {
934
- numLinesEst++;
935
- if (cur.indexOf('\n') >= 0) numLinesEst++;
936
- return prev + cur.length + 1;
937
- }, 0);
938
-
939
- if (length > 60) {
940
- return braces[0] +
941
- (base === '' ? '' : base + '\n ') +
942
- ' ' +
943
- output.join(',\n ') +
944
- ' ' +
945
- braces[1];
946
- }
947
-
948
- return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];
949
- }
950
-
951
-
952
- // NOTE: These type checking functions intentionally don't use `instanceof`
953
- // because it is fragile and can be easily faked with `Object.create()`.
954
- function isArray(ar) {
955
- return Array.isArray(ar) ||
956
- (typeof ar === 'object' && objectToString(ar) === '[object Array]');
957
- }
958
- exports.isArray = isArray;
959
-
960
-
961
- function isRegExp(re) {
962
- return typeof re === 'object' && objectToString(re) === '[object RegExp]';
963
- }
964
- exports.isRegExp = isRegExp;
965
-
966
-
967
- function isDate(d) {
968
- return typeof d === 'object' && objectToString(d) === '[object Date]';
969
- }
970
- exports.isDate = isDate;
971
-
972
-
973
- function isError(e) {
974
- return typeof e === 'object' && objectToString(e) === '[object Error]';
975
- }
976
- exports.isError = isError;
977
-
978
-
979
- function objectToString(o) {
980
- return Object.prototype.toString.call(o);
981
- }
982
-
983
-
984
- // exports.p = function() {
985
- // for (var i = 0, len = arguments.length; i < len; ++i) {
986
- // error(exports.inspect(arguments[i]));
987
- // }
988
- // };
989
- // module.deprecate('p', 'Use `util.puts(util.inspect())` instead.');
990
-
991
-
992
- function pad(n) {
993
- return n < 10 ? '0' + n.toString(10) : n.toString(10);
994
- }
995
-
996
-
997
- var months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',
998
- 'Oct', 'Nov', 'Dec'];
999
-
1000
- // 26 Feb 16:19:34
1001
- function timestamp() {
1002
- var d = new Date();
1003
- var time = [pad(d.getHours()),
1004
- pad(d.getMinutes()),
1005
- pad(d.getSeconds())].join(':');
1006
- return [d.getDate(), months[d.getMonth()], time].join(' ');
1007
- }
1008
-
1009
-
1010
- exports.log = function(msg) {
1011
- exports.puts(timestamp() + ' - ' + msg.toString());
1012
- };
1013
-
1014
-
1015
- // exports.exec = function() {
1016
- // return require('child_process').exec.apply(this, arguments);
1017
- // };
1018
- // module.deprecate('exec', 'It is now called `child_process.exec`.');
1019
-
1020
-
1021
- exports.pump = function(readStream, writeStream, callback) {
1022
- var callbackCalled = false;
1023
-
1024
- function call(a, b, c) {
1025
- if (callback && !callbackCalled) {
1026
- callback(a, b, c);
1027
- callbackCalled = true;
1028
- }
1029
- }
1030
-
1031
- readStream.addListener('data', function(chunk) {
1032
- if (writeStream.write(chunk) === false) readStream.pause();
1033
- });
1034
-
1035
- writeStream.addListener('drain', function() {
1036
- readStream.resume();
1037
- });
1038
-
1039
- readStream.addListener('end', function() {
1040
- writeStream.end();
1041
- });
1042
-
1043
- readStream.addListener('close', function() {
1044
- call();
1045
- });
1046
-
1047
- readStream.addListener('error', function(err) {
1048
- writeStream.end();
1049
- call(err);
1050
- });
1051
-
1052
- writeStream.addListener('error', function(err) {
1053
- readStream.destroy();
1054
- call(err);
1055
- });
1056
- };
1057
-
1058
-
1059
- /**
1060
- * Inherit the prototype methods from one constructor into another.
1061
- *
1062
- * The Function.prototype.inherits from lang.js rewritten as a standalone
1063
- * function (not on Function.prototype). NOTE: If this file is to be loaded
1064
- * during bootstrapping this function needs to be rewritten using some native
1065
- * functions as prototype setup using normal JavaScript does not work as
1066
- * expected during bootstrapping (see mirror.js in r114903).
1067
- *
1068
- * @param {function} ctor Constructor function which needs to inherit the
1069
- * prototype.
1070
- * @param {function} superCtor Constructor function to inherit prototype from.
1071
- */
1072
- exports.inherits = function(ctor, superCtor) {
1073
- ctor.super_ = superCtor;
1074
- ctor.prototype = Object.create(superCtor.prototype, {
1075
- constructor: {
1076
- value: ctor,
1077
- enumerable: false,
1078
- writable: true,
1079
- configurable: true
1080
- }
1081
- });
1082
- };
1083
-
1084
- exports._extend = function(origin, add) {
1085
- // Don't do anything if add isn't an object
1086
- if (!add) return origin;
1087
-
1088
- var keys = Object.keys(add);
1089
- var i = keys.length;
1090
- while (i--) {
1091
- origin[keys[i]] = add[keys[i]];
1092
- }
1093
- return origin;
1094
- };
1095
-
1096
- });
1097
-
1098
- /*global define:true */
1099
-
1100
-
1101
-
1102
- define('react/error',['util'], function (util) {
1103
-
1104
- function ensureStackTraceLimitSet(stackTraceLimit) {
1105
- if (!Error.stackTraceLimit || Error.stackTraceLimit < stackTraceLimit) {
1106
- Error.stackTraceLimit = stackTraceLimit;
1107
- }
1108
- }
1109
-
1110
- function fName(fn) {
1111
- if (!fn) return 'undefined';
1112
- return (fn && fn.name) ? fn.name : fn;
1113
- }
1114
-
1115
- function formatErrorMeta(err) {
1116
- if (!err.meta) return;
1117
- var vcon = err.meta.vcon;
1118
- var task = err.meta.task;
1119
- var errString = '\n\n';
1120
- if (task && task.f && task.a) {
1121
- errString += ('Error occurs in Task function: ' + fName(task.f) + '(' + task.a.join(',') + ')\n\n');
1122
- }
1123
- if (vcon) {
1124
- errString += 'Variable Context: \n';
1125
- errString += util.inspect(vcon);
1126
- errString += '\n\n';
1127
- }
1128
- if (task && task.f) {
1129
- errString += 'Task Source:\n\n';
1130
- errString += task.f.toString(); //TODO need to pretty print function, gets collapsed
1131
- errString += '\n\n';
1132
- }
1133
- return errString;
1134
- }
1135
-
1136
- function augmentError(err, meta) {
1137
- if (typeof(err) === 'string') { err = new Error(err); } //props will be lost on non-objects
1138
- var origMsg = err.toString();
1139
- err.meta = meta;
1140
- err.toString = function () { return origMsg + formatErrorMeta(err); };
1141
- return err;
1142
- }
1143
-
1144
- return {
1145
- ensureStackTraceLimitSet: ensureStackTraceLimitSet,
1146
- augmentError: augmentError
1147
- };
1148
-
1149
- });
1150
-
1151
- /*global define:true sprint:true */
1152
-
1153
-
1154
-
1155
- define('react/sprintf',['util'], function (util) {
1156
-
1157
- /**
1158
- Abstract the details of getting a sprintf function.
1159
- Currently using the simple format capabilities of node's util.format
1160
- */
1161
-
1162
- var sprintf = util.format;
1163
- return sprintf;
1164
-
1165
- });
1166
- (function (root, factory) {
1167
- /*global define:true */
1168
-
1169
- if (typeof exports === 'object') {
1170
- // Node. Does not work with strict CommonJS, but
1171
- // only CommonJS-like enviroments that support module.exports,
1172
- // like Node.
1173
- module.exports = factory();
1174
- } else if (typeof define === 'function' && define.amd) {
1175
- // AMD. Register as an anonymous module.
1176
- define('ensure-array',[], factory);
1177
- } else {
1178
- // Browser globals
1179
- root.ensureArray = factory();
1180
- }
1181
- }(this, function () {
1182
-
1183
-
1184
- function ensureArray(a, b, n) {
1185
- if (arguments.length === 0) return []; //no args, ret []
1186
- if (arguments.length === 1) { //single argument
1187
- if (a === undefined || a === null) return []; // undefined or null, ret []
1188
- if (Array.isArray(a)) return a; // isArray, return it
1189
- }
1190
- return Array.prototype.slice.call(arguments); //return array with copy of all arguments
1191
- }
1192
-
1193
- return ensureArray;
1194
- }));
1195
-
1196
-
1197
-
1198
- /*global define:true */
1199
-
1200
-
1201
-
1202
- define('react/status',[], function () {
1203
-
1204
- var STATUS = { READY: 'ready', RUNNING: 'running', ERRORED: 'errored', COMPLETE: 'complete' };
1205
-
1206
- return STATUS;
1207
-
1208
- });
1209
-
1210
- /*global define:true process:false*/
1211
-
1212
-
1213
-
1214
- define('react/event-manager',['./eventemitter'], function (EventEmitter) {
1215
- /*jshint regexp:false */
1216
-
1217
- var EVENT_EMITTER2_CONFIG = {
1218
- wildcard: true, // should the event emitter use wildcards.
1219
- delimiter: '.', // the delimiter used to segment namespaces, defaults to `.`.
1220
- maxListeners: 30 // the max number of listeners that can be assigned to an event, defaults to 10.
1221
- };
1222
-
1223
- var PASS_EVENTS_PROCESS_RE = /^ast.defined$/; // events to pass up to global process
1224
-
1225
- var TYPES = {
1226
- // Flow monitoring events and their params
1227
- AST_DEFINED: 'ast.defined', // ast
1228
- FLOW_BEGIN: 'flow.begin', // env
1229
- TASK_BEGIN: 'task.begin', // task
1230
- TASK_COMPLETE: 'task.complete', // task
1231
- TASK_ERRORED: 'task.errored', // task
1232
- FLOW_COMPLETE: 'flow.complete', // env
1233
- FLOW_ERRORED: 'flow.errored', // env
1234
-
1235
- // Internal Hooks
1236
- EXEC_FLOW_START: 'exec.flow.start', // env
1237
- EXEC_INPUT_PREPROCESS: 'exec.input.preprocess', // parsedInput
1238
- EXEC_TASKS_PRECREATE: 'exec.tasks.precreate', // env
1239
- EXEC_OUTTASK_CREATE: 'exec.outTask.create', // outTaskOptions
1240
- EXEC_TASK_START: 'exec.task.start', // task
1241
- EXEC_TASK_COMPLETE: 'exec.task.complete', // task
1242
- EXEC_TASK_ERRORED: 'exec.task.errored', // task
1243
- EXEC_FLOW_COMPLETE: 'exec.flow.complete', // env
1244
- EXEC_FLOW_ERRORED: 'exec.flow.errored' // env
1245
- };
1246
-
1247
- /**
1248
- Event manager which emits events up to its parent if exists.
1249
- Allows a hierarchy of emitters, which communicate up the
1250
- chain.
1251
- */
1252
- function EventManager() {
1253
- }
1254
-
1255
- EventManager.create = function () { return new EventManager(); };
1256
-
1257
- EventManager.TYPES = TYPES;
1258
- EventManager.prototype.TYPES = TYPES;
1259
-
1260
- EventManager.prototype.isEnabled = function () { // if has listener or an ancestor has listener
1261
- return !!(this.emitter || (this.parent && this.parent.isEnabled()));
1262
- };
1263
-
1264
- /**
1265
- Add listener. Wildcard events are allowed like 'foo.*'
1266
- Use '*' to listen to any event
1267
- */
1268
- EventManager.prototype.on = function (event, listener) {
1269
- if (!this.emitter) this.emitter = new EventEmitter(EVENT_EMITTER2_CONFIG);
1270
- if (event === '*') this.emitter.onAny(listener);
1271
- else this.emitter.on(event, listener);
1272
- };
1273
-
1274
- EventManager.prototype.emit = function (event, arg1, arg2, argN) {
1275
- if (event === undefined) throw new Error('event is undefined');
1276
- if (this.emitter) this.emitter.emit.apply(this.emitter, arguments);
1277
- if (this.parent && this.parent.isEnabled()) this.parent.emit.apply(this.parent, arguments);
1278
- if (PASS_EVENTS_PROCESS_RE.test(event) && typeof(process) !== 'undefined' && process.emit) {
1279
- process.emit.apply(process, arguments); // pass some to process
1280
- }
1281
- };
1282
-
1283
- EventManager.prototype.removeListener = function (event, listener) {
1284
- if (this.emitter) this.emitter.removeListener.apply(this.emitter, arguments);
1285
- };
1286
-
1287
- EventManager.prototype.removeAllListeners = function (event) {
1288
- if (this.emitter) this.emitter.removeAllListeners.apply(this.emitter, arguments);
1289
- };
1290
-
1291
-
1292
- EventManager.global = EventManager.create(); // create one top level emitter
1293
- return EventManager;
1294
-
1295
- });
1296
-
1297
- /*global define:true */
1298
-
1299
-
1300
-
1301
- define('react/base-task',['ensure-array', './status', './event-manager'],
1302
- function (array, STATUS, EventManager) {
1303
-
1304
- function BaseTask() {
1305
- }
1306
-
1307
- /**
1308
- Getter Fn to retrieveAn array of the output param names for this task.
1309
- */
1310
- BaseTask.prototype.getOutParams = function () {
1311
- return array(this.out); // ensure array
1312
- };
1313
-
1314
- BaseTask.prototype.isComplete = function () {
1315
- return (this.status === STATUS.COMPLETE);
1316
- };
1317
-
1318
- BaseTask.prototype.start = function (args) { // mark task as started with args and note time
1319
- /*jshint validthis: true */
1320
- this.args = args;
1321
- this.env.currentTask = this;
1322
- this.env.flowEmitter.emit(EventManager.TYPES.EXEC_TASK_START, this);
1323
- };
1324
-
1325
- BaseTask.prototype.complete = function (args) { //args that were used are available
1326
- /*jshint validthis: true */
1327
- this.status = STATUS.COMPLETE;
1328
- this.results = args;
1329
- this.env.currentTask = this;
1330
- this.env.flowEmitter.emit(EventManager.TYPES.EXEC_TASK_COMPLETE, this);
1331
- };
1332
-
1333
- BaseTask.prototype.functionExists = function (vCon) {
1334
- var fn = this.f;
1335
- if (!fn) return false;
1336
- if (fn instanceof Function) return true;
1337
- if (typeof(fn) === 'string') {
1338
- var f = vCon.getVar(fn); // fn/method by string
1339
- if (f && f instanceof Function) return true;
1340
- }
1341
- return false;
1342
- };
1343
-
1344
- BaseTask.prototype.areAllDepArgsDefined = function (vCon) {
1345
- return this.a.every(function (k) { return (vCon.getVar(k) !== undefined); });
1346
- };
1347
-
1348
- BaseTask.prototype.depTasksAreDone = function (tasksByName) {
1349
- return (!this.after || !this.after.length || // no dep tasks OR
1350
- this.after.every(function (n) { return tasksByName[n].isComplete(); })); //all done
1351
- };
1352
-
1353
- function isObjProperty(str) { return (str.indexOf('.') !== -1); }
1354
-
1355
- /**
1356
- check that obj parent is def and not null so writing to obj.prop
1357
- will not fail. ex: 'b.c' checks that b is def and not null.
1358
- Also returns true if not obj.prop but simple var ex: 'b'.
1359
- Tasks will implement outParentsExist() passing each out str
1360
- to this if they want to do this check.
1361
- */
1362
- BaseTask.prototype.parentExists = function (objPropStr, vCon) {
1363
- if (!isObjProperty(objPropStr)) return true; // NOT obj prop, just simple arg, ret true
1364
- var nameAndProps = objPropStr.split('.');
1365
- nameAndProps.pop(); // pop off final prop
1366
- var parent = nameAndProps.reduce(function (accObj, prop) {
1367
- if (accObj === undefined || accObj === null) return undefined; // prevent exception
1368
- return accObj[prop];
1369
- }, vCon.values); // vCon['foo']['bar']
1370
- return (parent !== undefined && parent !== null);
1371
- };
1372
-
1373
- /**
1374
- If params are obj property writes make sure the dst objects
1375
- are defined and not null. cb: ['b.c'] -> b is def and not null.
1376
- If null is specified then param is valid and will be ignored.
1377
- @returns true if all obj prop parents are def and non null
1378
- */
1379
- BaseTask.prototype.outParentsExist = function (vCon) {
1380
- var self = this;
1381
- return this.getOutParams().every(function (x) {
1382
- if (x === null) return true;
1383
- return self.parentExists(x, vCon);
1384
- });
1385
- };
1386
-
1387
- BaseTask.prototype.isReady = function (vCon, tasksByName) {
1388
- return !this.status && // not started AND
1389
- this.functionExists(vCon) && // function/method exists AND
1390
- this.areAllDepArgsDefined(vCon) && // all dep vars defined AND
1391
- this.depTasksAreDone(tasksByName) && // all dep tasks are done AND
1392
- (!this.outParentsExist || // (task does not implement outParentsExist method OR
1393
- this.outParentsExist(vCon)); // output parents exists (for obj property writes)
1394
- };
1395
-
1396
- BaseTask.prototype.isMethodCall = function () {
1397
- /*jshint regexp: false */
1398
- return (typeof(this.f) === 'string' && /^.*\..*$/.test(this.f)); //str contains .
1399
- };
1400
-
1401
- BaseTask.prototype.getMethodObj = function (vCon) { //obj.prop.prop2, returns obj.prop or undefined
1402
- var name = this.f;
1403
- if (!name) return undefined;
1404
- var nameAndProps = name.split('.');
1405
- nameAndProps.pop(); // pop off last one
1406
- if (!nameAndProps.length) return undefined;
1407
- var result = nameAndProps.reduce(function (accObj, prop) {
1408
- if (accObj === undefined || accObj === null) return undefined; // prevent exception
1409
- return accObj[prop];
1410
- }, vCon.values); // vCon['foo']['bar']
1411
- return result;
1412
- };
1413
-
1414
- return BaseTask;
1415
-
1416
- });
1417
-
1418
- /*global define:true */
1419
-
1420
-
1421
-
1422
- define('react/cb-task',['util', './sprintf', './base-task'], function (util, sprintf, BaseTask) {
1423
-
1424
- function format_error(errmsg, obj) {
1425
- return sprintf('%s - %s', errmsg, util.inspect(obj));
1426
- }
1427
-
1428
- var REQ = 'cbTask requires f, a, out';
1429
- var FN_REQ = 'cbTask requires f to be a function or string';
1430
- var A_REQ = 'cbTask requires a to be an array of string param names';
1431
- var CB_REQ = 'cbTask requires out to be an array of string param names';
1432
-
1433
- function CbTask(taskDef) {
1434
- var self = this;
1435
- Object.keys(taskDef).forEach(function (k) { self[k] = taskDef[k]; });
1436
- }
1437
-
1438
- CbTask.prototype = new BaseTask();
1439
- CbTask.prototype.constructor = CbTask;
1440
-
1441
- CbTask.validate = function (taskDef) {
1442
- var errors = [];
1443
- if (!taskDef.f || !taskDef.a || !taskDef.out) {
1444
- errors.push(format_error(REQ, taskDef));
1445
- } else {
1446
- var ftype = typeof(taskDef.f);
1447
- if (! ((taskDef.f instanceof Function) || (ftype === 'string'))) {
1448
- errors.push(format_error(FN_REQ, taskDef));
1449
- }
1450
- if (! (Array.isArray(taskDef.a) &&
1451
- taskDef.a.every(function (x) { return (typeof(x) === 'string'); }))) {
1452
- errors.push(format_error(A_REQ, taskDef));
1453
- }
1454
- if (! (Array.isArray(taskDef.out) &&
1455
- taskDef.out.every(function (x) { return (typeof(x) === 'string'); }))) {
1456
- errors.push(format_error(CB_REQ, taskDef));
1457
- }
1458
- }
1459
- return errors;
1460
- };
1461
-
1462
- CbTask.prototype.prepare = function prepare(handleTaskError, vCon, contExec) {
1463
- var self = this;
1464
- this.cbFun = function (err, arg0, arg1, argn) {
1465
- var args = Array.prototype.slice.call(arguments, 1);
1466
- if (err) { handleTaskError(self, err); return; } //handle error and return, we are done
1467
-
1468
- //no error, save callback args to vCon context, then continue execution
1469
- vCon.saveResults(self.out, args);
1470
- self.complete(args);
1471
- contExec();
1472
- };
1473
- };
1474
-
1475
- CbTask.prototype.exec = function exec(vCon, handleError, contExec) {
1476
- try {
1477
- var args = this.a.map(function (k) { return vCon.getVar(k); }); //get args from vCon
1478
- //console.error('CbTask.exec.args=', args);
1479
- //console.error('CbTask.exec.vCon=', vCon);
1480
- this.start(args); //note the start time, args
1481
- args.push(this.cbFun); // push callback fn on end
1482
- var func = this.f;
1483
- var bindObj = vCon.getVar('this'); //global space or the original this
1484
- if (this.isMethodCall()) { //if method call then reset func and bindObj
1485
- func = vCon.getVar(this.f);
1486
- bindObj = this.getMethodObj(vCon);
1487
- } else if (typeof(func) === 'string') {
1488
- func = vCon.getVar(func); // we want the actual fn from this string
1489
- }
1490
- func.apply(bindObj, args);
1491
- } catch (err) { //catch and handle the task error, calling final cb
1492
- handleError(this, err);
1493
- }
1494
- };
1495
-
1496
- return CbTask;
1497
-
1498
- });
1499
-
1500
-
1501
- /*global define:true */
1502
-
1503
-
1504
-
1505
- define('react/promise-task',['util', './sprintf', './base-task'], function (util, sprintf, BaseTask) {
1506
-
1507
- /**
1508
- PromiseTask is a task which executes a fn that returns a promise
1509
- and when it completes it sets the values in vCon
1510
- */
1511
-
1512
- function format_error(errmsg, obj) {
1513
- return sprintf('%s - %s', errmsg, util.inspect(obj));
1514
- }
1515
-
1516
- var REQ = 'promiseTask requires f, a, out';
1517
- var FN_REQ = 'promiseTask requires f to be a function or string';
1518
- var A_REQ = 'promiseTask requires a to be an array of string param names';
1519
- var OUT_REQ = 'promiseTask requires out to be an array[1] of string param names';
1520
-
1521
- function PromiseTask(taskDef) {
1522
- var self = this;
1523
- Object.keys(taskDef).forEach(function (k) { self[k] = taskDef[k]; });
1524
- }
1525
-
1526
- PromiseTask.prototype = new BaseTask();
1527
- PromiseTask.prototype.constructor = PromiseTask;
1528
-
1529
- PromiseTask.validate = function (taskDef) {
1530
- var errors = [];
1531
- if (!taskDef.f || !taskDef.a || !taskDef.out) {
1532
- errors.push(format_error(REQ, taskDef));
1533
- } else {
1534
- var ftype = typeof(taskDef.f);
1535
- if (! ((taskDef.f instanceof Function) || (ftype === 'string'))) {
1536
- errors.push(format_error(FN_REQ, taskDef));
1537
- }
1538
- if (! (Array.isArray(taskDef.a) &&
1539
- taskDef.a.every(function (x) { return (typeof(x) === 'string'); }))) {
1540
- errors.push(format_error(A_REQ, taskDef));
1541
- }
1542
- if (! (Array.isArray(taskDef.out) && taskDef.out.length <= 1 &&
1543
- taskDef.out.every(function (x) { return (typeof(x) === 'string'); }))) {
1544
- errors.push(format_error(OUT_REQ, taskDef));
1545
- }
1546
- }
1547
- return errors;
1548
- };
1549
-
1550
- PromiseTask.prototype.prepare = function prepare(handleTaskError, vCon, contExec) {
1551
- var self = this;
1552
- this.nextFn = function (arg) {
1553
- var args = Array.prototype.slice.call(arguments);
1554
- vCon.saveResults(self.out, args);
1555
- self.complete(args);
1556
- contExec();
1557
- };
1558
- this.failFn = function (err) {
1559
- handleTaskError(self, err);
1560
- };
1561
- };
1562
-
1563
- PromiseTask.prototype.exec = function exec(vCon, handleError, contExec) {
1564
- try {
1565
- var args = this.a.map(function (k) { return vCon.getVar(k); }); //get args from vCon
1566
- //console.error('PromiseTask.exec.args=', args);
1567
- //console.error('PromiseTask.exec.vCon=', vCon);
1568
- this.start(args); //note the start time, args
1569
- var func = this.f;
1570
- var bindObj = vCon.getVar('this'); //global space or the original this
1571
- if (this.isMethodCall()) { //if method call then reset func and bindObj
1572
- func = vCon.getVar(this.f);
1573
- bindObj = this.getMethodObj(vCon);
1574
- } else if (typeof(func) === 'string') {
1575
- func = vCon.getVar(func); // we want the actual fn from this string
1576
- }
1577
- var retValue = func.apply(bindObj, args);
1578
- if (retValue && typeof(retValue.then) === 'function') { // is a promise
1579
- retValue.then(this.nextFn, this.failFn);
1580
- } else { // just a value, proceed now
1581
- this.nextFn(retValue);
1582
- }
1583
- } catch (err) { //catch and handle the task error, calling final cb
1584
- handleError(this, err);
1585
- }
1586
- };
1587
-
1588
- return PromiseTask;
1589
-
1590
- });
1591
-
1592
- /*global define:true */
1593
-
1594
-
1595
-
1596
- define('react/ret-task',['util', './sprintf', './base-task'], function (util, sprintf, BaseTask) {
1597
-
1598
- function format_error(errmsg, obj) {
1599
- return sprintf('%s - %s', errmsg, util.inspect(obj));
1600
- }
1601
-
1602
- var REQ = 'retTask requires f, a, out';
1603
- var FN_REQ = 'retTask requires f to be a function or string';
1604
- var A_REQ = 'retTask requires a to be an array of string param names';
1605
- var RET_REQ = 'retTask requires out to be an array with single string param name or []';
1606
-
1607
- function RetTask(taskDef) {
1608
- var self = this;
1609
- Object.keys(taskDef).forEach(function (k) { self[k] = taskDef[k]; });
1610
- }
1611
-
1612
- RetTask.prototype = new BaseTask();
1613
- RetTask.prototype.constructor = RetTask;
1614
-
1615
- RetTask.validate = function (taskDef) {
1616
- var errors = [];
1617
- if (!taskDef.f || !taskDef.a || !taskDef.out) {
1618
- errors.push(format_error(REQ, taskDef));
1619
- } else {
1620
- var ftype = typeof(taskDef.f);
1621
- if (! ((taskDef.f instanceof Function) || (ftype === 'string'))) {
1622
- errors.push(format_error(FN_REQ, taskDef));
1623
- }
1624
- if (! (Array.isArray(taskDef.a) &&
1625
- taskDef.a.every(function (x) { return (typeof(x) === 'string'); }))) {
1626
- errors.push(format_error(A_REQ, taskDef));
1627
- }
1628
-
1629
- if (! (Array.isArray(taskDef.out) &&
1630
- (taskDef.out.length === 0 ||
1631
- (taskDef.out.length === 1 && typeof(taskDef.out[0] === 'string'))))) {
1632
- errors.push(format_error(RET_REQ, taskDef));
1633
- }
1634
- }
1635
- return errors;
1636
- };
1637
-
1638
- RetTask.prototype.exec = function exec(vCon, handleError, contExec) {
1639
- try {
1640
- var args = this.a.map(function (k) { return vCon.getVar(k); }); //get args from vCon
1641
- this.start(args); //note the start time, args
1642
- var func = this.f;
1643
- var bindObj = vCon.getVar('this'); //global space or the original this
1644
- if (this.isMethodCall()) { //if method call then reset func and bindObj
1645
- func = vCon.getVar(this.f);
1646
- bindObj = this.getMethodObj(vCon);
1647
- } else if (typeof(func) === 'string') {
1648
- func = vCon.getVar(func); // we want the actual fn from this string
1649
- }
1650
- var results = [func.apply(bindObj, args)];
1651
- vCon.saveResults(this.out, results); // save retval, takes arrays
1652
- this.complete(results);
1653
- contExec(); // continue since no callback to run this
1654
- } catch (err) { handleError(this, err); } // catch and handle the task error, calling final cb
1655
- };
1656
-
1657
- return RetTask;
1658
-
1659
- });
1660
-
1661
- /*global define:true */
1662
-
1663
-
1664
-
1665
- define('react/when-task',['util', './sprintf', './base-task'], function (util, sprintf, BaseTask) {
1666
-
1667
- /**
1668
- When task which checks if is a promise (has a then method)
1669
- and waits for it to resolve.
1670
-
1671
- If argument does not have a then method, it resolves immediately
1672
- */
1673
-
1674
- function format_error(errmsg, obj) {
1675
- return sprintf('%s - %s', errmsg, util.inspect(obj));
1676
- }
1677
-
1678
- var REQ = 'whenTask requires a, out';
1679
- var A_REQ = 'whenTask requires a to be an array[1] of string param names';
1680
- var OUT_REQ = 'whenTask requires out to be an array[1] of string param names';
1681
-
1682
- function WhenTask(taskDef) {
1683
- var self = this;
1684
- Object.keys(taskDef).forEach(function (k) { self[k] = taskDef[k]; });
1685
- }
1686
-
1687
- WhenTask.prototype = new BaseTask();
1688
- WhenTask.prototype.constructor = WhenTask;
1689
-
1690
- WhenTask.prototype.f = function when() { // just here to keep validations happy
1691
- }
1692
-
1693
- WhenTask.validate = function (taskDef) {
1694
- var errors = [];
1695
- if (!taskDef.a || !taskDef.out) {
1696
- errors.push(format_error(REQ, taskDef));
1697
- } else {
1698
- if (! (Array.isArray(taskDef.a) && taskDef.a.length === 1 &&
1699
- taskDef.a.every(function (x) { return (typeof(x) === 'string'); }))) {
1700
- errors.push(format_error(A_REQ, taskDef));
1701
- }
1702
- if (! (Array.isArray(taskDef.out) && taskDef.out.length <= 1 &&
1703
- taskDef.out.every(function (x) { return (typeof(x) === 'string'); }))) {
1704
- errors.push(format_error(OUT_REQ, taskDef));
1705
- }
1706
- }
1707
- return errors;
1708
- };
1709
-
1710
- WhenTask.prototype.prepare = function prepare(handleTaskError, vCon, contExec) {
1711
- var self = this;
1712
- this.nextFn = function (arg) {
1713
- var args = Array.prototype.slice.call(arguments);
1714
- vCon.saveResults(self.out, args);
1715
- self.complete(args);
1716
- contExec();
1717
- };
1718
- this.failFn = function (err) {
1719
- handleTaskError(self, err);
1720
- };
1721
- };
1722
-
1723
- WhenTask.prototype.exec = function exec(vCon, handleError, contExec) {
1724
- try {
1725
- var args = this.a.map(function (k) { return vCon.getVar(k); }); //get args from vCon
1726
- //console.error('WhenTask.exec.args=', args);
1727
- //console.error('WhenTask.exec.vCon=', vCon);
1728
- this.start(args); //note the start time, args
1729
- var arg = args[0]; // one value allowed
1730
- if (arg && typeof(arg.then) === 'function') { // is a promise
1731
- arg.then(this.nextFn, this.failFn);
1732
- } else { // not a promise continue immediately
1733
- this.nextFn(arg);
1734
- }
1735
- } catch (err) { //catch and handle the task error, calling final cb
1736
- handleError(this, err);
1737
- }
1738
- };
1739
-
1740
- return WhenTask;
1741
-
1742
- });
1743
-
1744
- /*global define:true */
1745
-
1746
-
1747
-
1748
- define('react/finalcb-task',['./sprintf', 'util', './status', './event-manager'],
1749
- function (sprintf, util, STATUS, EventManager) {
1750
-
1751
- var OUTTASK_A_REQ = 'ast.outTask.a should be an array of string param names';
1752
-
1753
- function FinalCbTask(outTaskOptions) {
1754
- var taskDef = outTaskOptions.taskDef;
1755
- if (typeof(outTaskOptions.cbFunc) !== 'function') throw new Error('callback is not a function');
1756
- var self = this;
1757
- for (var k in taskDef) {
1758
- if (true) self[k] = taskDef[k]; // if to make jshint happy
1759
- }
1760
- this.f = outTaskOptions.cbFunc;
1761
- this.tasks = outTaskOptions.tasks;
1762
- this.vCon = outTaskOptions.vCon;
1763
- this.retValue = outTaskOptions.retValue;
1764
- this.execOptions = outTaskOptions.execOptions;
1765
- this.env = outTaskOptions.env;
1766
- }
1767
-
1768
- function format_error(errmsg, obj) {
1769
- return sprintf('%s - %s', errmsg, util.inspect(obj));
1770
- }
1771
-
1772
-
1773
- FinalCbTask.validate = function (taskDef) {
1774
- var errors = [];
1775
- if (! (Array.isArray(taskDef.a) &&
1776
- taskDef.a.every(function (x) { return (typeof(x) === 'string'); }))) {
1777
- errors.push(format_error(OUTTASK_A_REQ, taskDef));
1778
- }
1779
- return errors;
1780
- };
1781
-
1782
- FinalCbTask.prototype.isReady = function () {
1783
- return (this.tasks.every(function (t) { return (t.status === STATUS.COMPLETE); }));
1784
- };
1785
-
1786
- FinalCbTask.prototype.exec = function (err) {
1787
- if (!this.f) return; //must have already been called
1788
- if (err) {
1789
- this.env.error = err;
1790
- this.env.flowEmitter.emit(EventManager.TYPES.EXEC_FLOW_ERRORED, this.env);
1791
- this.f.call(null, err); //call the final callback with the first error hit
1792
- } else { // no error, call with args
1793
- var vCon = this.vCon;
1794
- var finalArgs = this.a.map(function (k) { return vCon.getVar(k); });
1795
- finalArgs.unshift(null); //unshift err=null to front
1796
- this.env.results = finalArgs;
1797
- this.env.flowEmitter.emit(EventManager.TYPES.EXEC_FLOW_COMPLETE, this.env);
1798
- this.f.apply(null, finalArgs);
1799
- }
1800
- this.f = null; // prevent multiple calls
1801
- };
1802
-
1803
- return FinalCbTask;
1804
-
1805
- });
1806
-
1807
- /*global define:true */
1808
-
1809
-
1810
-
1811
- define('react/vcon',[], function () {
1812
-
1813
- var LAST_RESULTS_KEY = ':LAST_RESULTS';
1814
-
1815
- function VContext() {
1816
- }
1817
-
1818
- VContext.prototype.getLastResults = function () { return this.getVar(LAST_RESULTS_KEY); };
1819
- VContext.prototype.setLastResults = function (args) { this.setVar(LAST_RESULTS_KEY, args); };
1820
-
1821
- VContext.prototype.getVar = function (name) { //name might be simple or obj.prop, also literals
1822
- /*jshint regexp: false */
1823
- var vConValues = this.values;
1824
- if (typeof(name) !== 'string') return name; // literal boolean or number
1825
- name = name.trim();
1826
- // literal checks need to match what is in validate.js
1827
- if (name === 'true') return true;
1828
- if (name === 'false') return false;
1829
- if (name === 'null') return null;
1830
- if (/^-?[0-9]+$/.test(name)) return parseInt(name, 10); //int
1831
- if (/^-?[0-9.]+$/.test(name)) return parseFloat(name); //float
1832
- var m = /^("|')([^\1]*)\1$/.exec(name); //check for quoted string " or '
1833
- if (m) return m[2]; // if is quoted str, return inside of the quotes
1834
- var nameAndProps = name.split('.');
1835
- return nameAndProps.reduce(function (accObj, prop) {
1836
- if (accObj === undefined || accObj === null) return undefined; // prevent exception
1837
- return accObj[prop];
1838
- }, vConValues); // vCon['foo']['bar']
1839
- };
1840
-
1841
- /**
1842
- Saves all the results from a task as a unit, also sets special
1843
- variable :LAST_RESULTS which keeps an array of the last values
1844
- which can be used for chaining and testing last results, etc.
1845
- */
1846
- VContext.prototype.saveResults = function (paramArr, valuesArr) { // set values for params
1847
- var self = this;
1848
- paramArr.forEach(function (k, idx) { //save values to v context
1849
- self.setVar(k, (valuesArr[idx] !== undefined) ? valuesArr[idx] : null); //upgrade any undefined to null
1850
- });
1851
- this.setLastResults(valuesArr);
1852
- };
1853
-
1854
- VContext.prototype.setVar = function (name, value) { //name might be simple or obj.prop
1855
- if (!name) return; // if name is undefined or null, then discard
1856
- var vConValues = this.values;
1857
- var nameAndProps = name.split('.');
1858
- var lastProp = nameAndProps.pop();
1859
- var obj = nameAndProps.reduce(function (accObj, prop) {
1860
- var o = accObj[prop];
1861
- if (o === undefined || o === null) { // if doesn't exist create it
1862
- o = accObj[prop] = { };
1863
- }
1864
- return o;
1865
- }, vConValues); // vCon['foo']['bar']
1866
- obj[lastProp] = value;
1867
- };
1868
-
1869
-
1870
- /**
1871
- Create Variable Context using arguments passed in.
1872
- Ignore extra arguments passed in. Locals can be
1873
- passed into seed the VContext otherwise empty {}
1874
- will be used
1875
- @param self used to pass 'this' context in
1876
- */
1877
- VContext.create = function (args, inParams, locals, self) {
1878
- var initValues = {};
1879
- if (self) initValues['this'] = self;
1880
- if (locals) Object.keys(locals).forEach(function (k) { initValues[k] = locals[k]; }); // copy over keys
1881
- var vContext = new VContext();
1882
- vContext.values = args.reduce(function (vcon, x, idx) { // create vCon start with input args
1883
- var param = inParams[idx];
1884
- if (param) vcon[param] = (x !== undefined) ? x : null; // upgrade undefined to null
1885
- return vcon;
1886
- }, initValues);
1887
- return vContext;
1888
- };
1889
-
1890
-
1891
- return VContext;
1892
-
1893
- });
1894
-
1895
- /*global define:true */
1896
-
1897
-
1898
-
1899
- define('react/finalcb-first-task',['./sprintf', 'util', './status', './vcon', './event-manager'],
1900
- function (sprintf, util, STATUS, VContext, EventManager) {
1901
-
1902
- var OUTTASK_A_REQ = 'ast.outTask.a should be an array of string param names';
1903
-
1904
- function FinalCbFirstSuccTask(outTaskOptions) {
1905
- var taskDef = outTaskOptions.taskDef;
1906
- if (typeof(outTaskOptions.cbFunc) !== 'function') throw new Error('callback is not a function');
1907
- var self = this;
1908
- for (var k in taskDef) {
1909
- if (true) self[k] = taskDef[k]; // if to make jshint happy
1910
- }
1911
- this.f = outTaskOptions.cbFunc;
1912
- this.tasks = outTaskOptions.tasks;
1913
- this.vCon = outTaskOptions.vCon;
1914
- this.retValue = outTaskOptions.retValue;
1915
- this.env = outTaskOptions.env;
1916
- }
1917
-
1918
- function format_error(errmsg, obj) {
1919
- return sprintf('%s - %s', errmsg, util.inspect(obj));
1920
- }
1921
-
1922
- FinalCbFirstSuccTask.validate = function (taskDef) {
1923
- var errors = [];
1924
- if (! (Array.isArray(taskDef.a) &&
1925
- taskDef.a.every(function (x) { return (typeof(x) === 'string'); }))) {
1926
- errors.push(format_error(OUTTASK_A_REQ, taskDef));
1927
- }
1928
- return errors;
1929
- };
1930
-
1931
- /**
1932
- is ready to exit when any task comes back with non-null defined value
1933
- */
1934
- FinalCbFirstSuccTask.prototype.isReady = function () {
1935
- var lastres = this.vCon.getLastResults();
1936
- if (!lastres) return false; // no results yet
1937
- return (lastres.some(function (v) { return (v !== undefined && v !== null); }));
1938
- };
1939
-
1940
- FinalCbFirstSuccTask.prototype.exec = function (err) {
1941
- if (!this.f) return; //must have already been called
1942
- if (err) {
1943
- this.env.error = err;
1944
- this.env.flowEmitter.emit(EventManager.TYPES.EXEC_FLOW_ERRORED, this.env);
1945
- this.f.call(null, err); //call the final callback with the first error hit
1946
- } else { // no error, call with args
1947
- var vCon = this.vCon;
1948
- var finalArgs = this.a.map(function (k) { return vCon.getVar(k); });
1949
- finalArgs.unshift(null); //unshift err=null to front
1950
- this.env.results = finalArgs;
1951
- this.env.flowEmitter.emit(EventManager.TYPES.EXEC_FLOW_COMPLETE, this.env);
1952
- this.f.apply(null, finalArgs);
1953
- }
1954
- this.f = null; // prevent multiple calls
1955
- };
1956
-
1957
- return FinalCbFirstSuccTask;
1958
-
1959
- });
1960
-
1961
- /*global define:true */
1962
-
1963
-
1964
-
1965
- define('react/task',['util', './sprintf', 'ensure-array', './cb-task', './promise-task',
1966
- './ret-task', './when-task', './finalcb-task', './finalcb-first-task',
1967
- './status', './error', './vcon', './event-manager'],
1968
- function (util, sprintf, array, CbTask, PromiseTask,
1969
- RetTask, WhenTask, FinalCbTask, FinalCbFirstSuccTask,
1970
- STATUS, error, VContext, EventManager) {
1971
-
1972
- var TASK_TYPES = {
1973
- cb: CbTask,
1974
- ret: RetTask,
1975
- promise: PromiseTask,
1976
- when: WhenTask
1977
- };
1978
-
1979
- var DEFAULT_TASK_NAME = 'task_%s'; // for unnamed tasks use task_idx, like task_0
1980
-
1981
- function taskTypeKeys() { return Object.keys(TASK_TYPES); }
1982
-
1983
- var OUT_TASK_TYPES = {
1984
- finalcb: FinalCbTask, //first task is the default if no type specified in taskDef
1985
- finalcbFirst: FinalCbFirstSuccTask
1986
- };
1987
- function outTaskTypeKeys() { return Object.keys(OUT_TASK_TYPES); }
1988
-
1989
- var LOCAL_FN_MISSING = 'function: %s not found in locals or input params - task[%s]';
1990
- var TASKDEF_IS_OBJECT = 'task must be an object';
1991
- var NO_TASKS_RUNNING_WONT_COMPLETE = 'no tasks running, flow will not complete, remaining tasks: %s';
1992
- var TASK_TYPE_SHOULD_MATCH = 'task.type should match one of ' +
1993
- Object.keys(TASK_TYPES).join(', ');
1994
-
1995
- function format_error(errmsg, obj) {
1996
- return sprintf('%s - %s', errmsg, util.inspect(obj));
1997
- }
1998
-
1999
- /**
2000
- guess the missing types from params.
2001
- Augments in place but also returns taskDef.
2002
- If not specified then is 'cb'
2003
- */
2004
- function setMissingType(taskDef) {
2005
- if (taskDef.type) return taskDef; //already set, return
2006
- taskDef.type = 'cb';
2007
- return taskDef;
2008
- }
2009
-
2010
- function setMissingOutTaskType(taskDef) {
2011
- if (!taskDef.type) taskDef.type = Object.keys(OUT_TASK_TYPES)[0]; //use first outTask type as default
2012
- }
2013
-
2014
- function ensureAfterArrStrings(taskDef) { // convert any fn to str, and make sure is array
2015
- if (!taskDef.after) return;
2016
- var afterArr = array(taskDef.after); // ensure is array, null becomes []
2017
- afterArr = afterArr.map(function (a) { return (typeof(a) === 'function') ? a.name : a; });
2018
- taskDef.after = afterArr;
2019
- }
2020
-
2021
- /**
2022
- @returns array of errors for taskDef, could be empty
2023
- */
2024
- function validate(taskDef) {
2025
- if (!taskDef || typeof(taskDef) !== 'object') {
2026
- return [format_error(TASKDEF_IS_OBJECT, taskDef)];
2027
- }
2028
- setMissingType(taskDef);
2029
- ensureAfterArrStrings(taskDef);
2030
- var errors = [];
2031
- errors = errors.concat(validateTaskType(taskDef));
2032
- errors = errors.concat(validateTask(taskDef));
2033
- return errors;
2034
- }
2035
-
2036
- function validateTaskType(taskDef) {
2037
- var errors = [];
2038
- if (!Object.keys(TASK_TYPES).some(
2039
- function (type) { return (taskDef.type === type); })) {
2040
- errors.push(format_error(TASK_TYPE_SHOULD_MATCH, taskDef));
2041
- }
2042
- return errors;
2043
- }
2044
-
2045
- function validateTask(taskDef) {
2046
- var errors = [];
2047
- var taskCons = TASK_TYPES[taskDef.type];
2048
- if (taskCons) {
2049
- errors = errors.concat(taskCons.validate(taskDef));
2050
- }
2051
- return errors;
2052
- }
2053
-
2054
- function validateOutTask(taskDef) {
2055
- var errors = [];
2056
- setMissingOutTaskType(taskDef);
2057
- var taskCons = OUT_TASK_TYPES[taskDef.type];
2058
- errors = errors.concat(taskCons.validate(taskDef));
2059
- return errors;
2060
- }
2061
-
2062
-
2063
- function validateLocalFunctions(inParams, taskDefs, locals) {
2064
- var errors = [];
2065
- function foo() { } //used to mock args as fns for validation check
2066
- var mock_args = inParams.map(function (p) { return foo; }); //mock args with fns
2067
- var vCon = VContext.create(mock_args, inParams, locals);
2068
- var tasks = taskDefs.map(create);
2069
- var tasksWFunctions = tasks.filter(function (t) { return (t.type !== 'when'); }); // non-when tasks need f
2070
- tasksWFunctions.forEach(function (t, idx) {
2071
- if (!t.functionExists(vCon)) { // error if function doesnt exist AND
2072
- if (!t.isMethodCall()) errors.push(sprintf(LOCAL_FN_MISSING, t.f, idx)); // not method OR
2073
- else {
2074
- var obj = t.getMethodObj(vCon);
2075
- if (obj && obj !== foo) { // (has parent but not our mock)
2076
- errors.push(sprintf(LOCAL_FN_MISSING, t.f, idx));
2077
- }
2078
- }
2079
- }
2080
- });
2081
- return errors;
2082
- }
2083
-
2084
- function fName(fn) {
2085
- if (typeof(fn) === 'function') {
2086
- return fn.name;
2087
- }
2088
- return (fn) ? fn : '';
2089
- }
2090
-
2091
- /**
2092
- Name tasks that are not already named. Prenamed task uniquness validation
2093
- will be done in validate.
2094
-
2095
- This modifies the tasks with the new names.
2096
-
2097
- @returns map of names to tasks
2098
- */
2099
- function nameTasks(tasks) { //name tasks that are not already named, validation done elsewhere, ret map
2100
- var namesMap = tasks.reduce(function (map, t) {
2101
- if (t.name) { map[t.name] = t; }
2102
- return map;
2103
- }, {});
2104
- tasks.forEach(function (t, idx) {
2105
- if (!t.name) { //not already named
2106
- var name = fName(t.f);
2107
- if (!name) name = sprintf(DEFAULT_TASK_NAME, idx);
2108
- if (!name || namesMap[name]) {
2109
- name = sprintf('%s_%s', name, idx); //if empty or already used, postfix with _idx
2110
- }
2111
- t.name = name;
2112
- namesMap[name] = t;
2113
- }
2114
- });
2115
- return namesMap;
2116
- }
2117
-
2118
- function create(taskDef) {
2119
- var TaskConstructor = TASK_TYPES[taskDef.type];
2120
- return new TaskConstructor(taskDef);
2121
- }
2122
-
2123
- function createOutTask(taskDef, cbFunc, tasks, vCon, execOptions, env) {
2124
- setMissingOutTaskType(taskDef);
2125
- var outTaskOptions = {
2126
- taskDef: taskDef,
2127
- cbFunc: cbFunc,
2128
- tasks: tasks,
2129
- vCon: vCon,
2130
- execOptions: execOptions,
2131
- env: env,
2132
- TaskConstructor: OUT_TASK_TYPES[taskDef.type]
2133
- };
2134
- EventManager.global.emit(EventManager.TYPES.EXEC_OUTTASK_CREATE, outTaskOptions); // hook
2135
- var TaskConstructor = outTaskOptions.TaskConstructor; // hook could have changed
2136
- return new TaskConstructor(outTaskOptions);
2137
- }
2138
-
2139
- function createErrorHandler(vCon, outTask) {
2140
- return function handleError(task, err) {
2141
- task.status = STATUS.ERRORED;
2142
- task.error = err;
2143
- outTask.env.currentTask = task;
2144
- outTask.env.flowEmitter.emit(EventManager.TYPES.EXEC_TASK_ERRORED, task);
2145
- var errWithMeta = error.augmentError(err, {task: task, vcon: vCon});
2146
- outTask.exec(errWithMeta); //call the final callback with the first error hit
2147
- };
2148
- }
2149
-
2150
- function findTasksReady(vCon, tasks, tasksByName) {
2151
- return tasks.filter(function (t) { return t.isReady(vCon, tasksByName); });
2152
- }
2153
-
2154
- function execTasks(tasksReady, vCon, handleError, contExec) {
2155
- tasksReady.forEach(function (t) { t.status = STATUS.READY; }); //set ready first, no double exec
2156
- tasksReady.forEach(function (t) { t.exec(vCon, handleError, contExec); });
2157
- }
2158
-
2159
- /**
2160
- this will be called if there are no tasks found to run,
2161
- and it will check if there are still tasks running or ready
2162
- (which means they will be running shortly), in which
2163
- case everything is fine. If no tasks are running then
2164
- call handleError since this will never complete.
2165
- */
2166
- function checkIfTasksRunning(vCon, tasks, handleError, env) {
2167
- var tasksRunning = tasks.filter(function (t) {
2168
- return (t.status === STATUS.RUNNING || t.status === STATUS.READY);
2169
- });
2170
- if (!tasksRunning.length) {
2171
- var remainingTasks = tasks.filter(function (t) { return (!t.status); });
2172
- var remainingTNames = remainingTasks.map(function (t) { return t.name; });
2173
- var errMsg = sprintf(NO_TASKS_RUNNING_WONT_COMPLETE, remainingTNames.join(', '));
2174
- var emptyTask = { env: env };
2175
- handleError(emptyTask, new Error(errMsg));
2176
- }
2177
- }
2178
-
2179
- function findReadyAndExec(vCon, tasks, tasksByName, handleError, contExec, env) {
2180
- var tasksReady = findTasksReady(vCon, tasks, tasksByName);
2181
- if (!tasksReady.length) checkIfTasksRunning(vCon, tasks, handleError, env); // no tasks to run, check if ok
2182
- execTasks(tasksReady, vCon, handleError, contExec);
2183
- }
2184
-
2185
- function serializeTasks(tasks) { // conveniently set after for each task idx > 0
2186
- nameTasks(tasks);
2187
- tasks.forEach(function (t, idx, arr) { if (idx !== 0) t.after = [arr[idx - 1].name]; });
2188
- return tasks;
2189
- }
2190
-
2191
- return {
2192
- serializeTasks: serializeTasks,
2193
- TASK_TYPES: TASK_TYPES,
2194
- taskTypeKeys: taskTypeKeys,
2195
- OUT_TASK_TYPES: OUT_TASK_TYPES,
2196
- outTaskTypeKeys: outTaskTypeKeys,
2197
- setMissingType: setMissingType,
2198
- validate: validate,
2199
- validateOutTask: validateOutTask,
2200
- validateLocalFunctions: validateLocalFunctions,
2201
- nameTasks: nameTasks,
2202
- create: create,
2203
- createOutTask: createOutTask,
2204
- createErrorHandler: createErrorHandler,
2205
- findReadyAndExec: findReadyAndExec
2206
- };
2207
-
2208
- });
2209
-
2210
- /*global define:true */
2211
-
2212
-
2213
-
2214
- define('react/validate',['util', './sprintf', 'ensure-array', './task'], function (util, sprintf, array, taskUtil) {
2215
- /*jshint latedef:false */
2216
-
2217
- var AST_IS_OBJECT = 'ast must be an object with inParams, tasks, and outTask';
2218
- var INPARAMS_ARR_STR = 'ast.inParams must be an array of strings';
2219
- var TASKS_ARR = 'ast.tasks must be an array of tasks';
2220
- var NAMES_UNIQUE = 'ast.tasks that specify name need to be unique, duplicate:';
2221
- var LOCALS_NOTNULL = 'ast.locals should not be null';
2222
- var DUP_OUTPUTS = 'multiple tasks output the same param, must be unique. param';
2223
- var MISSING_INPUTS = 'missing or mispelled variable referenced in flow definition: %s';
2224
-
2225
- // match any of our literals true, false, int, float, quoted strings, or is property (has dot), match vcon.js
2226
- var LITERAL_OR_PROP_RE = /^(true|false|this|null|\-?[0-9\.]+)$|'|"|\./i;
2227
-
2228
- function format_error(errmsg, obj) {
2229
- return sprintf('%s - %s', errmsg, util.inspect(obj));
2230
- }
2231
-
2232
- /**
2233
- true if is a literal name
2234
- */
2235
- function isLiteralOrProp(name) { // need to match what is in vcon.js, TODO consolidate?
2236
- return LITERAL_OR_PROP_RE.test(name);
2237
- }
2238
-
2239
- /**
2240
- validate the AST return Errors
2241
- @example
2242
- var validate = require('./validate');
2243
- var errors = validate(ast);
2244
- @returns array of errors, could be empty
2245
- */
2246
- function validate(ast) {
2247
- if (!ast || !ast.inParams || !ast.tasks || !ast.outTask) return [AST_IS_OBJECT];
2248
- var errors = [];
2249
- errors = errors.concat(validateInParams(ast.inParams));
2250
- errors = errors.concat(validateTasks(ast.tasks));
2251
- errors = errors.concat(validateTaskNamesUnique(ast.tasks));
2252
- errors = errors.concat(taskUtil.validateOutTask(ast.outTask));
2253
- errors = errors.concat(validateLocals(ast.locals));
2254
- if (errors.length === 0) { // if no errors do additional validation
2255
- if (ast.outTask.type !== 'finalcbFirst') errors = errors.concat(validateOuputsUnique(ast.tasks));
2256
- errors = errors.concat(taskUtil.validateLocalFunctions(ast.inParams, ast.tasks, ast.locals));
2257
- errors = errors.concat(validateNoMissingNames(ast));
2258
- }
2259
- return errors;
2260
- }
2261
-
2262
- /**
2263
- @returns array of errors, could be empty
2264
- */
2265
- function validateInParams(inParams) {
2266
- if (!Array.isArray(inParams) ||
2267
- !inParams.every(function (x) { return (typeof(x) === 'string'); })) {
2268
- return [INPARAMS_ARR_STR];
2269
- }
2270
- return [];
2271
- }
2272
-
2273
- /**
2274
- @returns array of errors, could be empty
2275
- */
2276
- function validateTasks(tasks) {
2277
- if (!Array.isArray(tasks)) return [TASKS_ARR];
2278
- var errors = [];
2279
- tasks.forEach(function (t) {
2280
- errors = errors.concat(taskUtil.validate(t));
2281
- });
2282
- return errors;
2283
- }
2284
-
2285
- function validateTaskNamesUnique(tasks) {
2286
- if (!Array.isArray(tasks)) return [];
2287
- var errors = [];
2288
- var namedTasks = tasks.filter(function (t) { return (t.name); });
2289
- var names = namedTasks.map(function (t) { return t.name; });
2290
- names.reduce(function (accum, name) {
2291
- if (accum[name]) errors.push(sprintf('%s %s', NAMES_UNIQUE, name));
2292
- else accum[name] = true;
2293
- return accum;
2294
- }, {});
2295
- return errors;
2296
- }
2297
-
2298
- function validateLocals(locals) {
2299
- var errors = [];
2300
- if (locals === null) errors.push(LOCALS_NOTNULL);
2301
- return errors;
2302
- }
2303
-
2304
- function getOutputParams(taskDef) {
2305
- return array(taskDef.out); //ensure array
2306
- }
2307
-
2308
- function validateOuputsUnique(taskDefs) {
2309
- var errors = [];
2310
- taskDefs.reduce(function (accum, t) {
2311
- getOutputParams(t).forEach(function (param) {
2312
- if (accum[param] !== undefined) errors.push(sprintf('%s: %s', DUP_OUTPUTS, param));
2313
- else accum[param] = true;
2314
- });
2315
- return accum;
2316
- }, {});
2317
- return errors;
2318
- }
2319
-
2320
-
2321
- /**
2322
- validate there are no missing or mispelled param names in any task inputs
2323
- or the final task output
2324
-
2325
- @return array of errors, or empty array if none
2326
- */
2327
- function validateNoMissingNames(ast) {
2328
- var errors = [];
2329
- var names = {};
2330
- if (ast.locals) {
2331
- names = Object.keys(ast.locals).reduce(function (accum, k) { // start with locals
2332
- accum[k] = true;
2333
- return accum;
2334
- }, names);
2335
- }
2336
- ast.inParams.reduce(function (accum, p) { // add input params
2337
- accum[p] = true;
2338
- return accum;
2339
- }, names);
2340
- ast.tasks.reduce(function (accum, t) { // add task outputs
2341
- return t.out.reduce(function (innerAccum, p) {
2342
- innerAccum[p] = true;
2343
- return innerAccum;
2344
- }, accum);
2345
- }, names);
2346
-
2347
- // now we have all possible provided vars, check task inputs are accounted for
2348
- ast.tasks.reduce(function (accum, t) { // for all tasks
2349
- return t.a.reduce(function (innerAccum, p) { // for all in params, except property
2350
- if (!isLiteralOrProp(p) && !names[p]) innerAccum.push(sprintf(MISSING_INPUTS, p)); // add error if missing
2351
- return innerAccum;
2352
- }, accum);
2353
- }, errors);
2354
-
2355
- // now check the final task outputs
2356
- ast.outTask.a.reduce(function (accum, p) { // for final task out params
2357
- if (!isLiteralOrProp(p) && !names[p]) accum.push(sprintf(MISSING_INPUTS, p)); // add error if missing
2358
- return accum;
2359
- }, errors);
2360
- return errors;
2361
- }
2362
-
2363
- return validate;
2364
-
2365
- });
2366
-
2367
- /*global define:true */
2368
-
2369
-
2370
-
2371
- define('react/input-parser',['./event-manager'], function (EventManager) {
2372
-
2373
- var defaultExecOptions = {
2374
- reactExecOptions: true,
2375
- outputStyle: 'cb',
2376
- };
2377
-
2378
- var OUTPUT_STYLES = {
2379
- CALLBACK: 'cb',
2380
- NONE: 'none'
2381
- };
2382
-
2383
- function isExecOptions(x) { return (x && x.reactExecOptions); }
2384
- function execOptionsFilter(x) { return isExecOptions(x); }
2385
- function nonExecOptionsFilter(x) { return !isExecOptions(x); }
2386
- function mergeExecOptions(accum, options) {
2387
- Object.keys(options).forEach(function (k) { accum[k] = options[k]; });
2388
- return accum;
2389
- }
2390
-
2391
- function splitArgs(args, inParams, style) {
2392
- var result = { };
2393
- result.args = inParams.map(function (p) { return args.shift(); }); // take args for input params first
2394
- if (style === OUTPUT_STYLES.CALLBACK && args.length) result.cb = args.shift(); // next take the cb
2395
- result.extra = args; // these remaining were after the callback
2396
- return result;
2397
- }
2398
-
2399
- function inputParser(inputArgs, ast) {
2400
- var parsedInput = { };
2401
- var execOptionsArr = inputArgs.filter(execOptionsFilter);
2402
- execOptionsArr.unshift(defaultExecOptions);
2403
- parsedInput.options = execOptionsArr.reduce(mergeExecOptions, {});
2404
-
2405
- var args = inputArgs.filter(nonExecOptionsFilter);
2406
- var splitResult = splitArgs(args, ast.inParams, parsedInput.options.outputStyle);
2407
- parsedInput.args = splitResult.args;
2408
- parsedInput.cb = splitResult.cb;
2409
- if (splitResult.outputStyle) parsedInput.options.outputStyle = splitResult.outputStyle;
2410
- if (splitResult.extra) parsedInput.extraArgs = splitResult.extra;
2411
- EventManager.global.emit(EventManager.TYPES.EXEC_INPUT_PREPROCESS, parsedInput); // hook
2412
- return parsedInput;
2413
- }
2414
-
2415
-
2416
- inputParser.defaultExecOptions = defaultExecOptions;
2417
- return inputParser;
2418
-
2419
- });
2420
-
2421
- /*global define:true */
2422
-
2423
-
2424
-
2425
- define('react/id',[], function () {
2426
-
2427
- var startingId = 0;
2428
-
2429
- function createUniqueId() {
2430
- startingId += 1;
2431
- if (startingId === Number.MAX_VALUE) startingId = 0; // if hits this start over //TODO need something better?
2432
- return startingId;
2433
- }
2434
-
2435
- return {
2436
- createUniqueId: createUniqueId
2437
- };
2438
-
2439
- });
2440
-
2441
- /*global define:true */
2442
-
2443
-
2444
-
2445
- define('react/core',['./eventemitter', './error', './validate', './task', './status',
2446
- './vcon', './event-manager', './input-parser', './id', './sprintf'],
2447
- function (EventEmitter, error, validate, taskUtil, STATUS,
2448
- VContext, EventManager, inputParser, idGenerator, sprintf) {
2449
-
2450
- var reactOptions = {
2451
- stackTraceLimitMin: 30
2452
- };
2453
-
2454
- var reactEmitter = EventManager.global; // the top emitter
2455
-
2456
- /**
2457
- merge global react options with parsed options
2458
- */
2459
- function mergeOptions(parsedOptions) {
2460
- return Object.keys(reactOptions).reduce(function (accum, k) {
2461
- if (!accum[k]) accum[k] = reactOptions[k];
2462
- return accum;
2463
- }, parsedOptions);
2464
- }
2465
-
2466
- /**
2467
- generate a flow name when one is not provided
2468
- */
2469
- function generateFlowName() {
2470
- return sprintf('flow_%s', idGenerator.createUniqueId());
2471
- }
2472
-
2473
- /**
2474
- Creates react function which the AST can be manipulated and then
2475
- is ready to be executed. Can be used directly or a DSL can wrap this
2476
- to provide the AST.
2477
-
2478
- @example
2479
- var react = require('react');
2480
- var fn = react();
2481
- var valid2 = fn.setAndValidateAST({
2482
- name: 'optionalName',
2483
- inParams: ['a', 'b'],
2484
- tasks: [
2485
- { type: 'cb', f: multiply, a: ['a', 'b'], out: ['c'] }
2486
- ],
2487
- outTask: { a: ['c'] }
2488
- });
2489
- console.log(fn.ast); // view
2490
- fn(123, 456, cb);
2491
- */
2492
- function reactFactory() {
2493
- if (arguments.length) throw new Error('react() takes no args, check API');
2494
-
2495
- error.ensureStackTraceLimitSet(reactOptions.stackTraceLimitMin);
2496
- var flowEmitter = EventManager.create();
2497
- flowEmitter.parent = reactEmitter;
2498
-
2499
- var ast = {
2500
- name: undefined,
2501
- inParams: [],
2502
- tasks: [],
2503
- outTask: {},
2504
- locals: {}
2505
- };
2506
-
2507
- function setAndValidateAST(newAST) { //set AST then validate, ret error[]
2508
- Object.keys(newAST).forEach(function (k) { ast[k] = newAST[k]; }); // copy all properties
2509
- var errors = validate(ast);
2510
- if (!errors.length) {
2511
- if (!ast.name) ast.name = generateFlowName();
2512
- taskUtil.nameTasks(ast.tasks); //run this so names can be checked in ast
2513
- }
2514
- if (Object.freeze) { //lets freeze the AST so plugin writers don't accidentally manip the ast
2515
- Object.keys(newAST).forEach(function (k) {
2516
- if (typeof(newAST[k]) === 'object') Object.freeze(newAST[k]);
2517
- });
2518
- Object.freeze(newAST);
2519
- }
2520
- flowEmitter.emit(EventManager.TYPES.AST_DEFINED, ast);
2521
- return errors;
2522
- }
2523
-
2524
- function exec(arg1, arg2, argN, cb) { // called to execute the flow
2525
- /*jshint validthis: true */
2526
- var args = Array.prototype.slice.call(arguments);
2527
- var env = {
2528
- execId: idGenerator.createUniqueId(),
2529
- args: args,
2530
- ast: ast,
2531
- flowEmitter: flowEmitter
2532
- };
2533
- env.name = ast.name || env.execId;
2534
- flowEmitter.emit(EventManager.TYPES.EXEC_FLOW_START, env); // hook
2535
- var parsedInput = inputParser(args, ast);
2536
- var vCon = VContext.create(parsedInput.args, ast.inParams, ast.locals, this); // create var ctx with in args & locals
2537
-
2538
- env.parsedInput = parsedInput;
2539
- env.options = mergeOptions(parsedInput.options);
2540
- env.vCon = vCon;
2541
- env.taskDefs = ast.tasks.slice(); // create copy
2542
- env.outTaskDef = Object.create(ast.outTask); // create copy
2543
- reactEmitter.emit(EventManager.TYPES.EXEC_TASKS_PRECREATE, env); // hook
2544
-
2545
- var tasks = env.taskDefs.map(taskUtil.create);
2546
- var tasksByName = taskUtil.nameTasks(tasks); // map names to working tasks
2547
- var outTask = taskUtil.createOutTask(env.outTaskDef, parsedInput.cb, tasks, vCon, env.options, env);
2548
- var handleError = taskUtil.createErrorHandler(vCon, outTask);
2549
-
2550
- function contExec() {
2551
- if (!outTask.f) { return; } //stop execution, we already hit an error, f was cleared
2552
- if (outTask.isReady()) return outTask.exec(); // all tasks done, exec cb, return
2553
- taskUtil.findReadyAndExec(vCon, tasks, tasksByName, handleError, contExec, env); //exec tasks that ready to run
2554
- }
2555
-
2556
- tasks.forEach(function (t) {
2557
- t.id = idGenerator.createUniqueId();
2558
- t.env = env;
2559
- if (t.prepare) t.prepare(handleError, vCon, contExec, flowEmitter);
2560
- }); // create callbacks
2561
- contExec(); // start things off
2562
- return outTask.retValue; // could return promise
2563
- }
2564
-
2565
- var reactFn = exec; // make the exec() the function returned
2566
- reactFn.ast = ast; // put AST hanging off the fn so it can be inspected
2567
- reactFn.setAndValidateAST = setAndValidateAST; // call to set AST and then validate
2568
- reactFn.events = flowEmitter; // used to listen to execution events for this flow
2569
- return reactFn;
2570
- }
2571
-
2572
- reactFactory.options = reactOptions; // global react options
2573
- reactFactory.events = reactEmitter; // global react emitter
2574
- return reactFactory; // module returns reactFactory to create a react fn
2575
- });
2576
-
2577
- /*global define:true */
2578
-
2579
-
2580
-
2581
- define('react/parse',['./sprintf'], function (sprintf) {
2582
-
2583
- function splitTrimFilterArgs(commaSepArgs) { //parse 'one, two' into ['one', 'two']
2584
- if (!commaSepArgs) return [];
2585
- return commaSepArgs.split(',') //split on commas
2586
- .map(function (s) { return s.trim(); }) //trim
2587
- .filter(function (s) { return (s); }); //filter out empty strings
2588
- }
2589
-
2590
- /**
2591
- @param patternFn regex + fn or splitStr + fn
2592
- */
2593
- function parseReduce(accum, patternFn) {
2594
- if (typeof(accum) !== 'string') return accum; // already matched
2595
- var m = (patternFn.regex) ? patternFn.regex.exec(accum) : accum.split(patternFn.splitStr);
2596
- if (m) return patternFn.fn(m, accum); // pass in matches and origStr, return result obj
2597
- return accum; // no match, return str, will try next matcher
2598
- }
2599
-
2600
- function parseStr(str, parseMatchers, errStr) {
2601
- var result = parseMatchers.reduce(parseReduce, str);
2602
- if (typeof(result) !== 'string') { // matched
2603
- return result;
2604
- } else { // no match
2605
- throw new Error(sprintf(errStr, str));
2606
- }
2607
- }
2608
-
2609
- return {
2610
- splitTrimFilterArgs: splitTrimFilterArgs,
2611
- parseStr: parseStr
2612
- };
2613
-
2614
- });
2615
-
2616
-
2617
- /*global define:true */
2618
-
2619
-
2620
-
2621
- define('react/dsl',['./sprintf', './core', './parse', './task'],
2622
- function (sprintf, core, parse, taskUtil) {
2623
- /*jshint regexp: false */
2624
-
2625
- var MISSING_NAME = 'first flow parameter should be the flow name, but found in/out def: %s';
2626
- var INOUT_PARAMS_NO_MATCH = 'params in wrong format, wanted "foo, bar, cb -> err, baz" - found: %s';
2627
- var MISSING_ERR = 'callback specified, but first out param was not "err", use for clarity. Found in/out def: %s';
2628
- 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';
2629
- var EXTRA_TASKARG = 'extra unmatched task arg: %s';
2630
-
2631
- var INOUT_RE = /\->/; // used to detect missing name, in/out as first arg
2632
- var CB_NAMES_RE = /^cb|callback$/i; //cb, Cb, CB, callback, Callback
2633
- var ERR_NAMES_RE = /^err$/i; // err, ERR, Err, ...
2634
-
2635
- function filterOutTrailingCbParam(args) { // if has trailing cb | callback param, filter it out
2636
- if (args.length && args[args.length - 1].match(CB_NAMES_RE)) args.pop();
2637
- return args;
2638
- }
2639
-
2640
- function filterOutLeadingErrParam(args) { // if leading err param, filter it out
2641
- if (args.length && args[0].match(ERR_NAMES_RE)) args.shift();
2642
- return args;
2643
- }
2644
-
2645
- var inOutDefParse = {
2646
- splitStr: '->',
2647
- fn: function (m, origStr) {
2648
- var inParams = parse.splitTrimFilterArgs(m[0]);
2649
- var lastParam = inParams[inParams.length - 1];
2650
- var type = (lastParam && CB_NAMES_RE.test(lastParam)) ? 'cb' : 'ret';
2651
- var outParams = parse.splitTrimFilterArgs(m[1]);
2652
- var firstOutParam = outParams[0];
2653
- if (type === 'cb' && (!firstOutParam || !ERR_NAMES_RE.test(firstOutParam))) {
2654
- throw new Error(sprintf(MISSING_ERR, origStr)); // found cb, but no err param
2655
- } else if (type === 'ret' && firstOutParam && ERR_NAMES_RE.test(firstOutParam)) {
2656
- throw new Error(sprintf(MISSING_CB, origStr)); // found err but not cb param
2657
- }
2658
- return {
2659
- type: type,
2660
- inDef: filterOutTrailingCbParam(inParams),
2661
- outDef: filterOutLeadingErrParam(outParams)
2662
- };
2663
- }
2664
- };
2665
-
2666
- function parseInOutParams(str) {
2667
- var objDef = parse.parseStr(str, [inOutDefParse], INOUT_PARAMS_NO_MATCH);
2668
- objDef.inDef = filterOutTrailingCbParam(objDef.inDef);
2669
- return objDef;
2670
- }
2671
-
2672
- function parseTasks(arr) {
2673
- var tasks = [];
2674
- var fn, obj, result;
2675
- while (arr.length >= 2) {
2676
- obj = {};
2677
- fn = arr.shift();
2678
- result = parseInOutParams(arr.shift());
2679
- if (typeof(arr[0]) === 'object') obj = arr.shift(); // has options, use as obj
2680
- obj.f = fn;
2681
- obj.a = result.inDef;
2682
- var type = result.type;
2683
- obj.out = result.outDef;
2684
- obj.type = type;
2685
- tasks.push(obj);
2686
- }
2687
- if (arr.length) throw new Error(sprintf(EXTRA_TASKARG, arr[0]));
2688
- return tasks;
2689
- }
2690
-
2691
- /**
2692
- Parse the variable arguments into in/out params, options, tasks
2693
- */
2694
- function parseVargs(vargs) {
2695
- var inOutParamStr = vargs.shift() || '';
2696
- // if next arg is object, shift it off as options
2697
- var options = (vargs.length && typeof(vargs[0]) === 'object') ? vargs.shift() : { };
2698
- var taskDefArr = vargs; // rest are for the tasks
2699
- var defObj = {
2700
- inOutParamStr: inOutParamStr,
2701
- taskDefArr: taskDefArr,
2702
- options: options
2703
- };
2704
- return defObj;
2705
- }
2706
-
2707
-
2708
- function dslDefine(name, arg1, arg2, argN) {
2709
- var reactFn = core();
2710
- if (name && INOUT_RE.test(name)) throw new Error(sprintf(MISSING_NAME, name));
2711
- var defObj = parseVargs(Array.prototype.slice.call(arguments, 1)); // name, already used
2712
- var inOutDef = parseInOutParams(defObj.inOutParamStr);
2713
- var ast = {
2714
- name: name,
2715
- inParams: inOutDef.inDef,
2716
- tasks: parseTasks(defObj.taskDefArr),
2717
- outTask: { a: inOutDef.outDef }
2718
- };
2719
- if (defObj.options) Object.keys(defObj.options).forEach(function (k) { ast[k] = defObj.options[k]; });
2720
- var errors = reactFn.setAndValidateAST(ast);
2721
- if (errors.length) {
2722
- var errorStr = errors.join('\n');
2723
- throw new Error(errorStr);
2724
- }
2725
- return reactFn;
2726
- }
2727
-
2728
- function selectFirst(name, arg1, arg2, argN) {
2729
- var reactFn = core();
2730
- var defObj = parseVargs(Array.prototype.slice.call(arguments, 1)); // name, already used
2731
- var inOutDef = parseInOutParams(defObj.inOutParamStr);
2732
- var tasks = taskUtil.serializeTasks(parseTasks(defObj.taskDefArr));
2733
- var ast = {
2734
- name: name,
2735
- inParams: inOutDef.inDef,
2736
- tasks: tasks,
2737
- outTask: { type: 'finalcbFirst', a: inOutDef.outDef },
2738
- };
2739
- if (defObj.options) Object.keys(defObj.options).forEach(function (k) { ast[k] = defObj.options[k]; });
2740
- var errors = reactFn.setAndValidateAST(ast);
2741
- if (errors.length) {
2742
- var errorStr = errors.join('\n');
2743
- throw new Error(errorStr);
2744
- }
2745
- return reactFn;
2746
- }
2747
-
2748
- dslDefine.selectFirst = selectFirst;
2749
- return dslDefine;
2750
-
2751
- });
2752
-
2753
- /*global define:true */
2754
-
2755
-
2756
-
2757
- define('react/track-tasks',[], function () {
2758
-
2759
- /**
2760
- Track the tasks, start, complete, args, results, elapsed time
2761
- Emits events that can be monitored
2762
-
2763
- - track start and complete
2764
- - record args each task was called with
2765
- - record results at completion
2766
- - record start, end, and calc elapsed time
2767
- - emits flow.begin with flowEnv
2768
- - emits task.begin with task
2769
- - emits task.complete with task
2770
- - emits flow complete with flowEnv
2771
- - emits flow errored with flowEnv
2772
-
2773
- @example
2774
- var react = require('react');
2775
- react.trackTasks(); // enable task and flow tracking
2776
- */
2777
-
2778
-
2779
- var trackingTasks = false;
2780
-
2781
- function trackTasks(react) {
2782
- if (trackingTasks) return; // already tracking
2783
- trackingTasks = true;
2784
-
2785
- react.events.on(react.events.TYPES.EXEC_FLOW_START, function (env) {
2786
- env.startTime = Date.now();
2787
- env.flowEmitter.emit(react.events.TYPES.FLOW_BEGIN, env); //fire public ev
2788
- });
2789
-
2790
- react.events.on(react.events.TYPES.EXEC_TASK_START, function (task) {
2791
- task.startTime = Date.now();
2792
- task.env.flowEmitter.emit(react.events.TYPES.TASK_BEGIN, task); //fire public ev
2793
- });
2794
-
2795
- react.events.on(react.events.TYPES.EXEC_TASK_COMPLETE, function (task) {
2796
- task.endTime = Date.now();
2797
- task.elapsedTime = task.endTime - task.startTime;
2798
- task.env.flowEmitter.emit(react.events.TYPES.TASK_COMPLETE, task); // fire public ev
2799
- });
2800
-
2801
- react.events.on(react.events.TYPES.EXEC_TASK_ERRORED, function (task) {
2802
- task.endTime = Date.now();
2803
- task.elapsedTime = task.endTime - task.startTime;
2804
- task.env.flowEmitter.emit(react.events.TYPES.TASK_ERRORED, task); // fire public ev
2805
- });
2806
-
2807
- react.events.on(react.events.TYPES.EXEC_FLOW_COMPLETE, function (env) {
2808
- env.endTime = Date.now();
2809
- env.elapsedTime = env.endTime - env.startTime;
2810
- env.flowEmitter.emit(react.events.TYPES.FLOW_COMPLETE, env); //fire public ev
2811
- });
2812
-
2813
- react.events.on(react.events.TYPES.EXEC_FLOW_ERRORED, function (env) {
2814
- env.endTime = Date.now();
2815
- env.elapsedTime = env.endTime - env.startTime;
2816
- env.flowEmitter.emit(react.events.TYPES.FLOW_ERRORED, env); //fire public ev
2817
- });
2818
-
2819
- }
2820
-
2821
- return trackTasks;
2822
-
2823
- });
2824
-
2825
- /*global define:true */
2826
-
2827
-
2828
-
2829
- define('react/log-events',['util'], function (util) { // TODO replace util.inspect with something portable to browser
2830
-
2831
- var logEventsMod = { };
2832
-
2833
- /**
2834
- Log events to console.error
2835
-
2836
- @example
2837
- var react = require('react');
2838
- react.logEvents(); // log all task and flow events on all react functions
2839
- react.logEvents('task.*'); // log all task events on all react functions
2840
- react.logEvents(flowFn); // log all task and flow events on flowFn only
2841
- react.logEvents(flowFn, 'flow.*'); // log all flow events on flowFn only
2842
- */
2843
-
2844
- var ALL_FLOW_EVENTS = 'flow.*';
2845
- var ALL_TASK_EVENTS = 'task.*';
2846
- var FLOW_RE = /^flow\./;
2847
-
2848
- function flowLog(obj) {
2849
- /*jshint validthis: true */
2850
- var time = new Date();
2851
- time.setTime(obj.startTime);
2852
- var argsNoCb = obj.args.filter(function (a) { return (typeof(a) !== 'function'); });
2853
- var eventTimeStr = time.toISOString();
2854
- if (this.event === 'flow.complete') {
2855
- var env = obj;
2856
- console.error('%s: %s \tmsecs: %s \n\targs: %s \n\tresults: %s\n',
2857
- this.event, env.name, env.elapsedTime, util.inspect(argsNoCb), util.inspect(env.results));
2858
- } else {
2859
- var name = obj.name;
2860
- var args = obj.args;
2861
- console.error('%s: %s \n\targs: %s\n', this.event, name, util.inspect(argsNoCb));
2862
- }
2863
- }
2864
-
2865
- function taskLog(obj) {
2866
- /*jshint validthis: true */
2867
- var time = new Date();
2868
- time.setTime(obj.startTime);
2869
- var argsNoCb = obj.args.filter(function (a) { return (typeof(a) !== 'function'); });
2870
- var eventTimeStr = time.toISOString();
2871
- if (this.event === 'task.complete') {
2872
- var task = obj;
2873
- console.error('%s: %s:%s \tmsecs: %s \n\targs: %s \n\tresults: %s\n',
2874
- this.event, task.env.name, task.name, task.elapsedTime, util.inspect(argsNoCb), util.inspect(task.results));
2875
- } else {
2876
- var name = obj.name;
2877
- var args = obj.args;
2878
- console.error('%s: %s:%s \n\targs: %s\n', this.event, obj.env.name, obj.name, util.inspect(argsNoCb));
2879
- }
2880
-
2881
- }
2882
-
2883
- /**
2884
- Log flow and task events for a flowFn or all of react.
2885
- If called multiple times, remove previous listener (if any) before
2886
- adding.
2887
-
2888
- @example
2889
- var react = require('react');
2890
- react.logEvents(flowFn, eventWildcard); //log events on flowfn matching wildcard
2891
-
2892
- @param flowFn Flow function or global react object
2893
- @param eventWildcard wildcarded event type, if not provided use flow.* and task.*
2894
- */
2895
- function logEvents(flowFn, eventWildcard) {
2896
- if (!flowFn) throw new Error('flowFn is required');
2897
- if (!flowFn.events._loggingEvents) flowFn.events._loggingEvents = [];
2898
- if (eventWildcard === false) { // turn off logging
2899
- flowFn.events._loggingEvents.forEach(function (evt) {
2900
- flowFn.events.removeAllListeners(evt);
2901
- });
2902
- flowFn.events._loggingEvents.length = 0; // clear
2903
- } else if (eventWildcard && eventWildcard !== '*') {
2904
- var logFn = (FLOW_RE.test(eventWildcard)) ? flowLog : taskLog;
2905
- flowFn.events.removeListener(eventWildcard, logFn);
2906
- flowFn.events.on(eventWildcard, logFn);
2907
- flowFn.events._loggingEvents.push(eventWildcard);
2908
- } else { // none provided, use flow.* and task.*
2909
- //output events as tasks start and complete
2910
- flowFn.events.removeListener(ALL_FLOW_EVENTS, flowLog);
2911
- flowFn.events.on(ALL_FLOW_EVENTS, flowLog);
2912
- flowFn.events._loggingEvents.push(ALL_FLOW_EVENTS);
2913
- flowFn.events.removeListener(ALL_TASK_EVENTS, taskLog);
2914
- flowFn.events.on(ALL_TASK_EVENTS, taskLog);
2915
- flowFn.events._loggingEvents.push(ALL_TASK_EVENTS);
2916
- }
2917
- }
2918
-
2919
- logEventsMod.logEvents = logEvents;
2920
- return logEventsMod;
2921
-
2922
- });
2923
-
2924
- /*global define:true */
2925
-
2926
-
2927
-
2928
- define('react/promise-resolve',[], function () {
2929
-
2930
- /**
2931
- Auto resolve promises passed in as arguments to the flow
2932
-
2933
- - Detects promises by checking for .then()
2934
- - Create promise name for param (param__promise)
2935
- - moves existing vCon promise into the param__promise
2936
- - creates WhenTask which resolves param__promise into param
2937
- */
2938
-
2939
-
2940
- var PROMISE_SUFFIX = '__promise'; // added to param names that are promises
2941
-
2942
- var resolvingPromises = false;
2943
-
2944
- function resolvePromises(react) {
2945
- if (resolvingPromises) return; // already resolving
2946
- resolvingPromises = true;
2947
-
2948
- react.events.on(react.events.TYPES.EXEC_TASKS_PRECREATE, function (env) {
2949
- var vConValues = env.vCon.values;
2950
- var promiseParams = env.ast.inParams.filter(function (p) {
2951
- var value = vConValues[p];
2952
- return (value && typeof(value.then) === 'function');
2953
- });
2954
- promiseParams.forEach(function (p) {
2955
- var promiseName = p + PROMISE_SUFFIX;
2956
- vConValues[promiseName] = vConValues[p];
2957
- vConValues[p] = undefined;
2958
- env.taskDefs.push({
2959
- type: 'when',
2960
- a: [promiseName],
2961
- out: [p]
2962
- });
2963
- });
2964
- });
2965
-
2966
- }
2967
-
2968
- return resolvePromises;
2969
-
2970
- });
2971
-
2972
- /*global define:true */
2973
-
2974
-
2975
-
2976
- define('react/event-collector',[], function () {
2977
-
2978
- /**
2979
- create an instance of the event collector
2980
- */
2981
- function instantiate(react) {
2982
- react.trackTasks(); // enable task tracking
2983
-
2984
- var AST_EVENTS_RE = /^ast\./;
2985
- var TASK_EVENTS_RE = /^task\./;
2986
- var FLOW_EVENTS_RE = /^flow\./;
2987
-
2988
- /**
2989
- Accumulator to make it easy to capture events
2990
-
2991
- @example
2992
- var react = require('react');
2993
- var collector = react.createEventCollector();
2994
- collector.capture(); // capture all flow and task events for all react flows
2995
- collector.capture('flow.*'); // capture all flow events for all react flows
2996
- collector.capture(flowFn, 'task.*'); // capture task events on a flow
2997
- collector.capture(flowFn, 'flow.*'); // add capture flow events on a flow
2998
- var events = collector.list(); // retrieve the list of events
2999
- collector.clear(); // clear the list of events;
3000
- */
3001
- function EventCollector() {
3002
- this.events = [];
3003
- }
3004
-
3005
- /**
3006
- register listener to capture events for a specific flow
3007
- @param flowFn the react flow function or can pass global react
3008
- @param eventId event id or wildcarded id
3009
- */
3010
- EventCollector.prototype.capture = function (flowFn, eventId) {
3011
- /*jshint validthis: true */
3012
- if (!eventId && typeof(flowFn) === 'string') { // only eventId provided
3013
- eventId = flowFn;
3014
- flowFn = react; // global react
3015
- } else if (!flowFn) flowFn = react; // global react
3016
- if (!eventId) eventId = '*'; // default to all
3017
- var emitter = flowFn.events;
3018
- var self = this;
3019
- function accumEvents(obj) {
3020
- var eventObject = {
3021
- event: this.event,
3022
- time: Date.now()
3023
- };
3024
- if (FLOW_EVENTS_RE.test(this.event)) {
3025
- eventObject.env = obj;
3026
- } else if (TASK_EVENTS_RE.test(this.event)) {
3027
- eventObject.task = obj;
3028
- } else if (AST_EVENTS_RE.test(this.event)) {
3029
- eventObject.ast = obj;
3030
- }
3031
- self.events.push(eventObject);
3032
- }
3033
- emitter.on(eventId, accumEvents);
3034
- };
3035
-
3036
- EventCollector.prototype.list = function () {
3037
- return this.events;
3038
- };
3039
-
3040
- EventCollector.prototype.clear = function () {
3041
- this.events = []; // clear
3042
- };
3043
-
3044
- return new EventCollector();
3045
- }
3046
-
3047
- return instantiate; // return the factory for creating EventCollector
3048
-
3049
- });
3050
-
3051
- /*global define:true */
3052
-
3053
-
3054
-
3055
- define('react/react',['./core', './dsl', './track-tasks', './log-events', './promise-resolve', './event-collector'],
3056
- function (core, dsl, trackTasksFn, logEventsMod, resolvePromisesFn, eventCollectorFactory) {
3057
-
3058
- var react = dsl; // core + default dsl
3059
-
3060
- /**
3061
- Enable detection of promises and resolution
3062
- */
3063
- function resolvePromises() {
3064
- resolvePromisesFn(react);
3065
- }
3066
-
3067
- /**
3068
- Enable tracking of tasks and flow execution, emitting events and
3069
- tracking start, end, elapsed time
3070
- */
3071
- function trackTasks() {
3072
- trackTasksFn(react);
3073
- }
3074
-
3075
- /**
3076
- If called, load the built-in plugin for log events and invoke
3077
-
3078
- @param flowFn [function] if not provided uses global react
3079
- @param eventWildcard [string] pattern to log events for
3080
- */
3081
- function logEvents(flowFn, eventWildcard) {
3082
- if (typeof(flowFn) !== 'function') { // only wildcard provided
3083
- eventWildcard = flowFn;
3084
- flowFn = undefined;
3085
- }
3086
- if (!flowFn) flowFn = react; // use global
3087
- trackTasks();
3088
- return logEventsMod.logEvents(flowFn, eventWildcard);
3089
- }
3090
-
3091
- /**
3092
- Instantiate an event collector
3093
- */
3094
- function createEventCollector() {
3095
- return eventCollectorFactory(react);
3096
- }
3097
-
3098
- react.options = core.options; // global react options
3099
- react.events = core.events; // global react event emitter
3100
- react.logEvents = logEvents; // enable event logging
3101
- react.resolvePromises = resolvePromises; // enable promise resolution
3102
- react.trackTasks = trackTasks; // enable tracking of tasks
3103
- react.createEventCollector = createEventCollector; // create instance of EventCollector
3104
- return react;
3105
-
3106
- });
3107
- define('react', ['react/react'], function (main) { return main; });