@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
@@ -5,13 +5,13 @@
5
5
  * Use of this source code is governed by an MIT-style license that can be
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
- import { assertDefined, assertEqual } from '../util/assert';
8
+ import { assertDefined } from '../util/assert';
9
9
  import { assertLViewOrUndefined } from './assert';
10
10
  import { CONTEXT, DECLARATION_VIEW, TVIEW } from './interfaces/view';
11
+ import { MATH_ML_NAMESPACE, SVG_NAMESPACE } from './namespaces';
11
12
  export var instructionState = {
12
13
  lFrame: createLFrame(null),
13
14
  bindingsEnabled: true,
14
- elementExitFn: null,
15
15
  checkNoChangesMode: false,
16
16
  };
17
17
  export function getElementDepthCount() {
@@ -23,12 +23,6 @@ export function increaseElementDepthCount() {
23
23
  export function decreaseElementDepthCount() {
24
24
  instructionState.lFrame.elementDepthCount--;
25
25
  }
26
- export function getCurrentDirectiveDef() {
27
- return instructionState.lFrame.currentDirectiveDef;
28
- }
29
- export function setCurrentDirectiveDef(def) {
30
- instructionState.lFrame.currentDirectiveDef = def;
31
- }
32
26
  export function getBindingsEnabled() {
33
27
  return instructionState.bindingsEnabled;
34
28
  }
@@ -77,112 +71,16 @@ export function ɵɵdisableBindings() {
77
71
  instructionState.bindingsEnabled = false;
78
72
  }
79
73
  /**
80
- * Return the current LView.
81
- *
82
- * The return value can be `null` if the method is called outside of template. This can happen if
83
- * directive is instantiated by module injector (rather than by node injector.)
74
+ * Return the current `LView`.
84
75
  */
85
76
  export function getLView() {
86
- // TODO(misko): the return value should be `LView|null` but doing so breaks a lot of code.
87
- var lFrame = instructionState.lFrame;
88
- return lFrame === null ? null : lFrame.lView;
77
+ return instructionState.lFrame.lView;
89
78
  }
90
79
  /**
91
- * Determines whether or not a flag is currently set for the active element.
80
+ * Return the current `TView`.
92
81
  */
93
- export function hasActiveElementFlag(flag) {
94
- return (instructionState.lFrame.selectedIndex & flag) === flag;
95
- }
96
- /**
97
- * Sets a flag is for the active element.
98
- */
99
- function setActiveElementFlag(flag) {
100
- instructionState.lFrame.selectedIndex |= flag;
101
- }
102
- /**
103
- * Sets the active directive host element and resets the directive id value
104
- * (when the provided elementIndex value has changed).
105
- *
106
- * @param elementIndex the element index value for the host element where
107
- * the directive/component instance lives
108
- */
109
- export function setActiveHostElement(elementIndex) {
110
- if (hasActiveElementFlag(1 /* RunExitFn */)) {
111
- executeElementExitFn();
112
- }
113
- setSelectedIndex(elementIndex === null ? -1 : elementIndex);
114
- instructionState.lFrame.activeDirectiveId = 0;
115
- }
116
- export function executeElementExitFn() {
117
- instructionState.elementExitFn();
118
- instructionState.lFrame.selectedIndex &= ~1 /* RunExitFn */;
119
- }
120
- /**
121
- * Queues a function to be run once the element is "exited" in CD.
122
- *
123
- * Change detection will focus on an element either when the `advance()`
124
- * instruction is called or when the template or host bindings instruction
125
- * code is invoked. The element is then "exited" when the next element is
126
- * selected or when change detection for the template or host bindings is
127
- * complete. When this occurs (the element change operation) then an exit
128
- * function will be invoked if it has been set. This function can be used
129
- * to assign that exit function.
130
- *
131
- * @param fn
132
- */
133
- export function setElementExitFn(fn) {
134
- setActiveElementFlag(1 /* RunExitFn */);
135
- if (instructionState.elementExitFn === null) {
136
- instructionState.elementExitFn = fn;
137
- }
138
- ngDevMode &&
139
- assertEqual(instructionState.elementExitFn, fn, 'Expecting to always get the same function');
140
- }
141
- /**
142
- * Returns the current id value of the current directive.
143
- *
144
- * For example we have an element that has two directives on it:
145
- * <div dir-one dir-two></div>
146
- *
147
- * dirOne->hostBindings() (id == 1)
148
- * dirTwo->hostBindings() (id == 2)
149
- *
150
- * Note that this is only active when `hostBinding` functions are being processed.
151
- *
152
- * Note that directive id values are specific to an element (this means that
153
- * the same id value could be present on another element with a completely
154
- * different set of directives).
155
- */
156
- export function getActiveDirectiveId() {
157
- return instructionState.lFrame.activeDirectiveId;
158
- }
159
- /**
160
- * Increments the current directive id value.
161
- *
162
- * For example we have an element that has two directives on it:
163
- * <div dir-one dir-two></div>
164
- *
165
- * dirOne->hostBindings() (index = 1)
166
- * // increment
167
- * dirTwo->hostBindings() (index = 2)
168
- *
169
- * Depending on whether or not a previous directive had any inherited
170
- * directives present, that value will be incremented in addition
171
- * to the id jumping up by one.
172
- *
173
- * Note that this is only active when `hostBinding` functions are being processed.
174
- *
175
- * Note that directive id values are specific to an element (this means that
176
- * the same id value could be present on another element with a completely
177
- * different set of directives).
178
- */
179
- export function incrementActiveDirectiveId() {
180
- // Each directive gets a uniqueId value that is the same for both
181
- // create and update calls when the hostBindings function is called. The
182
- // directive uniqueId is not set anywhere--it is just incremented between
183
- // each hostBindings call and is useful for helping instruction code
184
- // uniquely determine which directive is currently active when executed.
185
- instructionState.lFrame.activeDirectiveId += 1;
82
+ export function getTView() {
83
+ return instructionState.lFrame.tView;
186
84
  }
187
85
  /**
188
86
  * Restores `contextViewData` to the given OpaqueViewState instance.
@@ -218,6 +116,7 @@ export function getContextLView() {
218
116
  return instructionState.lFrame.contextLView;
219
117
  }
220
118
  export function getCheckNoChangesMode() {
119
+ // TODO(misko): remove this from the LView since it is ngDevMode=true mode only.
221
120
  return instructionState.checkNoChangesMode;
222
121
  }
223
122
  export function setCheckNoChangesMode(mode) {
@@ -228,8 +127,7 @@ export function getBindingRoot() {
228
127
  var lFrame = instructionState.lFrame;
229
128
  var index = lFrame.bindingRootIndex;
230
129
  if (index === -1) {
231
- var lView = lFrame.lView;
232
- index = lFrame.bindingRootIndex = lView[TVIEW].bindingStartIndex;
130
+ index = lFrame.bindingRootIndex = lFrame.tView.bindingStartIndex;
233
131
  }
234
132
  return index;
235
133
  }
@@ -254,10 +152,23 @@ export function incrementBindingIndex(count) {
254
152
  * Bindings inside the host template are 0 index. But because we don't know ahead of time
255
153
  * how many host bindings we have we can't pre-compute them. For this reason they are all
256
154
  * 0 index and we just shift the root so that they match next available location in the LView.
257
- * @param value
155
+ *
156
+ * @param bindingRootIndex Root index for `hostBindings`
157
+ * @param currentDirectiveIndex `TData[currentDirectiveIndex]` will point to the current directive
158
+ * whose `hostBindings` are being processed.
159
+ */
160
+ export function setBindingRootForHostBindings(bindingRootIndex, currentDirectiveIndex) {
161
+ var lFrame = instructionState.lFrame;
162
+ lFrame.bindingIndex = lFrame.bindingRootIndex = bindingRootIndex;
163
+ lFrame.currentDirectiveIndex = currentDirectiveIndex;
164
+ }
165
+ /**
166
+ * When host binding is executing this points to the directive index.
167
+ * `TView.data[getCurrentDirectiveIndex()]` is `DirectiveDef`
168
+ * `LView[getCurrentDirectiveIndex()]` is directive instance.
258
169
  */
259
- export function setBindingRoot(value) {
260
- instructionState.lFrame.bindingRootIndex = value;
170
+ export function getCurrentDirectiveIndex() {
171
+ return instructionState.lFrame.currentDirectiveIndex;
261
172
  }
262
173
  export function getCurrentQueryIndex() {
263
174
  return instructionState.lFrame.currentQueryIndex;
@@ -284,8 +195,6 @@ export function enterDI(newView, tNode) {
284
195
  newLFrame.elementDepthCount = DEV_MODE_VALUE;
285
196
  newLFrame.currentNamespace = DEV_MODE_VALUE;
286
197
  newLFrame.currentSanitizer = DEV_MODE_VALUE;
287
- newLFrame.currentDirectiveDef = DEV_MODE_VALUE;
288
- newLFrame.activeDirectiveId = DEV_MODE_VALUE;
289
198
  newLFrame.bindingRootIndex = DEV_MODE_VALUE;
290
199
  newLFrame.currentQueryIndex = DEV_MODE_VALUE;
291
200
  }
@@ -312,19 +221,20 @@ export var leaveDI = leaveView;
312
221
  export function enterView(newView, tNode) {
313
222
  ngDevMode && assertLViewOrUndefined(newView);
314
223
  var newLFrame = allocLFrame();
224
+ var tView = newView[TVIEW];
315
225
  instructionState.lFrame = newLFrame;
316
226
  newLFrame.previousOrParentTNode = tNode;
317
227
  newLFrame.isParent = true;
318
228
  newLFrame.lView = newView;
229
+ newLFrame.tView = tView;
319
230
  newLFrame.selectedIndex = 0;
320
231
  newLFrame.contextLView = newView;
321
232
  newLFrame.elementDepthCount = 0;
233
+ newLFrame.currentDirectiveIndex = -1;
322
234
  newLFrame.currentNamespace = null;
323
235
  newLFrame.currentSanitizer = null;
324
- newLFrame.currentDirectiveDef = null;
325
- newLFrame.activeDirectiveId = 0;
326
236
  newLFrame.bindingRootIndex = -1;
327
- newLFrame.bindingIndex = newView === null ? -1 : newView[TVIEW].bindingStartIndex;
237
+ newLFrame.bindingIndex = tView.bindingStartIndex;
328
238
  newLFrame.currentQueryIndex = 0;
329
239
  }
330
240
  /**
@@ -341,13 +251,13 @@ function createLFrame(parent) {
341
251
  previousOrParentTNode: null,
342
252
  isParent: true,
343
253
  lView: null,
254
+ tView: null,
344
255
  selectedIndex: 0,
345
256
  contextLView: null,
346
257
  elementDepthCount: 0,
347
258
  currentNamespace: null,
348
259
  currentSanitizer: null,
349
- currentDirectiveDef: null,
350
- activeDirectiveId: 0,
260
+ currentDirectiveIndex: -1,
351
261
  bindingRootIndex: -1,
352
262
  bindingIndex: -1,
353
263
  currentQueryIndex: 0,
@@ -357,12 +267,6 @@ function createLFrame(parent) {
357
267
  parent !== null && (parent.child = lFrame); // link the new LFrame for reuse.
358
268
  return lFrame;
359
269
  }
360
- export function leaveViewProcessExit() {
361
- if (hasActiveElementFlag(1 /* RunExitFn */)) {
362
- executeElementExitFn();
363
- }
364
- leaveView();
365
- }
366
270
  export function leaveView() {
367
271
  instructionState.lFrame = instructionState.lFrame.parent;
368
272
  }
@@ -380,13 +284,13 @@ function walkUpViews(nestingLevel, currentView) {
380
284
  return currentView;
381
285
  }
382
286
  /**
383
- * Gets the most recent index passed to {@link select}
287
+ * Gets the currently selected element index.
384
288
  *
385
289
  * Used with {@link property} instruction (and more in the future) to identify the index in the
386
290
  * current `LView` to act on.
387
291
  */
388
292
  export function getSelectedIndex() {
389
- return instructionState.lFrame.selectedIndex >> 1 /* Size */;
293
+ return instructionState.lFrame.selectedIndex;
390
294
  }
391
295
  /**
392
296
  * Sets the most recent index passed to {@link select}
@@ -398,7 +302,7 @@ export function getSelectedIndex() {
398
302
  * run if and when the provided `index` value is different from the current selected index value.)
399
303
  */
400
304
  export function setSelectedIndex(index) {
401
- instructionState.lFrame.selectedIndex = index << 1 /* Size */;
305
+ instructionState.lFrame.selectedIndex = index;
402
306
  }
403
307
  /**
404
308
  * Sets the namespace used to create elements to `'http://www.w3.org/2000/svg'` in global state.
@@ -406,7 +310,7 @@ export function setSelectedIndex(index) {
406
310
  * @codeGenApi
407
311
  */
408
312
  export function ɵɵnamespaceSVG() {
409
- instructionState.lFrame.currentNamespace = 'http://www.w3.org/2000/svg';
313
+ instructionState.lFrame.currentNamespace = SVG_NAMESPACE;
410
314
  }
411
315
  /**
412
316
  * Sets the namespace used to create elements to `'http://www.w3.org/1998/MathML/'` in global state.
@@ -414,7 +318,7 @@ export function ɵɵnamespaceSVG() {
414
318
  * @codeGenApi
415
319
  */
416
320
  export function ɵɵnamespaceMathML() {
417
- instructionState.lFrame.currentNamespace = 'http://www.w3.org/1998/MathML/';
321
+ instructionState.lFrame.currentNamespace = MATH_ML_NAMESPACE;
418
322
  }
419
323
  /**
420
324
  * Sets the namespace used to create elements to `null`, which forces element creation to use
@@ -447,4 +351,4 @@ export function getCurrentStyleSanitizer() {
447
351
  var lFrame = instructionState.lFrame;
448
352
  return lFrame === null ? null : lFrame.currentSanitizer;
449
353
  }
450
- //# 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"]}
354
+ //# 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,39 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google Inc. All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ import { assertNotEqual } from '../../util/assert';
9
+ /**
10
+ * Returns an index of `classToSearch` in `className` taking token boundaries into account.
11
+ *
12
+ * `classIndexOf('AB A', 'A', 0)` will be 3 (not 0 since `AB!==A`)
13
+ *
14
+ * @param className A string containing classes (whitespace separated)
15
+ * @param classToSearch A class name to locate
16
+ * @param startingIndex Starting location of search
17
+ * @returns an index of the located class (or -1 if not found)
18
+ */
19
+ export function classIndexOf(className, classToSearch, startingIndex) {
20
+ ngDevMode && assertNotEqual(classToSearch, '', 'can not look for "" string.');
21
+ var end = className.length;
22
+ while (true) {
23
+ var foundIndex = className.indexOf(classToSearch, startingIndex);
24
+ if (foundIndex === -1)
25
+ return foundIndex;
26
+ if (foundIndex === 0 || className.charCodeAt(foundIndex - 1) <= 32 /* SPACE */) {
27
+ // Ensure that it has leading whitespace
28
+ var length_1 = classToSearch.length;
29
+ if (foundIndex + length_1 === end ||
30
+ className.charCodeAt(foundIndex + length_1) <= 32 /* SPACE */) {
31
+ // Ensure that it has trailing whitespace
32
+ return foundIndex;
33
+ }
34
+ }
35
+ // False positive, keep searching from where we left off.
36
+ startingIndex = foundIndex + 1;
37
+ }
38
+ }
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xhc3NfZGlmZmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvcmVuZGVyMy9zdHlsaW5nL2NsYXNzX2RpZmZlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0VBTUU7QUFFRixPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFJakQ7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxVQUFVLFlBQVksQ0FDeEIsU0FBaUIsRUFBRSxhQUFxQixFQUFFLGFBQXFCO0lBQ2pFLFNBQVMsSUFBSSxjQUFjLENBQUMsYUFBYSxFQUFFLEVBQUUsRUFBRSw2QkFBNkIsQ0FBQyxDQUFDO0lBQzlFLElBQUksR0FBRyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUM7SUFDM0IsT0FBTyxJQUFJLEVBQUU7UUFDWCxJQUFNLFVBQVUsR0FBRyxTQUFTLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxhQUFhLENBQUMsQ0FBQztRQUNuRSxJQUFJLFVBQVUsS0FBSyxDQUFDLENBQUM7WUFBRSxPQUFPLFVBQVUsQ0FBQztRQUN6QyxJQUFJLFVBQVUsS0FBSyxDQUFDLElBQUksU0FBUyxDQUFDLFVBQVUsQ0FBQyxVQUFVLEdBQUcsQ0FBQyxDQUFDLGtCQUFrQixFQUFFO1lBQzlFLHdDQUF3QztZQUN4QyxJQUFNLFFBQU0sR0FBRyxhQUFhLENBQUMsTUFBTSxDQUFDO1lBQ3BDLElBQUksVUFBVSxHQUFHLFFBQU0sS0FBSyxHQUFHO2dCQUMzQixTQUFTLENBQUMsVUFBVSxDQUFDLFVBQVUsR0FBRyxRQUFNLENBQUMsa0JBQWtCLEVBQUU7Z0JBQy9ELHlDQUF5QztnQkFDekMsT0FBTyxVQUFVLENBQUM7YUFDbkI7U0FDRjtRQUNELHlEQUF5RDtRQUN6RCxhQUFhLEdBQUcsVUFBVSxHQUFHLENBQUMsQ0FBQztLQUNoQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiogQGxpY2Vuc2VcbiogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4qXG4qIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4qIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiovXG5cbmltcG9ydCB7YXNzZXJ0Tm90RXF1YWx9IGZyb20gJy4uLy4uL3V0aWwvYXNzZXJ0JztcbmltcG9ydCB7Q2hhckNvZGV9IGZyb20gJy4uLy4uL3V0aWwvY2hhcl9jb2RlJztcblxuXG4vKipcbiAqIFJldHVybnMgYW4gaW5kZXggb2YgYGNsYXNzVG9TZWFyY2hgIGluIGBjbGFzc05hbWVgIHRha2luZyB0b2tlbiBib3VuZGFyaWVzIGludG8gYWNjb3VudC5cbiAqXG4gKiBgY2xhc3NJbmRleE9mKCdBQiBBJywgJ0EnLCAwKWAgd2lsbCBiZSAzIChub3QgMCBzaW5jZSBgQUIhPT1BYClcbiAqXG4gKiBAcGFyYW0gY2xhc3NOYW1lIEEgc3RyaW5nIGNvbnRhaW5pbmcgY2xhc3NlcyAod2hpdGVzcGFjZSBzZXBhcmF0ZWQpXG4gKiBAcGFyYW0gY2xhc3NUb1NlYXJjaCBBIGNsYXNzIG5hbWUgdG8gbG9jYXRlXG4gKiBAcGFyYW0gc3RhcnRpbmdJbmRleCBTdGFydGluZyBsb2NhdGlvbiBvZiBzZWFyY2hcbiAqIEByZXR1cm5zIGFuIGluZGV4IG9mIHRoZSBsb2NhdGVkIGNsYXNzIChvciAtMSBpZiBub3QgZm91bmQpXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjbGFzc0luZGV4T2YoXG4gICAgY2xhc3NOYW1lOiBzdHJpbmcsIGNsYXNzVG9TZWFyY2g6IHN0cmluZywgc3RhcnRpbmdJbmRleDogbnVtYmVyKTogbnVtYmVyIHtcbiAgbmdEZXZNb2RlICYmIGFzc2VydE5vdEVxdWFsKGNsYXNzVG9TZWFyY2gsICcnLCAnY2FuIG5vdCBsb29rIGZvciBcIlwiIHN0cmluZy4nKTtcbiAgbGV0IGVuZCA9IGNsYXNzTmFtZS5sZW5ndGg7XG4gIHdoaWxlICh0cnVlKSB7XG4gICAgY29uc3QgZm91bmRJbmRleCA9IGNsYXNzTmFtZS5pbmRleE9mKGNsYXNzVG9TZWFyY2gsIHN0YXJ0aW5nSW5kZXgpO1xuICAgIGlmIChmb3VuZEluZGV4ID09PSAtMSkgcmV0dXJuIGZvdW5kSW5kZXg7XG4gICAgaWYgKGZvdW5kSW5kZXggPT09IDAgfHwgY2xhc3NOYW1lLmNoYXJDb2RlQXQoZm91bmRJbmRleCAtIDEpIDw9IENoYXJDb2RlLlNQQUNFKSB7XG4gICAgICAvLyBFbnN1cmUgdGhhdCBpdCBoYXMgbGVhZGluZyB3aGl0ZXNwYWNlXG4gICAgICBjb25zdCBsZW5ndGggPSBjbGFzc1RvU2VhcmNoLmxlbmd0aDtcbiAgICAgIGlmIChmb3VuZEluZGV4ICsgbGVuZ3RoID09PSBlbmQgfHxcbiAgICAgICAgICBjbGFzc05hbWUuY2hhckNvZGVBdChmb3VuZEluZGV4ICsgbGVuZ3RoKSA8PSBDaGFyQ29kZS5TUEFDRSkge1xuICAgICAgICAvLyBFbnN1cmUgdGhhdCBpdCBoYXMgdHJhaWxpbmcgd2hpdGVzcGFjZVxuICAgICAgICByZXR1cm4gZm91bmRJbmRleDtcbiAgICAgIH1cbiAgICB9XG4gICAgLy8gRmFsc2UgcG9zaXRpdmUsIGtlZXAgc2VhcmNoaW5nIGZyb20gd2hlcmUgd2UgbGVmdCBvZmYuXG4gICAgc3RhcnRpbmdJbmRleCA9IGZvdW5kSW5kZXggKyAxO1xuICB9XG59Il19
@@ -0,0 +1,42 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google Inc. All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ import { concatStringsWithSpace } from '../../util/stringify';
9
+ import { assertFirstCreatePass } from '../assert';
10
+ import { getTView } from '../state';
11
+ /**
12
+ * Compute the static styling (class/style) from `TAttributes`.
13
+ *
14
+ * This function should be called during `firstCreatePass` only.
15
+ *
16
+ * @param tNode The `TNode` into which the styling information should be loaded.
17
+ * @param attrs `TAttributes` containing the styling information.
18
+ */
19
+ export function computeStaticStyling(tNode, attrs) {
20
+ ngDevMode &&
21
+ assertFirstCreatePass(getTView(), 'Expecting to be called in first template pass only');
22
+ var styles = tNode.styles;
23
+ var classes = tNode.classes;
24
+ var mode = 0;
25
+ for (var i = 0; i < attrs.length; i++) {
26
+ var value = attrs[i];
27
+ if (typeof value === 'number') {
28
+ mode = value;
29
+ }
30
+ else if (mode == 1 /* Classes */) {
31
+ classes = concatStringsWithSpace(classes, value);
32
+ }
33
+ else if (mode == 2 /* Styles */) {
34
+ var style = value;
35
+ var styleValue = attrs[++i];
36
+ styles = concatStringsWithSpace(styles, style + ': ' + styleValue + ';');
37
+ }
38
+ }
39
+ styles !== null && (tNode.styles = styles);
40
+ classes !== null && (tNode.classes = classes);
41
+ }
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdGljX3N0eWxpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy9yZW5kZXIzL3N0eWxpbmcvc3RhdGljX3N0eWxpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztFQU1FO0FBRUYsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDNUQsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sV0FBVyxDQUFDO0FBRWhELE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxVQUFVLENBQUM7QUFFbEM7Ozs7Ozs7R0FPRztBQUNILE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxLQUFZLEVBQUUsS0FBa0I7SUFDbkUsU0FBUztRQUNMLHFCQUFxQixDQUFDLFFBQVEsRUFBRSxFQUFFLG9EQUFvRCxDQUFDLENBQUM7SUFDNUYsSUFBSSxNQUFNLEdBQWdCLEtBQUssQ0FBQyxNQUFNLENBQUM7SUFDdkMsSUFBSSxPQUFPLEdBQWdCLEtBQUssQ0FBQyxPQUFPLENBQUM7SUFDekMsSUFBSSxJQUFJLEdBQXNCLENBQUMsQ0FBQztJQUNoQyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtRQUNyQyxJQUFNLEtBQUssR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdkIsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUU7WUFDN0IsSUFBSSxHQUFHLEtBQUssQ0FBQztTQUNkO2FBQU0sSUFBSSxJQUFJLG1CQUEyQixFQUFFO1lBQzFDLE9BQU8sR0FBRyxzQkFBc0IsQ0FBQyxPQUFPLEVBQUUsS0FBZSxDQUFDLENBQUM7U0FDNUQ7YUFBTSxJQUFJLElBQUksa0JBQTBCLEVBQUU7WUFDekMsSUFBTSxLQUFLLEdBQUcsS0FBZSxDQUFDO1lBQzlCLElBQU0sVUFBVSxHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBVyxDQUFDO1lBQ3hDLE1BQU0sR0FBRyxzQkFBc0IsQ0FBQyxNQUFNLEVBQUUsS0FBSyxHQUFHLElBQUksR0FBRyxVQUFVLEdBQUcsR0FBRyxDQUFDLENBQUM7U0FDMUU7S0FDRjtJQUNELE1BQU0sS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxDQUFDO0lBQzNDLE9BQU8sS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxDQUFDO0FBQ2hELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiogQGxpY2Vuc2VcbiogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4qXG4qIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4qIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiovXG5cbmltcG9ydCB7Y29uY2F0U3RyaW5nc1dpdGhTcGFjZX0gZnJvbSAnLi4vLi4vdXRpbC9zdHJpbmdpZnknO1xuaW1wb3J0IHthc3NlcnRGaXJzdENyZWF0ZVBhc3N9IGZyb20gJy4uL2Fzc2VydCc7XG5pbXBvcnQge0F0dHJpYnV0ZU1hcmtlciwgVEF0dHJpYnV0ZXMsIFROb2RlfSBmcm9tICcuLi9pbnRlcmZhY2VzL25vZGUnO1xuaW1wb3J0IHtnZXRUVmlld30gZnJvbSAnLi4vc3RhdGUnO1xuXG4vKipcbiAqIENvbXB1dGUgdGhlIHN0YXRpYyBzdHlsaW5nIChjbGFzcy9zdHlsZSkgZnJvbSBgVEF0dHJpYnV0ZXNgLlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gc2hvdWxkIGJlIGNhbGxlZCBkdXJpbmcgYGZpcnN0Q3JlYXRlUGFzc2Agb25seS5cbiAqXG4gKiBAcGFyYW0gdE5vZGUgVGhlIGBUTm9kZWAgaW50byB3aGljaCB0aGUgc3R5bGluZyBpbmZvcm1hdGlvbiBzaG91bGQgYmUgbG9hZGVkLlxuICogQHBhcmFtIGF0dHJzIGBUQXR0cmlidXRlc2AgY29udGFpbmluZyB0aGUgc3R5bGluZyBpbmZvcm1hdGlvbi5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNvbXB1dGVTdGF0aWNTdHlsaW5nKHROb2RlOiBUTm9kZSwgYXR0cnM6IFRBdHRyaWJ1dGVzKTogdm9pZCB7XG4gIG5nRGV2TW9kZSAmJlxuICAgICAgYXNzZXJ0Rmlyc3RDcmVhdGVQYXNzKGdldFRWaWV3KCksICdFeHBlY3RpbmcgdG8gYmUgY2FsbGVkIGluIGZpcnN0IHRlbXBsYXRlIHBhc3Mgb25seScpO1xuICBsZXQgc3R5bGVzOiBzdHJpbmd8bnVsbCA9IHROb2RlLnN0eWxlcztcbiAgbGV0IGNsYXNzZXM6IHN0cmluZ3xudWxsID0gdE5vZGUuY2xhc3NlcztcbiAgbGV0IG1vZGU6IEF0dHJpYnV0ZU1hcmtlcnwwID0gMDtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBhdHRycy5sZW5ndGg7IGkrKykge1xuICAgIGNvbnN0IHZhbHVlID0gYXR0cnNbaV07XG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcicpIHtcbiAgICAgIG1vZGUgPSB2YWx1ZTtcbiAgICB9IGVsc2UgaWYgKG1vZGUgPT0gQXR0cmlidXRlTWFya2VyLkNsYXNzZXMpIHtcbiAgICAgIGNsYXNzZXMgPSBjb25jYXRTdHJpbmdzV2l0aFNwYWNlKGNsYXNzZXMsIHZhbHVlIGFzIHN0cmluZyk7XG4gICAgfSBlbHNlIGlmIChtb2RlID09IEF0dHJpYnV0ZU1hcmtlci5TdHlsZXMpIHtcbiAgICAgIGNvbnN0IHN0eWxlID0gdmFsdWUgYXMgc3RyaW5nO1xuICAgICAgY29uc3Qgc3R5bGVWYWx1ZSA9IGF0dHJzWysraV0gYXMgc3RyaW5nO1xuICAgICAgc3R5bGVzID0gY29uY2F0U3RyaW5nc1dpdGhTcGFjZShzdHlsZXMsIHN0eWxlICsgJzogJyArIHN0eWxlVmFsdWUgKyAnOycpO1xuICAgIH1cbiAgfVxuICBzdHlsZXMgIT09IG51bGwgJiYgKHROb2RlLnN0eWxlcyA9IHN0eWxlcyk7XG4gIGNsYXNzZXMgIT09IG51bGwgJiYgKHROb2RlLmNsYXNzZXMgPSBjbGFzc2VzKTtcbn0iXX0=