@angular/core 9.0.0-rc.9 → 9.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (196) hide show
  1. package/bundles/core-testing.umd.js +10 -9
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +6 -6
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +3619 -3914
  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 +483 -651
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.js +17 -17
  12. package/esm2015/index.js +2 -2
  13. package/esm2015/public_api.js +2 -2
  14. package/esm2015/src/application_ref.js +7 -7
  15. package/esm2015/src/core.js +3 -3
  16. package/esm2015/src/core_private_export.js +7 -7
  17. package/esm2015/src/core_render3_private_export.js +2 -2
  18. package/esm2015/src/debug/debug_node.js +44 -12
  19. package/esm2015/src/i18n/locale_data_api.js +1 -2
  20. package/esm2015/src/interface/type.js +1 -1
  21. package/esm2015/src/metadata/ng_module.js +1 -1
  22. package/esm2015/src/render/api.js +4 -1
  23. package/esm2015/src/render3/assert.js +9 -1
  24. package/esm2015/src/render3/bindings.js +16 -5
  25. package/esm2015/src/render3/component.js +54 -25
  26. package/esm2015/src/render3/component_ref.js +11 -15
  27. package/esm2015/src/render3/definition.js +3 -1
  28. package/esm2015/src/render3/di.js +3 -4
  29. package/esm2015/src/render3/di_setup.js +5 -7
  30. package/esm2015/src/render3/errors.js +3 -1
  31. package/esm2015/src/render3/features/inherit_definition_feature.js +41 -13
  32. package/esm2015/src/render3/features/ng_onchanges_feature.js +2 -2
  33. package/esm2015/src/render3/global_utils_api.js +3 -3
  34. package/esm2015/src/render3/i18n.js +60 -56
  35. package/esm2015/src/render3/index.js +2 -2
  36. package/esm2015/src/render3/instructions/advance.js +10 -11
  37. package/esm2015/src/render3/instructions/all.js +4 -5
  38. package/esm2015/src/render3/instructions/attribute.js +6 -6
  39. package/esm2015/src/render3/instructions/attribute_interpolation.js +40 -21
  40. package/esm2015/src/render3/instructions/change_detection.js +8 -23
  41. package/esm2015/src/render3/instructions/class_map_interpolation.js +13 -12
  42. package/esm2015/src/render3/instructions/container.js +15 -12
  43. package/esm2015/src/render3/instructions/element.js +40 -127
  44. package/esm2015/src/render3/instructions/element_container.js +8 -10
  45. package/esm2015/src/render3/instructions/embedded_view.js +7 -7
  46. package/esm2015/src/render3/instructions/host_property.js +10 -7
  47. package/esm2015/src/render3/instructions/listener.js +18 -16
  48. package/esm2015/src/render3/instructions/lview_debug.js +160 -23
  49. package/esm2015/src/render3/instructions/projection.js +7 -5
  50. package/esm2015/src/render3/instructions/property.js +27 -6
  51. package/esm2015/src/render3/instructions/property_interpolation.js +40 -22
  52. package/esm2015/src/render3/instructions/shared.js +267 -240
  53. package/esm2015/src/render3/instructions/storage.js +6 -8
  54. package/esm2015/src/render3/instructions/style_prop_interpolation.js +12 -12
  55. package/esm2015/src/render3/instructions/styling.js +731 -475
  56. package/esm2015/src/render3/instructions/text.js +5 -5
  57. package/esm2015/src/render3/interfaces/definition.js +41 -1
  58. package/esm2015/src/render3/interfaces/node.js +160 -115
  59. package/esm2015/src/render3/interfaces/styling.js +183 -375
  60. package/esm2015/src/render3/interfaces/view.js +10 -2
  61. package/esm2015/src/render3/jit/environment.js +1 -3
  62. package/esm2015/src/render3/node_manipulation.js +177 -57
  63. package/esm2015/src/render3/node_selector_matcher.js +39 -24
  64. package/esm2015/src/render3/node_util.js +12 -7
  65. package/esm2015/src/render3/pipe.js +4 -6
  66. package/esm2015/src/render3/query.js +32 -26
  67. package/esm2015/src/render3/state.js +54 -183
  68. package/esm2015/src/render3/styling/class_differ.js +47 -0
  69. package/esm2015/src/render3/styling/static_styling.js +54 -0
  70. package/esm2015/src/render3/styling/style_binding_list.js +437 -0
  71. package/esm2015/src/render3/styling/styling_parser.js +336 -0
  72. package/esm2015/src/render3/tokens.js +2 -2
  73. package/esm2015/src/render3/util/attrs_utils.js +125 -2
  74. package/esm2015/src/render3/util/change_detection_utils.js +33 -0
  75. package/esm2015/src/render3/util/discovery_utils.js +146 -119
  76. package/esm2015/src/render3/util/global_utils.js +5 -5
  77. package/esm2015/src/render3/util/view_utils.js +6 -6
  78. package/esm2015/src/render3/view_engine_compatibility.js +16 -17
  79. package/esm2015/src/render3/view_ref.js +16 -13
  80. package/esm2015/src/sanitization/bypass.js +1 -1
  81. package/esm2015/src/sanitization/sanitization.js +20 -5
  82. package/esm2015/src/util/array_utils.js +240 -1
  83. package/esm2015/src/util/assert.js +37 -21
  84. package/esm2015/src/util/char_code.js +8 -0
  85. package/esm2015/src/util/iterable.js +4 -1
  86. package/esm2015/src/util/ng_dev_mode.js +1 -12
  87. package/esm2015/src/util/stringify.js +14 -1
  88. package/esm2015/src/version.js +1 -1
  89. package/esm2015/testing/src/r3_test_bed.js +5 -1
  90. package/esm2015/testing/src/r3_test_bed_compiler.js +2 -12
  91. package/esm2015/testing/src/styling.js +103 -0
  92. package/esm5/core.js +17 -17
  93. package/esm5/src/application_ref.js +6 -6
  94. package/esm5/src/core_private_export.js +7 -7
  95. package/esm5/src/core_render3_private_export.js +2 -2
  96. package/esm5/src/debug/debug_node.js +29 -11
  97. package/esm5/src/i18n/locale_data_api.js +1 -2
  98. package/esm5/src/interface/type.js +1 -1
  99. package/esm5/src/metadata/ng_module.js +1 -1
  100. package/esm5/src/render/api.js +4 -1
  101. package/esm5/src/render3/assert.js +4 -1
  102. package/esm5/src/render3/bindings.js +19 -2
  103. package/esm5/src/render3/component.js +47 -22
  104. package/esm5/src/render3/component_ref.js +9 -14
  105. package/esm5/src/render3/definition.js +3 -1
  106. package/esm5/src/render3/di.js +3 -4
  107. package/esm5/src/render3/di_setup.js +4 -5
  108. package/esm5/src/render3/errors.js +3 -1
  109. package/esm5/src/render3/features/inherit_definition_feature.js +36 -12
  110. package/esm5/src/render3/features/ng_onchanges_feature.js +1 -1
  111. package/esm5/src/render3/global_utils_api.js +3 -3
  112. package/esm5/src/render3/i18n.js +51 -51
  113. package/esm5/src/render3/index.js +2 -2
  114. package/esm5/src/render3/instructions/advance.js +9 -11
  115. package/esm5/src/render3/instructions/all.js +1 -2
  116. package/esm5/src/render3/instructions/attribute.js +5 -6
  117. package/esm5/src/render3/instructions/attribute_interpolation.js +31 -21
  118. package/esm5/src/render3/instructions/change_detection.js +8 -21
  119. package/esm5/src/render3/instructions/class_map_interpolation.js +13 -12
  120. package/esm5/src/render3/instructions/container.js +13 -12
  121. package/esm5/src/render3/instructions/element.js +36 -108
  122. package/esm5/src/render3/instructions/element_container.js +8 -9
  123. package/esm5/src/render3/instructions/embedded_view.js +7 -7
  124. package/esm5/src/render3/instructions/host_property.js +8 -7
  125. package/esm5/src/render3/instructions/listener.js +13 -13
  126. package/esm5/src/render3/instructions/lview_debug.js +56 -15
  127. package/esm5/src/render3/instructions/projection.js +6 -5
  128. package/esm5/src/render3/instructions/property.js +17 -6
  129. package/esm5/src/render3/instructions/property_interpolation.js +31 -23
  130. package/esm5/src/render3/instructions/shared.js +247 -207
  131. package/esm5/src/render3/instructions/storage.js +4 -6
  132. package/esm5/src/render3/instructions/style_prop_interpolation.js +12 -12
  133. package/esm5/src/render3/instructions/styling.js +685 -367
  134. package/esm5/src/render3/instructions/text.js +5 -5
  135. package/esm5/src/render3/interfaces/definition.js +1 -1
  136. package/esm5/src/render3/interfaces/node.js +49 -1
  137. package/esm5/src/render3/interfaces/styling.js +57 -1
  138. package/esm5/src/render3/interfaces/view.js +1 -1
  139. package/esm5/src/render3/jit/environment.js +1 -3
  140. package/esm5/src/render3/node_manipulation.js +167 -54
  141. package/esm5/src/render3/node_selector_matcher.js +40 -20
  142. package/esm5/src/render3/node_util.js +12 -7
  143. package/esm5/src/render3/pipe.js +4 -6
  144. package/esm5/src/render3/query.js +25 -24
  145. package/esm5/src/render3/state.js +34 -131
  146. package/esm5/src/render3/styling/class_differ.js +39 -0
  147. package/esm5/src/render3/styling/static_styling.js +42 -0
  148. package/esm5/src/render3/styling/style_binding_list.js +411 -0
  149. package/esm5/src/render3/styling/styling_parser.js +265 -0
  150. package/esm5/src/render3/tokens.js +2 -2
  151. package/esm5/src/render3/util/attrs_utils.js +117 -2
  152. package/esm5/src/render3/util/change_detection_utils.js +23 -0
  153. package/esm5/src/render3/util/discovery_utils.js +115 -99
  154. package/esm5/src/render3/util/global_utils.js +5 -5
  155. package/esm5/src/render3/util/view_utils.js +5 -5
  156. package/esm5/src/render3/view_engine_compatibility.js +37 -39
  157. package/esm5/src/render3/view_ref.js +14 -13
  158. package/esm5/src/sanitization/bypass.js +1 -1
  159. package/esm5/src/sanitization/sanitization.js +16 -5
  160. package/esm5/src/util/array_utils.js +240 -1
  161. package/esm5/src/util/assert.js +37 -21
  162. package/esm5/src/util/char_code.js +8 -0
  163. package/esm5/src/util/iterable.js +4 -1
  164. package/esm5/src/util/ng_dev_mode.js +1 -12
  165. package/esm5/src/util/stringify.js +14 -1
  166. package/esm5/src/version.js +1 -1
  167. package/esm5/testing/src/r3_test_bed.js +9 -1
  168. package/esm5/testing/src/r3_test_bed_compiler.js +2 -9
  169. package/esm5/testing/src/styling.js +82 -0
  170. package/fesm2015/core.js +5917 -6880
  171. package/fesm2015/core.js.map +1 -1
  172. package/fesm2015/testing.js +6 -12
  173. package/fesm2015/testing.js.map +1 -1
  174. package/fesm5/core.js +3588 -3884
  175. package/fesm5/core.js.map +1 -1
  176. package/fesm5/testing.js +10 -9
  177. package/fesm5/testing.js.map +1 -1
  178. package/package.json +1 -1
  179. package/src/r3_symbols.d.ts +1 -1
  180. package/testing/testing.d.ts +1 -3
  181. package/testing/testing.metadata.json +1 -1
  182. package/testing.d.ts +1 -1
  183. package/esm2015/global.js +0 -7
  184. package/esm2015/src/render3/instructions/alloc_host_vars.js +0 -80
  185. package/esm2015/src/render3/styling/bindings.js +0 -1248
  186. package/esm2015/src/render3/styling/map_based_bindings.js +0 -384
  187. package/esm2015/src/render3/styling/state.js +0 -135
  188. package/esm2015/src/render3/styling/styling_debug.js +0 -655
  189. package/esm2015/src/render3/util/styling_utils.js +0 -625
  190. package/esm5/global.js +0 -9
  191. package/esm5/src/render3/instructions/alloc_host_vars.js +0 -62
  192. package/esm5/src/render3/styling/bindings.js +0 -949
  193. package/esm5/src/render3/styling/map_based_bindings.js +0 -310
  194. package/esm5/src/render3/styling/state.js +0 -56
  195. package/esm5/src/render3/styling/styling_debug.js +0 -315
  196. package/esm5/src/render3/util/styling_utils.js +0 -378
@@ -10,7 +10,7 @@
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
16
  /**
@@ -41,10 +41,18 @@ if (false) {
41
41
  * @type {?}
42
42
  */
43
43
  LFrame.prototype.lView;
44
+ /**
45
+ * Current `TView` associated with the `LFrame.lView`.
46
+ *
47
+ * One can get `TView` from `lFrame[TVIEW]` however because it is so common it makes sense to
48
+ * store it in `LFrame` for perf reasons.
49
+ * @type {?}
50
+ */
51
+ LFrame.prototype.tView;
44
52
  /**
45
53
  * Used to set the parent property when nodes are created and track query results.
46
54
  *
47
- * This is used in conjection with `isParent`.
55
+ * This is used in conjunction with `isParent`.
48
56
  * @type {?}
49
57
  */
50
58
  LFrame.prototype.previousOrParentTNode;
@@ -93,20 +101,6 @@ if (false) {
93
101
  * @type {?}
94
102
  */
95
103
  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
104
  /**
111
105
  * The root index from which pure function instructions should calculate their binding
112
106
  * indices. In component views, this is TView.bindingStartIndex. In a host binding
@@ -120,6 +114,13 @@ if (false) {
120
114
  * @type {?}
121
115
  */
122
116
  LFrame.prototype.currentQueryIndex;
117
+ /**
118
+ * When host binding is executing this points to the directive index.
119
+ * `TView.data[currentDirectiveIndex]` is `DirectiveDef`
120
+ * `LView[currentDirectiveIndex]` is directive instance.
121
+ * @type {?}
122
+ */
123
+ LFrame.prototype.currentDirectiveIndex;
123
124
  }
124
125
  /**
125
126
  * All implicit instruction state is stored here.
@@ -167,19 +168,11 @@ if (false) {
167
168
  * @type {?}
168
169
  */
169
170
  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
171
  }
178
172
  /** @type {?} */
179
173
  export const instructionState = {
180
174
  lFrame: createLFrame(null),
181
175
  bindingsEnabled: true,
182
- elementExitFn: null,
183
176
  checkNoChangesMode: false,
184
177
  };
185
178
  /**
@@ -200,19 +193,6 @@ export function increaseElementDepthCount() {
200
193
  export function decreaseElementDepthCount() {
201
194
  instructionState.lFrame.elementDepthCount--;
202
195
  }
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
196
  /**
217
197
  * @return {?}
218
198
  */
@@ -266,132 +246,18 @@ export function ɵɵdisableBindings() {
266
246
  instructionState.bindingsEnabled = false;
267
247
  }
268
248
  /**
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.)
249
+ * Return the current `LView`.
273
250
  * @return {?}
274
251
  */
275
252
  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;
253
+ return instructionState.lFrame.lView;
366
254
  }
367
255
  /**
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).
256
+ * Return the current `TView`.
386
257
  * @return {?}
387
258
  */
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;
259
+ export function getTView() {
260
+ return instructionState.lFrame.tView;
395
261
  }
396
262
  /**
397
263
  * Restores `contextViewData` to the given OpaqueViewState instance.
@@ -451,6 +317,7 @@ export function getContextLView() {
451
317
  * @return {?}
452
318
  */
453
319
  export function getCheckNoChangesMode() {
320
+ // TODO(misko): remove this from the LView since it is ngDevMode=true mode only.
454
321
  return instructionState.checkNoChangesMode;
455
322
  }
456
323
  /**
@@ -470,9 +337,7 @@ export function getBindingRoot() {
470
337
  /** @type {?} */
471
338
  let index = lFrame.bindingRootIndex;
472
339
  if (index === -1) {
473
- /** @type {?} */
474
- const lView = lFrame.lView;
475
- index = lFrame.bindingRootIndex = lView[TVIEW].bindingStartIndex;
340
+ index = lFrame.bindingRootIndex = lFrame.tView.bindingStartIndex;
476
341
  }
477
342
  return index;
478
343
  }
@@ -513,11 +378,26 @@ export function incrementBindingIndex(count) {
513
378
  * Bindings inside the host template are 0 index. But because we don't know ahead of time
514
379
  * how many host bindings we have we can't pre-compute them. For this reason they are all
515
380
  * 0 index and we just shift the root so that they match next available location in the LView.
516
- * @param {?} value
381
+ *
382
+ * @param {?} bindingRootIndex Root index for `hostBindings`
383
+ * @param {?} currentDirectiveIndex `TData[currentDirectiveIndex]` will point to the current directive
384
+ * whose `hostBindings` are being processed.
517
385
  * @return {?}
518
386
  */
519
- export function setBindingRoot(value) {
520
- instructionState.lFrame.bindingRootIndex = value;
387
+ export function setBindingRootForHostBindings(bindingRootIndex, currentDirectiveIndex) {
388
+ /** @type {?} */
389
+ const lFrame = instructionState.lFrame;
390
+ lFrame.bindingIndex = lFrame.bindingRootIndex = bindingRootIndex;
391
+ lFrame.currentDirectiveIndex = currentDirectiveIndex;
392
+ }
393
+ /**
394
+ * When host binding is executing this points to the directive index.
395
+ * `TView.data[getCurrentDirectiveIndex()]` is `DirectiveDef`
396
+ * `LView[getCurrentDirectiveIndex()]` is directive instance.
397
+ * @return {?}
398
+ */
399
+ export function getCurrentDirectiveIndex() {
400
+ return instructionState.lFrame.currentDirectiveIndex;
521
401
  }
522
402
  /**
523
403
  * @return {?}
@@ -553,8 +433,6 @@ export function enterDI(newView, tNode) {
553
433
  newLFrame.elementDepthCount = DEV_MODE_VALUE;
554
434
  newLFrame.currentNamespace = DEV_MODE_VALUE;
555
435
  newLFrame.currentSanitizer = DEV_MODE_VALUE;
556
- newLFrame.currentDirectiveDef = DEV_MODE_VALUE;
557
- newLFrame.activeDirectiveId = DEV_MODE_VALUE;
558
436
  newLFrame.bindingRootIndex = DEV_MODE_VALUE;
559
437
  newLFrame.currentQueryIndex = DEV_MODE_VALUE;
560
438
  }
@@ -584,19 +462,21 @@ export function enterView(newView, tNode) {
584
462
  ngDevMode && assertLViewOrUndefined(newView);
585
463
  /** @type {?} */
586
464
  const newLFrame = allocLFrame();
465
+ /** @type {?} */
466
+ const tView = newView[TVIEW];
587
467
  instructionState.lFrame = newLFrame;
588
468
  newLFrame.previousOrParentTNode = (/** @type {?} */ (tNode));
589
469
  newLFrame.isParent = true;
590
470
  newLFrame.lView = newView;
471
+ newLFrame.tView = tView;
591
472
  newLFrame.selectedIndex = 0;
592
473
  newLFrame.contextLView = (/** @type {?} */ (newView));
593
474
  newLFrame.elementDepthCount = 0;
475
+ newLFrame.currentDirectiveIndex = -1;
594
476
  newLFrame.currentNamespace = null;
595
477
  newLFrame.currentSanitizer = null;
596
- newLFrame.currentDirectiveDef = null;
597
- newLFrame.activeDirectiveId = 0;
598
478
  newLFrame.bindingRootIndex = -1;
599
- newLFrame.bindingIndex = newView === null ? -1 : newView[TVIEW].bindingStartIndex;
479
+ newLFrame.bindingIndex = tView.bindingStartIndex;
600
480
  newLFrame.currentQueryIndex = 0;
601
481
  }
602
482
  /**
@@ -625,6 +505,8 @@ function createLFrame(parent) {
625
505
  //
626
506
  lView: (/** @type {?} */ (null)),
627
507
  //
508
+ tView: (/** @type {?} */ (null)),
509
+ //
628
510
  selectedIndex: 0,
629
511
  //
630
512
  contextLView: (/** @type {?} */ (null)),
@@ -635,9 +517,7 @@ function createLFrame(parent) {
635
517
  //
636
518
  currentSanitizer: null,
637
519
  //
638
- currentDirectiveDef: null,
639
- //
640
- activeDirectiveId: 0,
520
+ currentDirectiveIndex: -1,
641
521
  //
642
522
  bindingRootIndex: -1,
643
523
  //
@@ -652,15 +532,6 @@ function createLFrame(parent) {
652
532
  parent !== null && (parent.child = lFrame); // link the new LFrame for reuse.
653
533
  return lFrame;
654
534
  }
655
- /**
656
- * @return {?}
657
- */
658
- export function leaveViewProcessExit() {
659
- if (hasActiveElementFlag(1 /* RunExitFn */)) {
660
- executeElementExitFn();
661
- }
662
- leaveView();
663
- }
664
535
  /**
665
536
  * @return {?}
666
537
  */
@@ -692,14 +563,14 @@ function walkUpViews(nestingLevel, currentView) {
692
563
  return currentView;
693
564
  }
694
565
  /**
695
- * Gets the most recent index passed to {\@link select}
566
+ * Gets the currently selected element index.
696
567
  *
697
568
  * Used with {\@link property} instruction (and more in the future) to identify the index in the
698
569
  * current `LView` to act on.
699
570
  * @return {?}
700
571
  */
701
572
  export function getSelectedIndex() {
702
- return instructionState.lFrame.selectedIndex >> 1 /* Size */;
573
+ return instructionState.lFrame.selectedIndex;
703
574
  }
704
575
  /**
705
576
  * Sets the most recent index passed to {\@link select}
@@ -713,7 +584,7 @@ export function getSelectedIndex() {
713
584
  * @return {?}
714
585
  */
715
586
  export function setSelectedIndex(index) {
716
- instructionState.lFrame.selectedIndex = index << 1 /* Size */;
587
+ instructionState.lFrame.selectedIndex = index;
717
588
  }
718
589
  /**
719
590
  * Sets the namespace used to create elements to `'http://www.w3.org/2000/svg'` in global state.
@@ -780,4 +651,4 @@ export function getCurrentStyleSanitizer() {
780
651
  const lFrame = instructionState.lFrame;
781
652
  return lFrame === null ? null : lFrame.currentSanitizer;
782
653
  }
783
- //# 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, 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"]}
654
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/state.ts"],"names":[],"mappings":";;;;;;;;;;;;AASA,OAAO,EAAC,aAAa,EAAC,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAC,sBAAsB,EAAC,MAAM,UAAU,CAAC;AAEhD,OAAO,EAAC,OAAO,EAAE,gBAAgB,EAA0B,KAAK,EAAQ,MAAM,mBAAmB,CAAC;;;;;AAMlG,qBAuGC;;;;;;;;IAjGC,wBAAe;;;;;;;IAOf,uBAAmB;;;;;;;;IAQnB,uBAAa;;;;;;;;IAQb,uBAAa;;;;;;;IAOb,uCAA6B;;;;;;;IAO7B,0BAAkB;;;;;;;IAOlB,+BAAsB;;;;;IAKtB,8BAAqB;;;;;;;;IAQrB,8BAAoB;;;;;;;;IAQpB,mCAA0B;;;;;IAK1B,kCAA8B;;;;;IAK9B,kCAAuC;;;;;;;IAQvC,kCAAyB;;;;;;IAMzB,mCAA0B;;;;;;;IAO1B,uCAA8B;;;;;;;;;;;;AAYhC,+BAkCC;;;;;;;;IA5BC,kCAAe;;;;;;;;;;;;;;;;;;;;IAoBf,2CAAyB;;;;;;;IAOzB,8CAA4B;;;AAG9B,MAAM,OAAO,gBAAgB,GAAqB;IAChD,MAAM,EAAE,YAAY,CAAC,IAAI,CAAC;IAC1B,eAAe,EAAE,IAAI;IACrB,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,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;;;;;AAKD,MAAM,UAAU,QAAQ;IACtB,OAAO,gBAAgB,CAAC,MAAM,CAAC,KAAK,CAAC;AACvC,CAAC;;;;;AAKD,MAAM,UAAU,QAAQ;IACtB,OAAO,gBAAgB,CAAC,MAAM,CAAC,KAAK,CAAC;AACvC,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,gFAAgF;IAChF,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;QAChB,KAAK,GAAG,MAAM,CAAC,gBAAgB,GAAG,MAAM,CAAC,KAAK,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;;;;;;;;;;;;;AAaD,MAAM,UAAU,6BAA6B,CACzC,gBAAwB,EAAE,qBAA6B;;UACnD,MAAM,GAAG,gBAAgB,CAAC,MAAM;IACtC,MAAM,CAAC,YAAY,GAAG,MAAM,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;IACjE,MAAM,CAAC,qBAAqB,GAAG,qBAAqB,CAAC;AACvD,CAAC;;;;;;;AAOD,MAAM,UAAU,wBAAwB;IACtC,OAAO,gBAAgB,CAAC,MAAM,CAAC,qBAAqB,CAAC;AACvD,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,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;;UACzB,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;IAC5B,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,KAAK,GAAG,KAAK,CAAC;IACxB,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,qBAAqB,GAAG,CAAC,CAAC,CAAC;IACrC,SAAS,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAClC,SAAS,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAClC,SAAS,CAAC,gBAAgB,GAAG,CAAC,CAAC,CAAC;IAChC,SAAS,CAAC,YAAY,GAAG,KAAK,CAAC,iBAAiB,CAAC;IACjD,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,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,qBAAqB,EAAE,CAAC,CAAC;;QACzB,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,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,CAAC;AAC/C,CAAC;;;;;;;;;;;;AAWD,MAAM,UAAU,gBAAgB,CAAC,KAAa;IAC5C,gBAAgB,CAAC,MAAM,CAAC,aAAa,GAAG,KAAK,CAAC;AAChD,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} from '../util/assert';\nimport {assertLViewOrUndefined} from './assert';\nimport {TNode} from './interfaces/node';\nimport {CONTEXT, DECLARATION_VIEW, LView, OpaqueViewState, TVIEW, 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   * 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 = '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"]}
@@ -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=