@angular/core 9.0.0-rc.7 → 9.0.1

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 (222) hide show
  1. package/bundles/core-testing.umd.js +18 -16
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +7 -7
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +6386 -6384
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +182 -175
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +726 -734
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.externs.js +5 -5
  12. package/esm2015/core.js +17 -15
  13. package/esm2015/index.js +2 -2
  14. package/esm2015/public_api.js +2 -2
  15. package/esm2015/src/application_init.js +10 -2
  16. package/esm2015/src/application_module.js +6 -3
  17. package/esm2015/src/application_ref.js +7 -7
  18. package/esm2015/src/core.js +4 -4
  19. package/esm2015/src/core_private_export.js +7 -7
  20. package/esm2015/src/core_render3_private_export.js +2 -2
  21. package/esm2015/src/debug/debug_node.js +55 -16
  22. package/esm2015/src/di/injectable.js +1 -13
  23. package/esm2015/src/di/injector.js +12 -10
  24. package/esm2015/src/di/interface/provider.js +1 -1
  25. package/esm2015/src/di/r3_injector.js +5 -4
  26. package/esm2015/src/i18n/locale_data_api.js +22 -6
  27. package/esm2015/src/i18n/locale_en.js +16 -5
  28. package/esm2015/src/i18n/localization.js +7 -1
  29. package/esm2015/src/i18n/tokens.js +41 -1
  30. package/esm2015/src/interface/type.js +1 -1
  31. package/esm2015/src/metadata/ng_module.js +1 -1
  32. package/esm2015/src/render/api.js +4 -1
  33. package/esm2015/src/render3/assert.js +9 -1
  34. package/esm2015/src/render3/bindings.js +16 -5
  35. package/esm2015/src/render3/component.js +54 -25
  36. package/esm2015/src/render3/component_ref.js +28 -18
  37. package/esm2015/src/render3/definition.js +3 -1
  38. package/esm2015/src/render3/di.js +3 -4
  39. package/esm2015/src/render3/di_setup.js +5 -7
  40. package/esm2015/src/render3/errors.js +3 -1
  41. package/esm2015/src/render3/features/inherit_definition_feature.js +89 -52
  42. package/esm2015/src/render3/features/ng_onchanges_feature.js +2 -2
  43. package/esm2015/src/render3/global_utils_api.js +3 -3
  44. package/esm2015/src/render3/i18n.js +60 -56
  45. package/esm2015/src/render3/index.js +2 -2
  46. package/esm2015/src/render3/instructions/advance.js +10 -11
  47. package/esm2015/src/render3/instructions/all.js +4 -5
  48. package/esm2015/src/render3/instructions/attribute.js +12 -5
  49. package/esm2015/src/render3/instructions/attribute_interpolation.js +66 -14
  50. package/esm2015/src/render3/instructions/change_detection.js +8 -23
  51. package/esm2015/src/render3/instructions/class_map_interpolation.js +13 -12
  52. package/esm2015/src/render3/instructions/container.js +15 -12
  53. package/esm2015/src/render3/instructions/element.js +45 -132
  54. package/esm2015/src/render3/instructions/element_container.js +8 -10
  55. package/esm2015/src/render3/instructions/embedded_view.js +7 -7
  56. package/esm2015/src/render3/instructions/host_property.js +10 -7
  57. package/esm2015/src/render3/instructions/listener.js +18 -16
  58. package/esm2015/src/render3/instructions/lview_debug.js +160 -23
  59. package/esm2015/src/render3/instructions/projection.js +7 -5
  60. package/esm2015/src/render3/instructions/property.js +27 -6
  61. package/esm2015/src/render3/instructions/property_interpolation.js +42 -23
  62. package/esm2015/src/render3/instructions/shared.js +279 -244
  63. package/esm2015/src/render3/instructions/storage.js +6 -8
  64. package/esm2015/src/render3/instructions/style_prop_interpolation.js +12 -12
  65. package/esm2015/src/render3/instructions/styling.js +731 -475
  66. package/esm2015/src/render3/instructions/text.js +5 -5
  67. package/esm2015/src/render3/interfaces/definition.js +41 -1
  68. package/esm2015/src/render3/interfaces/node.js +160 -115
  69. package/esm2015/src/render3/interfaces/styling.js +183 -375
  70. package/esm2015/src/render3/interfaces/view.js +10 -2
  71. package/esm2015/src/render3/jit/environment.js +1 -3
  72. package/esm2015/src/render3/namespaces.js +17 -0
  73. package/esm2015/src/render3/node_manipulation.js +177 -57
  74. package/esm2015/src/render3/node_selector_matcher.js +128 -24
  75. package/esm2015/src/render3/node_util.js +12 -7
  76. package/esm2015/src/render3/pipe.js +10 -14
  77. package/esm2015/src/render3/pure_function.js +107 -42
  78. package/esm2015/src/render3/query.js +32 -26
  79. package/esm2015/src/render3/state.js +57 -185
  80. package/esm2015/src/render3/styling/class_differ.js +47 -0
  81. package/esm2015/src/render3/styling/static_styling.js +54 -0
  82. package/esm2015/src/render3/styling/style_binding_list.js +437 -0
  83. package/esm2015/src/render3/styling/styling_parser.js +336 -0
  84. package/esm2015/src/render3/tokens.js +2 -2
  85. package/esm2015/src/render3/util/attrs_utils.js +125 -2
  86. package/esm2015/src/render3/util/change_detection_utils.js +33 -0
  87. package/esm2015/src/render3/util/discovery_utils.js +146 -119
  88. package/esm2015/src/render3/util/global_utils.js +5 -5
  89. package/esm2015/src/render3/util/view_utils.js +6 -6
  90. package/esm2015/src/render3/view_engine_compatibility.js +16 -17
  91. package/esm2015/src/render3/view_ref.js +16 -13
  92. package/esm2015/src/sanitization/bypass.js +1 -1
  93. package/esm2015/src/sanitization/sanitization.js +20 -5
  94. package/esm2015/src/util/array_utils.js +240 -1
  95. package/esm2015/src/util/assert.js +37 -21
  96. package/esm2015/src/util/char_code.js +8 -0
  97. package/esm2015/src/util/iterable.js +4 -1
  98. package/esm2015/src/util/ng_dev_mode.js +1 -12
  99. package/esm2015/src/util/stringify.js +14 -1
  100. package/esm2015/src/version.js +1 -1
  101. package/esm2015/src/view/services.js +1 -1
  102. package/esm2015/testing/src/r3_test_bed.js +5 -1
  103. package/esm2015/testing/src/r3_test_bed_compiler.js +5 -13
  104. package/esm2015/testing/src/styling.js +103 -0
  105. package/esm5/core.js +17 -15
  106. package/esm5/src/application_init.js +10 -2
  107. package/esm5/src/application_module.js +6 -3
  108. package/esm5/src/application_ref.js +6 -6
  109. package/esm5/src/core.js +2 -2
  110. package/esm5/src/core_private_export.js +7 -7
  111. package/esm5/src/core_render3_private_export.js +2 -2
  112. package/esm5/src/debug/debug_node.js +39 -14
  113. package/esm5/src/di/injectable.js +1 -1
  114. package/esm5/src/di/injector.js +12 -12
  115. package/esm5/src/di/interface/provider.js +1 -1
  116. package/esm5/src/di/r3_injector.js +5 -4
  117. package/esm5/src/i18n/locale_data_api.js +20 -6
  118. package/esm5/src/i18n/locale_en.js +16 -5
  119. package/esm5/src/i18n/localization.js +6 -1
  120. package/esm5/src/i18n/tokens.js +40 -1
  121. package/esm5/src/interface/type.js +1 -1
  122. package/esm5/src/metadata/ng_module.js +1 -1
  123. package/esm5/src/render/api.js +4 -1
  124. package/esm5/src/render3/assert.js +4 -1
  125. package/esm5/src/render3/bindings.js +19 -2
  126. package/esm5/src/render3/component.js +47 -22
  127. package/esm5/src/render3/component_ref.js +20 -17
  128. package/esm5/src/render3/definition.js +3 -1
  129. package/esm5/src/render3/di.js +3 -4
  130. package/esm5/src/render3/di_setup.js +4 -5
  131. package/esm5/src/render3/errors.js +3 -1
  132. package/esm5/src/render3/features/inherit_definition_feature.js +74 -42
  133. package/esm5/src/render3/features/ng_onchanges_feature.js +1 -1
  134. package/esm5/src/render3/global_utils_api.js +3 -3
  135. package/esm5/src/render3/i18n.js +51 -51
  136. package/esm5/src/render3/index.js +2 -2
  137. package/esm5/src/render3/instructions/advance.js +9 -11
  138. package/esm5/src/render3/instructions/all.js +1 -2
  139. package/esm5/src/render3/instructions/attribute.js +9 -5
  140. package/esm5/src/render3/instructions/attribute_interpolation.js +49 -13
  141. package/esm5/src/render3/instructions/change_detection.js +8 -21
  142. package/esm5/src/render3/instructions/class_map_interpolation.js +13 -12
  143. package/esm5/src/render3/instructions/container.js +13 -12
  144. package/esm5/src/render3/instructions/element.js +41 -113
  145. package/esm5/src/render3/instructions/element_container.js +8 -9
  146. package/esm5/src/render3/instructions/embedded_view.js +7 -7
  147. package/esm5/src/render3/instructions/host_property.js +8 -7
  148. package/esm5/src/render3/instructions/listener.js +13 -13
  149. package/esm5/src/render3/instructions/lview_debug.js +56 -15
  150. package/esm5/src/render3/instructions/projection.js +6 -5
  151. package/esm5/src/render3/instructions/property.js +17 -6
  152. package/esm5/src/render3/instructions/property_interpolation.js +32 -24
  153. package/esm5/src/render3/instructions/shared.js +258 -210
  154. package/esm5/src/render3/instructions/storage.js +4 -6
  155. package/esm5/src/render3/instructions/style_prop_interpolation.js +12 -12
  156. package/esm5/src/render3/instructions/styling.js +685 -367
  157. package/esm5/src/render3/instructions/text.js +5 -5
  158. package/esm5/src/render3/interfaces/definition.js +1 -1
  159. package/esm5/src/render3/interfaces/node.js +49 -1
  160. package/esm5/src/render3/interfaces/styling.js +57 -1
  161. package/esm5/src/render3/interfaces/view.js +1 -1
  162. package/esm5/src/render3/jit/environment.js +1 -3
  163. package/esm5/src/render3/namespaces.js +10 -0
  164. package/esm5/src/render3/node_manipulation.js +167 -54
  165. package/esm5/src/render3/node_selector_matcher.js +113 -20
  166. package/esm5/src/render3/node_util.js +12 -7
  167. package/esm5/src/render3/pipe.js +10 -14
  168. package/esm5/src/render3/pure_function.js +103 -33
  169. package/esm5/src/render3/query.js +25 -24
  170. package/esm5/src/render3/state.js +37 -133
  171. package/esm5/src/render3/styling/class_differ.js +39 -0
  172. package/esm5/src/render3/styling/static_styling.js +42 -0
  173. package/esm5/src/render3/styling/style_binding_list.js +411 -0
  174. package/esm5/src/render3/styling/styling_parser.js +265 -0
  175. package/esm5/src/render3/tokens.js +2 -2
  176. package/esm5/src/render3/util/attrs_utils.js +117 -2
  177. package/esm5/src/render3/util/change_detection_utils.js +23 -0
  178. package/esm5/src/render3/util/discovery_utils.js +115 -99
  179. package/esm5/src/render3/util/global_utils.js +5 -5
  180. package/esm5/src/render3/util/view_utils.js +5 -5
  181. package/esm5/src/render3/view_engine_compatibility.js +37 -39
  182. package/esm5/src/render3/view_ref.js +14 -13
  183. package/esm5/src/sanitization/bypass.js +1 -1
  184. package/esm5/src/sanitization/sanitization.js +16 -5
  185. package/esm5/src/util/array_utils.js +240 -1
  186. package/esm5/src/util/assert.js +37 -21
  187. package/esm5/src/util/char_code.js +8 -0
  188. package/esm5/src/util/iterable.js +4 -1
  189. package/esm5/src/util/ng_dev_mode.js +1 -12
  190. package/esm5/src/util/stringify.js +14 -1
  191. package/esm5/src/version.js +1 -1
  192. package/esm5/src/view/services.js +1 -1
  193. package/esm5/testing/src/r3_test_bed.js +9 -1
  194. package/esm5/testing/src/r3_test_bed_compiler.js +9 -15
  195. package/esm5/testing/src/styling.js +82 -0
  196. package/fesm2015/core.js +6431 -7075
  197. package/fesm2015/core.js.map +1 -1
  198. package/fesm2015/testing.js +10 -14
  199. package/fesm2015/testing.js.map +1 -1
  200. package/fesm5/core.js +6354 -6361
  201. package/fesm5/core.js.map +1 -1
  202. package/fesm5/testing.js +18 -16
  203. package/fesm5/testing.js.map +1 -1
  204. package/package.json +1 -1
  205. package/src/r3_symbols.d.ts +46 -23
  206. package/testing/testing.d.ts +3 -5
  207. package/testing/testing.metadata.json +1 -1
  208. package/testing.d.ts +2 -2
  209. package/esm2015/global.js +0 -7
  210. package/esm2015/src/render3/instructions/alloc_host_vars.js +0 -80
  211. package/esm2015/src/render3/styling/bindings.js +0 -1248
  212. package/esm2015/src/render3/styling/map_based_bindings.js +0 -384
  213. package/esm2015/src/render3/styling/state.js +0 -135
  214. package/esm2015/src/render3/styling/styling_debug.js +0 -655
  215. package/esm2015/src/render3/util/styling_utils.js +0 -625
  216. package/esm5/global.js +0 -9
  217. package/esm5/src/render3/instructions/alloc_host_vars.js +0 -62
  218. package/esm5/src/render3/styling/bindings.js +0 -949
  219. package/esm5/src/render3/styling/map_based_bindings.js +0 -310
  220. package/esm5/src/render3/styling/state.js +0 -56
  221. package/esm5/src/render3/styling/styling_debug.js +0 -315
  222. package/esm5/src/render3/util/styling_utils.js +0 -378
@@ -10,9 +10,10 @@
10
10
  * Use of this source code is governed by an MIT-style license that can be
11
11
  * found in the LICENSE file at https://angular.io/license
12
12
  */
13
- import { assertDefined, assertEqual } from '../util/assert';
13
+ import { assertDefined } from '../util/assert';
14
14
  import { assertLViewOrUndefined } from './assert';
15
15
  import { CONTEXT, DECLARATION_VIEW, TVIEW } from './interfaces/view';
16
+ import { MATH_ML_NAMESPACE, SVG_NAMESPACE } from './namespaces';
16
17
  /**
17
18
  *
18
19
  * @record
@@ -41,10 +42,18 @@ if (false) {
41
42
  * @type {?}
42
43
  */
43
44
  LFrame.prototype.lView;
45
+ /**
46
+ * Current `TView` associated with the `LFrame.lView`.
47
+ *
48
+ * One can get `TView` from `lFrame[TVIEW]` however because it is so common it makes sense to
49
+ * store it in `LFrame` for perf reasons.
50
+ * @type {?}
51
+ */
52
+ LFrame.prototype.tView;
44
53
  /**
45
54
  * Used to set the parent property when nodes are created and track query results.
46
55
  *
47
- * This is used in conjection with `isParent`.
56
+ * This is used in conjunction with `isParent`.
48
57
  * @type {?}
49
58
  */
50
59
  LFrame.prototype.previousOrParentTNode;
@@ -93,20 +102,6 @@ if (false) {
93
102
  * @type {?}
94
103
  */
95
104
  LFrame.prototype.currentSanitizer;
96
- /**
97
- * Used when processing host bindings.
98
- * @type {?}
99
- */
100
- LFrame.prototype.currentDirectiveDef;
101
- /**
102
- * Used as the starting directive id value.
103
- *
104
- * All subsequent directives are incremented from this value onwards.
105
- * The reason why this value is `1` instead of `0` is because the `0`
106
- * value is reserved for the template.
107
- * @type {?}
108
- */
109
- LFrame.prototype.activeDirectiveId;
110
105
  /**
111
106
  * The root index from which pure function instructions should calculate their binding
112
107
  * indices. In component views, this is TView.bindingStartIndex. In a host binding
@@ -120,6 +115,13 @@ if (false) {
120
115
  * @type {?}
121
116
  */
122
117
  LFrame.prototype.currentQueryIndex;
118
+ /**
119
+ * When host binding is executing this points to the directive index.
120
+ * `TView.data[currentDirectiveIndex]` is `DirectiveDef`
121
+ * `LView[currentDirectiveIndex]` is directive instance.
122
+ * @type {?}
123
+ */
124
+ LFrame.prototype.currentDirectiveIndex;
123
125
  }
124
126
  /**
125
127
  * All implicit instruction state is stored here.
@@ -167,19 +169,11 @@ if (false) {
167
169
  * @type {?}
168
170
  */
169
171
  InstructionState.prototype.checkNoChangesMode;
170
- /**
171
- * Function to be called when the element is exited.
172
- *
173
- * NOTE: The function is here for tree shakable purposes since it is only needed by styling.
174
- * @type {?}
175
- */
176
- InstructionState.prototype.elementExitFn;
177
172
  }
178
173
  /** @type {?} */
179
174
  export const instructionState = {
180
175
  lFrame: createLFrame(null),
181
176
  bindingsEnabled: true,
182
- elementExitFn: null,
183
177
  checkNoChangesMode: false,
184
178
  };
185
179
  /**
@@ -200,19 +194,6 @@ export function increaseElementDepthCount() {
200
194
  export function decreaseElementDepthCount() {
201
195
  instructionState.lFrame.elementDepthCount--;
202
196
  }
203
- /**
204
- * @return {?}
205
- */
206
- export function getCurrentDirectiveDef() {
207
- return instructionState.lFrame.currentDirectiveDef;
208
- }
209
- /**
210
- * @param {?} def
211
- * @return {?}
212
- */
213
- export function setCurrentDirectiveDef(def) {
214
- instructionState.lFrame.currentDirectiveDef = def;
215
- }
216
197
  /**
217
198
  * @return {?}
218
199
  */
@@ -266,132 +247,18 @@ export function ɵɵdisableBindings() {
266
247
  instructionState.bindingsEnabled = false;
267
248
  }
268
249
  /**
269
- * Return the current LView.
270
- *
271
- * The return value can be `null` if the method is called outside of template. This can happen if
272
- * directive is instantiated by module injector (rather than by node injector.)
250
+ * Return the current `LView`.
273
251
  * @return {?}
274
252
  */
275
253
  export function getLView() {
276
- // TODO(misko): the return value should be `LView|null` but doing so breaks a lot of code.
277
- /** @type {?} */
278
- const lFrame = instructionState.lFrame;
279
- return lFrame === null ? (/** @type {?} */ (null)) : lFrame.lView;
280
- }
281
- /** @enum {number} */
282
- const ActiveElementFlags = {
283
- Initial: 0,
284
- RunExitFn: 1,
285
- Size: 1,
286
- };
287
- export { ActiveElementFlags };
288
- /**
289
- * Determines whether or not a flag is currently set for the active element.
290
- * @param {?} flag
291
- * @return {?}
292
- */
293
- export function hasActiveElementFlag(flag) {
294
- return (instructionState.lFrame.selectedIndex & flag) === flag;
295
- }
296
- /**
297
- * Sets a flag is for the active element.
298
- * @param {?} flag
299
- * @return {?}
300
- */
301
- function setActiveElementFlag(flag) {
302
- instructionState.lFrame.selectedIndex |= flag;
303
- }
304
- /**
305
- * Sets the active directive host element and resets the directive id value
306
- * (when the provided elementIndex value has changed).
307
- *
308
- * @param {?} elementIndex the element index value for the host element where
309
- * the directive/component instance lives
310
- * @return {?}
311
- */
312
- export function setActiveHostElement(elementIndex) {
313
- if (hasActiveElementFlag(1 /* RunExitFn */)) {
314
- executeElementExitFn();
315
- }
316
- setSelectedIndex(elementIndex === null ? -1 : elementIndex);
317
- instructionState.lFrame.activeDirectiveId = 0;
318
- }
319
- /**
320
- * @return {?}
321
- */
322
- export function executeElementExitFn() {
323
- (/** @type {?} */ (instructionState.elementExitFn))();
324
- instructionState.lFrame.selectedIndex &= ~1 /* RunExitFn */;
325
- }
326
- /**
327
- * Queues a function to be run once the element is "exited" in CD.
328
- *
329
- * Change detection will focus on an element either when the `advance()`
330
- * instruction is called or when the template or host bindings instruction
331
- * code is invoked. The element is then "exited" when the next element is
332
- * selected or when change detection for the template or host bindings is
333
- * complete. When this occurs (the element change operation) then an exit
334
- * function will be invoked if it has been set. This function can be used
335
- * to assign that exit function.
336
- *
337
- * @param {?} fn
338
- * @return {?}
339
- */
340
- export function setElementExitFn(fn) {
341
- setActiveElementFlag(1 /* RunExitFn */);
342
- if (instructionState.elementExitFn === null) {
343
- instructionState.elementExitFn = fn;
344
- }
345
- ngDevMode &&
346
- assertEqual(instructionState.elementExitFn, fn, 'Expecting to always get the same function');
347
- }
348
- /**
349
- * Returns the current id value of the current directive.
350
- *
351
- * For example we have an element that has two directives on it:
352
- * <div dir-one dir-two></div>
353
- *
354
- * dirOne->hostBindings() (id == 1)
355
- * dirTwo->hostBindings() (id == 2)
356
- *
357
- * Note that this is only active when `hostBinding` functions are being processed.
358
- *
359
- * Note that directive id values are specific to an element (this means that
360
- * the same id value could be present on another element with a completely
361
- * different set of directives).
362
- * @return {?}
363
- */
364
- export function getActiveDirectiveId() {
365
- return instructionState.lFrame.activeDirectiveId;
254
+ return instructionState.lFrame.lView;
366
255
  }
367
256
  /**
368
- * Increments the current directive id value.
369
- *
370
- * For example we have an element that has two directives on it:
371
- * <div dir-one dir-two></div>
372
- *
373
- * dirOne->hostBindings() (index = 1)
374
- * // increment
375
- * dirTwo->hostBindings() (index = 2)
376
- *
377
- * Depending on whether or not a previous directive had any inherited
378
- * directives present, that value will be incremented in addition
379
- * to the id jumping up by one.
380
- *
381
- * Note that this is only active when `hostBinding` functions are being processed.
382
- *
383
- * Note that directive id values are specific to an element (this means that
384
- * the same id value could be present on another element with a completely
385
- * different set of directives).
257
+ * Return the current `TView`.
386
258
  * @return {?}
387
259
  */
388
- export function incrementActiveDirectiveId() {
389
- // Each directive gets a uniqueId value that is the same for both
390
- // create and update calls when the hostBindings function is called. The
391
- // directive uniqueId is not set anywhere--it is just incremented between
392
- // each hostBindings call and is useful for helping instruction code
393
- // uniquely determine which directive is currently active when executed.
394
- instructionState.lFrame.activeDirectiveId += 1;
260
+ export function getTView() {
261
+ return instructionState.lFrame.tView;
395
262
  }
396
263
  /**
397
264
  * Restores `contextViewData` to the given OpaqueViewState instance.
@@ -451,6 +318,7 @@ export function getContextLView() {
451
318
  * @return {?}
452
319
  */
453
320
  export function getCheckNoChangesMode() {
321
+ // TODO(misko): remove this from the LView since it is ngDevMode=true mode only.
454
322
  return instructionState.checkNoChangesMode;
455
323
  }
456
324
  /**
@@ -470,9 +338,7 @@ export function getBindingRoot() {
470
338
  /** @type {?} */
471
339
  let index = lFrame.bindingRootIndex;
472
340
  if (index === -1) {
473
- /** @type {?} */
474
- const lView = lFrame.lView;
475
- index = lFrame.bindingRootIndex = lView[TVIEW].bindingStartIndex;
341
+ index = lFrame.bindingRootIndex = lFrame.tView.bindingStartIndex;
476
342
  }
477
343
  return index;
478
344
  }
@@ -513,11 +379,26 @@ export function incrementBindingIndex(count) {
513
379
  * Bindings inside the host template are 0 index. But because we don't know ahead of time
514
380
  * how many host bindings we have we can't pre-compute them. For this reason they are all
515
381
  * 0 index and we just shift the root so that they match next available location in the LView.
516
- * @param {?} value
382
+ *
383
+ * @param {?} bindingRootIndex Root index for `hostBindings`
384
+ * @param {?} currentDirectiveIndex `TData[currentDirectiveIndex]` will point to the current directive
385
+ * whose `hostBindings` are being processed.
517
386
  * @return {?}
518
387
  */
519
- export function setBindingRoot(value) {
520
- instructionState.lFrame.bindingRootIndex = value;
388
+ export function setBindingRootForHostBindings(bindingRootIndex, currentDirectiveIndex) {
389
+ /** @type {?} */
390
+ const lFrame = instructionState.lFrame;
391
+ lFrame.bindingIndex = lFrame.bindingRootIndex = bindingRootIndex;
392
+ lFrame.currentDirectiveIndex = currentDirectiveIndex;
393
+ }
394
+ /**
395
+ * When host binding is executing this points to the directive index.
396
+ * `TView.data[getCurrentDirectiveIndex()]` is `DirectiveDef`
397
+ * `LView[getCurrentDirectiveIndex()]` is directive instance.
398
+ * @return {?}
399
+ */
400
+ export function getCurrentDirectiveIndex() {
401
+ return instructionState.lFrame.currentDirectiveIndex;
521
402
  }
522
403
  /**
523
404
  * @return {?}
@@ -553,8 +434,6 @@ export function enterDI(newView, tNode) {
553
434
  newLFrame.elementDepthCount = DEV_MODE_VALUE;
554
435
  newLFrame.currentNamespace = DEV_MODE_VALUE;
555
436
  newLFrame.currentSanitizer = DEV_MODE_VALUE;
556
- newLFrame.currentDirectiveDef = DEV_MODE_VALUE;
557
- newLFrame.activeDirectiveId = DEV_MODE_VALUE;
558
437
  newLFrame.bindingRootIndex = DEV_MODE_VALUE;
559
438
  newLFrame.currentQueryIndex = DEV_MODE_VALUE;
560
439
  }
@@ -584,19 +463,21 @@ export function enterView(newView, tNode) {
584
463
  ngDevMode && assertLViewOrUndefined(newView);
585
464
  /** @type {?} */
586
465
  const newLFrame = allocLFrame();
466
+ /** @type {?} */
467
+ const tView = newView[TVIEW];
587
468
  instructionState.lFrame = newLFrame;
588
469
  newLFrame.previousOrParentTNode = (/** @type {?} */ (tNode));
589
470
  newLFrame.isParent = true;
590
471
  newLFrame.lView = newView;
472
+ newLFrame.tView = tView;
591
473
  newLFrame.selectedIndex = 0;
592
474
  newLFrame.contextLView = (/** @type {?} */ (newView));
593
475
  newLFrame.elementDepthCount = 0;
476
+ newLFrame.currentDirectiveIndex = -1;
594
477
  newLFrame.currentNamespace = null;
595
478
  newLFrame.currentSanitizer = null;
596
- newLFrame.currentDirectiveDef = null;
597
- newLFrame.activeDirectiveId = 0;
598
479
  newLFrame.bindingRootIndex = -1;
599
- newLFrame.bindingIndex = newView === null ? -1 : newView[TVIEW].bindingStartIndex;
480
+ newLFrame.bindingIndex = tView.bindingStartIndex;
600
481
  newLFrame.currentQueryIndex = 0;
601
482
  }
602
483
  /**
@@ -625,6 +506,8 @@ function createLFrame(parent) {
625
506
  //
626
507
  lView: (/** @type {?} */ (null)),
627
508
  //
509
+ tView: (/** @type {?} */ (null)),
510
+ //
628
511
  selectedIndex: 0,
629
512
  //
630
513
  contextLView: (/** @type {?} */ (null)),
@@ -635,9 +518,7 @@ function createLFrame(parent) {
635
518
  //
636
519
  currentSanitizer: null,
637
520
  //
638
- currentDirectiveDef: null,
639
- //
640
- activeDirectiveId: 0,
521
+ currentDirectiveIndex: -1,
641
522
  //
642
523
  bindingRootIndex: -1,
643
524
  //
@@ -652,15 +533,6 @@ function createLFrame(parent) {
652
533
  parent !== null && (parent.child = lFrame); // link the new LFrame for reuse.
653
534
  return lFrame;
654
535
  }
655
- /**
656
- * @return {?}
657
- */
658
- export function leaveViewProcessExit() {
659
- if (hasActiveElementFlag(1 /* RunExitFn */)) {
660
- executeElementExitFn();
661
- }
662
- leaveView();
663
- }
664
536
  /**
665
537
  * @return {?}
666
538
  */
@@ -692,14 +564,14 @@ function walkUpViews(nestingLevel, currentView) {
692
564
  return currentView;
693
565
  }
694
566
  /**
695
- * Gets the most recent index passed to {\@link select}
567
+ * Gets the currently selected element index.
696
568
  *
697
569
  * Used with {\@link property} instruction (and more in the future) to identify the index in the
698
570
  * current `LView` to act on.
699
571
  * @return {?}
700
572
  */
701
573
  export function getSelectedIndex() {
702
- return instructionState.lFrame.selectedIndex >> 1 /* Size */;
574
+ return instructionState.lFrame.selectedIndex;
703
575
  }
704
576
  /**
705
577
  * Sets the most recent index passed to {\@link select}
@@ -713,7 +585,7 @@ export function getSelectedIndex() {
713
585
  * @return {?}
714
586
  */
715
587
  export function setSelectedIndex(index) {
716
- instructionState.lFrame.selectedIndex = index << 1 /* Size */;
588
+ instructionState.lFrame.selectedIndex = index;
717
589
  }
718
590
  /**
719
591
  * Sets the namespace used to create elements to `'http://www.w3.org/2000/svg'` in global state.
@@ -722,7 +594,7 @@ export function setSelectedIndex(index) {
722
594
  * @return {?}
723
595
  */
724
596
  export function ɵɵnamespaceSVG() {
725
- instructionState.lFrame.currentNamespace = 'http://www.w3.org/2000/svg';
597
+ instructionState.lFrame.currentNamespace = SVG_NAMESPACE;
726
598
  }
727
599
  /**
728
600
  * Sets the namespace used to create elements to `'http://www.w3.org/1998/MathML/'` in global state.
@@ -731,7 +603,7 @@ export function ɵɵnamespaceSVG() {
731
603
  * @return {?}
732
604
  */
733
605
  export function ɵɵnamespaceMathML() {
734
- instructionState.lFrame.currentNamespace = 'http://www.w3.org/1998/MathML/';
606
+ instructionState.lFrame.currentNamespace = MATH_ML_NAMESPACE;
735
607
  }
736
608
  /**
737
609
  * Sets the namespace used to create elements to `null`, which forces element creation to use
@@ -780,4 +652,4 @@ export function getCurrentStyleSanitizer() {
780
652
  const lFrame = instructionState.lFrame;
781
653
  return lFrame === null ? null : lFrame.currentSanitizer;
782
654
  }
783
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/state.ts"],"names":[],"mappings":";;;;;;;;;;;;AASA,OAAO,EAAC,aAAa,EAAE,WAAW,EAAC,MAAM,gBAAgB,CAAC;AAE1D,OAAO,EAAC,sBAAsB,EAAC,MAAM,UAAU,CAAC;AAGhD,OAAO,EAAC,OAAO,EAAE,gBAAgB,EAA0B,KAAK,EAAC,MAAM,mBAAmB,CAAC;;;;;AAM3F,qBAsGC;;;;;;;;IAhGC,wBAAe;;;;;;;IAOf,uBAAmB;;;;;;;;IAQnB,uBAAa;;;;;;;IAOb,uCAA6B;;;;;;;IAO7B,0BAAkB;;;;;;;IAOlB,+BAAsB;;;;;IAKtB,8BAAqB;;;;;;;;IAQrB,8BAAoB;;;;;;;;IAQpB,mCAA0B;;;;;IAK1B,kCAA8B;;;;;IAK9B,kCAAuC;;;;;IAMvC,qCAA8D;;;;;;;;;IAS9D,mCAA0B;;;;;;;IAO1B,kCAAyB;;;;;;IAMzB,mCAA0B;;;;;;;;;;;;AAY5B,+BAyCC;;;;;;;;IAnCC,kCAAe;;;;;;;;;;;;;;;;;;;;IAoBf,2CAAyB;;;;;;;IAOzB,8CAA4B;;;;;;;IAO5B,yCAAiC;;;AAGnC,MAAM,OAAO,gBAAgB,GAAqB;IAChD,MAAM,EAAE,YAAY,CAAC,IAAI,CAAC;IAC1B,eAAe,EAAE,IAAI;IACrB,aAAa,EAAE,IAAI;IACnB,kBAAkB,EAAE,KAAK;CAC1B;;;;AAGD,MAAM,UAAU,oBAAoB;IAClC,OAAO,gBAAgB,CAAC,MAAM,CAAC,iBAAiB,CAAC;AACnD,CAAC;;;;AAED,MAAM,UAAU,yBAAyB;IACvC,gBAAgB,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC;AAC9C,CAAC;;;;AAED,MAAM,UAAU,yBAAyB;IACvC,gBAAgB,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC;AAC9C,CAAC;;;;AAED,MAAM,UAAU,sBAAsB;IACpC,OAAO,gBAAgB,CAAC,MAAM,CAAC,mBAAmB,CAAC;AACrD,CAAC;;;;;AAED,MAAM,UAAU,sBAAsB,CAAC,GAA+C;IACpF,gBAAgB,CAAC,MAAM,CAAC,mBAAmB,GAAG,GAAG,CAAC;AACpD,CAAC;;;;AAED,MAAM,UAAU,kBAAkB;IAChC,OAAO,gBAAgB,CAAC,eAAe,CAAC;AAC1C,CAAC;;;;;;;;;;;;;;;;;;;;;AAsBD,MAAM,UAAU,gBAAgB;IAC9B,gBAAgB,CAAC,eAAe,GAAG,IAAI,CAAC;AAC1C,CAAC;;;;;;;;;;;;;;;;;;;;;AAqBD,MAAM,UAAU,iBAAiB;IAC/B,gBAAgB,CAAC,eAAe,GAAG,KAAK,CAAC;AAC3C,CAAC;;;;;;;;AAQD,MAAM,UAAU,QAAQ;;;UAEhB,MAAM,GAAG,gBAAgB,CAAC,MAAM;IACtC,OAAO,MAAM,KAAK,IAAI,CAAC,CAAC,CAAC,mBAAA,IAAI,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;AACjD,CAAC;;AAYD,MAAkB,kBAAkB;IAClC,OAAO,GAAO;IACd,SAAS,GAAO;IAChB,IAAI,GAAI;EACT;;;;;;;AAKD,MAAM,UAAU,oBAAoB,CAAC,IAAwB;IAC3D,OAAO,CAAC,gBAAgB,CAAC,MAAM,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,IAAI,CAAC;AACjE,CAAC;;;;;;AAKD,SAAS,oBAAoB,CAAC,IAAwB;IACpD,gBAAgB,CAAC,MAAM,CAAC,aAAa,IAAI,IAAI,CAAC;AAChD,CAAC;;;;;;;;;AASD,MAAM,UAAU,oBAAoB,CAAC,YAA2B;IAC9D,IAAI,oBAAoB,mBAA8B,EAAE;QACtD,oBAAoB,EAAE,CAAC;KACxB;IACD,gBAAgB,CAAC,YAAY,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC;IAC5D,gBAAgB,CAAC,MAAM,CAAC,iBAAiB,GAAG,CAAC,CAAC;AAChD,CAAC;;;;AAED,MAAM,UAAU,oBAAoB;IAClC,mBAAA,gBAAgB,CAAC,aAAa,EAAE,EAAE,CAAC;IACnC,gBAAgB,CAAC,MAAM,CAAC,aAAa,IAAI,kBAA6B,CAAC;AACzE,CAAC;;;;;;;;;;;;;;;AAeD,MAAM,UAAU,gBAAgB,CAAC,EAAc;IAC7C,oBAAoB,mBAA8B,CAAC;IACnD,IAAI,gBAAgB,CAAC,aAAa,KAAK,IAAI,EAAE;QAC3C,gBAAgB,CAAC,aAAa,GAAG,EAAE,CAAC;KACrC;IACD,SAAS;QACL,WAAW,CAAC,gBAAgB,CAAC,aAAa,EAAE,EAAE,EAAE,2CAA2C,CAAC,CAAC;AACnG,CAAC;;;;;;;;;;;;;;;;;AAiBD,MAAM,UAAU,oBAAoB;IAClC,OAAO,gBAAgB,CAAC,MAAM,CAAC,iBAAiB,CAAC;AACnD,CAAC;;;;;;;;;;;;;;;;;;;;;;AAsBD,MAAM,UAAU,0BAA0B;IACxC,iEAAiE;IACjE,wEAAwE;IACxE,yEAAyE;IACzE,oEAAoE;IACpE,wEAAwE;IACxE,gBAAgB,CAAC,MAAM,CAAC,iBAAiB,IAAI,CAAC,CAAC;AACjD,CAAC;;;;;;;;;;;;;AAaD,MAAM,UAAU,aAAa,CAAC,aAA8B;IAC1D,gBAAgB,CAAC,MAAM,CAAC,YAAY,GAAG,mBAAA,mBAAA,aAAa,EAAO,EAAS,CAAC;AACvE,CAAC;;;;AAED,MAAM,UAAU,wBAAwB;IACtC,OAAO,gBAAgB,CAAC,MAAM,CAAC,qBAAqB,CAAC;AACvD,CAAC;;;;;;AAED,MAAM,UAAU,wBAAwB,CAAC,KAAY,EAAE,SAAkB;IACvE,gBAAgB,CAAC,MAAM,CAAC,qBAAqB,GAAG,KAAK,CAAC;IACtD,gBAAgB,CAAC,MAAM,CAAC,QAAQ,GAAG,SAAS,CAAC;AAC/C,CAAC;;;;AAED,MAAM,UAAU,WAAW;IACzB,OAAO,gBAAgB,CAAC,MAAM,CAAC,QAAQ,CAAC;AAC1C,CAAC;;;;AAED,MAAM,UAAU,cAAc;IAC5B,gBAAgB,CAAC,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC;AAC3C,CAAC;;;;AACD,MAAM,UAAU,WAAW;IACzB,gBAAgB,CAAC,MAAM,CAAC,QAAQ,GAAG,IAAI,CAAC;AAC1C,CAAC;;;;AAED,MAAM,UAAU,eAAe;IAC7B,OAAO,gBAAgB,CAAC,MAAM,CAAC,YAAY,CAAC;AAC9C,CAAC;;;;AAED,MAAM,UAAU,qBAAqB;IACnC,OAAO,gBAAgB,CAAC,kBAAkB,CAAC;AAC7C,CAAC;;;;;AAED,MAAM,UAAU,qBAAqB,CAAC,IAAa;IACjD,gBAAgB,CAAC,kBAAkB,GAAG,IAAI,CAAC;AAC7C,CAAC;;;;;AAGD,MAAM,UAAU,cAAc;;UACtB,MAAM,GAAG,gBAAgB,CAAC,MAAM;;QAClC,KAAK,GAAG,MAAM,CAAC,gBAAgB;IACnC,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;;cACV,KAAK,GAAG,MAAM,CAAC,KAAK;QAC1B,KAAK,GAAG,MAAM,CAAC,gBAAgB,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,iBAAiB,CAAC;KAClE;IACD,OAAO,KAAK,CAAC;AACf,CAAC;;;;AAED,MAAM,UAAU,eAAe;IAC7B,OAAO,gBAAgB,CAAC,MAAM,CAAC,YAAY,CAAC;AAC9C,CAAC;;;;;AAED,MAAM,UAAU,eAAe,CAAC,KAAa;IAC3C,OAAO,gBAAgB,CAAC,MAAM,CAAC,YAAY,GAAG,KAAK,CAAC;AACtD,CAAC;;;;AAED,MAAM,UAAU,gBAAgB;IAC9B,OAAO,gBAAgB,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;AAChD,CAAC;;;;;AAED,MAAM,UAAU,qBAAqB,CAAC,KAAa;;UAC3C,MAAM,GAAG,gBAAgB,CAAC,MAAM;;UAChC,KAAK,GAAG,MAAM,CAAC,YAAY;IACjC,MAAM,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,GAAG,KAAK,CAAC;IAClD,OAAO,KAAK,CAAC;AACf,CAAC;;;;;;;;;;AAUD,MAAM,UAAU,cAAc,CAAC,KAAa;IAC1C,gBAAgB,CAAC,MAAM,CAAC,gBAAgB,GAAG,KAAK,CAAC;AACnD,CAAC;;;;AAED,MAAM,UAAU,oBAAoB;IAClC,OAAO,gBAAgB,CAAC,MAAM,CAAC,iBAAiB,CAAC;AACnD,CAAC;;;;;AAED,MAAM,UAAU,oBAAoB,CAAC,KAAa;IAChD,gBAAgB,CAAC,MAAM,CAAC,iBAAiB,GAAG,KAAK,CAAC;AACpD,CAAC;;;;;;;AAOD,MAAM,UAAU,OAAO,CAAC,OAAc,EAAE,KAAY;IAClD,SAAS,IAAI,sBAAsB,CAAC,OAAO,CAAC,CAAC;;UACvC,SAAS,GAAG,WAAW,EAAE;IAC/B,gBAAgB,CAAC,MAAM,GAAG,SAAS,CAAC;IACpC,SAAS,CAAC,qBAAqB,GAAG,mBAAA,KAAK,EAAE,CAAC;IAC1C,SAAS,CAAC,KAAK,GAAG,OAAO,CAAC;IAC1B,IAAI,SAAS,EAAE;QACb,yCAAyC;QACzC,SAAS,CAAC,QAAQ,GAAG,cAAc,CAAC;QACpC,SAAS,CAAC,aAAa,GAAG,cAAc,CAAC;QACzC,SAAS,CAAC,YAAY,GAAG,cAAc,CAAC;QACxC,SAAS,CAAC,iBAAiB,GAAG,cAAc,CAAC;QAC7C,SAAS,CAAC,gBAAgB,GAAG,cAAc,CAAC;QAC5C,SAAS,CAAC,gBAAgB,GAAG,cAAc,CAAC;QAC5C,SAAS,CAAC,mBAAmB,GAAG,cAAc,CAAC;QAC/C,SAAS,CAAC,iBAAiB,GAAG,cAAc,CAAC;QAC7C,SAAS,CAAC,gBAAgB,GAAG,cAAc,CAAC;QAC5C,SAAS,CAAC,iBAAiB,GAAG,cAAc,CAAC;KAC9C;AACH,CAAC;;MAEK,cAAc,GAChB,0FAA0F;;;;;;;AAO9F,MAAM,OAAO,OAAO,GAAG,SAAS;;;;;;;;;;;;;AAchC,MAAM,UAAU,SAAS,CAAC,OAAc,EAAE,KAAmB;IAC3D,SAAS,IAAI,sBAAsB,CAAC,OAAO,CAAC,CAAC;;UACvC,SAAS,GAAG,WAAW,EAAE;IAC/B,gBAAgB,CAAC,MAAM,GAAG,SAAS,CAAC;IACpC,SAAS,CAAC,qBAAqB,GAAG,mBAAA,KAAK,EAAE,CAAC;IAC1C,SAAS,CAAC,QAAQ,GAAG,IAAI,CAAC;IAC1B,SAAS,CAAC,KAAK,GAAG,OAAO,CAAC;IAC1B,SAAS,CAAC,aAAa,GAAG,CAAC,CAAC;IAC5B,SAAS,CAAC,YAAY,GAAG,mBAAA,OAAO,EAAE,CAAC;IACnC,SAAS,CAAC,iBAAiB,GAAG,CAAC,CAAC;IAChC,SAAS,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAClC,SAAS,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAClC,SAAS,CAAC,mBAAmB,GAAG,IAAI,CAAC;IACrC,SAAS,CAAC,iBAAiB,GAAG,CAAC,CAAC;IAChC,SAAS,CAAC,gBAAgB,GAAG,CAAC,CAAC,CAAC;IAChC,SAAS,CAAC,YAAY,GAAG,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,iBAAiB,CAAC;IAClF,SAAS,CAAC,iBAAiB,GAAG,CAAC,CAAC;AAClC,CAAC;;;;;AAKD,SAAS,WAAW;;UACZ,aAAa,GAAG,gBAAgB,CAAC,MAAM;;UACvC,WAAW,GAAG,aAAa,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK;;UACjE,SAAS,GAAG,WAAW,KAAK,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,WAAW;IAClF,OAAO,SAAS,CAAC;AACnB,CAAC;;;;;AAED,SAAS,YAAY,CAAC,MAAqB;;UACnC,MAAM,GAAW;QACrB,qBAAqB,EAAE,mBAAA,IAAI,EAAE;;QAC7B,QAAQ,EAAE,IAAI;;QACd,KAAK,EAAE,mBAAA,IAAI,EAAE;;QACb,aAAa,EAAE,CAAC;;QAChB,YAAY,EAAE,mBAAA,IAAI,EAAE;;QACpB,iBAAiB,EAAE,CAAC;;QACpB,gBAAgB,EAAE,IAAI;;QACtB,gBAAgB,EAAE,IAAI;;QACtB,mBAAmB,EAAE,IAAI;;QACzB,iBAAiB,EAAE,CAAC;;QACpB,gBAAgB,EAAE,CAAC,CAAC;;QACpB,YAAY,EAAE,CAAC,CAAC;;QAChB,iBAAiB,EAAE,CAAC;;QACpB,MAAM,EAAE,mBAAA,MAAM,EAAE;;QAChB,KAAK,EAAE,IAAI;KACZ;IACD,MAAM,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC,CAAE,iCAAiC;IAC9E,OAAO,MAAM,CAAC;AAChB,CAAC;;;;AAED,MAAM,UAAU,oBAAoB;IAClC,IAAI,oBAAoB,mBAA8B,EAAE;QACtD,oBAAoB,EAAE,CAAC;KACxB;IACD,SAAS,EAAE,CAAC;AACd,CAAC;;;;AAED,MAAM,UAAU,SAAS;IACvB,gBAAgB,CAAC,MAAM,GAAG,gBAAgB,CAAC,MAAM,CAAC,MAAM,CAAC;AAC3D,CAAC;;;;;;AAED,MAAM,UAAU,eAAe,CAAU,KAAa;;UAC9C,YAAY,GAAG,gBAAgB,CAAC,MAAM,CAAC,YAAY;QACrD,WAAW,CAAC,KAAK,EAAE,mBAAA,gBAAgB,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;IAC9D,OAAO,mBAAA,YAAY,CAAC,OAAO,CAAC,EAAK,CAAC;AACpC,CAAC;;;;;;AAED,SAAS,WAAW,CAAC,YAAoB,EAAE,WAAkB;IAC3D,OAAO,YAAY,GAAG,CAAC,EAAE;QACvB,SAAS,IAAI,aAAa,CACT,WAAW,CAAC,gBAAgB,CAAC,EAC7B,wEAAwE,CAAC,CAAC;QAC3F,WAAW,GAAG,mBAAA,WAAW,CAAC,gBAAgB,CAAC,EAAE,CAAC;QAC9C,YAAY,EAAE,CAAC;KAChB;IACD,OAAO,WAAW,CAAC;AACrB,CAAC;;;;;;;;AAQD,MAAM,UAAU,gBAAgB;IAC9B,OAAO,gBAAgB,CAAC,MAAM,CAAC,aAAa,gBAA2B,CAAC;AAC1E,CAAC;;;;;;;;;;;;AAWD,MAAM,UAAU,gBAAgB,CAAC,KAAa;IAC5C,gBAAgB,CAAC,MAAM,CAAC,aAAa,GAAG,KAAK,gBAA2B,CAAC;AAC3E,CAAC;;;;;;;AAQD,MAAM,UAAU,cAAc;IAC5B,gBAAgB,CAAC,MAAM,CAAC,gBAAgB,GAAG,4BAA4B,CAAC;AAC1E,CAAC;;;;;;;AAOD,MAAM,UAAU,iBAAiB;IAC/B,gBAAgB,CAAC,MAAM,CAAC,gBAAgB,GAAG,gCAAgC,CAAC;AAC9E,CAAC;;;;;;;;AAQD,MAAM,UAAU,eAAe;IAC7B,qBAAqB,EAAE,CAAC;AAC1B,CAAC;;;;;;AAMD,MAAM,UAAU,qBAAqB;IACnC,gBAAgB,CAAC,MAAM,CAAC,gBAAgB,GAAG,IAAI,CAAC;AAClD,CAAC;;;;AAED,MAAM,UAAU,YAAY;IAC1B,OAAO,gBAAgB,CAAC,MAAM,CAAC,gBAAgB,CAAC;AAClD,CAAC;;;;;AAED,MAAM,UAAU,wBAAwB,CAAC,SAAiC;IACxE,gBAAgB,CAAC,MAAM,CAAC,gBAAgB,GAAG,SAAS,CAAC;AACvD,CAAC;;;;AAED,MAAM,UAAU,0BAA0B;IACxC,wBAAwB,CAAC,IAAI,CAAC,CAAC;AACjC,CAAC;;;;AAED,MAAM,UAAU,wBAAwB;;;;UAGhC,MAAM,GAAG,gBAAgB,CAAC,MAAM;IACtC,OAAO,MAAM,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,gBAAgB,CAAC;AAC1D,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {StyleSanitizeFn} from '../sanitization/style_sanitizer';\nimport {assertDefined, assertEqual} from '../util/assert';\n\nimport {assertLViewOrUndefined} from './assert';\nimport {ComponentDef, DirectiveDef} from './interfaces/definition';\nimport {TNode} from './interfaces/node';\nimport {CONTEXT, DECLARATION_VIEW, LView, OpaqueViewState, TVIEW} from './interfaces/view';\n\n\n/**\n *\n */\ninterface LFrame {\n  /**\n   * Parent LFrame.\n   *\n   * This is needed when `leaveView` is called to restore the previous state.\n   */\n  parent: LFrame;\n\n  /**\n   * Child LFrame.\n   *\n   * This is used to cache existing LFrames to relieve the memory pressure.\n   */\n  child: LFrame|null;\n\n  /**\n   * State of the current view being processed.\n   *\n   * An array of nodes (text, element, container, etc), pipes, their bindings, and\n   * any local variables that need to be stored between invocations.\n   */\n  lView: LView;\n\n  /**\n   * Used to set the parent property when nodes are created and track query results.\n   *\n   * This is used in conjection with `isParent`.\n   */\n  previousOrParentTNode: TNode;\n\n  /**\n   * If `isParent` is:\n   *  - `true`: then `previousOrParentTNode` points to a parent node.\n   *  - `false`: then `previousOrParentTNode` points to previous node (sibling).\n   */\n  isParent: boolean;\n\n  /**\n   * Index of currently selected element in LView.\n   *\n   * Used by binding instructions. Updated as part of advance instruction.\n   */\n  selectedIndex: number;\n\n  /**\n   * Current pointer to the binding index.\n   */\n  bindingIndex: number;\n\n  /**\n   * The last viewData retrieved by nextContext().\n   * Allows building nextContext() and reference() calls.\n   *\n   * e.g. const inner = x().$implicit; const outer = x().$implicit;\n   */\n  contextLView: LView;\n\n  /**\n   * Store the element depth count. This is used to identify the root elements of the template\n   * so that we can then attach patch data `LView` to only those elements. We know that those\n   * are the only places where the patch data could change, this way we will save on number\n   * of places where tha patching occurs.\n   */\n  elementDepthCount: number;\n\n  /**\n   * Current namespace to be used when creating elements\n   */\n  currentNamespace: string|null;\n\n  /**\n   * Current sanitizer\n   */\n  currentSanitizer: StyleSanitizeFn|null;\n\n\n  /**\n   * Used when processing host bindings.\n   */\n  currentDirectiveDef: DirectiveDef<any>|ComponentDef<any>|null;\n\n  /**\n   * Used as the starting directive id value.\n   *\n   * All subsequent directives are incremented from this value onwards.\n   * The reason why this value is `1` instead of `0` is because the `0`\n   * value is reserved for the template.\n   */\n  activeDirectiveId: number;\n\n  /**\n   * The root index from which pure function instructions should calculate their binding\n   * indices. In component views, this is TView.bindingStartIndex. In a host binding\n   * context, this is the TView.expandoStartIndex + any dirs/hostVars before the given dir.\n   */\n  bindingRootIndex: number;\n\n  /**\n   * Current index of a View or Content Query which needs to be processed next.\n   * We iterate over the list of Queries and increment current query index at every step.\n   */\n  currentQueryIndex: number;\n}\n\n/**\n * All implicit instruction state is stored here.\n *\n * It is useful to have a single object where all of the state is stored as a mental model\n * (rather it being spread across many different variables.)\n *\n * PERF NOTE: Turns out that writing to a true global variable is slower than\n * having an intermediate object with properties.\n */\ninterface InstructionState {\n  /**\n   * Current `LFrame`\n   *\n   * `null` if we have not called `enterView`\n   */\n  lFrame: LFrame;\n\n  /**\n   * Stores whether directives should be matched to elements.\n   *\n   * When template contains `ngNonBindable` then we need to prevent the runtime from matching\n   * directives on children of that element.\n   *\n   * Example:\n   * ```\n   * <my-comp my-directive>\n   *   Should match component / directive.\n   * </my-comp>\n   * <div ngNonBindable>\n   *   <my-comp my-directive>\n   *     Should not match component / directive because we are in ngNonBindable.\n   *   </my-comp>\n   * </div>\n   * ```\n   */\n  bindingsEnabled: boolean;\n\n  /**\n   * In this mode, any changes in bindings will throw an ExpressionChangedAfterChecked error.\n   *\n   * Necessary to support ChangeDetectorRef.checkNoChanges().\n   */\n  checkNoChangesMode: boolean;\n\n  /**\n   * Function to be called when the element is exited.\n   *\n   * NOTE: The function is here for tree shakable purposes since it is only needed by styling.\n   */\n  elementExitFn: (() => void)|null;\n}\n\nexport const instructionState: InstructionState = {\n  lFrame: createLFrame(null),\n  bindingsEnabled: true,\n  elementExitFn: null,\n  checkNoChangesMode: false,\n};\n\n\nexport function getElementDepthCount() {\n  return instructionState.lFrame.elementDepthCount;\n}\n\nexport function increaseElementDepthCount() {\n  instructionState.lFrame.elementDepthCount++;\n}\n\nexport function decreaseElementDepthCount() {\n  instructionState.lFrame.elementDepthCount--;\n}\n\nexport function getCurrentDirectiveDef(): DirectiveDef<any>|ComponentDef<any>|null {\n  return instructionState.lFrame.currentDirectiveDef;\n}\n\nexport function setCurrentDirectiveDef(def: DirectiveDef<any>| ComponentDef<any>| null): void {\n  instructionState.lFrame.currentDirectiveDef = def;\n}\n\nexport function getBindingsEnabled(): boolean {\n  return instructionState.bindingsEnabled;\n}\n\n\n/**\n * Enables directive matching on elements.\n *\n *  * Example:\n * ```\n * <my-comp my-directive>\n *   Should match component / directive.\n * </my-comp>\n * <div ngNonBindable>\n *   <!-- ɵɵdisableBindings() -->\n *   <my-comp my-directive>\n *     Should not match component / directive because we are in ngNonBindable.\n *   </my-comp>\n *   <!-- ɵɵenableBindings() -->\n * </div>\n * ```\n *\n * @codeGenApi\n */\nexport function ɵɵenableBindings(): void {\n  instructionState.bindingsEnabled = true;\n}\n\n/**\n * Disables directive matching on element.\n *\n *  * Example:\n * ```\n * <my-comp my-directive>\n *   Should match component / directive.\n * </my-comp>\n * <div ngNonBindable>\n *   <!-- ɵɵdisableBindings() -->\n *   <my-comp my-directive>\n *     Should not match component / directive because we are in ngNonBindable.\n *   </my-comp>\n *   <!-- ɵɵenableBindings() -->\n * </div>\n * ```\n *\n * @codeGenApi\n */\nexport function ɵɵdisableBindings(): void {\n  instructionState.bindingsEnabled = false;\n}\n\n/**\n * Return the current LView.\n *\n * The return value can be `null` if the method is called outside of template. This can happen if\n * directive is instantiated by module injector (rather than by node injector.)\n */\nexport function getLView(): LView {\n  // TODO(misko): the return value should be `LView|null` but doing so breaks a lot of code.\n  const lFrame = instructionState.lFrame;\n  return lFrame === null ? null ! : lFrame.lView;\n}\n\n/**\n * Flags used for an active element during change detection.\n *\n * These flags are used within other instructions to inform cleanup or\n * exit operations to run when an element is being processed.\n *\n * Note that these flags are reset each time an element changes (whether it\n * happens when `advance()` is run or when change detection exits out of a template\n * function or when all host bindings are processed for an element).\n */\nexport const enum ActiveElementFlags {\n  Initial = 0b00,\n  RunExitFn = 0b01,\n  Size = 1,\n}\n\n/**\n * Determines whether or not a flag is currently set for the active element.\n */\nexport function hasActiveElementFlag(flag: ActiveElementFlags) {\n  return (instructionState.lFrame.selectedIndex & flag) === flag;\n}\n\n/**\n * Sets a flag is for the active element.\n */\nfunction setActiveElementFlag(flag: ActiveElementFlags) {\n  instructionState.lFrame.selectedIndex |= flag;\n}\n\n/**\n * Sets the active directive host element and resets the directive id value\n * (when the provided elementIndex value has changed).\n *\n * @param elementIndex the element index value for the host element where\n *                     the directive/component instance lives\n */\nexport function setActiveHostElement(elementIndex: number | null) {\n  if (hasActiveElementFlag(ActiveElementFlags.RunExitFn)) {\n    executeElementExitFn();\n  }\n  setSelectedIndex(elementIndex === null ? -1 : elementIndex);\n  instructionState.lFrame.activeDirectiveId = 0;\n}\n\nexport function executeElementExitFn() {\n  instructionState.elementExitFn !();\n  instructionState.lFrame.selectedIndex &= ~ActiveElementFlags.RunExitFn;\n}\n\n/**\n * Queues a function to be run once the element is \"exited\" in CD.\n *\n * Change detection will focus on an element either when the `advance()`\n * instruction is called or when the template or host bindings instruction\n * code is invoked. The element is then \"exited\" when the next element is\n * selected or when change detection for the template or host bindings is\n * complete. When this occurs (the element change operation) then an exit\n * function will be invoked if it has been set. This function can be used\n * to assign that exit function.\n *\n * @param fn\n */\nexport function setElementExitFn(fn: () => void): void {\n  setActiveElementFlag(ActiveElementFlags.RunExitFn);\n  if (instructionState.elementExitFn === null) {\n    instructionState.elementExitFn = fn;\n  }\n  ngDevMode &&\n      assertEqual(instructionState.elementExitFn, fn, 'Expecting to always get the same function');\n}\n\n/**\n * Returns the current id value of the current directive.\n *\n * For example we have an element that has two directives on it:\n * <div dir-one dir-two></div>\n *\n * dirOne->hostBindings() (id == 1)\n * dirTwo->hostBindings() (id == 2)\n *\n * Note that this is only active when `hostBinding` functions are being processed.\n *\n * Note that directive id values are specific to an element (this means that\n * the same id value could be present on another element with a completely\n * different set of directives).\n */\nexport function getActiveDirectiveId() {\n  return instructionState.lFrame.activeDirectiveId;\n}\n\n/**\n * Increments the current directive id value.\n *\n * For example we have an element that has two directives on it:\n * <div dir-one dir-two></div>\n *\n * dirOne->hostBindings() (index = 1)\n * // increment\n * dirTwo->hostBindings() (index = 2)\n *\n * Depending on whether or not a previous directive had any inherited\n * directives present, that value will be incremented in addition\n * to the id jumping up by one.\n *\n * Note that this is only active when `hostBinding` functions are being processed.\n *\n * Note that directive id values are specific to an element (this means that\n * the same id value could be present on another element with a completely\n * different set of directives).\n */\nexport function incrementActiveDirectiveId() {\n  // Each directive gets a uniqueId value that is the same for both\n  // create and update calls when the hostBindings function is called. The\n  // directive uniqueId is not set anywhere--it is just incremented between\n  // each hostBindings call and is useful for helping instruction code\n  // uniquely determine which directive is currently active when executed.\n  instructionState.lFrame.activeDirectiveId += 1;\n}\n\n/**\n * Restores `contextViewData` to the given OpaqueViewState instance.\n *\n * Used in conjunction with the getCurrentView() instruction to save a snapshot\n * of the current view and restore it when listeners are invoked. This allows\n * walking the declaration view tree in listeners to get vars from parent views.\n *\n * @param viewToRestore The OpaqueViewState instance to restore.\n *\n * @codeGenApi\n */\nexport function ɵɵrestoreView(viewToRestore: OpaqueViewState) {\n  instructionState.lFrame.contextLView = viewToRestore as any as LView;\n}\n\nexport function getPreviousOrParentTNode(): TNode {\n  return instructionState.lFrame.previousOrParentTNode;\n}\n\nexport function setPreviousOrParentTNode(tNode: TNode, _isParent: boolean) {\n  instructionState.lFrame.previousOrParentTNode = tNode;\n  instructionState.lFrame.isParent = _isParent;\n}\n\nexport function getIsParent(): boolean {\n  return instructionState.lFrame.isParent;\n}\n\nexport function setIsNotParent(): void {\n  instructionState.lFrame.isParent = false;\n}\nexport function setIsParent(): void {\n  instructionState.lFrame.isParent = true;\n}\n\nexport function getContextLView(): LView {\n  return instructionState.lFrame.contextLView;\n}\n\nexport function getCheckNoChangesMode(): boolean {\n  return instructionState.checkNoChangesMode;\n}\n\nexport function setCheckNoChangesMode(mode: boolean): void {\n  instructionState.checkNoChangesMode = mode;\n}\n\n// top level variables should not be exported for performance reasons (PERF_NOTES.md)\nexport function getBindingRoot() {\n  const lFrame = instructionState.lFrame;\n  let index = lFrame.bindingRootIndex;\n  if (index === -1) {\n    const lView = lFrame.lView;\n    index = lFrame.bindingRootIndex = lView[TVIEW].bindingStartIndex;\n  }\n  return index;\n}\n\nexport function getBindingIndex(): number {\n  return instructionState.lFrame.bindingIndex;\n}\n\nexport function setBindingIndex(value: number): number {\n  return instructionState.lFrame.bindingIndex = value;\n}\n\nexport function nextBindingIndex(): number {\n  return instructionState.lFrame.bindingIndex++;\n}\n\nexport function incrementBindingIndex(count: number): number {\n  const lFrame = instructionState.lFrame;\n  const index = lFrame.bindingIndex;\n  lFrame.bindingIndex = lFrame.bindingIndex + count;\n  return index;\n}\n\n/**\n * Set a new binding root index so that host template functions can execute.\n *\n * Bindings inside the host template are 0 index. But because we don't know ahead of time\n * how many host bindings we have we can't pre-compute them. For this reason they are all\n * 0 index and we just shift the root so that they match next available location in the LView.\n * @param value\n */\nexport function setBindingRoot(value: number) {\n  instructionState.lFrame.bindingRootIndex = value;\n}\n\nexport function getCurrentQueryIndex(): number {\n  return instructionState.lFrame.currentQueryIndex;\n}\n\nexport function setCurrentQueryIndex(value: number): void {\n  instructionState.lFrame.currentQueryIndex = value;\n}\n\n/**\n * This is a light weight version of the `enterView` which is needed by the DI system.\n * @param newView\n * @param tNode\n */\nexport function enterDI(newView: LView, tNode: TNode) {\n  ngDevMode && assertLViewOrUndefined(newView);\n  const newLFrame = allocLFrame();\n  instructionState.lFrame = newLFrame;\n  newLFrame.previousOrParentTNode = tNode !;\n  newLFrame.lView = newView;\n  if (ngDevMode) {\n    // resetting for safety in dev mode only.\n    newLFrame.isParent = DEV_MODE_VALUE;\n    newLFrame.selectedIndex = DEV_MODE_VALUE;\n    newLFrame.contextLView = DEV_MODE_VALUE;\n    newLFrame.elementDepthCount = DEV_MODE_VALUE;\n    newLFrame.currentNamespace = DEV_MODE_VALUE;\n    newLFrame.currentSanitizer = DEV_MODE_VALUE;\n    newLFrame.currentDirectiveDef = DEV_MODE_VALUE;\n    newLFrame.activeDirectiveId = DEV_MODE_VALUE;\n    newLFrame.bindingRootIndex = DEV_MODE_VALUE;\n    newLFrame.currentQueryIndex = DEV_MODE_VALUE;\n  }\n}\n\nconst DEV_MODE_VALUE: any =\n    'Value indicating that DI is trying to read value which it should not need to know about.';\n\n/**\n * This is a light weight version of the `leaveView` which is needed by the DI system.\n *\n * Because the implementation is same it is only an alias\n */\nexport const leaveDI = leaveView;\n\n/**\n * Swap the current lView with a new lView.\n *\n * For performance reasons we store the lView in the top level of the module.\n * This way we minimize the number of properties to read. Whenever a new view\n * is entered we have to store the lView for later, and when the view is\n * exited the state has to be restored\n *\n * @param newView New lView to become active\n * @param tNode Element to which the View is a child of\n * @returns the previously active lView;\n */\nexport function enterView(newView: LView, tNode: TNode | null): void {\n  ngDevMode && assertLViewOrUndefined(newView);\n  const newLFrame = allocLFrame();\n  instructionState.lFrame = newLFrame;\n  newLFrame.previousOrParentTNode = tNode !;\n  newLFrame.isParent = true;\n  newLFrame.lView = newView;\n  newLFrame.selectedIndex = 0;\n  newLFrame.contextLView = newView !;\n  newLFrame.elementDepthCount = 0;\n  newLFrame.currentNamespace = null;\n  newLFrame.currentSanitizer = null;\n  newLFrame.currentDirectiveDef = null;\n  newLFrame.activeDirectiveId = 0;\n  newLFrame.bindingRootIndex = -1;\n  newLFrame.bindingIndex = newView === null ? -1 : newView[TVIEW].bindingStartIndex;\n  newLFrame.currentQueryIndex = 0;\n}\n\n/**\n * Allocates next free LFrame. This function tries to reuse the `LFrame`s to lower memory pressure.\n */\nfunction allocLFrame() {\n  const currentLFrame = instructionState.lFrame;\n  const childLFrame = currentLFrame === null ? null : currentLFrame.child;\n  const newLFrame = childLFrame === null ? createLFrame(currentLFrame) : childLFrame;\n  return newLFrame;\n}\n\nfunction createLFrame(parent: LFrame | null): LFrame {\n  const lFrame: LFrame = {\n    previousOrParentTNode: null !,  //\n    isParent: true,                 //\n    lView: null !,                  //\n    selectedIndex: 0,               //\n    contextLView: null !,           //\n    elementDepthCount: 0,           //\n    currentNamespace: null,         //\n    currentSanitizer: null,         //\n    currentDirectiveDef: null,      //\n    activeDirectiveId: 0,           //\n    bindingRootIndex: -1,           //\n    bindingIndex: -1,               //\n    currentQueryIndex: 0,           //\n    parent: parent !,               //\n    child: null,                    //\n  };\n  parent !== null && (parent.child = lFrame);  // link the new LFrame for reuse.\n  return lFrame;\n}\n\nexport function leaveViewProcessExit() {\n  if (hasActiveElementFlag(ActiveElementFlags.RunExitFn)) {\n    executeElementExitFn();\n  }\n  leaveView();\n}\n\nexport function leaveView() {\n  instructionState.lFrame = instructionState.lFrame.parent;\n}\n\nexport function nextContextImpl<T = any>(level: number): T {\n  const contextLView = instructionState.lFrame.contextLView =\n      walkUpViews(level, instructionState.lFrame.contextLView !);\n  return contextLView[CONTEXT] as T;\n}\n\nfunction walkUpViews(nestingLevel: number, currentView: LView): LView {\n  while (nestingLevel > 0) {\n    ngDevMode && assertDefined(\n                     currentView[DECLARATION_VIEW],\n                     'Declaration view should be defined if nesting level is greater than 0.');\n    currentView = currentView[DECLARATION_VIEW] !;\n    nestingLevel--;\n  }\n  return currentView;\n}\n\n/**\n * Gets the most recent index passed to {@link select}\n *\n * Used with {@link property} instruction (and more in the future) to identify the index in the\n * current `LView` to act on.\n */\nexport function getSelectedIndex() {\n  return instructionState.lFrame.selectedIndex >> ActiveElementFlags.Size;\n}\n\n/**\n * Sets the most recent index passed to {@link select}\n *\n * Used with {@link property} instruction (and more in the future) to identify the index in the\n * current `LView` to act on.\n *\n * (Note that if an \"exit function\" was set earlier (via `setElementExitFn()`) then that will be\n * run if and when the provided `index` value is different from the current selected index value.)\n */\nexport function setSelectedIndex(index: number) {\n  instructionState.lFrame.selectedIndex = index << ActiveElementFlags.Size;\n}\n\n\n/**\n * Sets the namespace used to create elements to `'http://www.w3.org/2000/svg'` in global state.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceSVG() {\n  instructionState.lFrame.currentNamespace = 'http://www.w3.org/2000/svg';\n}\n\n/**\n * Sets the namespace used to create elements to `'http://www.w3.org/1998/MathML/'` in global state.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceMathML() {\n  instructionState.lFrame.currentNamespace = 'http://www.w3.org/1998/MathML/';\n}\n\n/**\n * Sets the namespace used to create elements to `null`, which forces element creation to use\n * `createElement` rather than `createElementNS`.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceHTML() {\n  namespaceHTMLInternal();\n}\n\n/**\n * Sets the namespace used to create elements to `null`, which forces element creation to use\n * `createElement` rather than `createElementNS`.\n */\nexport function namespaceHTMLInternal() {\n  instructionState.lFrame.currentNamespace = null;\n}\n\nexport function getNamespace(): string|null {\n  return instructionState.lFrame.currentNamespace;\n}\n\nexport function setCurrentStyleSanitizer(sanitizer: StyleSanitizeFn | null) {\n  instructionState.lFrame.currentSanitizer = sanitizer;\n}\n\nexport function resetCurrentStyleSanitizer() {\n  setCurrentStyleSanitizer(null);\n}\n\nexport function getCurrentStyleSanitizer() {\n  // TODO(misko): This should throw when there is no LView, but it turns out we can get here from\n  // `NodeStyleDebug` hence we return `null`. This should be fixed\n  const lFrame = instructionState.lFrame;\n  return lFrame === null ? null : lFrame.currentSanitizer;\n}\n"]}
655
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/state.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {StyleSanitizeFn} from '../sanitization/style_sanitizer';\nimport {assertDefined} from '../util/assert';\nimport {assertLViewOrUndefined} from './assert';\nimport {TNode} from './interfaces/node';\nimport {CONTEXT, DECLARATION_VIEW, LView, OpaqueViewState, TVIEW, TView} from './interfaces/view';\nimport {MATH_ML_NAMESPACE, SVG_NAMESPACE} from './namespaces';\n\n\n/**\n *\n */\ninterface LFrame {\n  /**\n   * Parent LFrame.\n   *\n   * This is needed when `leaveView` is called to restore the previous state.\n   */\n  parent: LFrame;\n\n  /**\n   * Child LFrame.\n   *\n   * This is used to cache existing LFrames to relieve the memory pressure.\n   */\n  child: LFrame|null;\n\n  /**\n   * State of the current view being processed.\n   *\n   * An array of nodes (text, element, container, etc), pipes, their bindings, and\n   * any local variables that need to be stored between invocations.\n   */\n  lView: LView;\n\n  /**\n   * Current `TView` associated with the `LFrame.lView`.\n   *\n   * One can get `TView` from `lFrame[TVIEW]` however because it is so common it makes sense to\n   * store it in `LFrame` for perf reasons.\n   */\n  tView: TView;\n\n  /**\n   * Used to set the parent property when nodes are created and track query results.\n   *\n   * This is used in conjunction with `isParent`.\n   */\n  previousOrParentTNode: TNode;\n\n  /**\n   * If `isParent` is:\n   *  - `true`: then `previousOrParentTNode` points to a parent node.\n   *  - `false`: then `previousOrParentTNode` points to previous node (sibling).\n   */\n  isParent: boolean;\n\n  /**\n   * Index of currently selected element in LView.\n   *\n   * Used by binding instructions. Updated as part of advance instruction.\n   */\n  selectedIndex: number;\n\n  /**\n   * Current pointer to the binding index.\n   */\n  bindingIndex: number;\n\n  /**\n   * The last viewData retrieved by nextContext().\n   * Allows building nextContext() and reference() calls.\n   *\n   * e.g. const inner = x().$implicit; const outer = x().$implicit;\n   */\n  contextLView: LView;\n\n  /**\n   * Store the element depth count. This is used to identify the root elements of the template\n   * so that we can then attach patch data `LView` to only those elements. We know that those\n   * are the only places where the patch data could change, this way we will save on number\n   * of places where tha patching occurs.\n   */\n  elementDepthCount: number;\n\n  /**\n   * Current namespace to be used when creating elements\n   */\n  currentNamespace: string|null;\n\n  /**\n   * Current sanitizer\n   */\n  currentSanitizer: StyleSanitizeFn|null;\n\n\n  /**\n   * The root index from which pure function instructions should calculate their binding\n   * indices. In component views, this is TView.bindingStartIndex. In a host binding\n   * context, this is the TView.expandoStartIndex + any dirs/hostVars before the given dir.\n   */\n  bindingRootIndex: number;\n\n  /**\n   * Current index of a View or Content Query which needs to be processed next.\n   * We iterate over the list of Queries and increment current query index at every step.\n   */\n  currentQueryIndex: number;\n\n  /**\n   * When host binding is executing this points to the directive index.\n   * `TView.data[currentDirectiveIndex]` is `DirectiveDef`\n   * `LView[currentDirectiveIndex]` is directive instance.\n   */\n  currentDirectiveIndex: number;\n}\n\n/**\n * All implicit instruction state is stored here.\n *\n * It is useful to have a single object where all of the state is stored as a mental model\n * (rather it being spread across many different variables.)\n *\n * PERF NOTE: Turns out that writing to a true global variable is slower than\n * having an intermediate object with properties.\n */\ninterface InstructionState {\n  /**\n   * Current `LFrame`\n   *\n   * `null` if we have not called `enterView`\n   */\n  lFrame: LFrame;\n\n  /**\n   * Stores whether directives should be matched to elements.\n   *\n   * When template contains `ngNonBindable` then we need to prevent the runtime from matching\n   * directives on children of that element.\n   *\n   * Example:\n   * ```\n   * <my-comp my-directive>\n   *   Should match component / directive.\n   * </my-comp>\n   * <div ngNonBindable>\n   *   <my-comp my-directive>\n   *     Should not match component / directive because we are in ngNonBindable.\n   *   </my-comp>\n   * </div>\n   * ```\n   */\n  bindingsEnabled: boolean;\n\n  /**\n   * In this mode, any changes in bindings will throw an ExpressionChangedAfterChecked error.\n   *\n   * Necessary to support ChangeDetectorRef.checkNoChanges().\n   */\n  checkNoChangesMode: boolean;\n}\n\nexport const instructionState: InstructionState = {\n  lFrame: createLFrame(null),\n  bindingsEnabled: true,\n  checkNoChangesMode: false,\n};\n\n\nexport function getElementDepthCount() {\n  return instructionState.lFrame.elementDepthCount;\n}\n\nexport function increaseElementDepthCount() {\n  instructionState.lFrame.elementDepthCount++;\n}\n\nexport function decreaseElementDepthCount() {\n  instructionState.lFrame.elementDepthCount--;\n}\n\nexport function getBindingsEnabled(): boolean {\n  return instructionState.bindingsEnabled;\n}\n\n\n/**\n * Enables directive matching on elements.\n *\n *  * Example:\n * ```\n * <my-comp my-directive>\n *   Should match component / directive.\n * </my-comp>\n * <div ngNonBindable>\n *   <!-- ɵɵdisableBindings() -->\n *   <my-comp my-directive>\n *     Should not match component / directive because we are in ngNonBindable.\n *   </my-comp>\n *   <!-- ɵɵenableBindings() -->\n * </div>\n * ```\n *\n * @codeGenApi\n */\nexport function ɵɵenableBindings(): void {\n  instructionState.bindingsEnabled = true;\n}\n\n/**\n * Disables directive matching on element.\n *\n *  * Example:\n * ```\n * <my-comp my-directive>\n *   Should match component / directive.\n * </my-comp>\n * <div ngNonBindable>\n *   <!-- ɵɵdisableBindings() -->\n *   <my-comp my-directive>\n *     Should not match component / directive because we are in ngNonBindable.\n *   </my-comp>\n *   <!-- ɵɵenableBindings() -->\n * </div>\n * ```\n *\n * @codeGenApi\n */\nexport function ɵɵdisableBindings(): void {\n  instructionState.bindingsEnabled = false;\n}\n\n/**\n * Return the current `LView`.\n */\nexport function getLView(): LView {\n  return instructionState.lFrame.lView;\n}\n\n/**\n * Return the current `TView`.\n */\nexport function getTView(): TView {\n  return instructionState.lFrame.tView;\n}\n\n/**\n * Restores `contextViewData` to the given OpaqueViewState instance.\n *\n * Used in conjunction with the getCurrentView() instruction to save a snapshot\n * of the current view and restore it when listeners are invoked. This allows\n * walking the declaration view tree in listeners to get vars from parent views.\n *\n * @param viewToRestore The OpaqueViewState instance to restore.\n *\n * @codeGenApi\n */\nexport function ɵɵrestoreView(viewToRestore: OpaqueViewState) {\n  instructionState.lFrame.contextLView = viewToRestore as any as LView;\n}\n\nexport function getPreviousOrParentTNode(): TNode {\n  return instructionState.lFrame.previousOrParentTNode;\n}\n\nexport function setPreviousOrParentTNode(tNode: TNode, _isParent: boolean) {\n  instructionState.lFrame.previousOrParentTNode = tNode;\n  instructionState.lFrame.isParent = _isParent;\n}\n\nexport function getIsParent(): boolean {\n  return instructionState.lFrame.isParent;\n}\n\nexport function setIsNotParent(): void {\n  instructionState.lFrame.isParent = false;\n}\nexport function setIsParent(): void {\n  instructionState.lFrame.isParent = true;\n}\n\nexport function getContextLView(): LView {\n  return instructionState.lFrame.contextLView;\n}\n\nexport function getCheckNoChangesMode(): boolean {\n  // TODO(misko): remove this from the LView since it is ngDevMode=true mode only.\n  return instructionState.checkNoChangesMode;\n}\n\nexport function setCheckNoChangesMode(mode: boolean): void {\n  instructionState.checkNoChangesMode = mode;\n}\n\n// top level variables should not be exported for performance reasons (PERF_NOTES.md)\nexport function getBindingRoot() {\n  const lFrame = instructionState.lFrame;\n  let index = lFrame.bindingRootIndex;\n  if (index === -1) {\n    index = lFrame.bindingRootIndex = lFrame.tView.bindingStartIndex;\n  }\n  return index;\n}\n\nexport function getBindingIndex(): number {\n  return instructionState.lFrame.bindingIndex;\n}\n\nexport function setBindingIndex(value: number): number {\n  return instructionState.lFrame.bindingIndex = value;\n}\n\nexport function nextBindingIndex(): number {\n  return instructionState.lFrame.bindingIndex++;\n}\n\nexport function incrementBindingIndex(count: number): number {\n  const lFrame = instructionState.lFrame;\n  const index = lFrame.bindingIndex;\n  lFrame.bindingIndex = lFrame.bindingIndex + count;\n  return index;\n}\n\n/**\n * Set a new binding root index so that host template functions can execute.\n *\n * Bindings inside the host template are 0 index. But because we don't know ahead of time\n * how many host bindings we have we can't pre-compute them. For this reason they are all\n * 0 index and we just shift the root so that they match next available location in the LView.\n *\n * @param bindingRootIndex Root index for `hostBindings`\n * @param currentDirectiveIndex `TData[currentDirectiveIndex]` will point to the current directive\n *        whose `hostBindings` are being processed.\n */\nexport function setBindingRootForHostBindings(\n    bindingRootIndex: number, currentDirectiveIndex: number) {\n  const lFrame = instructionState.lFrame;\n  lFrame.bindingIndex = lFrame.bindingRootIndex = bindingRootIndex;\n  lFrame.currentDirectiveIndex = currentDirectiveIndex;\n}\n\n/**\n * When host binding is executing this points to the directive index.\n * `TView.data[getCurrentDirectiveIndex()]` is `DirectiveDef`\n * `LView[getCurrentDirectiveIndex()]` is directive instance.\n */\nexport function getCurrentDirectiveIndex(): number {\n  return instructionState.lFrame.currentDirectiveIndex;\n}\n\nexport function getCurrentQueryIndex(): number {\n  return instructionState.lFrame.currentQueryIndex;\n}\n\nexport function setCurrentQueryIndex(value: number): void {\n  instructionState.lFrame.currentQueryIndex = value;\n}\n\n/**\n * This is a light weight version of the `enterView` which is needed by the DI system.\n * @param newView\n * @param tNode\n */\nexport function enterDI(newView: LView, tNode: TNode) {\n  ngDevMode && assertLViewOrUndefined(newView);\n  const newLFrame = allocLFrame();\n  instructionState.lFrame = newLFrame;\n  newLFrame.previousOrParentTNode = tNode !;\n  newLFrame.lView = newView;\n  if (ngDevMode) {\n    // resetting for safety in dev mode only.\n    newLFrame.isParent = DEV_MODE_VALUE;\n    newLFrame.selectedIndex = DEV_MODE_VALUE;\n    newLFrame.contextLView = DEV_MODE_VALUE;\n    newLFrame.elementDepthCount = DEV_MODE_VALUE;\n    newLFrame.currentNamespace = DEV_MODE_VALUE;\n    newLFrame.currentSanitizer = DEV_MODE_VALUE;\n    newLFrame.bindingRootIndex = DEV_MODE_VALUE;\n    newLFrame.currentQueryIndex = DEV_MODE_VALUE;\n  }\n}\n\nconst DEV_MODE_VALUE: any =\n    'Value indicating that DI is trying to read value which it should not need to know about.';\n\n/**\n * This is a light weight version of the `leaveView` which is needed by the DI system.\n *\n * Because the implementation is same it is only an alias\n */\nexport const leaveDI = leaveView;\n\n/**\n * Swap the current lView with a new lView.\n *\n * For performance reasons we store the lView in the top level of the module.\n * This way we minimize the number of properties to read. Whenever a new view\n * is entered we have to store the lView for later, and when the view is\n * exited the state has to be restored\n *\n * @param newView New lView to become active\n * @param tNode Element to which the View is a child of\n * @returns the previously active lView;\n */\nexport function enterView(newView: LView, tNode: TNode | null): void {\n  ngDevMode && assertLViewOrUndefined(newView);\n  const newLFrame = allocLFrame();\n  const tView = newView[TVIEW];\n  instructionState.lFrame = newLFrame;\n  newLFrame.previousOrParentTNode = tNode !;\n  newLFrame.isParent = true;\n  newLFrame.lView = newView;\n  newLFrame.tView = tView;\n  newLFrame.selectedIndex = 0;\n  newLFrame.contextLView = newView !;\n  newLFrame.elementDepthCount = 0;\n  newLFrame.currentDirectiveIndex = -1;\n  newLFrame.currentNamespace = null;\n  newLFrame.currentSanitizer = null;\n  newLFrame.bindingRootIndex = -1;\n  newLFrame.bindingIndex = tView.bindingStartIndex;\n  newLFrame.currentQueryIndex = 0;\n}\n\n/**\n * Allocates next free LFrame. This function tries to reuse the `LFrame`s to lower memory pressure.\n */\nfunction allocLFrame() {\n  const currentLFrame = instructionState.lFrame;\n  const childLFrame = currentLFrame === null ? null : currentLFrame.child;\n  const newLFrame = childLFrame === null ? createLFrame(currentLFrame) : childLFrame;\n  return newLFrame;\n}\n\nfunction createLFrame(parent: LFrame | null): LFrame {\n  const lFrame: LFrame = {\n    previousOrParentTNode: null !,  //\n    isParent: true,                 //\n    lView: null !,                  //\n    tView: null !,                  //\n    selectedIndex: 0,               //\n    contextLView: null !,           //\n    elementDepthCount: 0,           //\n    currentNamespace: null,         //\n    currentSanitizer: null,         //\n    currentDirectiveIndex: -1,      //\n    bindingRootIndex: -1,           //\n    bindingIndex: -1,               //\n    currentQueryIndex: 0,           //\n    parent: parent !,               //\n    child: null,                    //\n  };\n  parent !== null && (parent.child = lFrame);  // link the new LFrame for reuse.\n  return lFrame;\n}\n\nexport function leaveView() {\n  instructionState.lFrame = instructionState.lFrame.parent;\n}\n\nexport function nextContextImpl<T = any>(level: number): T {\n  const contextLView = instructionState.lFrame.contextLView =\n      walkUpViews(level, instructionState.lFrame.contextLView !);\n  return contextLView[CONTEXT] as T;\n}\n\nfunction walkUpViews(nestingLevel: number, currentView: LView): LView {\n  while (nestingLevel > 0) {\n    ngDevMode && assertDefined(\n                     currentView[DECLARATION_VIEW],\n                     'Declaration view should be defined if nesting level is greater than 0.');\n    currentView = currentView[DECLARATION_VIEW] !;\n    nestingLevel--;\n  }\n  return currentView;\n}\n\n/**\n * Gets the currently selected element index.\n *\n * Used with {@link property} instruction (and more in the future) to identify the index in the\n * current `LView` to act on.\n */\nexport function getSelectedIndex() {\n  return instructionState.lFrame.selectedIndex;\n}\n\n/**\n * Sets the most recent index passed to {@link select}\n *\n * Used with {@link property} instruction (and more in the future) to identify the index in the\n * current `LView` to act on.\n *\n * (Note that if an \"exit function\" was set earlier (via `setElementExitFn()`) then that will be\n * run if and when the provided `index` value is different from the current selected index value.)\n */\nexport function setSelectedIndex(index: number) {\n  instructionState.lFrame.selectedIndex = index;\n}\n\n\n/**\n * Sets the namespace used to create elements to `'http://www.w3.org/2000/svg'` in global state.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceSVG() {\n  instructionState.lFrame.currentNamespace = SVG_NAMESPACE;\n}\n\n/**\n * Sets the namespace used to create elements to `'http://www.w3.org/1998/MathML/'` in global state.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceMathML() {\n  instructionState.lFrame.currentNamespace = MATH_ML_NAMESPACE;\n}\n\n/**\n * Sets the namespace used to create elements to `null`, which forces element creation to use\n * `createElement` rather than `createElementNS`.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceHTML() {\n  namespaceHTMLInternal();\n}\n\n/**\n * Sets the namespace used to create elements to `null`, which forces element creation to use\n * `createElement` rather than `createElementNS`.\n */\nexport function namespaceHTMLInternal() {\n  instructionState.lFrame.currentNamespace = null;\n}\n\nexport function getNamespace(): string|null {\n  return instructionState.lFrame.currentNamespace;\n}\n\nexport function setCurrentStyleSanitizer(sanitizer: StyleSanitizeFn | null) {\n  instructionState.lFrame.currentSanitizer = sanitizer;\n}\n\nexport function resetCurrentStyleSanitizer() {\n  setCurrentStyleSanitizer(null);\n}\n\nexport function getCurrentStyleSanitizer() {\n  // TODO(misko): This should throw when there is no LView, but it turns out we can get here from\n  // `NodeStyleDebug` hence we return `null`. This should be fixed\n  const lFrame = instructionState.lFrame;\n  return lFrame === null ? null : lFrame.currentSanitizer;\n}\n"]}
@@ -0,0 +1,47 @@
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * Generated from: packages/core/src/render3/styling/class_differ.ts
4
+ * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
+ */
6
+ /**
7
+ * @license
8
+ * Copyright Google Inc. All Rights Reserved.
9
+ *
10
+ * Use of this source code is governed by an MIT-style license that can be
11
+ * found in the LICENSE file at https://angular.io/license
12
+ */
13
+ import { assertNotEqual } from '../../util/assert';
14
+ /**
15
+ * Returns an index of `classToSearch` in `className` taking token boundaries into account.
16
+ *
17
+ * `classIndexOf('AB A', 'A', 0)` will be 3 (not 0 since `AB!==A`)
18
+ *
19
+ * @param {?} className A string containing classes (whitespace separated)
20
+ * @param {?} classToSearch A class name to locate
21
+ * @param {?} startingIndex Starting location of search
22
+ * @return {?} an index of the located class (or -1 if not found)
23
+ */
24
+ export function classIndexOf(className, classToSearch, startingIndex) {
25
+ ngDevMode && assertNotEqual(classToSearch, '', 'can not look for "" string.');
26
+ /** @type {?} */
27
+ let end = className.length;
28
+ while (true) {
29
+ /** @type {?} */
30
+ const foundIndex = className.indexOf(classToSearch, startingIndex);
31
+ if (foundIndex === -1)
32
+ return foundIndex;
33
+ if (foundIndex === 0 || className.charCodeAt(foundIndex - 1) <= 32 /* SPACE */) {
34
+ // Ensure that it has leading whitespace
35
+ /** @type {?} */
36
+ const length = classToSearch.length;
37
+ if (foundIndex + length === end ||
38
+ className.charCodeAt(foundIndex + length) <= 32 /* SPACE */) {
39
+ // Ensure that it has trailing whitespace
40
+ return foundIndex;
41
+ }
42
+ }
43
+ // False positive, keep searching from where we left off.
44
+ startingIndex = foundIndex + 1;
45
+ }
46
+ }
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xhc3NfZGlmZmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvcmVuZGVyMy9zdHlsaW5nL2NsYXNzX2RpZmZlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFRQSxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sbUJBQW1CLENBQUM7Ozs7Ozs7Ozs7O0FBY2pELE1BQU0sVUFBVSxZQUFZLENBQ3hCLFNBQWlCLEVBQUUsYUFBcUIsRUFBRSxhQUFxQjtJQUNqRSxTQUFTLElBQUksY0FBYyxDQUFDLGFBQWEsRUFBRSxFQUFFLEVBQUUsNkJBQTZCLENBQUMsQ0FBQzs7UUFDMUUsR0FBRyxHQUFHLFNBQVMsQ0FBQyxNQUFNO0lBQzFCLE9BQU8sSUFBSSxFQUFFOztjQUNMLFVBQVUsR0FBRyxTQUFTLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxhQUFhLENBQUM7UUFDbEUsSUFBSSxVQUFVLEtBQUssQ0FBQyxDQUFDO1lBQUUsT0FBTyxVQUFVLENBQUM7UUFDekMsSUFBSSxVQUFVLEtBQUssQ0FBQyxJQUFJLFNBQVMsQ0FBQyxVQUFVLENBQUMsVUFBVSxHQUFHLENBQUMsQ0FBQyxrQkFBa0IsRUFBRTs7O2tCQUV4RSxNQUFNLEdBQUcsYUFBYSxDQUFDLE1BQU07WUFDbkMsSUFBSSxVQUFVLEdBQUcsTUFBTSxLQUFLLEdBQUc7Z0JBQzNCLFNBQVMsQ0FBQyxVQUFVLENBQUMsVUFBVSxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsRUFBRTtnQkFDL0QseUNBQXlDO2dCQUN6QyxPQUFPLFVBQVUsQ0FBQzthQUNuQjtTQUNGO1FBQ0QseURBQXlEO1FBQ3pELGFBQWEsR0FBRyxVQUFVLEdBQUcsQ0FBQyxDQUFDO0tBQ2hDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuKiBAbGljZW5zZVxuKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbipcbiogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuKi9cblxuaW1wb3J0IHthc3NlcnROb3RFcXVhbH0gZnJvbSAnLi4vLi4vdXRpbC9hc3NlcnQnO1xuaW1wb3J0IHtDaGFyQ29kZX0gZnJvbSAnLi4vLi4vdXRpbC9jaGFyX2NvZGUnO1xuXG5cbi8qKlxuICogUmV0dXJucyBhbiBpbmRleCBvZiBgY2xhc3NUb1NlYXJjaGAgaW4gYGNsYXNzTmFtZWAgdGFraW5nIHRva2VuIGJvdW5kYXJpZXMgaW50byBhY2NvdW50LlxuICpcbiAqIGBjbGFzc0luZGV4T2YoJ0FCIEEnLCAnQScsIDApYCB3aWxsIGJlIDMgKG5vdCAwIHNpbmNlIGBBQiE9PUFgKVxuICpcbiAqIEBwYXJhbSBjbGFzc05hbWUgQSBzdHJpbmcgY29udGFpbmluZyBjbGFzc2VzICh3aGl0ZXNwYWNlIHNlcGFyYXRlZClcbiAqIEBwYXJhbSBjbGFzc1RvU2VhcmNoIEEgY2xhc3MgbmFtZSB0byBsb2NhdGVcbiAqIEBwYXJhbSBzdGFydGluZ0luZGV4IFN0YXJ0aW5nIGxvY2F0aW9uIG9mIHNlYXJjaFxuICogQHJldHVybnMgYW4gaW5kZXggb2YgdGhlIGxvY2F0ZWQgY2xhc3MgKG9yIC0xIGlmIG5vdCBmb3VuZClcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNsYXNzSW5kZXhPZihcbiAgICBjbGFzc05hbWU6IHN0cmluZywgY2xhc3NUb1NlYXJjaDogc3RyaW5nLCBzdGFydGluZ0luZGV4OiBudW1iZXIpOiBudW1iZXIge1xuICBuZ0Rldk1vZGUgJiYgYXNzZXJ0Tm90RXF1YWwoY2xhc3NUb1NlYXJjaCwgJycsICdjYW4gbm90IGxvb2sgZm9yIFwiXCIgc3RyaW5nLicpO1xuICBsZXQgZW5kID0gY2xhc3NOYW1lLmxlbmd0aDtcbiAgd2hpbGUgKHRydWUpIHtcbiAgICBjb25zdCBmb3VuZEluZGV4ID0gY2xhc3NOYW1lLmluZGV4T2YoY2xhc3NUb1NlYXJjaCwgc3RhcnRpbmdJbmRleCk7XG4gICAgaWYgKGZvdW5kSW5kZXggPT09IC0xKSByZXR1cm4gZm91bmRJbmRleDtcbiAgICBpZiAoZm91bmRJbmRleCA9PT0gMCB8fCBjbGFzc05hbWUuY2hhckNvZGVBdChmb3VuZEluZGV4IC0gMSkgPD0gQ2hhckNvZGUuU1BBQ0UpIHtcbiAgICAgIC8vIEVuc3VyZSB0aGF0IGl0IGhhcyBsZWFkaW5nIHdoaXRlc3BhY2VcbiAgICAgIGNvbnN0IGxlbmd0aCA9IGNsYXNzVG9TZWFyY2gubGVuZ3RoO1xuICAgICAgaWYgKGZvdW5kSW5kZXggKyBsZW5ndGggPT09IGVuZCB8fFxuICAgICAgICAgIGNsYXNzTmFtZS5jaGFyQ29kZUF0KGZvdW5kSW5kZXggKyBsZW5ndGgpIDw9IENoYXJDb2RlLlNQQUNFKSB7XG4gICAgICAgIC8vIEVuc3VyZSB0aGF0IGl0IGhhcyB0cmFpbGluZyB3aGl0ZXNwYWNlXG4gICAgICAgIHJldHVybiBmb3VuZEluZGV4O1xuICAgICAgfVxuICAgIH1cbiAgICAvLyBGYWxzZSBwb3NpdGl2ZSwga2VlcCBzZWFyY2hpbmcgZnJvbSB3aGVyZSB3ZSBsZWZ0IG9mZi5cbiAgICBzdGFydGluZ0luZGV4ID0gZm91bmRJbmRleCArIDE7XG4gIH1cbn0iXX0=