@angular/core 8.0.3 → 8.1.0-beta.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 (206) hide show
  1. package/bundles/core-testing.umd.js +35 -9
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +10 -10
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +11379 -9387
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +205 -135
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +1286 -406
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.js +2 -3
  12. package/esm2015/index.js +2 -2
  13. package/esm2015/public_api.js +2 -2
  14. package/esm2015/src/application_ref.js +7 -1
  15. package/esm2015/src/codegen_private_exports.js +2 -2
  16. package/esm2015/src/compiler/compiler_facade_interface.js +1 -1
  17. package/esm2015/src/core.js +4 -4
  18. package/esm2015/src/core_private_export.js +3 -1
  19. package/esm2015/src/core_render3_private_export.js +5 -3
  20. package/esm2015/src/debug/debug_node.js +4 -4
  21. package/esm2015/src/di/index.js +3 -3
  22. package/esm2015/src/di/injectable.js +1 -1
  23. package/esm2015/src/di/injector.js +24 -96
  24. package/esm2015/src/di/injector_compatibility.js +103 -6
  25. package/esm2015/src/di/interface/defs.js +24 -3
  26. package/esm2015/src/di/interface/provider.js +1 -1
  27. package/esm2015/src/di/r3_injector.js +82 -49
  28. package/esm2015/src/di/reflective_injector.js +3 -2
  29. package/esm2015/src/di.js +1 -1
  30. package/esm2015/src/i18n/locale_data.js +61 -0
  31. package/esm2015/src/i18n/locale_data_api.js +53 -0
  32. package/esm2015/src/i18n/locale_en.js +51 -0
  33. package/esm2015/src/i18n/localization.js +37 -0
  34. package/esm2015/src/linker/ng_module_factory_loader.js +4 -52
  35. package/esm2015/src/linker/ng_module_factory_registration.js +83 -0
  36. package/esm2015/src/metadata/directives.js +2 -2
  37. package/esm2015/src/metadata/ng_module.js +6 -1
  38. package/esm2015/src/metadata/resource_loading.js +2 -2
  39. package/esm2015/src/reflection/reflection_capabilities.js +14 -3
  40. package/esm2015/src/render3/assert.js +3 -2
  41. package/esm2015/src/render3/component.js +11 -5
  42. package/esm2015/src/render3/component_ref.js +4 -2
  43. package/esm2015/src/render3/debug.js +23 -15
  44. package/esm2015/src/render3/definition.js +12 -2
  45. package/esm2015/src/render3/errors.js +29 -1
  46. package/esm2015/src/render3/features/inherit_definition_feature.js +51 -37
  47. package/esm2015/src/render3/fields.js +3 -1
  48. package/esm2015/src/render3/i18n.js +76 -465
  49. package/esm2015/src/render3/index.js +3 -3
  50. package/esm2015/src/render3/instructions/all.js +10 -5
  51. package/esm2015/src/render3/instructions/attribute.js +28 -0
  52. package/esm2015/src/render3/instructions/attribute_interpolation.js +376 -0
  53. package/esm2015/src/render3/instructions/container.js +17 -16
  54. package/esm2015/src/render3/instructions/element.js +57 -35
  55. package/esm2015/src/render3/instructions/element_container.js +9 -8
  56. package/esm2015/src/render3/instructions/embedded_view.js +9 -12
  57. package/esm2015/src/render3/instructions/interpolation.js +375 -0
  58. package/esm2015/src/render3/instructions/listener.js +3 -2
  59. package/esm2015/src/render3/instructions/projection.js +18 -57
  60. package/esm2015/src/render3/instructions/property.js +10 -4
  61. package/esm2015/src/render3/instructions/property_interpolation.js +49 -382
  62. package/esm2015/src/render3/instructions/shared.js +82 -118
  63. package/esm2015/src/render3/instructions/styling.js +189 -236
  64. package/esm2015/src/render3/instructions/text.js +8 -7
  65. package/esm2015/src/render3/instructions/text_interpolation.js +357 -0
  66. package/esm2015/src/render3/interfaces/container.js +9 -5
  67. package/esm2015/src/render3/interfaces/definition.js +12 -6
  68. package/esm2015/src/render3/interfaces/node.js +20 -8
  69. package/esm2015/src/render3/interfaces/projection.js +1 -1
  70. package/esm2015/src/render3/interfaces/styling.js +16 -15
  71. package/esm2015/src/render3/interfaces/view.js +2 -2
  72. package/esm2015/src/render3/jit/directive.js +14 -5
  73. package/esm2015/src/render3/jit/environment.js +30 -15
  74. package/esm2015/src/render3/jit/module.js +38 -19
  75. package/esm2015/src/render3/ng_module_ref.js +39 -3
  76. package/esm2015/src/render3/node_manipulation.js +45 -43
  77. package/esm2015/src/render3/node_selector_matcher.js +40 -14
  78. package/esm2015/src/render3/query.js +77 -61
  79. package/esm2015/src/render3/state.js +33 -6
  80. package/esm2015/src/render3/styling/class_and_style_bindings.js +92 -80
  81. package/esm2015/src/render3/styling/host_instructions_queue.js +8 -5
  82. package/esm2015/src/render3/styling/shared.js +2 -2
  83. package/esm2015/src/render3/styling/util.js +2 -2
  84. package/esm2015/src/render3/styling_next/bindings.js +602 -0
  85. package/esm2015/src/render3/styling_next/instructions.js +366 -0
  86. package/esm2015/src/render3/styling_next/interfaces.js +374 -0
  87. package/esm2015/src/render3/styling_next/map_based_bindings.js +408 -0
  88. package/esm2015/src/render3/styling_next/state.js +51 -0
  89. package/esm2015/src/render3/styling_next/styling_debug.js +291 -0
  90. package/esm2015/src/render3/styling_next/util.js +259 -0
  91. package/esm2015/src/render3/util/attrs_utils.js +4 -3
  92. package/esm2015/src/render3/util/debug_utils.js +18 -0
  93. package/esm2015/src/render3/util/view_traversal_utils.js +2 -2
  94. package/esm2015/src/render3/view_engine_compatibility.js +24 -10
  95. package/esm2015/src/sanitization/sanitization.js +17 -7
  96. package/esm2015/src/sanitization/style_sanitizer.js +11 -1
  97. package/esm2015/src/util/ng_dev_mode.js +7 -3
  98. package/esm2015/src/version.js +1 -1
  99. package/esm2015/src/view/ng_module.js +3 -3
  100. package/esm2015/src/view/util.js +2 -2
  101. package/esm2015/testing/src/r3_test_bed_compiler.js +44 -12
  102. package/esm2015/testing/src/test_bed_common.js +2 -5
  103. package/esm5/core.js +2 -3
  104. package/esm5/src/application_ref.js +6 -1
  105. package/esm5/src/codegen_private_exports.js +2 -2
  106. package/esm5/src/compiler/compiler_facade_interface.js +1 -1
  107. package/esm5/src/core_private_export.js +3 -1
  108. package/esm5/src/core_render3_private_export.js +5 -3
  109. package/esm5/src/debug/debug_node.js +4 -4
  110. package/esm5/src/di/index.js +3 -3
  111. package/esm5/src/di/injectable.js +1 -1
  112. package/esm5/src/di/injector.js +14 -74
  113. package/esm5/src/di/injector_compatibility.js +77 -6
  114. package/esm5/src/di/interface/defs.js +24 -3
  115. package/esm5/src/di/interface/provider.js +1 -1
  116. package/esm5/src/di/r3_injector.js +60 -37
  117. package/esm5/src/di/reflective_injector.js +3 -2
  118. package/esm5/src/i18n/locale_data.js +38 -0
  119. package/esm5/src/i18n/locale_data_api.js +46 -0
  120. package/esm5/src/i18n/locale_en.js +39 -0
  121. package/esm5/src/i18n/localization.js +29 -0
  122. package/esm5/src/linker/ng_module_factory_loader.js +4 -32
  123. package/esm5/src/linker/ng_module_factory_registration.js +50 -0
  124. package/esm5/src/metadata/directives.js +2 -2
  125. package/esm5/src/metadata/ng_module.js +1 -1
  126. package/esm5/src/metadata/resource_loading.js +2 -2
  127. package/esm5/src/reflection/reflection_capabilities.js +14 -3
  128. package/esm5/src/render3/assert.js +2 -1
  129. package/esm5/src/render3/component.js +10 -4
  130. package/esm5/src/render3/component_ref.js +4 -2
  131. package/esm5/src/render3/debug.js +17 -10
  132. package/esm5/src/render3/definition.js +8 -2
  133. package/esm5/src/render3/errors.js +14 -1
  134. package/esm5/src/render3/features/inherit_definition_feature.js +41 -36
  135. package/esm5/src/render3/fields.js +2 -1
  136. package/esm5/src/render3/i18n.js +67 -437
  137. package/esm5/src/render3/index.js +3 -3
  138. package/esm5/src/render3/instructions/all.js +6 -1
  139. package/esm5/src/render3/instructions/attribute.js +22 -0
  140. package/esm5/src/render3/instructions/attribute_interpolation.js +346 -0
  141. package/esm5/src/render3/instructions/container.js +16 -15
  142. package/esm5/src/render3/instructions/element.js +43 -32
  143. package/esm5/src/render3/instructions/element_container.js +9 -8
  144. package/esm5/src/render3/instructions/embedded_view.js +8 -11
  145. package/esm5/src/render3/instructions/interpolation.js +243 -0
  146. package/esm5/src/render3/instructions/listener.js +3 -2
  147. package/esm5/src/render3/instructions/projection.js +19 -54
  148. package/esm5/src/render3/instructions/property.js +10 -4
  149. package/esm5/src/render3/instructions/property_interpolation.js +40 -254
  150. package/esm5/src/render3/instructions/shared.js +70 -105
  151. package/esm5/src/render3/instructions/styling.js +167 -209
  152. package/esm5/src/render3/instructions/text.js +8 -7
  153. package/esm5/src/render3/instructions/text_interpolation.js +264 -0
  154. package/esm5/src/render3/interfaces/container.js +8 -2
  155. package/esm5/src/render3/interfaces/definition.js +1 -1
  156. package/esm5/src/render3/interfaces/node.js +1 -8
  157. package/esm5/src/render3/interfaces/projection.js +1 -1
  158. package/esm5/src/render3/interfaces/styling.js +2 -2
  159. package/esm5/src/render3/interfaces/view.js +1 -1
  160. package/esm5/src/render3/jit/directive.js +12 -5
  161. package/esm5/src/render3/jit/environment.js +30 -15
  162. package/esm5/src/render3/jit/module.js +23 -18
  163. package/esm5/src/render3/ng_module_ref.js +37 -3
  164. package/esm5/src/render3/node_manipulation.js +39 -38
  165. package/esm5/src/render3/node_selector_matcher.js +36 -14
  166. package/esm5/src/render3/query.js +75 -53
  167. package/esm5/src/render3/state.js +29 -5
  168. package/esm5/src/render3/styling/class_and_style_bindings.js +80 -66
  169. package/esm5/src/render3/styling/host_instructions_queue.js +6 -3
  170. package/esm5/src/render3/styling/shared.js +2 -2
  171. package/esm5/src/render3/styling/util.js +2 -2
  172. package/esm5/src/render3/styling_next/bindings.js +446 -0
  173. package/esm5/src/render3/styling_next/instructions.js +277 -0
  174. package/esm5/src/render3/styling_next/interfaces.js +1 -0
  175. package/esm5/src/render3/styling_next/map_based_bindings.js +324 -0
  176. package/esm5/src/render3/styling_next/state.js +23 -0
  177. package/esm5/src/render3/styling_next/styling_debug.js +130 -0
  178. package/esm5/src/render3/styling_next/util.js +147 -0
  179. package/esm5/src/render3/util/attrs_utils.js +4 -3
  180. package/esm5/src/render3/util/debug_utils.js +11 -0
  181. package/esm5/src/render3/util/view_traversal_utils.js +2 -2
  182. package/esm5/src/render3/view_engine_compatibility.js +23 -10
  183. package/esm5/src/sanitization/sanitization.js +14 -6
  184. package/esm5/src/sanitization/style_sanitizer.js +1 -1
  185. package/esm5/src/util/ng_dev_mode.js +7 -3
  186. package/esm5/src/version.js +1 -1
  187. package/esm5/src/view/ng_module.js +3 -3
  188. package/esm5/src/view/util.js +2 -2
  189. package/esm5/testing/src/r3_test_bed_compiler.js +37 -11
  190. package/esm5/testing/src/test_bed_common.js +1 -1
  191. package/fesm2015/core.js +13604 -10868
  192. package/fesm2015/core.js.map +1 -1
  193. package/fesm2015/testing.js +43 -11
  194. package/fesm2015/testing.js.map +1 -1
  195. package/fesm5/core.js +11279 -9305
  196. package/fesm5/core.js.map +1 -1
  197. package/fesm5/testing.js +36 -10
  198. package/fesm5/testing.js.map +1 -1
  199. package/package.json +1 -1
  200. package/schematics/migrations/injectable-pipe/index.js +2 -5
  201. package/schematics/migrations/move-document/index.js +2 -5
  202. package/schematics/migrations/static-queries/index.js +2 -5
  203. package/schematics/migrations/template-var-assignment/index.js +2 -5
  204. package/src/r3_symbols.d.ts +24 -18
  205. package/testing/testing.d.ts +2 -5
  206. package/testing.d.ts +1 -1
@@ -231,8 +231,8 @@ export function updateContextWithBindings(context, directiveIndex, classBindingN
231
231
  let multiClassesStartIndex = multiStylesStartIndex + stylesOffset;
232
232
  // because we're inserting more bindings into the context, this means that the
233
233
  // binding values need to be referenced the singlePropOffsetValues array so that
234
- // the template/directive can easily find them inside of the `elementStyleProp`
235
- // and the `elementClassProp` functions without iterating through the entire context.
234
+ // the template/directive can easily find them inside of the `styleProp`
235
+ // and the `classProp` functions without iterating through the entire context.
236
236
  // The first step to setting up these reference points is to mark how many bindings
237
237
  // are being added. Even if these bindings already exist in the context, the directive
238
238
  // or template code will still call them unknowingly. Therefore the total values need
@@ -491,17 +491,43 @@ function getMatchingBindingIndex(context, bindingName, start, end) {
491
491
  return -1;
492
492
  }
493
493
  /**
494
- * Registers the provided multi styling (`[style]` and `[class]`) values to the context.
494
+ * Registers the provided multi class values to the context.
495
495
  *
496
- * This function will iterate over the provided `classesInput` and `stylesInput` map
497
- * values and insert/update or remove them from the context at exactly the right
498
- * spot.
496
+ * This function will iterate over the provided `classesInput` values and
497
+ * insert/update or remove them from the context at exactly the right spot.
498
+ *
499
+ * This function also takes in a directive which implies that the styling values will
500
+ * be evaluated for that directive with respect to any other styling that already exists
501
+ * on the context. When there are styles that conflict (e.g. say `ngClass` and `[class]`
502
+ * both update the `foo` className value at the same time) then the styling algorithm code below
503
+ * will decide which one wins based on the directive styling prioritization mechanism. (This
504
+ * mechanism is better explained in render3/interfaces/styling.ts#directives).
505
+ *
506
+ * This function will not render any styling values on screen, but is rather designed to
507
+ * prepare the context for that. `renderStyling` must be called afterwards to render any
508
+ * styling data that was set in this function (note that `updateClassProp` and
509
+ * `updateStyleProp` are designed to be run after this function is run).
510
+ *
511
+ * @param {?} context The styling context that will be updated with the
512
+ * newly provided style values.
513
+ * @param {?} classesInput The key/value map of CSS class names that will be used for the update.
514
+ * @param {?=} directiveIndex
515
+ * @return {?}
516
+ */
517
+ export function updateClassMap(context, classesInput, directiveIndex = 0) {
518
+ updateStylingMap(context, classesInput, true, directiveIndex);
519
+ }
520
+ /**
521
+ * Registers the provided multi style values to the context.
522
+ *
523
+ * This function will iterate over the provided `stylesInput` values and
524
+ * insert/update or remove them from the context at exactly the right spot.
499
525
  *
500
526
  * This function also takes in a directive which implies that the styling values will
501
527
  * be evaluated for that directive with respect to any other styling that already exists
502
528
  * on the context. When there are styles that conflict (e.g. say `ngStyle` and `[style]`
503
529
  * both update the `width` property at the same time) then the styling algorithm code below
504
- * will decide which one wins based on the directive styling prioritization mechanism. This
530
+ * will decide which one wins based on the directive styling prioritization mechanism. (This
505
531
  * mechanism is better explained in render3/interfaces/styling.ts#directives).
506
532
  *
507
533
  * This function will not render any styling values on screen, but is rather designed to
@@ -511,101 +537,84 @@ function getMatchingBindingIndex(context, bindingName, start, end) {
511
537
  *
512
538
  * @param {?} context The styling context that will be updated with the
513
539
  * newly provided style values.
514
- * @param {?} classesInput The key/value map of CSS class names that will be used for the update.
515
- * @param {?=} stylesInput The key/value map of CSS styles that will be used for the update.
540
+ * @param {?} stylesInput The key/value map of CSS styles that will be used for the update.
516
541
  * @param {?=} directiveIndex
517
542
  * @return {?}
518
543
  */
519
- export function updateStylingMap(context, classesInput, stylesInput, directiveIndex = 0) {
520
- ngDevMode && ngDevMode.stylingMap++;
544
+ export function updateStyleMap(context, stylesInput, directiveIndex = 0) {
545
+ updateStylingMap(context, stylesInput, false, directiveIndex);
546
+ }
547
+ /**
548
+ * @param {?} context
549
+ * @param {?} input
550
+ * @param {?} entryIsClassBased
551
+ * @param {?=} directiveIndex
552
+ * @return {?}
553
+ */
554
+ function updateStylingMap(context, input, entryIsClassBased, directiveIndex = 0) {
555
+ ngDevMode && (entryIsClassBased ? ngDevMode.classMap++ : ngDevMode.styleMap++);
521
556
  ngDevMode && assertValidDirectiveIndex(context, directiveIndex);
522
- classesInput = classesInput || null;
523
- stylesInput = stylesInput || null;
524
- /** @type {?} */
525
- const ignoreAllClassUpdates = isMultiValueCacheHit(context, true, directiveIndex, classesInput);
526
- /** @type {?} */
527
- const ignoreAllStyleUpdates = isMultiValueCacheHit(context, false, directiveIndex, stylesInput);
528
557
  // early exit (this is what's done to avoid using ctx.bind() to cache the value)
529
- if (ignoreAllClassUpdates && ignoreAllStyleUpdates)
558
+ if (isMultiValueCacheHit(context, entryIsClassBased, directiveIndex, input))
530
559
  return;
531
- classesInput =
532
- classesInput === NO_CHANGE ? readCachedMapValue(context, true, directiveIndex) : classesInput;
533
- stylesInput =
534
- stylesInput === NO_CHANGE ? readCachedMapValue(context, false, directiveIndex) : stylesInput;
560
+ input =
561
+ input === NO_CHANGE ? readCachedMapValue(context, entryIsClassBased, directiveIndex) : input;
535
562
  /** @type {?} */
536
563
  const element = (/** @type {?} */ ((/** @type {?} */ (context[0 /* ElementPosition */]))));
537
564
  /** @type {?} */
538
- const classesPlayerBuilder = classesInput instanceof BoundPlayerFactory ?
539
- new ClassAndStylePlayerBuilder((/** @type {?} */ (classesInput)), element, 1 /* Class */) :
565
+ const playerBuilder = input instanceof BoundPlayerFactory ?
566
+ new ClassAndStylePlayerBuilder((/** @type {?} */ (input)), element, entryIsClassBased ? 1 /* Class */ : 2 /* Style */) :
540
567
  null;
541
568
  /** @type {?} */
542
- const stylesPlayerBuilder = stylesInput instanceof BoundPlayerFactory ?
543
- new ClassAndStylePlayerBuilder((/** @type {?} */ (stylesInput)), element, 2 /* Style */) :
544
- null;
569
+ const rawValue = playerBuilder ? (/** @type {?} */ (((/** @type {?} */ (input))))).value : input;
570
+ // the position is always the same, but whether the player builder gets set
571
+ // at all (depending if its set) will be reflected in the index value below...
545
572
  /** @type {?} */
546
- const classesValue = classesPlayerBuilder ?
547
- (/** @type {?} */ (((/** @type {?} */ (classesInput))))).value :
548
- classesInput;
573
+ const playerBuilderPosition = entryIsClassBased ? 1 /* ClassMapPlayerBuilderPosition */ :
574
+ 3 /* StyleMapPlayerBuilderPosition */;
549
575
  /** @type {?} */
550
- const stylesValue = stylesPlayerBuilder ? (/** @type {?} */ (stylesInput))['value'] : stylesInput;
551
- /** @type {?} */
552
- let classNames = EMPTY_ARRAY;
553
- /** @type {?} */
554
- let applyAllClasses = false;
576
+ let playerBuilderIndex = playerBuilder ? playerBuilderPosition : 0;
555
577
  /** @type {?} */
556
578
  let playerBuildersAreDirty = false;
557
- /** @type {?} */
558
- const classesPlayerBuilderIndex = classesPlayerBuilder ? 1 /* ClassMapPlayerBuilderPosition */ : 0;
559
- if (hasPlayerBuilderChanged(context, classesPlayerBuilder, 1 /* ClassMapPlayerBuilderPosition */)) {
560
- setPlayerBuilder(context, classesPlayerBuilder, 1 /* ClassMapPlayerBuilderPosition */);
561
- playerBuildersAreDirty = true;
562
- }
563
- /** @type {?} */
564
- const stylesPlayerBuilderIndex = stylesPlayerBuilder ? 3 /* StyleMapPlayerBuilderPosition */ : 0;
565
- if (hasPlayerBuilderChanged(context, stylesPlayerBuilder, 3 /* StyleMapPlayerBuilderPosition */)) {
566
- setPlayerBuilder(context, stylesPlayerBuilder, 3 /* StyleMapPlayerBuilderPosition */);
579
+ if (hasPlayerBuilderChanged(context, playerBuilder, playerBuilderPosition)) {
580
+ setPlayerBuilder(context, playerBuilder, playerBuilderPosition);
567
581
  playerBuildersAreDirty = true;
568
582
  }
569
583
  // each time a string-based value pops up then it shouldn't require a deep
570
584
  // check of what's changed.
571
- if (!ignoreAllClassUpdates) {
572
- if (typeof classesValue == 'string') {
573
- classNames = classesValue.split(/\s+/);
574
- // this boolean is used to avoid having to create a key/value map of `true` values
575
- // since a classname string implies that all those classes are added
576
- applyAllClasses = true;
577
- }
578
- else {
579
- classNames = classesValue ? Object.keys(classesValue) : EMPTY_ARRAY;
580
- }
581
- }
582
585
  /** @type {?} */
583
- const multiStylesStartIndex = getMultiStylesStartIndex(context);
586
+ let startIndex;
584
587
  /** @type {?} */
585
- let multiClassesStartIndex = getMultiClassesStartIndex(context);
588
+ let endIndex;
586
589
  /** @type {?} */
587
- let multiClassesEndIndex = context.length;
588
- if (!ignoreAllStyleUpdates) {
589
- /** @type {?} */
590
- const styleProps = stylesValue ? Object.keys(stylesValue) : EMPTY_ARRAY;
591
- /** @type {?} */
592
- const styles = stylesValue || EMPTY_OBJ;
593
- /** @type {?} */
594
- const totalNewEntries = patchStylingMapIntoContext(context, directiveIndex, stylesPlayerBuilderIndex, multiStylesStartIndex, multiClassesStartIndex, styleProps, styles, stylesInput, false);
595
- if (totalNewEntries) {
596
- multiClassesStartIndex += totalNewEntries * 4 /* Size */;
597
- multiClassesEndIndex += totalNewEntries * 4 /* Size */;
590
+ let propNames;
591
+ /** @type {?} */
592
+ let applyAll = false;
593
+ if (entryIsClassBased) {
594
+ if (typeof rawValue == 'string') {
595
+ propNames = rawValue.split(/\s+/);
596
+ // this boolean is used to avoid having to create a key/value map of `true` values
597
+ // since a className string implies that all those classes are added
598
+ applyAll = true;
599
+ }
600
+ else {
601
+ propNames = rawValue ? Object.keys(rawValue) : EMPTY_ARRAY;
598
602
  }
603
+ startIndex = getMultiClassesStartIndex(context);
604
+ endIndex = context.length;
599
605
  }
600
- if (!ignoreAllClassUpdates) {
601
- /** @type {?} */
602
- const classes = (/** @type {?} */ ((classesValue || EMPTY_OBJ)));
603
- patchStylingMapIntoContext(context, directiveIndex, classesPlayerBuilderIndex, multiClassesStartIndex, multiClassesEndIndex, classNames, applyAllClasses || classes, classesInput, true);
606
+ else {
607
+ startIndex = getMultiStylesStartIndex(context);
608
+ endIndex = getMultiClassesStartIndex(context);
609
+ propNames = rawValue ? Object.keys(rawValue) : EMPTY_ARRAY;
604
610
  }
611
+ /** @type {?} */
612
+ const values = (/** @type {?} */ ((rawValue || EMPTY_OBJ)));
613
+ patchStylingMapIntoContext(context, directiveIndex, playerBuilderIndex, startIndex, endIndex, propNames, applyAll || values, input, entryIsClassBased);
605
614
  if (playerBuildersAreDirty) {
606
615
  setContextPlayersDirty(context, true);
607
616
  }
608
- ngDevMode && ngDevMode.stylingMapCacheMiss++;
617
+ ngDevMode && (entryIsClassBased ? ngDevMode.classMapCacheMiss++ : ngDevMode.styleMapCacheMiss++);
609
618
  }
610
619
  /**
611
620
  * Applies the given multi styling (styles or classes) values to the context.
@@ -954,7 +963,7 @@ function updateSingleStylingValue(context, offset, input, isClassBased, directiv
954
963
  const prop = getProp(context, singleIndex);
955
964
  /** @type {?} */
956
965
  const sanitizer = getStyleSanitizer(context, directiveIndex);
957
- setSanitizeFlag(context, singleIndex, (sanitizer && sanitizer(prop)) ? true : false);
966
+ setSanitizeFlag(context, singleIndex, (sanitizer && sanitizer(prop, null, 1 /* ValidateProperty */)) ? true : false);
958
967
  }
959
968
  // the value will always get updated (even if the dirty flag is skipped)
960
969
  setValue(context, singleIndex, value);
@@ -1147,7 +1156,8 @@ export function renderStyling(context, renderer, rootOrView, isFirstRender, clas
1147
1156
  * @return {?}
1148
1157
  */
1149
1158
  export function setStyle(native, prop, value, renderer, sanitizer, store, playerBuilder) {
1150
- value = sanitizer && value ? sanitizer(prop, value) : value;
1159
+ value =
1160
+ sanitizer && value ? sanitizer(prop, value, 3 /* ValidateAndSanitize */) : value;
1151
1161
  if (store || playerBuilder) {
1152
1162
  if (store) {
1153
1163
  store.setValue(prop, value);
@@ -1631,7 +1641,9 @@ function valueExists(value, isClassBased) {
1631
1641
  */
1632
1642
  function prepareInitialFlag(context, prop, entryIsClassBased, sanitizer) {
1633
1643
  /** @type {?} */
1634
- let flag = (sanitizer && sanitizer(prop)) ? 4 /* Sanitize */ : 0 /* None */;
1644
+ let flag = (sanitizer && sanitizer(prop, null, 1 /* ValidateProperty */)) ?
1645
+ 4 /* Sanitize */ :
1646
+ 0 /* None */;
1635
1647
  /** @type {?} */
1636
1648
  let initialIndex;
1637
1649
  if (entryIsClassBased) {
@@ -1897,7 +1909,7 @@ function diffSummaryValues(result, name, prop, a, b) {
1897
1909
  * @param {?} isClassBased
1898
1910
  * @return {?}
1899
1911
  */
1900
- function getSinglePropIndexValue(context, directiveIndex, offset, isClassBased) {
1912
+ export function getSinglePropIndexValue(context, directiveIndex, offset, isClassBased) {
1901
1913
  /** @type {?} */
1902
1914
  const singlePropOffsetRegistryIndex = (/** @type {?} */ (context[2 /* DirectiveRegistryPosition */][(directiveIndex * 2 /* Size */) +
1903
1915
  0 /* SinglePropValuesIndexOffset */]));
@@ -2020,7 +2032,7 @@ export function getInitialStyleStringValue(context) {
2020
2032
  return styleString;
2021
2033
  }
2022
2034
  /**
2023
- * Returns the current cached multi-value for a given directiveIndex within the provided context.
2035
+ * Returns the current cached mutli-value for a given directiveIndex within the provided context.
2024
2036
  * @param {?} context
2025
2037
  * @param {?} entryIsClassBased
2026
2038
  * @param {?} directiveIndex
@@ -2229,4 +2241,4 @@ function assertValidDirectiveIndex(context, directiveIndex) {
2229
2241
  throw new Error('The provided directive is not registered with the styling context');
2230
2242
  }
2231
2243
  }
2232
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"class_and_style_bindings.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/styling/class_and_style_bindings.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*/\nimport {StyleSanitizeFn} from '../../sanitization/style_sanitizer';\nimport {EMPTY_ARRAY, EMPTY_OBJ} from '../empty';\nimport {AttributeMarker, TAttributes} from '../interfaces/node';\nimport {BindingStore, BindingType, Player, PlayerBuilder, PlayerFactory, PlayerIndex} from '../interfaces/player';\nimport {RElement, Renderer3, RendererStyleFlags3, isProceduralRenderer} from '../interfaces/renderer';\nimport {DirectiveOwnerAndPlayerBuilderIndex, DirectiveRegistryValuesIndex, InitialStylingValues, InitialStylingValuesIndex, MapBasedOffsetValues, MapBasedOffsetValuesIndex, SinglePropOffsetValues, SinglePropOffsetValuesIndex, StylingContext, StylingFlags, StylingIndex} from '../interfaces/styling';\nimport {LView, RootContext} from '../interfaces/view';\nimport {NO_CHANGE} from '../tokens';\nimport {getRootContext} from '../util/view_traversal_utils';\n\nimport {allowFlush as allowHostInstructionsQueueFlush, flushQueue as flushHostInstructionsQueue} from './host_instructions_queue';\nimport {BoundPlayerFactory} from './player_factory';\nimport {addPlayerInternal, allocPlayerContext, allocateOrUpdateDirectiveIntoContext, createEmptyStylingContext, getPlayerContext} from './util';\n\n\n/**\n * This file includes the code to power all styling-binding operations in Angular.\n *\n * These include:\n * [style]=\"myStyleObj\"\n * [class]=\"myClassObj\"\n * [style.prop]=\"myPropValue\"\n * [class.name]=\"myClassValue\"\n *\n * It also includes code that will allow style binding code to operate within host\n * bindings for components/directives.\n *\n * There are many different ways in which these functions below are called. Please see\n * `render3/interfaces/styling.ts` to get a better idea of how the styling algorithm works.\n */\n\n\n\n/**\n * Creates a new StylingContext an fills it with the provided static styling attribute values.\n */\nexport function initializeStaticContext(\n    attrs: TAttributes, stylingStartIndex: number, directiveIndex: number = 0): StylingContext {\n  const context = createEmptyStylingContext();\n  patchContextWithStaticAttrs(context, attrs, stylingStartIndex, directiveIndex);\n  return context;\n}\n\n/**\n * Designed to update an existing styling context with new static styling\n * data (classes and styles).\n *\n * @param context the existing styling context\n * @param attrs an array of new static styling attributes that will be\n *              assigned to the context\n * @param attrsStylingStartIndex what index to start iterating within the\n *              provided `attrs` array to start reading style and class values\n */\nexport function patchContextWithStaticAttrs(\n    context: StylingContext, attrs: TAttributes, attrsStylingStartIndex: number,\n    directiveIndex: number): void {\n  // this means the context has already been set and instantiated\n  if (context[StylingIndex.MasterFlagPosition] & StylingFlags.BindingAllocationLocked) return;\n\n  allocateOrUpdateDirectiveIntoContext(context, directiveIndex);\n\n  let initialClasses: InitialStylingValues|null = null;\n  let initialStyles: InitialStylingValues|null = null;\n  let mode = -1;\n  for (let i = attrsStylingStartIndex; i < attrs.length; i++) {\n    const attr = attrs[i];\n    if (typeof attr == 'number') {\n      mode = attr;\n    } else if (mode == AttributeMarker.Classes) {\n      initialClasses = initialClasses || context[StylingIndex.InitialClassValuesPosition];\n      patchInitialStylingValue(initialClasses, attr as string, true, directiveIndex);\n    } else if (mode == AttributeMarker.Styles) {\n      initialStyles = initialStyles || context[StylingIndex.InitialStyleValuesPosition];\n      patchInitialStylingValue(initialStyles, attr as string, attrs[++i], directiveIndex);\n    }\n  }\n}\n\n/**\n * Designed to add a style or class value into the existing set of initial styles.\n *\n * The function will search and figure out if a style/class value is already present\n * within the provided initial styling array. If and when a style/class value is\n * present (allocated) then the code below will set the new value depending on the\n * following cases:\n *\n *  1) if the existing value is falsy (this happens because a `[class.prop]` or\n *     `[style.prop]` binding was set, but there wasn't a matching static style\n *     or class present on the context)\n *  2) if the value was set already by the template, component or directive, but the\n *     new value is set on a higher level (i.e. a sub component which extends a parent\n *     component sets its value after the parent has already set the same one)\n *  3) if the same directive provides a new set of styling values to set\n *\n * @param initialStyling the initial styling array where the new styling entry will be added to\n * @param prop the property value of the new entry (e.g. `width` (styles) or `foo` (classes))\n * @param value the styling value of the new entry (e.g. `absolute` (styles) or `true` (classes))\n * @param directiveOwnerIndex the directive owner index value of the styling source responsible\n *        for these styles (see `interfaces/styling.ts#directives` for more info)\n */\nfunction patchInitialStylingValue(\n    initialStyling: InitialStylingValues, prop: string, value: any,\n    directiveOwnerIndex: number): void {\n  for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < initialStyling.length;\n       i += InitialStylingValuesIndex.Size) {\n    const key = initialStyling[i + InitialStylingValuesIndex.PropOffset];\n    if (key === prop) {\n      const existingValue =\n          initialStyling[i + InitialStylingValuesIndex.ValueOffset] as string | null | boolean;\n      const existingOwner =\n          initialStyling[i + InitialStylingValuesIndex.DirectiveOwnerOffset] as number;\n      if (allowValueChange(existingValue, value, existingOwner, directiveOwnerIndex)) {\n        addOrUpdateStaticStyle(i, initialStyling, prop, value, directiveOwnerIndex);\n      }\n      return;\n    }\n  }\n\n  // We did not find existing key, add a new one.\n  addOrUpdateStaticStyle(null, initialStyling, prop, value, directiveOwnerIndex);\n}\n\n/**\n * Runs through the initial class values present in the provided\n * context and renders them via the provided renderer on the element.\n *\n * @param element the element the styling will be applied to\n * @param context the source styling context which contains the initial class values\n * @param renderer the renderer instance that will be used to apply the class\n * @returns the index that the classes were applied up until\n */\nexport function renderInitialClasses(\n    element: RElement, context: StylingContext, renderer: Renderer3, startIndex?: number): number {\n  const initialClasses = context[StylingIndex.InitialClassValuesPosition];\n  let i = startIndex || InitialStylingValuesIndex.KeyValueStartPosition;\n  while (i < initialClasses.length) {\n    const value = initialClasses[i + InitialStylingValuesIndex.ValueOffset];\n    if (value) {\n      setClass(\n          element, initialClasses[i + InitialStylingValuesIndex.PropOffset] as string, true,\n          renderer, null);\n    }\n    i += InitialStylingValuesIndex.Size;\n  }\n  return i;\n}\n\n/**\n * Runs through the initial styles values present in the provided\n * context and renders them via the provided renderer on the element.\n *\n * @param element the element the styling will be applied to\n * @param context the source styling context which contains the initial class values\n * @param renderer the renderer instance that will be used to apply the class\n * @returns the index that the styles were applied up until\n */\nexport function renderInitialStyles(\n    element: RElement, context: StylingContext, renderer: Renderer3, startIndex?: number) {\n  const initialStyles = context[StylingIndex.InitialStyleValuesPosition];\n  let i = startIndex || InitialStylingValuesIndex.KeyValueStartPosition;\n  while (i < initialStyles.length) {\n    const value = initialStyles[i + InitialStylingValuesIndex.ValueOffset];\n    if (value) {\n      setStyle(\n          element, initialStyles[i + InitialStylingValuesIndex.PropOffset] as string,\n          value as string, renderer, null);\n    }\n    i += InitialStylingValuesIndex.Size;\n  }\n  return i;\n}\n\nexport function allowNewBindingsForStylingContext(context: StylingContext): boolean {\n  return (context[StylingIndex.MasterFlagPosition] & StylingFlags.BindingAllocationLocked) === 0;\n}\n\n/**\n * Adds in new binding values to a styling context.\n *\n * If a directive value is provided then all provided class/style binding names will\n * reference the provided directive.\n *\n * @param context the existing styling context\n * @param classBindingNames an array of class binding names that will be added to the context\n * @param styleBindingNames an array of style binding names that will be added to the context\n * @param styleSanitizer an optional sanitizer that handle all sanitization on for each of\n *    the bindings added to the context. Note that if a directive is provided then the sanitizer\n *    instance will only be active if and when the directive updates the bindings that it owns.\n */\nexport function updateContextWithBindings(\n    context: StylingContext, directiveIndex: number, classBindingNames?: string[] | null,\n    styleBindingNames?: string[] | null, styleSanitizer?: StyleSanitizeFn | null) {\n  if (context[StylingIndex.MasterFlagPosition] & StylingFlags.BindingAllocationLocked) return;\n\n  // this means the context has already been patched with the directive's bindings\n  const isNewDirective =\n      findOrPatchDirectiveIntoRegistry(context, directiveIndex, false, styleSanitizer);\n  if (!isNewDirective) {\n    // this means the directive has already been patched in ... No point in doing anything\n    return;\n  }\n\n  if (styleBindingNames) {\n    styleBindingNames = hyphenateEntries(styleBindingNames);\n  }\n\n  // there are alot of variables being used below to track where in the context the new\n  // binding values will be placed. Because the context consists of multiple types of\n  // entries (single classes/styles and multi classes/styles) alot of the index positions\n  // need to be computed ahead of time and the context needs to be extended before the values\n  // are inserted in.\n  const singlePropOffsetValues = context[StylingIndex.SinglePropOffsetPositions];\n  const totalCurrentClassBindings =\n      singlePropOffsetValues[SinglePropOffsetValuesIndex.ClassesCountPosition];\n  const totalCurrentStyleBindings =\n      singlePropOffsetValues[SinglePropOffsetValuesIndex.StylesCountPosition];\n\n  const cachedClassMapValues = context[StylingIndex.CachedMultiClasses];\n  const cachedStyleMapValues = context[StylingIndex.CachedMultiStyles];\n\n  const classesOffset = totalCurrentClassBindings * StylingIndex.Size;\n  const stylesOffset = totalCurrentStyleBindings * StylingIndex.Size;\n\n  const singleStylesStartIndex = StylingIndex.SingleStylesStartPosition;\n  let singleClassesStartIndex = singleStylesStartIndex + stylesOffset;\n  let multiStylesStartIndex = singleClassesStartIndex + classesOffset;\n  let multiClassesStartIndex = multiStylesStartIndex + stylesOffset;\n\n  // because we're inserting more bindings into the context, this means that the\n  // binding values need to be referenced the singlePropOffsetValues array so that\n  // the template/directive can easily find them inside of the `elementStyleProp`\n  // and the `elementClassProp` functions without iterating through the entire context.\n  // The first step to setting up these reference points is to mark how many bindings\n  // are being added. Even if these bindings already exist in the context, the directive\n  // or template code will still call them unknowingly. Therefore the total values need\n  // to be registered so that we know how many bindings are assigned to each directive.\n  const currentSinglePropsLength = singlePropOffsetValues.length;\n  singlePropOffsetValues.push(\n      styleBindingNames ? styleBindingNames.length : 0,\n      classBindingNames ? classBindingNames.length : 0);\n\n  // the code below will check to see if a new style binding already exists in the context\n  // if so then there is no point in inserting it into the context again. Whether or not it\n  // exists the styling offset code will now know exactly where it is\n  let insertionOffset = 0;\n  const filteredStyleBindingNames: string[] = [];\n  if (styleBindingNames && styleBindingNames.length) {\n    for (let i = 0; i < styleBindingNames.length; i++) {\n      const name = styleBindingNames[i];\n      let singlePropIndex =\n          getMatchingBindingIndex(context, name, singleStylesStartIndex, singleClassesStartIndex);\n      if (singlePropIndex == -1) {\n        singlePropIndex = singleClassesStartIndex + insertionOffset;\n        insertionOffset += StylingIndex.Size;\n        filteredStyleBindingNames.push(name);\n      }\n      singlePropOffsetValues.push(singlePropIndex);\n    }\n  }\n\n  // just like with the style binding loop above, the new class bindings get the same treatment...\n  const filteredClassBindingNames: string[] = [];\n  if (classBindingNames && classBindingNames.length) {\n    for (let i = 0; i < classBindingNames.length; i++) {\n      const name = classBindingNames[i];\n      let singlePropIndex =\n          getMatchingBindingIndex(context, name, singleClassesStartIndex, multiStylesStartIndex);\n      if (singlePropIndex == -1) {\n        singlePropIndex = multiStylesStartIndex + insertionOffset;\n        insertionOffset += StylingIndex.Size;\n        filteredClassBindingNames.push(name);\n      } else {\n        singlePropIndex += filteredStyleBindingNames.length * StylingIndex.Size;\n      }\n      singlePropOffsetValues.push(singlePropIndex);\n    }\n  }\n\n  // because new styles are being inserted, this means the existing collection of style offset\n  // index values are incorrect (they point to the wrong values). The code below will run through\n  // the entire offset array and update the existing set of index values to point to their new\n  // locations while taking the new binding values into consideration.\n  let i = SinglePropOffsetValuesIndex.ValueStartPosition;\n  if (filteredStyleBindingNames.length) {\n    while (i < currentSinglePropsLength) {\n      const totalStyles =\n          singlePropOffsetValues[i + SinglePropOffsetValuesIndex.StylesCountPosition];\n      const totalClasses =\n          singlePropOffsetValues[i + SinglePropOffsetValuesIndex.ClassesCountPosition];\n      if (totalClasses) {\n        const start = i + SinglePropOffsetValuesIndex.ValueStartPosition + totalStyles;\n        for (let j = start; j < start + totalClasses; j++) {\n          singlePropOffsetValues[j] += filteredStyleBindingNames.length * StylingIndex.Size;\n        }\n      }\n\n      const total = totalStyles + totalClasses;\n      i += SinglePropOffsetValuesIndex.ValueStartPosition + total;\n    }\n  }\n\n  const totalNewEntries = filteredClassBindingNames.length + filteredStyleBindingNames.length;\n\n  // in the event that there are new style values being inserted, all existing class and style\n  // bindings need to have their pointer values offsetted with the new amount of space that is\n  // used for the new style/class bindings.\n  for (let i = singleStylesStartIndex; i < context.length; i += StylingIndex.Size) {\n    const isMultiBased = i >= multiStylesStartIndex;\n    const isClassBased = i >= (isMultiBased ? multiClassesStartIndex : singleClassesStartIndex);\n    const flag = getPointers(context, i);\n    const staticIndex = getInitialIndex(flag);\n    let singleOrMultiIndex = getMultiOrSingleIndex(flag);\n    if (isMultiBased) {\n      singleOrMultiIndex +=\n          isClassBased ? (filteredStyleBindingNames.length * StylingIndex.Size) : 0;\n    } else {\n      singleOrMultiIndex += (totalNewEntries * StylingIndex.Size) +\n          ((isClassBased ? filteredStyleBindingNames.length : 0) * StylingIndex.Size);\n    }\n    setFlag(context, i, pointers(flag, staticIndex, singleOrMultiIndex));\n  }\n\n  // this is where we make space in the context for the new style bindings\n  for (let i = 0; i < filteredStyleBindingNames.length * StylingIndex.Size; i++) {\n    context.splice(multiClassesStartIndex, 0, null);\n    context.splice(singleClassesStartIndex, 0, null);\n    singleClassesStartIndex++;\n    multiStylesStartIndex++;\n    multiClassesStartIndex += 2;  // both single + multi slots were inserted\n  }\n\n  // this is where we make space in the context for the new class bindings\n  for (let i = 0; i < filteredClassBindingNames.length * StylingIndex.Size; i++) {\n    context.splice(multiStylesStartIndex, 0, null);\n    context.push(null);\n    multiStylesStartIndex++;\n    multiClassesStartIndex++;\n  }\n\n  const initialClasses = context[StylingIndex.InitialClassValuesPosition];\n  const initialStyles = context[StylingIndex.InitialStyleValuesPosition];\n\n  // the code below will insert each new entry into the context and assign the appropriate\n  // flags and index values to them. It's important this runs at the end of this function\n  // because the context, property offset and index values have all been computed just before.\n  for (let i = 0; i < totalNewEntries; i++) {\n    const entryIsClassBased = i >= filteredStyleBindingNames.length;\n    const adjustedIndex = entryIsClassBased ? (i - filteredStyleBindingNames.length) : i;\n    const propName = entryIsClassBased ? filteredClassBindingNames[adjustedIndex] :\n                                         filteredStyleBindingNames[adjustedIndex];\n\n    let multiIndex, singleIndex;\n    if (entryIsClassBased) {\n      multiIndex = multiClassesStartIndex +\n          ((totalCurrentClassBindings + adjustedIndex) * StylingIndex.Size);\n      singleIndex = singleClassesStartIndex +\n          ((totalCurrentClassBindings + adjustedIndex) * StylingIndex.Size);\n    } else {\n      multiIndex =\n          multiStylesStartIndex + ((totalCurrentStyleBindings + adjustedIndex) * StylingIndex.Size);\n      singleIndex = singleStylesStartIndex +\n          ((totalCurrentStyleBindings + adjustedIndex) * StylingIndex.Size);\n    }\n\n    // if a property is not found in the initial style values list then it\n    // is ALWAYS added in case a follow-up directive introduces the same initial\n    // style/class value later on.\n    let initialValuesToLookup = entryIsClassBased ? initialClasses : initialStyles;\n    let indexForInitial = getInitialStylingValuesIndexOf(initialValuesToLookup, propName);\n    if (indexForInitial === -1) {\n      indexForInitial = addOrUpdateStaticStyle(\n                            null, initialValuesToLookup, propName, entryIsClassBased ? false : null,\n                            directiveIndex) +\n          InitialStylingValuesIndex.ValueOffset;\n    } else {\n      indexForInitial += InitialStylingValuesIndex.ValueOffset;\n    }\n\n    const initialFlag =\n        prepareInitialFlag(context, propName, entryIsClassBased, styleSanitizer || null);\n\n    setFlag(context, singleIndex, pointers(initialFlag, indexForInitial, multiIndex));\n    setProp(context, singleIndex, propName);\n    setValue(context, singleIndex, null);\n    setPlayerBuilderIndex(context, singleIndex, 0, directiveIndex);\n\n    setFlag(context, multiIndex, pointers(initialFlag, indexForInitial, singleIndex));\n    setProp(context, multiIndex, propName);\n    setValue(context, multiIndex, null);\n    setPlayerBuilderIndex(context, multiIndex, 0, directiveIndex);\n  }\n\n  // the total classes/style values are updated so the next time the context is patched\n  // additional style/class bindings from another directive then it knows exactly where\n  // to insert them in the context\n  singlePropOffsetValues[SinglePropOffsetValuesIndex.ClassesCountPosition] =\n      totalCurrentClassBindings + filteredClassBindingNames.length;\n  singlePropOffsetValues[SinglePropOffsetValuesIndex.StylesCountPosition] =\n      totalCurrentStyleBindings + filteredStyleBindingNames.length;\n\n  // the map-based values also need to know how many entries got inserted\n  cachedClassMapValues[MapBasedOffsetValuesIndex.EntriesCountPosition] +=\n      filteredClassBindingNames.length;\n  cachedStyleMapValues[MapBasedOffsetValuesIndex.EntriesCountPosition] +=\n      filteredStyleBindingNames.length;\n  const newStylesSpaceAllocationSize = filteredStyleBindingNames.length * StylingIndex.Size;\n  const newClassesSpaceAllocationSize = filteredClassBindingNames.length * StylingIndex.Size;\n\n  // update the multi styles cache with a reference for the directive that was just inserted\n  const directiveMultiStylesStartIndex =\n      multiStylesStartIndex + totalCurrentStyleBindings * StylingIndex.Size;\n  const cachedStyleMapIndex = cachedStyleMapValues.length;\n  registerMultiMapEntry(\n      context, directiveIndex, false, directiveMultiStylesStartIndex,\n      filteredStyleBindingNames.length);\n\n  for (let i = MapBasedOffsetValuesIndex.ValuesStartPosition; i < cachedStyleMapIndex;\n       i += MapBasedOffsetValuesIndex.Size) {\n    // multi values start after all the single values (which is also where classes are) in the\n    // context therefore the new class allocation size should be taken into account\n    cachedStyleMapValues[i + MapBasedOffsetValuesIndex.PositionStartOffset] +=\n        newClassesSpaceAllocationSize + newStylesSpaceAllocationSize;\n  }\n\n  // update the multi classes cache with a reference for the directive that was just inserted\n  const directiveMultiClassesStartIndex =\n      multiClassesStartIndex + totalCurrentClassBindings * StylingIndex.Size;\n  const cachedClassMapIndex = cachedClassMapValues.length;\n  registerMultiMapEntry(\n      context, directiveIndex, true, directiveMultiClassesStartIndex,\n      filteredClassBindingNames.length);\n\n  for (let i = MapBasedOffsetValuesIndex.ValuesStartPosition; i < cachedClassMapIndex;\n       i += MapBasedOffsetValuesIndex.Size) {\n    // the reason why both the styles + classes space is allocated to the existing offsets is\n    // because the styles show up before the classes in the context and any new inserted\n    // styles will offset any existing class entries in the context (even if there are no\n    // new class entries added) also the reason why it's *2 is because both single + multi\n    // entries for each new style have been added in the context before the multi class values\n    // actually start\n    cachedClassMapValues[i + MapBasedOffsetValuesIndex.PositionStartOffset] +=\n        (newStylesSpaceAllocationSize * 2) + newClassesSpaceAllocationSize;\n  }\n\n  // there is no initial value flag for the master index since it doesn't\n  // reference an initial style value\n  const masterFlag = pointers(0, 0, multiStylesStartIndex);\n  setFlag(context, StylingIndex.MasterFlagPosition, masterFlag);\n}\n\n/**\n * Searches through the existing registry of directives\n */\nexport function findOrPatchDirectiveIntoRegistry(\n    context: StylingContext, directiveIndex: number, staticModeOnly: boolean,\n    styleSanitizer?: StyleSanitizeFn | null): boolean {\n  const directiveRegistry = context[StylingIndex.DirectiveRegistryPosition];\n  const index = directiveIndex * DirectiveRegistryValuesIndex.Size;\n  const singlePropStartPosition = index + DirectiveRegistryValuesIndex.SinglePropValuesIndexOffset;\n\n  // this means that the directive has already been registered into the registry\n  if (index < directiveRegistry.length &&\n      (directiveRegistry[singlePropStartPosition] as number) >= 0)\n    return false;\n\n  const singlePropsStartIndex =\n      staticModeOnly ? -1 : context[StylingIndex.SinglePropOffsetPositions].length;\n  allocateOrUpdateDirectiveIntoContext(\n      context, directiveIndex, singlePropsStartIndex, styleSanitizer);\n  return true;\n}\n\nfunction getMatchingBindingIndex(\n    context: StylingContext, bindingName: string, start: number, end: number) {\n  for (let j = start; j < end; j += StylingIndex.Size) {\n    if (getProp(context, j) === bindingName) return j;\n  }\n  return -1;\n}\n\n/**\n * Registers the provided multi styling (`[style]` and `[class]`) values to the context.\n *\n * This function will iterate over the provided `classesInput` and `stylesInput` map\n * values and insert/update or remove them from the context at exactly the right\n * spot.\n *\n * This function also takes in a directive which implies that the styling values will\n * be evaluated for that directive with respect to any other styling that already exists\n * on the context. When there are styles that conflict (e.g. say `ngStyle` and `[style]`\n * both update the `width` property at the same time) then the styling algorithm code below\n * will decide which one wins based on the directive styling prioritization mechanism. This\n * mechanism is better explained in render3/interfaces/styling.ts#directives).\n *\n * This function will not render any styling values on screen, but is rather designed to\n * prepare the context for that. `renderStyling` must be called afterwards to render any\n * styling data that was set in this function (note that `updateClassProp` and\n * `updateStyleProp` are designed to be run after this function is run).\n *\n * @param context The styling context that will be updated with the\n *    newly provided style values.\n * @param classesInput The key/value map of CSS class names that will be used for the update.\n * @param stylesInput The key/value map of CSS styles that will be used for the update.\n */\nexport function updateStylingMap(\n    context: StylingContext, classesInput: {[key: string]: any} | string |\n        BoundPlayerFactory<null|string|{[key: string]: any}>| null,\n    stylesInput?: {[key: string]: any} | BoundPlayerFactory<null|{[key: string]: any}>| null,\n    directiveIndex: number = 0): void {\n  ngDevMode && ngDevMode.stylingMap++;\n  ngDevMode && assertValidDirectiveIndex(context, directiveIndex);\n  classesInput = classesInput || null;\n  stylesInput = stylesInput || null;\n  const ignoreAllClassUpdates = isMultiValueCacheHit(context, true, directiveIndex, classesInput);\n  const ignoreAllStyleUpdates = isMultiValueCacheHit(context, false, directiveIndex, stylesInput);\n\n  // early exit (this is what's done to avoid using ctx.bind() to cache the value)\n  if (ignoreAllClassUpdates && ignoreAllStyleUpdates) return;\n\n  classesInput =\n      classesInput === NO_CHANGE ? readCachedMapValue(context, true, directiveIndex) : classesInput;\n  stylesInput =\n      stylesInput === NO_CHANGE ? readCachedMapValue(context, false, directiveIndex) : stylesInput;\n\n  const element = context[StylingIndex.ElementPosition] !as HTMLElement;\n  const classesPlayerBuilder = classesInput instanceof BoundPlayerFactory ?\n      new ClassAndStylePlayerBuilder(classesInput as any, element, BindingType.Class) :\n      null;\n  const stylesPlayerBuilder = stylesInput instanceof BoundPlayerFactory ?\n      new ClassAndStylePlayerBuilder(stylesInput as any, element, BindingType.Style) :\n      null;\n\n  const classesValue = classesPlayerBuilder ?\n      (classesInput as BoundPlayerFactory<{[key: string]: any}|string>) !.value :\n      classesInput;\n  const stylesValue = stylesPlayerBuilder ? stylesInput !['value'] : stylesInput;\n\n  let classNames: string[] = EMPTY_ARRAY;\n  let applyAllClasses = false;\n  let playerBuildersAreDirty = false;\n\n  const classesPlayerBuilderIndex =\n      classesPlayerBuilder ? PlayerIndex.ClassMapPlayerBuilderPosition : 0;\n  if (hasPlayerBuilderChanged(\n          context, classesPlayerBuilder, PlayerIndex.ClassMapPlayerBuilderPosition)) {\n    setPlayerBuilder(context, classesPlayerBuilder, PlayerIndex.ClassMapPlayerBuilderPosition);\n    playerBuildersAreDirty = true;\n  }\n\n  const stylesPlayerBuilderIndex =\n      stylesPlayerBuilder ? PlayerIndex.StyleMapPlayerBuilderPosition : 0;\n  if (hasPlayerBuilderChanged(\n          context, stylesPlayerBuilder, PlayerIndex.StyleMapPlayerBuilderPosition)) {\n    setPlayerBuilder(context, stylesPlayerBuilder, PlayerIndex.StyleMapPlayerBuilderPosition);\n    playerBuildersAreDirty = true;\n  }\n\n  // each time a string-based value pops up then it shouldn't require a deep\n  // check of what's changed.\n  if (!ignoreAllClassUpdates) {\n    if (typeof classesValue == 'string') {\n      classNames = classesValue.split(/\\s+/);\n      // this boolean is used to avoid having to create a key/value map of `true` values\n      // since a classname string implies that all those classes are added\n      applyAllClasses = true;\n    } else {\n      classNames = classesValue ? Object.keys(classesValue) : EMPTY_ARRAY;\n    }\n  }\n\n  const multiStylesStartIndex = getMultiStylesStartIndex(context);\n  let multiClassesStartIndex = getMultiClassesStartIndex(context);\n  let multiClassesEndIndex = context.length;\n\n  if (!ignoreAllStyleUpdates) {\n    const styleProps = stylesValue ? Object.keys(stylesValue) : EMPTY_ARRAY;\n    const styles = stylesValue || EMPTY_OBJ;\n    const totalNewEntries = patchStylingMapIntoContext(\n        context, directiveIndex, stylesPlayerBuilderIndex, multiStylesStartIndex,\n        multiClassesStartIndex, styleProps, styles, stylesInput, false);\n    if (totalNewEntries) {\n      multiClassesStartIndex += totalNewEntries * StylingIndex.Size;\n      multiClassesEndIndex += totalNewEntries * StylingIndex.Size;\n    }\n  }\n\n  if (!ignoreAllClassUpdates) {\n    const classes = (classesValue || EMPTY_OBJ) as{[key: string]: any};\n    patchStylingMapIntoContext(\n        context, directiveIndex, classesPlayerBuilderIndex, multiClassesStartIndex,\n        multiClassesEndIndex, classNames, applyAllClasses || classes, classesInput, true);\n  }\n\n  if (playerBuildersAreDirty) {\n    setContextPlayersDirty(context, true);\n  }\n\n  ngDevMode && ngDevMode.stylingMapCacheMiss++;\n}\n\n/**\n * Applies the given multi styling (styles or classes) values to the context.\n *\n * The styling algorithm code that applies multi-level styling (things like `[style]` and `[class]`\n * values) resides here.\n *\n * Because this function understands that multiple directives may all write to the `[style]` and\n * `[class]` bindings (through host bindings), it relies of each directive applying its binding\n * value in order. This means that a directive like `classADirective` will always fire before\n * `classBDirective` and therefore its styling values (classes and styles) will always be evaluated\n * in the same order. Because of this consistent ordering, the first directive has a higher priority\n * than the second one. It is with this prioritzation mechanism that the styling algorithm knows how\n * to merge and apply redudant styling properties.\n *\n * The function itself applies the key/value entries (or an array of keys) to\n * the context in the following steps.\n *\n * STEP 1:\n *    First check to see what properties are already set and in use by another directive in the\n *    context (e.g. `ngClass` set the `width` value and `[style.width]=\"w\"` in a directive is\n *    attempting to set it as well).\n *\n * STEP 2:\n *    All remaining properties (that were not set prior to this directive) are now updated in\n *    the context. Any new properties are inserted exactly at their spot in the context and any\n *    previously set properties are shifted to exactly where the cursor sits while iterating over\n *    the context. The end result is a balanced context that includes the exact ordering of the\n *    styling properties/values for the provided input from the directive.\n *\n * STEP 3:\n *    Any unmatched properties in the context that belong to the directive are set to null\n *\n * Once the updating phase is done, then the algorithm will decide whether or not to flag the\n * follow-up directives (the directives that will pass in their styling values) depending on if\n * the \"shape\" of the multi-value map has changed (either if any keys are removed or added or\n * if there are any new `null` values). If any follow-up directives are flagged as dirty then the\n * algorithm will run again for them. Otherwise if the shape did not change then any follow-up\n * directives will not run (so long as their binding values stay the same).\n *\n * @returns the total amount of new slots that were allocated into the context due to new styling\n *          properties that were detected.\n */\nfunction patchStylingMapIntoContext(\n    context: StylingContext, directiveIndex: number, playerBuilderIndex: number, ctxStart: number,\n    ctxEnd: number, props: (string | null)[], values: {[key: string]: any} | true, cacheValue: any,\n    entryIsClassBased: boolean): number {\n  let dirty = false;\n\n  const cacheIndex = MapBasedOffsetValuesIndex.ValuesStartPosition +\n      directiveIndex * MapBasedOffsetValuesIndex.Size;\n\n  // the cachedValues array is the registry of all multi style values (map values). Each\n  // value is stored (cached) each time is updated.\n  const cachedValues =\n      context[entryIsClassBased ? StylingIndex.CachedMultiClasses : StylingIndex.CachedMultiStyles];\n\n  // this is the index in which this directive has ownership access to write to this\n  // value (anything before is owned by a previous directive that is more important)\n  const ownershipValuesStartIndex =\n      cachedValues[cacheIndex + MapBasedOffsetValuesIndex.PositionStartOffset];\n\n  const existingCachedValue = cachedValues[cacheIndex + MapBasedOffsetValuesIndex.ValueOffset];\n  const existingCachedValueCount =\n      cachedValues[cacheIndex + MapBasedOffsetValuesIndex.ValueCountOffset];\n  const existingCachedValueIsDirty =\n      cachedValues[cacheIndex + MapBasedOffsetValuesIndex.DirtyFlagOffset] === 1;\n\n  // A shape change means the provided map value has either removed or added new properties\n  // compared to what were in the last time. If a shape change occurs then it means that all\n  // follow-up multi-styling entries are obsolete and will be examined again when CD runs\n  // them. If a shape change has not occurred then there is no reason to check any other\n  // directive values if their identity has not changed. If a previous directive set this\n  // value as dirty (because its own shape changed) then this means that the object has been\n  // offset to a different area in the context. Because its value has been offset then it\n  // can't write to a region that it wrote to before (which may have been apart of another\n  // directive) and therefore its shape changes too.\n  let valuesEntryShapeChange =\n      existingCachedValueIsDirty || ((!existingCachedValue && cacheValue) ? true : false);\n\n  let totalUniqueValues = 0;\n  let totalNewAllocatedSlots = 0;\n\n  // this is a trick to avoid building {key:value} map where all the values\n  // are `true` (this happens when a className string is provided instead of a\n  // map as an input value to this styling algorithm)\n  const applyAllProps = values === true;\n\n  // STEP 1:\n  // loop through the earlier directives and figure out if any properties here will be placed\n  // in their area (this happens when the value is null because the earlier directive erased it).\n  let ctxIndex = ctxStart;\n  let totalRemainingProperties = props.length;\n  while (ctxIndex < ownershipValuesStartIndex) {\n    const currentProp = getProp(context, ctxIndex);\n    if (totalRemainingProperties) {\n      for (let i = 0; i < props.length; i++) {\n        const mapProp = props[i];\n        const normalizedProp = mapProp ? (entryIsClassBased ? mapProp : hyphenate(mapProp)) : null;\n        if (normalizedProp && currentProp === normalizedProp) {\n          const currentValue = getValue(context, ctxIndex);\n          const currentDirectiveIndex = getDirectiveIndexFromEntry(context, ctxIndex);\n          const value = applyAllProps ? true : (values as{[key: string]: any})[normalizedProp];\n          const currentFlag = getPointers(context, ctxIndex);\n          if (hasValueChanged(currentFlag, currentValue, value) &&\n              allowValueChange(currentValue, value, currentDirectiveIndex, directiveIndex)) {\n            setValue(context, ctxIndex, value);\n            setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);\n            if (hasInitialValueChanged(context, currentFlag, value)) {\n              setDirty(context, ctxIndex, true);\n              dirty = true;\n            }\n          }\n          props[i] = null;\n          totalRemainingProperties--;\n          break;\n        }\n      }\n    }\n    ctxIndex += StylingIndex.Size;\n  }\n\n  // STEP 2:\n  // apply the left over properties to the context in the correct order.\n  if (totalRemainingProperties) {\n    const sanitizer = entryIsClassBased ? null : getStyleSanitizer(context, directiveIndex);\n    propertiesLoop: for (let i = 0; i < props.length; i++) {\n      const mapProp = props[i];\n\n      if (!mapProp) {\n        // this is an early exit in case a value was already encountered above in the\n        // previous loop (which means that the property was applied or rejected)\n        continue;\n      }\n\n      const value = applyAllProps ? true : (values as{[key: string]: any})[mapProp];\n      const normalizedProp = entryIsClassBased ? mapProp : hyphenate(mapProp);\n      const isInsideOwnershipArea = ctxIndex >= ownershipValuesStartIndex;\n\n      for (let j = ctxIndex; j < ctxEnd; j += StylingIndex.Size) {\n        const distantCtxProp = getProp(context, j);\n        if (distantCtxProp === normalizedProp) {\n          const distantCtxDirectiveIndex = getDirectiveIndexFromEntry(context, j);\n          const distantCtxPlayerBuilderIndex = getPlayerBuilderIndex(context, j);\n          const distantCtxValue = getValue(context, j);\n          const distantCtxFlag = getPointers(context, j);\n\n          if (allowValueChange(distantCtxValue, value, distantCtxDirectiveIndex, directiveIndex)) {\n            // even if the entry isn't updated (by value or directiveIndex) then\n            // it should still be moved over to the correct spot in the array so\n            // the iteration loop is tighter.\n            if (isInsideOwnershipArea) {\n              swapMultiContextEntries(context, ctxIndex, j);\n              totalUniqueValues++;\n            }\n\n            if (hasValueChanged(distantCtxFlag, distantCtxValue, value)) {\n              if (value === null || value === undefined && value !== distantCtxValue) {\n                valuesEntryShapeChange = true;\n              }\n\n              setValue(context, ctxIndex, value);\n\n              // SKIP IF INITIAL CHECK\n              // If the former `value` is `null` then it means that an initial value\n              // could be being rendered on screen. If that is the case then there is\n              // no point in updating the value in case it matches. In other words if the\n              // new value is the exact same as the previously rendered value (which\n              // happens to be the initial value) then do nothing.\n              if (distantCtxValue !== null ||\n                  hasInitialValueChanged(context, distantCtxFlag, value)) {\n                setDirty(context, ctxIndex, true);\n                dirty = true;\n              }\n            }\n\n            if (distantCtxDirectiveIndex !== directiveIndex ||\n                playerBuilderIndex !== distantCtxPlayerBuilderIndex) {\n              setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);\n            }\n          }\n\n          ctxIndex += StylingIndex.Size;\n          continue propertiesLoop;\n        }\n      }\n\n      // fallback case ... value not found at all in the context\n      if (value != null) {\n        valuesEntryShapeChange = true;\n        totalUniqueValues++;\n        const flag = prepareInitialFlag(context, normalizedProp, entryIsClassBased, sanitizer) |\n            StylingFlags.Dirty;\n\n        const insertionIndex = isInsideOwnershipArea ?\n            ctxIndex :\n            (ownershipValuesStartIndex + totalNewAllocatedSlots * StylingIndex.Size);\n        insertNewMultiProperty(\n            context, insertionIndex, entryIsClassBased, normalizedProp, flag, value, directiveIndex,\n            playerBuilderIndex);\n\n        totalNewAllocatedSlots++;\n        ctxEnd += StylingIndex.Size;\n        ctxIndex += StylingIndex.Size;\n\n        dirty = true;\n      }\n    }\n  }\n\n  // STEP 3:\n  // Remove (nullify) any existing entries in the context that were not apart of the\n  // map input value that was passed into this algorithm for this directive.\n  while (ctxIndex < ctxEnd) {\n    valuesEntryShapeChange = true;  // some values are missing\n    const ctxValue = getValue(context, ctxIndex);\n    const ctxFlag = getPointers(context, ctxIndex);\n    const ctxDirective = getDirectiveIndexFromEntry(context, ctxIndex);\n    if (ctxValue != null) {\n      valuesEntryShapeChange = true;\n    }\n    if (hasValueChanged(ctxFlag, ctxValue, null)) {\n      setValue(context, ctxIndex, null);\n      // only if the initial value is falsy then\n      if (hasInitialValueChanged(context, ctxFlag, ctxValue)) {\n        setDirty(context, ctxIndex, true);\n        dirty = true;\n      }\n      setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);\n    }\n    ctxIndex += StylingIndex.Size;\n  }\n\n  // Because the object shape has changed, this means that all follow-up directives will need to\n  // reapply their values into the object. For this to happen, the cached array needs to be updated\n  // with dirty flags so that follow-up calls to `updateStylingMap` will reapply their styling code.\n  // the reapplication of styling code within the context will reshape it and update the offset\n  // values (also follow-up directives can write new values in case earlier directives set anything\n  // to null due to removals or falsy values).\n  valuesEntryShapeChange = valuesEntryShapeChange || existingCachedValueCount !== totalUniqueValues;\n  updateCachedMapValue(\n      context, directiveIndex, entryIsClassBased, cacheValue, ownershipValuesStartIndex, ctxEnd,\n      totalUniqueValues, valuesEntryShapeChange);\n\n  if (dirty) {\n    setContextDirty(context, true);\n  }\n\n  return totalNewAllocatedSlots;\n}\n\n/**\n * Sets and resolves a single class value on the provided `StylingContext` so\n * that they can be applied to the element once `renderStyling` is called.\n *\n * @param context The styling context that will be updated with the\n *    newly provided class value.\n * @param offset The index of the CSS class which is being updated.\n * @param addOrRemove Whether or not to add or remove the CSS class\n * @param forceOverride whether or not to skip all directive prioritization\n *    and just apply the value regardless.\n */\nexport function updateClassProp(\n    context: StylingContext, offset: number,\n    input: boolean | BoundPlayerFactory<boolean|null>| null, directiveIndex: number = 0,\n    forceOverride?: boolean): void {\n  updateSingleStylingValue(context, offset, input, true, directiveIndex, forceOverride);\n}\n\n/**\n * Sets and resolves a single style value on the provided `StylingContext` so\n * that they can be applied to the element once `renderStyling` is called.\n *\n * Note that prop-level styling values are considered higher priority than any styling that\n * has been applied using `updateStylingMap`, therefore, when styling values are rendered\n * then any styles/classes that have been applied using this function will be considered first\n * (then multi values second and then initial values as a backup).\n *\n * @param context The styling context that will be updated with the\n *    newly provided style value.\n * @param offset The index of the property which is being updated.\n * @param value The CSS style value that will be assigned\n * @param forceOverride whether or not to skip all directive prioritization\n *    and just apply the value regardless.\n */\nexport function updateStyleProp(\n    context: StylingContext, offset: number,\n    input: string | boolean | null | BoundPlayerFactory<string|boolean|null>,\n    directiveIndex: number = 0, forceOverride?: boolean): void {\n  updateSingleStylingValue(context, offset, input, false, directiveIndex, forceOverride);\n}\n\nfunction updateSingleStylingValue(\n    context: StylingContext, offset: number,\n    input: string | boolean | null | BoundPlayerFactory<string|boolean|null>, isClassBased: boolean,\n    directiveIndex: number, forceOverride?: boolean): void {\n  ngDevMode && assertValidDirectiveIndex(context, directiveIndex);\n  const singleIndex = getSinglePropIndexValue(context, directiveIndex, offset, isClassBased);\n  const currValue = getValue(context, singleIndex);\n  const currFlag = getPointers(context, singleIndex);\n  const currDirective = getDirectiveIndexFromEntry(context, singleIndex);\n  const value: string|boolean|null = (input instanceof BoundPlayerFactory) ? input.value : input;\n\n  ngDevMode && ngDevMode.stylingProp++;\n\n  if (hasValueChanged(currFlag, currValue, value) &&\n      (forceOverride || allowValueChange(currValue, value, currDirective, directiveIndex))) {\n    const isClassBased = (currFlag & StylingFlags.Class) === StylingFlags.Class;\n    const element = context[StylingIndex.ElementPosition] !as HTMLElement;\n    const playerBuilder = input instanceof BoundPlayerFactory ?\n        new ClassAndStylePlayerBuilder(\n            input as any, element, isClassBased ? BindingType.Class : BindingType.Style) :\n        null;\n    const value = (playerBuilder ? (input as BoundPlayerFactory<any>).value : input) as string |\n        boolean | null;\n    const currPlayerIndex = getPlayerBuilderIndex(context, singleIndex);\n\n    let playerBuildersAreDirty = false;\n    let playerBuilderIndex = playerBuilder ? currPlayerIndex : 0;\n    if (hasPlayerBuilderChanged(context, playerBuilder, currPlayerIndex)) {\n      const newIndex = setPlayerBuilder(context, playerBuilder, currPlayerIndex);\n      playerBuilderIndex = playerBuilder ? newIndex : 0;\n      playerBuildersAreDirty = true;\n    }\n\n    if (playerBuildersAreDirty || currDirective !== directiveIndex) {\n      setPlayerBuilderIndex(context, singleIndex, playerBuilderIndex, directiveIndex);\n    }\n\n    if (currDirective !== directiveIndex) {\n      const prop = getProp(context, singleIndex);\n      const sanitizer = getStyleSanitizer(context, directiveIndex);\n      setSanitizeFlag(context, singleIndex, (sanitizer && sanitizer(prop)) ? true : false);\n    }\n\n    // the value will always get updated (even if the dirty flag is skipped)\n    setValue(context, singleIndex, value);\n    const indexForMulti = getMultiOrSingleIndex(currFlag);\n\n    // if the value is the same in the multi-area then there's no point in re-assembling\n    const valueForMulti = getValue(context, indexForMulti);\n    if (!valueForMulti || hasValueChanged(currFlag, valueForMulti, value)) {\n      let multiDirty = false;\n      let singleDirty = true;\n\n      // only when the value is set to `null` should the multi-value get flagged\n      if (!valueExists(value, isClassBased) && valueExists(valueForMulti, isClassBased)) {\n        multiDirty = true;\n        singleDirty = false;\n      }\n\n      setDirty(context, indexForMulti, multiDirty);\n      setDirty(context, singleIndex, singleDirty);\n      setContextDirty(context, true);\n    }\n\n    if (playerBuildersAreDirty) {\n      setContextPlayersDirty(context, true);\n    }\n\n    ngDevMode && ngDevMode.stylingPropCacheMiss++;\n  }\n}\n\n\n/**\n * Renders all queued styling using a renderer onto the given element.\n *\n * This function works by rendering any styles (that have been applied\n * using `updateStylingMap`) and any classes (that have been applied using\n * `updateStyleProp`) onto the provided element using the provided renderer.\n * Just before the styles/classes are rendered a final key/value style map\n * will be assembled (if `styleStore` or `classStore` are provided).\n *\n * @param lElement the element that the styles will be rendered on\n * @param context The styling context that will be used to determine\n *      what styles will be rendered\n * @param renderer the renderer that will be used to apply the styling\n * @param classesStore if provided, the updated class values will be applied\n *    to this key/value map instead of being renderered via the renderer.\n * @param stylesStore if provided, the updated style values will be applied\n *    to this key/value map instead of being renderered via the renderer.\n * @returns number the total amount of players that got queued for animation (if any)\n */\nexport function renderStyling(\n    context: StylingContext, renderer: Renderer3 | null, rootOrView: RootContext | LView,\n    isFirstRender: boolean, classesStore?: BindingStore | null, stylesStore?: BindingStore | null,\n    directiveIndex: number = 0): number {\n  let totalPlayersQueued = 0;\n  ngDevMode && ngDevMode.stylingApply++;\n\n  // this prevents multiple attempts to render style/class values on\n  // the same element...\n  if (allowHostInstructionsQueueFlush(context, directiveIndex)) {\n    // all styling instructions present within any hostBindings functions\n    // do not update the context immediately when called. They are instead\n    // queued up and applied to the context right at this point. Why? This\n    // is because Angular evaluates component/directive and directive\n    // sub-class code at different points and it's important that the\n    // styling values are applied to the context in the right order\n    // (see `interfaces/styling.ts` for more information).\n    flushHostInstructionsQueue(context);\n\n    if (isContextDirty(context)) {\n      ngDevMode && ngDevMode.stylingApplyCacheMiss++;\n\n      // this is here to prevent things like <ng-container [style] [class]>...</ng-container>\n      // or if there are any host style or class bindings present in a directive set on\n      // a container node\n      const native = context[StylingIndex.ElementPosition] !as HTMLElement;\n\n      const flushPlayerBuilders: any =\n          context[StylingIndex.MasterFlagPosition] & StylingFlags.PlayerBuildersDirty;\n      const multiStartIndex = getMultiStylesStartIndex(context);\n\n      for (let i = StylingIndex.SingleStylesStartPosition; i < context.length;\n           i += StylingIndex.Size) {\n        // there is no point in rendering styles that have not changed on screen\n        if (isDirty(context, i)) {\n          const flag = getPointers(context, i);\n          const directiveIndex = getDirectiveIndexFromEntry(context, i);\n          const prop = getProp(context, i);\n          const value = getValue(context, i);\n          const styleSanitizer =\n              (flag & StylingFlags.Sanitize) ? getStyleSanitizer(context, directiveIndex) : null;\n          const playerBuilder = getPlayerBuilder(context, i);\n          const isClassBased = flag & StylingFlags.Class ? true : false;\n          const isInSingleRegion = i < multiStartIndex;\n\n          let valueToApply: string|boolean|null = value;\n\n          // VALUE DEFER CASE 1: Use a multi value instead of a null single value\n          // this check implies that a single value was removed and we\n          // should now defer to a multi value and use that (if set).\n          if (isInSingleRegion && !valueExists(valueToApply, isClassBased)) {\n            // single values ALWAYS have a reference to a multi index\n            const multiIndex = getMultiOrSingleIndex(flag);\n            valueToApply = getValue(context, multiIndex);\n          }\n\n          // VALUE DEFER CASE 2: Use the initial value if all else fails (is falsy)\n          // the initial value will always be a string or null,\n          // therefore we can safely adopt it in case there's nothing else\n          // note that this should always be a falsy check since `false` is used\n          // for both class and style comparisons (styles can't be false and false\n          // classes are turned off and should therefore defer to their initial values)\n          // Note that we ignore class-based deferals because otherwise a class can never\n          // be removed in the case that it exists as true in the initial classes list...\n          if (!valueExists(valueToApply, isClassBased)) {\n            valueToApply = getInitialValue(context, flag);\n          }\n\n          // if the first render is true then we do not want to start applying falsy\n          // values to the DOM element's styling. Otherwise then we know there has\n          // been a change and even if it's falsy then it's removing something that\n          // was truthy before.\n          const doApplyValue = renderer && (isFirstRender ? valueToApply : true);\n          if (doApplyValue) {\n            if (isClassBased) {\n              setClass(\n                  native, prop, valueToApply ? true : false, renderer !, classesStore,\n                  playerBuilder);\n            } else {\n              setStyle(\n                  native, prop, valueToApply as string | null, renderer !, styleSanitizer,\n                  stylesStore, playerBuilder);\n            }\n          }\n\n          setDirty(context, i, false);\n        }\n      }\n\n      if (flushPlayerBuilders) {\n        const rootContext =\n            Array.isArray(rootOrView) ? getRootContext(rootOrView) : rootOrView as RootContext;\n        const playerContext = getPlayerContext(context) !;\n        const playersStartIndex = playerContext[PlayerIndex.NonBuilderPlayersStart];\n        for (let i = PlayerIndex.PlayerBuildersStartPosition; i < playersStartIndex;\n             i += PlayerIndex.PlayerAndPlayerBuildersTupleSize) {\n          const builder = playerContext[i] as ClassAndStylePlayerBuilder<any>| null;\n          const playerInsertionIndex = i + PlayerIndex.PlayerOffsetPosition;\n          const oldPlayer = playerContext[playerInsertionIndex] as Player | null;\n          if (builder) {\n            const player = builder.buildPlayer(oldPlayer, isFirstRender);\n            if (player !== undefined) {\n              if (player != null) {\n                const wasQueued = addPlayerInternal(\n                    playerContext, rootContext, native as HTMLElement, player,\n                    playerInsertionIndex);\n                wasQueued && totalPlayersQueued++;\n              }\n              if (oldPlayer) {\n                oldPlayer.destroy();\n              }\n            }\n          } else if (oldPlayer) {\n            // the player builder has been removed ... therefore we should delete the associated\n            // player\n            oldPlayer.destroy();\n          }\n        }\n        setContextPlayersDirty(context, false);\n      }\n\n      setContextDirty(context, false);\n    }\n  }\n\n  return totalPlayersQueued;\n}\n\n/**\n * Assigns a style value to a style property for the given element.\n *\n * This function renders a given CSS prop/value entry using the\n * provided renderer. If a `store` value is provided then\n * that will be used a render context instead of the provided\n * renderer.\n *\n * @param native the DOM Element\n * @param prop the CSS style property that will be rendered\n * @param value the CSS style value that will be rendered\n * @param renderer\n * @param store an optional key/value map that will be used as a context to render styles on\n */\nexport function setStyle(\n    native: any, prop: string, value: string | null, renderer: Renderer3,\n    sanitizer: StyleSanitizeFn | null, store?: BindingStore | null,\n    playerBuilder?: ClassAndStylePlayerBuilder<any>| null) {\n  value = sanitizer && value ? sanitizer(prop, value) : value;\n  if (store || playerBuilder) {\n    if (store) {\n      store.setValue(prop, value);\n    }\n    if (playerBuilder) {\n      playerBuilder.setValue(prop, value);\n    }\n  } else if (value) {\n    value = value.toString();  // opacity, z-index and flexbox all have number values which may not\n    // assign as numbers\n    ngDevMode && ngDevMode.rendererSetStyle++;\n    isProceduralRenderer(renderer) ?\n        renderer.setStyle(native, prop, value, RendererStyleFlags3.DashCase) :\n        native.style.setProperty(prop, value);\n  } else {\n    ngDevMode && ngDevMode.rendererRemoveStyle++;\n    isProceduralRenderer(renderer) ?\n        renderer.removeStyle(native, prop, RendererStyleFlags3.DashCase) :\n        native.style.removeProperty(prop);\n  }\n}\n\n/**\n * Adds/removes the provided className value to the provided element.\n *\n * This function renders a given CSS class value using the provided\n * renderer (by adding or removing it from the provided element).\n * If a `store` value is provided then that will be used a render\n * context instead of the provided renderer.\n *\n * @param native the DOM Element\n * @param prop the CSS style property that will be rendered\n * @param value the CSS style value that will be rendered\n * @param renderer\n * @param store an optional key/value map that will be used as a context to render styles on\n */\nfunction setClass(\n    native: any, className: string, add: boolean, renderer: Renderer3, store?: BindingStore | null,\n    playerBuilder?: ClassAndStylePlayerBuilder<any>| null) {\n  if (store || playerBuilder) {\n    if (store) {\n      store.setValue(className, add);\n    }\n    if (playerBuilder) {\n      playerBuilder.setValue(className, add);\n    }\n    // DOMTokenList will throw if we try to add or remove an empty string.\n  } else if (className !== '') {\n    if (add) {\n      ngDevMode && ngDevMode.rendererAddClass++;\n      isProceduralRenderer(renderer) ? renderer.addClass(native, className) :\n                                       native['classList'].add(className);\n    } else {\n      ngDevMode && ngDevMode.rendererRemoveClass++;\n      isProceduralRenderer(renderer) ? renderer.removeClass(native, className) :\n                                       native['classList'].remove(className);\n    }\n  }\n}\n\nfunction setSanitizeFlag(context: StylingContext, index: number, sanitizeYes: boolean) {\n  if (sanitizeYes) {\n    (context[index] as number) |= StylingFlags.Sanitize;\n  } else {\n    (context[index] as number) &= ~StylingFlags.Sanitize;\n  }\n}\n\nfunction setDirty(context: StylingContext, index: number, isDirtyYes: boolean) {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  if (isDirtyYes) {\n    (context[adjustedIndex] as number) |= StylingFlags.Dirty;\n  } else {\n    (context[adjustedIndex] as number) &= ~StylingFlags.Dirty;\n  }\n}\n\nfunction isDirty(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Dirty) == StylingFlags.Dirty;\n}\n\nexport function isClassBasedValue(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Class) == StylingFlags.Class;\n}\n\nfunction isSanitizable(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Sanitize) == StylingFlags.Sanitize;\n}\n\nfunction pointers(configFlag: number, staticIndex: number, dynamicIndex: number) {\n  return (configFlag & StylingFlags.BitMask) | (staticIndex << StylingFlags.BitCountSize) |\n      (dynamicIndex << (StylingIndex.BitCountSize + StylingFlags.BitCountSize));\n}\n\nfunction getInitialValue(context: StylingContext, flag: number): string|boolean|null {\n  const index = getInitialIndex(flag);\n  const entryIsClassBased = flag & StylingFlags.Class;\n  const initialValues = entryIsClassBased ? context[StylingIndex.InitialClassValuesPosition] :\n                                            context[StylingIndex.InitialStyleValuesPosition];\n  return initialValues[index] as string | boolean | null;\n}\n\nfunction getInitialIndex(flag: number): number {\n  return (flag >> StylingFlags.BitCountSize) & StylingIndex.BitMask;\n}\n\nfunction getMultiOrSingleIndex(flag: number): number {\n  const index =\n      (flag >> (StylingIndex.BitCountSize + StylingFlags.BitCountSize)) & StylingIndex.BitMask;\n  return index >= StylingIndex.SingleStylesStartPosition ? index : -1;\n}\n\nfunction getMultiStartIndex(context: StylingContext): number {\n  return getMultiOrSingleIndex(context[StylingIndex.MasterFlagPosition]) as number;\n}\n\nfunction getMultiClassesStartIndex(context: StylingContext): number {\n  const classCache = context[StylingIndex.CachedMultiClasses];\n  return classCache\n      [MapBasedOffsetValuesIndex.ValuesStartPosition +\n       MapBasedOffsetValuesIndex.PositionStartOffset];\n}\n\nfunction getMultiStylesStartIndex(context: StylingContext): number {\n  const stylesCache = context[StylingIndex.CachedMultiStyles];\n  return stylesCache\n      [MapBasedOffsetValuesIndex.ValuesStartPosition +\n       MapBasedOffsetValuesIndex.PositionStartOffset];\n}\n\nfunction setProp(context: StylingContext, index: number, prop: string) {\n  context[index + StylingIndex.PropertyOffset] = prop;\n}\n\nfunction setValue(context: StylingContext, index: number, value: string | null | boolean) {\n  context[index + StylingIndex.ValueOffset] = value;\n}\n\nfunction hasPlayerBuilderChanged(\n    context: StylingContext, builder: ClassAndStylePlayerBuilder<any>| null, index: number) {\n  const playerContext = context[StylingIndex.PlayerContext] !;\n  if (builder) {\n    if (!playerContext || index === 0) {\n      return true;\n    }\n  } else if (!playerContext) {\n    return false;\n  }\n  return playerContext[index] !== builder;\n}\n\nfunction setPlayerBuilder(\n    context: StylingContext, builder: ClassAndStylePlayerBuilder<any>| null,\n    insertionIndex: number): number {\n  let playerContext = context[StylingIndex.PlayerContext] || allocPlayerContext(context);\n  if (insertionIndex > 0) {\n    playerContext[insertionIndex] = builder;\n  } else {\n    insertionIndex = playerContext[PlayerIndex.NonBuilderPlayersStart];\n    playerContext.splice(insertionIndex, 0, builder, null);\n    playerContext[PlayerIndex.NonBuilderPlayersStart] +=\n        PlayerIndex.PlayerAndPlayerBuildersTupleSize;\n  }\n  return insertionIndex;\n}\n\nexport function directiveOwnerPointers(directiveIndex: number, playerIndex: number) {\n  return (playerIndex << DirectiveOwnerAndPlayerBuilderIndex.BitCountSize) | directiveIndex;\n}\n\nfunction setPlayerBuilderIndex(\n    context: StylingContext, index: number, playerBuilderIndex: number, directiveIndex: number) {\n  const value = directiveOwnerPointers(directiveIndex, playerBuilderIndex);\n  context[index + StylingIndex.PlayerBuilderIndexOffset] = value;\n}\n\nfunction getPlayerBuilderIndex(context: StylingContext, index: number): number {\n  const flag = context[index + StylingIndex.PlayerBuilderIndexOffset] as number;\n  const playerBuilderIndex = (flag >> DirectiveOwnerAndPlayerBuilderIndex.BitCountSize) &\n      DirectiveOwnerAndPlayerBuilderIndex.BitMask;\n  return playerBuilderIndex;\n}\n\nfunction getPlayerBuilder(context: StylingContext, index: number): ClassAndStylePlayerBuilder<any>|\n    null {\n  const playerBuilderIndex = getPlayerBuilderIndex(context, index);\n  if (playerBuilderIndex) {\n    const playerContext = context[StylingIndex.PlayerContext];\n    if (playerContext) {\n      return playerContext[playerBuilderIndex] as ClassAndStylePlayerBuilder<any>| null;\n    }\n  }\n  return null;\n}\n\nfunction setFlag(context: StylingContext, index: number, flag: number) {\n  const adjustedIndex =\n      index === StylingIndex.MasterFlagPosition ? index : (index + StylingIndex.FlagsOffset);\n  context[adjustedIndex] = flag;\n}\n\nfunction getPointers(context: StylingContext, index: number): number {\n  const adjustedIndex =\n      index === StylingIndex.MasterFlagPosition ? index : (index + StylingIndex.FlagsOffset);\n  return context[adjustedIndex] as number;\n}\n\nexport function getValue(context: StylingContext, index: number): string|boolean|null {\n  return context[index + StylingIndex.ValueOffset] as string | boolean | null;\n}\n\nexport function getProp(context: StylingContext, index: number): string {\n  return context[index + StylingIndex.PropertyOffset] as string;\n}\n\nexport function isContextDirty(context: StylingContext): boolean {\n  return isDirty(context, StylingIndex.MasterFlagPosition);\n}\n\nexport function setContextDirty(context: StylingContext, isDirtyYes: boolean): void {\n  setDirty(context, StylingIndex.MasterFlagPosition, isDirtyYes);\n}\n\nexport function setContextPlayersDirty(context: StylingContext, isDirtyYes: boolean): void {\n  if (isDirtyYes) {\n    (context[StylingIndex.MasterFlagPosition] as number) |= StylingFlags.PlayerBuildersDirty;\n  } else {\n    (context[StylingIndex.MasterFlagPosition] as number) &= ~StylingFlags.PlayerBuildersDirty;\n  }\n}\n\nfunction swapMultiContextEntries(context: StylingContext, indexA: number, indexB: number) {\n  if (indexA === indexB) return;\n\n  const tmpValue = getValue(context, indexA);\n  const tmpProp = getProp(context, indexA);\n  const tmpFlag = getPointers(context, indexA);\n  const tmpPlayerBuilderIndex = getPlayerBuilderIndex(context, indexA);\n  const tmpDirectiveIndex = getDirectiveIndexFromEntry(context, indexA);\n\n  let flagA = tmpFlag;\n  let flagB = getPointers(context, indexB);\n\n  const singleIndexA = getMultiOrSingleIndex(flagA);\n  if (singleIndexA >= 0) {\n    const _flag = getPointers(context, singleIndexA);\n    const _initial = getInitialIndex(_flag);\n    setFlag(context, singleIndexA, pointers(_flag, _initial, indexB));\n  }\n\n  const singleIndexB = getMultiOrSingleIndex(flagB);\n  if (singleIndexB >= 0) {\n    const _flag = getPointers(context, singleIndexB);\n    const _initial = getInitialIndex(_flag);\n    setFlag(context, singleIndexB, pointers(_flag, _initial, indexA));\n  }\n\n  setValue(context, indexA, getValue(context, indexB));\n  setProp(context, indexA, getProp(context, indexB));\n  setFlag(context, indexA, getPointers(context, indexB));\n  const playerIndexA = getPlayerBuilderIndex(context, indexB);\n  const directiveIndexA = getDirectiveIndexFromEntry(context, indexB);\n  setPlayerBuilderIndex(context, indexA, playerIndexA, directiveIndexA);\n\n  setValue(context, indexB, tmpValue);\n  setProp(context, indexB, tmpProp);\n  setFlag(context, indexB, tmpFlag);\n  setPlayerBuilderIndex(context, indexB, tmpPlayerBuilderIndex, tmpDirectiveIndex);\n}\n\nfunction updateSinglePointerValues(context: StylingContext, indexStartPosition: number) {\n  for (let i = indexStartPosition; i < context.length; i += StylingIndex.Size) {\n    const multiFlag = getPointers(context, i);\n    const singleIndex = getMultiOrSingleIndex(multiFlag);\n    if (singleIndex > 0) {\n      const singleFlag = getPointers(context, singleIndex);\n      const initialIndexForSingle = getInitialIndex(singleFlag);\n      const flagValue = (isDirty(context, singleIndex) ? StylingFlags.Dirty : StylingFlags.None) |\n          (isClassBasedValue(context, singleIndex) ? StylingFlags.Class : StylingFlags.None) |\n          (isSanitizable(context, singleIndex) ? StylingFlags.Sanitize : StylingFlags.None);\n      const updatedFlag = pointers(flagValue, initialIndexForSingle, i);\n      setFlag(context, singleIndex, updatedFlag);\n    }\n  }\n}\n\nfunction insertNewMultiProperty(\n    context: StylingContext, index: number, classBased: boolean, name: string, flag: number,\n    value: string | boolean, directiveIndex: number, playerIndex: number): void {\n  const doShift = index < context.length;\n\n  // prop does not exist in the list, add it in\n  context.splice(\n      index, 0, flag | StylingFlags.Dirty | (classBased ? StylingFlags.Class : StylingFlags.None),\n      name, value, 0);\n  setPlayerBuilderIndex(context, index, playerIndex, directiveIndex);\n\n  if (doShift) {\n    // because the value was inserted midway into the array then we\n    // need to update all the shifted multi values' single value\n    // pointers to point to the newly shifted location\n    updateSinglePointerValues(context, index + StylingIndex.Size);\n  }\n}\n\nfunction valueExists(value: string | null | boolean, isClassBased?: boolean) {\n  return value !== null;\n}\n\nfunction prepareInitialFlag(\n    context: StylingContext, prop: string, entryIsClassBased: boolean,\n    sanitizer?: StyleSanitizeFn | null) {\n  let flag = (sanitizer && sanitizer(prop)) ? StylingFlags.Sanitize : StylingFlags.None;\n\n  let initialIndex: number;\n  if (entryIsClassBased) {\n    flag |= StylingFlags.Class;\n    initialIndex =\n        getInitialStylingValuesIndexOf(context[StylingIndex.InitialClassValuesPosition], prop);\n  } else {\n    initialIndex =\n        getInitialStylingValuesIndexOf(context[StylingIndex.InitialStyleValuesPosition], prop);\n  }\n\n  initialIndex = initialIndex > 0 ? (initialIndex + InitialStylingValuesIndex.ValueOffset) : 0;\n  return pointers(flag, initialIndex, 0);\n}\n\nfunction hasInitialValueChanged(context: StylingContext, flag: number, newValue: any) {\n  const initialValue = getInitialValue(context, flag);\n  return !initialValue || hasValueChanged(flag, initialValue, newValue);\n}\n\nfunction hasValueChanged(\n    flag: number, a: string | boolean | null, b: string | boolean | null): boolean {\n  const isClassBased = flag & StylingFlags.Class;\n  const hasValues = a && b;\n  const usesSanitizer = flag & StylingFlags.Sanitize;\n  // the toString() comparison ensures that a value is checked\n  // ... otherwise (during sanitization bypassing) the === comparsion\n  // would fail since a new String() instance is created\n  if (!isClassBased && hasValues && usesSanitizer) {\n    // we know for sure we're dealing with strings at this point\n    return (a as string).toString() !== (b as string).toString();\n  }\n\n  // everything else is safe to check with a normal equality check\n  return a !== b;\n}\n\nexport class ClassAndStylePlayerBuilder<T> implements PlayerBuilder {\n  private _values: {[key: string]: string | null} = {};\n  private _dirty = false;\n  private _factory: BoundPlayerFactory<T>;\n\n  constructor(factory: PlayerFactory, private _element: HTMLElement, private _type: BindingType) {\n    this._factory = factory as any;\n  }\n\n  setValue(prop: string, value: any) {\n    if (this._values[prop] !== value) {\n      this._values[prop] = value;\n      this._dirty = true;\n    }\n  }\n\n  buildPlayer(currentPlayer: Player|null, isFirstRender: boolean): Player|undefined|null {\n    // if no values have been set here then this means the binding didn't\n    // change and therefore the binding values were not updated through\n    // `setValue` which means no new player will be provided.\n    if (this._dirty) {\n      const player = this._factory.fn(\n          this._element, this._type, this._values !, isFirstRender, currentPlayer || null);\n      this._values = {};\n      this._dirty = false;\n      return player;\n    }\n\n    return undefined;\n  }\n}\n\n/**\n * Used to provide a summary of the state of the styling context.\n *\n * This is an internal interface that is only used inside of test tooling to\n * help summarize what's going on within the styling context. None of this code\n * is designed to be exported publicly and will, therefore, be tree-shaken away\n * during runtime.\n */\nexport interface LogSummary {\n  name: string;          //\n  staticIndex: number;   //\n  dynamicIndex: number;  //\n  value: number;         //\n  flags: {\n    dirty: boolean;                    //\n    class: boolean;                    //\n    sanitize: boolean;                 //\n    playerBuildersDirty: boolean;      //\n    bindingAllocationLocked: boolean;  //\n  };\n}\n\n/**\n * This function is not designed to be used in production.\n * It is a utility tool for debugging and testing and it\n * will automatically be tree-shaken away during production.\n */\nexport function generateConfigSummary(source: number): LogSummary;\nexport function generateConfigSummary(source: StylingContext): LogSummary;\nexport function generateConfigSummary(source: StylingContext, index: number): LogSummary;\nexport function generateConfigSummary(source: number | StylingContext, index?: number): LogSummary {\n  let flag, name = 'config value for ';\n  if (Array.isArray(source)) {\n    if (index) {\n      name += 'index: ' + index;\n    } else {\n      name += 'master config';\n    }\n    index = index || StylingIndex.MasterFlagPosition;\n    flag = source[index] as number;\n  } else {\n    flag = source;\n    name += 'index: ' + flag;\n  }\n  const dynamicIndex = getMultiOrSingleIndex(flag);\n  const staticIndex = getInitialIndex(flag);\n  return {\n    name,\n    staticIndex,\n    dynamicIndex,\n    value: flag,\n    flags: {\n      dirty: flag & StylingFlags.Dirty ? true : false,\n      class: flag & StylingFlags.Class ? true : false,\n      sanitize: flag & StylingFlags.Sanitize ? true : false,\n      playerBuildersDirty: flag & StylingFlags.PlayerBuildersDirty ? true : false,\n      bindingAllocationLocked: flag & StylingFlags.BindingAllocationLocked ? true : false,\n    }\n  };\n}\n\nexport function getDirectiveIndexFromEntry(context: StylingContext, index: number) {\n  const value = context[index + StylingIndex.PlayerBuilderIndexOffset] as number;\n  return value & DirectiveOwnerAndPlayerBuilderIndex.BitMask;\n}\n\nfunction getInitialStylingValuesIndexOf(keyValues: InitialStylingValues, key: string): number {\n  for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < keyValues.length;\n       i += InitialStylingValuesIndex.Size) {\n    if (keyValues[i] === key) return i;\n  }\n  return -1;\n}\n\nexport function compareLogSummaries(a: LogSummary, b: LogSummary) {\n  const log: string[] = [];\n  const diffs: [string, any, any][] = [];\n  diffSummaryValues(diffs, 'staticIndex', 'staticIndex', a, b);\n  diffSummaryValues(diffs, 'dynamicIndex', 'dynamicIndex', a, b);\n  Object.keys(a.flags).forEach(\n      name => { diffSummaryValues(diffs, 'flags.' + name, name, a.flags, b.flags); });\n\n  if (diffs.length) {\n    log.push('Log Summaries for:');\n    log.push('  A: ' + a.name);\n    log.push('  B: ' + b.name);\n    log.push('\\n  Differ in the following way (A !== B):');\n    diffs.forEach(result => {\n      const [name, aVal, bVal] = result;\n      log.push('    => ' + name);\n      log.push('    => ' + aVal + ' !== ' + bVal + '\\n');\n    });\n  }\n\n  return log;\n}\n\nfunction diffSummaryValues(result: any[], name: string, prop: string, a: any, b: any) {\n  const aVal = a[prop];\n  const bVal = b[prop];\n  if (aVal !== bVal) {\n    result.push([name, aVal, bVal]);\n  }\n}\n\nfunction getSinglePropIndexValue(\n    context: StylingContext, directiveIndex: number, offset: number, isClassBased: boolean) {\n  const singlePropOffsetRegistryIndex =\n      context[StylingIndex.DirectiveRegistryPosition]\n             [(directiveIndex * DirectiveRegistryValuesIndex.Size) +\n              DirectiveRegistryValuesIndex.SinglePropValuesIndexOffset] as number;\n  const offsets = context[StylingIndex.SinglePropOffsetPositions];\n  const indexForOffset = singlePropOffsetRegistryIndex +\n      SinglePropOffsetValuesIndex.ValueStartPosition +\n      (isClassBased ?\n           offsets\n               [singlePropOffsetRegistryIndex + SinglePropOffsetValuesIndex.StylesCountPosition] :\n           0) +\n      offset;\n  return offsets[indexForOffset];\n}\n\nfunction getStyleSanitizer(context: StylingContext, directiveIndex: number): StyleSanitizeFn|null {\n  const dirs = context[StylingIndex.DirectiveRegistryPosition];\n  const value = dirs\n                    [directiveIndex * DirectiveRegistryValuesIndex.Size +\n                     DirectiveRegistryValuesIndex.StyleSanitizerOffset] ||\n      dirs[DirectiveRegistryValuesIndex.StyleSanitizerOffset] || null;\n  return value as StyleSanitizeFn | null;\n}\n\nfunction allowValueChange(\n    currentValue: string | boolean | null, newValue: string | boolean | null,\n    currentDirectiveOwner: number, newDirectiveOwner: number) {\n  // the code below relies the importance of directive's being tied to their\n  // index value. The index values for each directive are derived from being\n  // registered into the styling context directive registry. The most important\n  // directive is the parent component directive (the template) and each directive\n  // that is added after is considered less important than the previous entry. This\n  // prioritization of directives enables the styling algorithm to decide if a style\n  // or class should be allowed to be updated/replaced in case an earlier directive\n  // already wrote to the exact same style-property or className value. In other words\n  // this decides what to do if and when there is a collision.\n  if (currentValue != null) {\n    if (newValue != null) {\n      // if a directive index is lower than it always has priority over the\n      // previous directive's value...\n      return newDirectiveOwner <= currentDirectiveOwner;\n    } else {\n      // only write a null value in case it's the same owner writing it.\n      // this avoids having a higher-priority directive write to null\n      // only to have a lesser-priority directive change right to a\n      // non-null value immediately afterwards.\n      return currentDirectiveOwner === newDirectiveOwner;\n    }\n  }\n  return true;\n}\n\n/**\n * Returns the className string of all the initial classes for the element.\n *\n * This function is designed to populate and cache all the static class\n * values into a className string. The caching mechanism works by placing\n * the completed className string into the initial values array into a\n * dedicated slot. This will prevent the function from having to populate\n * the string each time an element is created or matched.\n *\n * @returns the className string (e.g. `on active red`)\n */\nexport function getInitialClassNameValue(context: StylingContext): string {\n  const initialClassValues = context[StylingIndex.InitialClassValuesPosition];\n  let className = initialClassValues[InitialStylingValuesIndex.CachedStringValuePosition];\n  if (className === null) {\n    className = '';\n    for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < initialClassValues.length;\n         i += InitialStylingValuesIndex.Size) {\n      const isPresent = initialClassValues[i + 1];\n      if (isPresent) {\n        className += (className.length ? ' ' : '') + initialClassValues[i];\n      }\n    }\n    initialClassValues[InitialStylingValuesIndex.CachedStringValuePosition] = className;\n  }\n  return className;\n}\n\n/**\n * Returns the style string of all the initial styles for the element.\n *\n * This function is designed to populate and cache all the static style\n * values into a style string. The caching mechanism works by placing\n * the completed style string into the initial values array into a\n * dedicated slot. This will prevent the function from having to populate\n * the string each time an element is created or matched.\n *\n * @returns the style string (e.g. `width:100px;height:200px`)\n */\nexport function getInitialStyleStringValue(context: StylingContext): string {\n  const initialStyleValues = context[StylingIndex.InitialStyleValuesPosition];\n  let styleString = initialStyleValues[InitialStylingValuesIndex.CachedStringValuePosition];\n  if (styleString === null) {\n    styleString = '';\n    for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < initialStyleValues.length;\n         i += InitialStylingValuesIndex.Size) {\n      const value = initialStyleValues[i + 1];\n      if (value !== null) {\n        styleString += (styleString.length ? ';' : '') + `${initialStyleValues[i]}:${value}`;\n      }\n    }\n    initialStyleValues[InitialStylingValuesIndex.CachedStringValuePosition] = styleString;\n  }\n  return styleString;\n}\n\n/**\n * Returns the current cached multi-value for a given directiveIndex within the provided context.\n */\nfunction readCachedMapValue(\n    context: StylingContext, entryIsClassBased: boolean, directiveIndex: number) {\n  const values: MapBasedOffsetValues =\n      context[entryIsClassBased ? StylingIndex.CachedMultiClasses : StylingIndex.CachedMultiStyles];\n  const index = MapBasedOffsetValuesIndex.ValuesStartPosition +\n      directiveIndex * MapBasedOffsetValuesIndex.Size;\n  return values[index + MapBasedOffsetValuesIndex.ValueOffset] || null;\n}\n\n/**\n * Determines whether the provided multi styling value should be updated or not.\n *\n * Because `[style]` and `[class]` bindings rely on an identity change to occur before\n * applying new values, the styling algorithm may not update an existing entry into\n * the context if a previous directive's entry changed shape.\n *\n * This function will decide whether or not a value should be applied (if there is a\n * cache miss) to the context based on the following rules:\n *\n * - If there is an identity change between the existing value and new value\n * - If there is no existing value cached (first write)\n * - If a previous directive flagged the existing cached value as dirty\n */\nfunction isMultiValueCacheHit(\n    context: StylingContext, entryIsClassBased: boolean, directiveIndex: number,\n    newValue: any): boolean {\n  const indexOfCachedValues =\n      entryIsClassBased ? StylingIndex.CachedMultiClasses : StylingIndex.CachedMultiStyles;\n  const cachedValues = context[indexOfCachedValues] as MapBasedOffsetValues;\n  const index = MapBasedOffsetValuesIndex.ValuesStartPosition +\n      directiveIndex * MapBasedOffsetValuesIndex.Size;\n  if (cachedValues[index + MapBasedOffsetValuesIndex.DirtyFlagOffset]) return false;\n  return newValue === NO_CHANGE ||\n      readCachedMapValue(context, entryIsClassBased, directiveIndex) === newValue;\n}\n\n/**\n * Updates the cached status of a multi-styling value in the context.\n *\n * The cached map array (which exists in the context) contains a manifest of\n * each multi-styling entry (`[style]` and `[class]` entries) for the template\n * as well as all directives.\n *\n * This function will update the cached status of the provided multi-style\n * entry within the cache.\n *\n * When called, this function will update the following information:\n * - The actual cached value (the raw value that was passed into `[style]` or `[class]`)\n * - The total amount of unique styling entries that this value has written into the context\n * - The exact position of where the multi styling entries start in the context for this binding\n * - The dirty flag will be set to true\n *\n * If the `dirtyFutureValues` param is provided then it will update all future entries (binding\n * entries that exist as apart of other directives) to be dirty as well. This will force the\n * styling algorithm to reapply those values once change detection checks them (which will in\n * turn cause the styling context to update itself and the correct styling values will be\n * rendered on screen).\n */\nfunction updateCachedMapValue(\n    context: StylingContext, directiveIndex: number, entryIsClassBased: boolean, cacheValue: any,\n    startPosition: number, endPosition: number, totalValues: number, dirtyFutureValues: boolean) {\n  const values =\n      context[entryIsClassBased ? StylingIndex.CachedMultiClasses : StylingIndex.CachedMultiStyles];\n\n  const index = MapBasedOffsetValuesIndex.ValuesStartPosition +\n      directiveIndex * MapBasedOffsetValuesIndex.Size;\n\n  // in the event that this is true we assume that future values are dirty and therefore\n  // will be checked again in the next CD cycle\n  if (dirtyFutureValues) {\n    const nextStartPosition = startPosition + totalValues * MapBasedOffsetValuesIndex.Size;\n    for (let i = index + MapBasedOffsetValuesIndex.Size; i < values.length;\n         i += MapBasedOffsetValuesIndex.Size) {\n      values[i + MapBasedOffsetValuesIndex.PositionStartOffset] = nextStartPosition;\n      values[i + MapBasedOffsetValuesIndex.DirtyFlagOffset] = 1;\n    }\n  }\n\n  values[index + MapBasedOffsetValuesIndex.DirtyFlagOffset] = 0;\n  values[index + MapBasedOffsetValuesIndex.PositionStartOffset] = startPosition;\n  values[index + MapBasedOffsetValuesIndex.ValueOffset] = cacheValue;\n  values[index + MapBasedOffsetValuesIndex.ValueCountOffset] = totalValues;\n\n  // the code below counts the total amount of styling values that exist in\n  // the context up until this directive. This value will be later used to\n  // update the cached value map's total counter value.\n  let totalStylingEntries = totalValues;\n  for (let i = MapBasedOffsetValuesIndex.ValuesStartPosition; i < index;\n       i += MapBasedOffsetValuesIndex.Size) {\n    totalStylingEntries += values[i + MapBasedOffsetValuesIndex.ValueCountOffset];\n  }\n\n  // because style values come before class values in the context this means\n  // that if any new values were inserted then the cache values array for\n  // classes is out of sync. The code below will update the offsets to point\n  // to their new values.\n  if (!entryIsClassBased) {\n    const classCache = context[StylingIndex.CachedMultiClasses];\n    const classesStartPosition = classCache\n        [MapBasedOffsetValuesIndex.ValuesStartPosition +\n         MapBasedOffsetValuesIndex.PositionStartOffset];\n    const diffInStartPosition = endPosition - classesStartPosition;\n    for (let i = MapBasedOffsetValuesIndex.ValuesStartPosition; i < classCache.length;\n         i += MapBasedOffsetValuesIndex.Size) {\n      classCache[i + MapBasedOffsetValuesIndex.PositionStartOffset] += diffInStartPosition;\n    }\n  }\n\n  values[MapBasedOffsetValuesIndex.EntriesCountPosition] = totalStylingEntries;\n}\n\nfunction hyphenateEntries(entries: string[]): string[] {\n  const newEntries: string[] = [];\n  for (let i = 0; i < entries.length; i++) {\n    newEntries.push(hyphenate(entries[i]));\n  }\n  return newEntries;\n}\n\nfunction hyphenate(value: string): string {\n  return value.replace(\n      /[a-z][A-Z]/g, match => `${match.charAt(0)}-${match.charAt(1).toLowerCase()}`);\n}\n\nfunction registerMultiMapEntry(\n    context: StylingContext, directiveIndex: number, entryIsClassBased: boolean,\n    startPosition: number, count = 0) {\n  const cachedValues =\n      context[entryIsClassBased ? StylingIndex.CachedMultiClasses : StylingIndex.CachedMultiStyles];\n  if (directiveIndex > 0) {\n    const limit = MapBasedOffsetValuesIndex.ValuesStartPosition +\n        (directiveIndex * MapBasedOffsetValuesIndex.Size);\n    while (cachedValues.length < limit) {\n      // this means that ONLY directive class styling (like ngClass) was used\n      // therefore the root directive will still need to be filled in as well\n      // as any other directive spaces in case they only used static values\n      cachedValues.push(0, startPosition, null, 0);\n    }\n  }\n  cachedValues.push(0, startPosition, null, count);\n}\n\n/**\n * Inserts or updates an existing entry in the provided `staticStyles` collection.\n *\n * @param index the index representing an existing styling entry in the collection:\n *  if provided (numeric): then it will update the existing entry at the given position\n *  if null: then it will insert a new entry within the collection\n * @param staticStyles a collection of style or class entries where the value will\n *  be inserted or patched\n * @param prop the property value of the entry (e.g. `width` (styles) or `foo` (classes))\n * @param value the styling value of the entry (e.g. `absolute` (styles) or `true` (classes))\n * @param directiveOwnerIndex the directive owner index value of the styling source responsible\n *        for these styles (see `interfaces/styling.ts#directives` for more info)\n * @returns the index of the updated or new entry within the collection\n */\nfunction addOrUpdateStaticStyle(\n    index: number | null, staticStyles: InitialStylingValues, prop: string,\n    value: string | boolean | null, directiveOwnerIndex: number) {\n  if (index === null) {\n    index = staticStyles.length;\n    staticStyles.push(null, null, null);\n    staticStyles[index + InitialStylingValuesIndex.PropOffset] = prop;\n  }\n  staticStyles[index + InitialStylingValuesIndex.ValueOffset] = value;\n  staticStyles[index + InitialStylingValuesIndex.DirectiveOwnerOffset] = directiveOwnerIndex;\n  return index;\n}\n\nfunction assertValidDirectiveIndex(context: StylingContext, directiveIndex: number) {\n  const dirs = context[StylingIndex.DirectiveRegistryPosition];\n  const index = directiveIndex * DirectiveRegistryValuesIndex.Size;\n  if (index >= dirs.length ||\n      dirs[index + DirectiveRegistryValuesIndex.SinglePropValuesIndexOffset] === -1) {\n    throw new Error('The provided directive is not registered with the styling context');\n  }\n}"]}
2244
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"class_and_style_bindings.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/styling/class_and_style_bindings.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*/\nimport {StyleSanitizeFn, StyleSanitizeMode} from '../../sanitization/style_sanitizer';\nimport {EMPTY_ARRAY, EMPTY_OBJ} from '../empty';\nimport {AttributeMarker, TAttributes} from '../interfaces/node';\nimport {BindingStore, BindingType, Player, PlayerBuilder, PlayerFactory, PlayerIndex} from '../interfaces/player';\nimport {RElement, Renderer3, RendererStyleFlags3, isProceduralRenderer} from '../interfaces/renderer';\nimport {DirectiveOwnerAndPlayerBuilderIndex, DirectiveRegistryValuesIndex, InitialStylingValues, InitialStylingValuesIndex, MapBasedOffsetValues, MapBasedOffsetValuesIndex, SinglePropOffsetValues, SinglePropOffsetValuesIndex, StylingContext, StylingFlags, StylingIndex} from '../interfaces/styling';\nimport {LView, RootContext} from '../interfaces/view';\nimport {NO_CHANGE} from '../tokens';\nimport {getRootContext} from '../util/view_traversal_utils';\n\nimport {allowFlush as allowHostInstructionsQueueFlush, flushQueue as flushHostInstructionsQueue} from './host_instructions_queue';\nimport {BoundPlayerFactory} from './player_factory';\nimport {addPlayerInternal, allocPlayerContext, allocateOrUpdateDirectiveIntoContext, createEmptyStylingContext, getPlayerContext} from './util';\n\n\n/**\n * This file includes the code to power all styling-binding operations in Angular.\n *\n * These include:\n * [style]=\"myStyleObj\"\n * [class]=\"myClassObj\"\n * [style.prop]=\"myPropValue\"\n * [class.name]=\"myClassValue\"\n *\n * It also includes code that will allow style binding code to operate within host\n * bindings for components/directives.\n *\n * There are many different ways in which these functions below are called. Please see\n * `render3/interfaces/styling.ts` to get a better idea of how the styling algorithm works.\n */\n\n\n\n/**\n * Creates a new StylingContext an fills it with the provided static styling attribute values.\n */\nexport function initializeStaticContext(\n    attrs: TAttributes, stylingStartIndex: number, directiveIndex: number = 0): StylingContext {\n  const context = createEmptyStylingContext();\n  patchContextWithStaticAttrs(context, attrs, stylingStartIndex, directiveIndex);\n  return context;\n}\n\n/**\n * Designed to update an existing styling context with new static styling\n * data (classes and styles).\n *\n * @param context the existing styling context\n * @param attrs an array of new static styling attributes that will be\n *              assigned to the context\n * @param attrsStylingStartIndex what index to start iterating within the\n *              provided `attrs` array to start reading style and class values\n */\nexport function patchContextWithStaticAttrs(\n    context: StylingContext, attrs: TAttributes, attrsStylingStartIndex: number,\n    directiveIndex: number): void {\n  // this means the context has already been set and instantiated\n  if (context[StylingIndex.MasterFlagPosition] & StylingFlags.BindingAllocationLocked) return;\n\n  allocateOrUpdateDirectiveIntoContext(context, directiveIndex);\n\n  let initialClasses: InitialStylingValues|null = null;\n  let initialStyles: InitialStylingValues|null = null;\n  let mode = -1;\n  for (let i = attrsStylingStartIndex; i < attrs.length; i++) {\n    const attr = attrs[i];\n    if (typeof attr == 'number') {\n      mode = attr;\n    } else if (mode == AttributeMarker.Classes) {\n      initialClasses = initialClasses || context[StylingIndex.InitialClassValuesPosition];\n      patchInitialStylingValue(initialClasses, attr as string, true, directiveIndex);\n    } else if (mode == AttributeMarker.Styles) {\n      initialStyles = initialStyles || context[StylingIndex.InitialStyleValuesPosition];\n      patchInitialStylingValue(initialStyles, attr as string, attrs[++i], directiveIndex);\n    }\n  }\n}\n\n/**\n * Designed to add a style or class value into the existing set of initial styles.\n *\n * The function will search and figure out if a style/class value is already present\n * within the provided initial styling array. If and when a style/class value is\n * present (allocated) then the code below will set the new value depending on the\n * following cases:\n *\n *  1) if the existing value is falsy (this happens because a `[class.prop]` or\n *     `[style.prop]` binding was set, but there wasn't a matching static style\n *     or class present on the context)\n *  2) if the value was set already by the template, component or directive, but the\n *     new value is set on a higher level (i.e. a sub component which extends a parent\n *     component sets its value after the parent has already set the same one)\n *  3) if the same directive provides a new set of styling values to set\n *\n * @param initialStyling the initial styling array where the new styling entry will be added to\n * @param prop the property value of the new entry (e.g. `width` (styles) or `foo` (classes))\n * @param value the styling value of the new entry (e.g. `absolute` (styles) or `true` (classes))\n * @param directiveOwnerIndex the directive owner index value of the styling source responsible\n *        for these styles (see `interfaces/styling.ts#directives` for more info)\n */\nfunction patchInitialStylingValue(\n    initialStyling: InitialStylingValues, prop: string, value: any,\n    directiveOwnerIndex: number): void {\n  for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < initialStyling.length;\n       i += InitialStylingValuesIndex.Size) {\n    const key = initialStyling[i + InitialStylingValuesIndex.PropOffset];\n    if (key === prop) {\n      const existingValue =\n          initialStyling[i + InitialStylingValuesIndex.ValueOffset] as string | null | boolean;\n      const existingOwner =\n          initialStyling[i + InitialStylingValuesIndex.DirectiveOwnerOffset] as number;\n      if (allowValueChange(existingValue, value, existingOwner, directiveOwnerIndex)) {\n        addOrUpdateStaticStyle(i, initialStyling, prop, value, directiveOwnerIndex);\n      }\n      return;\n    }\n  }\n\n  // We did not find existing key, add a new one.\n  addOrUpdateStaticStyle(null, initialStyling, prop, value, directiveOwnerIndex);\n}\n\n/**\n * Runs through the initial class values present in the provided\n * context and renders them via the provided renderer on the element.\n *\n * @param element the element the styling will be applied to\n * @param context the source styling context which contains the initial class values\n * @param renderer the renderer instance that will be used to apply the class\n * @returns the index that the classes were applied up until\n */\nexport function renderInitialClasses(\n    element: RElement, context: StylingContext, renderer: Renderer3, startIndex?: number): number {\n  const initialClasses = context[StylingIndex.InitialClassValuesPosition];\n  let i = startIndex || InitialStylingValuesIndex.KeyValueStartPosition;\n  while (i < initialClasses.length) {\n    const value = initialClasses[i + InitialStylingValuesIndex.ValueOffset];\n    if (value) {\n      setClass(\n          element, initialClasses[i + InitialStylingValuesIndex.PropOffset] as string, true,\n          renderer, null);\n    }\n    i += InitialStylingValuesIndex.Size;\n  }\n  return i;\n}\n\n/**\n * Runs through the initial styles values present in the provided\n * context and renders them via the provided renderer on the element.\n *\n * @param element the element the styling will be applied to\n * @param context the source styling context which contains the initial class values\n * @param renderer the renderer instance that will be used to apply the class\n * @returns the index that the styles were applied up until\n */\nexport function renderInitialStyles(\n    element: RElement, context: StylingContext, renderer: Renderer3, startIndex?: number) {\n  const initialStyles = context[StylingIndex.InitialStyleValuesPosition];\n  let i = startIndex || InitialStylingValuesIndex.KeyValueStartPosition;\n  while (i < initialStyles.length) {\n    const value = initialStyles[i + InitialStylingValuesIndex.ValueOffset];\n    if (value) {\n      setStyle(\n          element, initialStyles[i + InitialStylingValuesIndex.PropOffset] as string,\n          value as string, renderer, null);\n    }\n    i += InitialStylingValuesIndex.Size;\n  }\n  return i;\n}\n\nexport function allowNewBindingsForStylingContext(context: StylingContext): boolean {\n  return (context[StylingIndex.MasterFlagPosition] & StylingFlags.BindingAllocationLocked) === 0;\n}\n\n/**\n * Adds in new binding values to a styling context.\n *\n * If a directive value is provided then all provided class/style binding names will\n * reference the provided directive.\n *\n * @param context the existing styling context\n * @param classBindingNames an array of class binding names that will be added to the context\n * @param styleBindingNames an array of style binding names that will be added to the context\n * @param styleSanitizer an optional sanitizer that handle all sanitization on for each of\n *    the bindings added to the context. Note that if a directive is provided then the sanitizer\n *    instance will only be active if and when the directive updates the bindings that it owns.\n */\nexport function updateContextWithBindings(\n    context: StylingContext, directiveIndex: number, classBindingNames?: string[] | null,\n    styleBindingNames?: string[] | null, styleSanitizer?: StyleSanitizeFn | null) {\n  if (context[StylingIndex.MasterFlagPosition] & StylingFlags.BindingAllocationLocked) return;\n\n  // this means the context has already been patched with the directive's bindings\n  const isNewDirective =\n      findOrPatchDirectiveIntoRegistry(context, directiveIndex, false, styleSanitizer);\n  if (!isNewDirective) {\n    // this means the directive has already been patched in ... No point in doing anything\n    return;\n  }\n\n  if (styleBindingNames) {\n    styleBindingNames = hyphenateEntries(styleBindingNames);\n  }\n\n  // there are alot of variables being used below to track where in the context the new\n  // binding values will be placed. Because the context consists of multiple types of\n  // entries (single classes/styles and multi classes/styles) alot of the index positions\n  // need to be computed ahead of time and the context needs to be extended before the values\n  // are inserted in.\n  const singlePropOffsetValues = context[StylingIndex.SinglePropOffsetPositions];\n  const totalCurrentClassBindings =\n      singlePropOffsetValues[SinglePropOffsetValuesIndex.ClassesCountPosition];\n  const totalCurrentStyleBindings =\n      singlePropOffsetValues[SinglePropOffsetValuesIndex.StylesCountPosition];\n\n  const cachedClassMapValues = context[StylingIndex.CachedMultiClasses];\n  const cachedStyleMapValues = context[StylingIndex.CachedMultiStyles];\n\n  const classesOffset = totalCurrentClassBindings * StylingIndex.Size;\n  const stylesOffset = totalCurrentStyleBindings * StylingIndex.Size;\n\n  const singleStylesStartIndex = StylingIndex.SingleStylesStartPosition;\n  let singleClassesStartIndex = singleStylesStartIndex + stylesOffset;\n  let multiStylesStartIndex = singleClassesStartIndex + classesOffset;\n  let multiClassesStartIndex = multiStylesStartIndex + stylesOffset;\n\n  // because we're inserting more bindings into the context, this means that the\n  // binding values need to be referenced the singlePropOffsetValues array so that\n  // the template/directive can easily find them inside of the `styleProp`\n  // and the `classProp` functions without iterating through the entire context.\n  // The first step to setting up these reference points is to mark how many bindings\n  // are being added. Even if these bindings already exist in the context, the directive\n  // or template code will still call them unknowingly. Therefore the total values need\n  // to be registered so that we know how many bindings are assigned to each directive.\n  const currentSinglePropsLength = singlePropOffsetValues.length;\n  singlePropOffsetValues.push(\n      styleBindingNames ? styleBindingNames.length : 0,\n      classBindingNames ? classBindingNames.length : 0);\n\n  // the code below will check to see if a new style binding already exists in the context\n  // if so then there is no point in inserting it into the context again. Whether or not it\n  // exists the styling offset code will now know exactly where it is\n  let insertionOffset = 0;\n  const filteredStyleBindingNames: string[] = [];\n  if (styleBindingNames && styleBindingNames.length) {\n    for (let i = 0; i < styleBindingNames.length; i++) {\n      const name = styleBindingNames[i];\n      let singlePropIndex =\n          getMatchingBindingIndex(context, name, singleStylesStartIndex, singleClassesStartIndex);\n      if (singlePropIndex == -1) {\n        singlePropIndex = singleClassesStartIndex + insertionOffset;\n        insertionOffset += StylingIndex.Size;\n        filteredStyleBindingNames.push(name);\n      }\n      singlePropOffsetValues.push(singlePropIndex);\n    }\n  }\n\n  // just like with the style binding loop above, the new class bindings get the same treatment...\n  const filteredClassBindingNames: string[] = [];\n  if (classBindingNames && classBindingNames.length) {\n    for (let i = 0; i < classBindingNames.length; i++) {\n      const name = classBindingNames[i];\n      let singlePropIndex =\n          getMatchingBindingIndex(context, name, singleClassesStartIndex, multiStylesStartIndex);\n      if (singlePropIndex == -1) {\n        singlePropIndex = multiStylesStartIndex + insertionOffset;\n        insertionOffset += StylingIndex.Size;\n        filteredClassBindingNames.push(name);\n      } else {\n        singlePropIndex += filteredStyleBindingNames.length * StylingIndex.Size;\n      }\n      singlePropOffsetValues.push(singlePropIndex);\n    }\n  }\n\n  // because new styles are being inserted, this means the existing collection of style offset\n  // index values are incorrect (they point to the wrong values). The code below will run through\n  // the entire offset array and update the existing set of index values to point to their new\n  // locations while taking the new binding values into consideration.\n  let i = SinglePropOffsetValuesIndex.ValueStartPosition;\n  if (filteredStyleBindingNames.length) {\n    while (i < currentSinglePropsLength) {\n      const totalStyles =\n          singlePropOffsetValues[i + SinglePropOffsetValuesIndex.StylesCountPosition];\n      const totalClasses =\n          singlePropOffsetValues[i + SinglePropOffsetValuesIndex.ClassesCountPosition];\n      if (totalClasses) {\n        const start = i + SinglePropOffsetValuesIndex.ValueStartPosition + totalStyles;\n        for (let j = start; j < start + totalClasses; j++) {\n          singlePropOffsetValues[j] += filteredStyleBindingNames.length * StylingIndex.Size;\n        }\n      }\n\n      const total = totalStyles + totalClasses;\n      i += SinglePropOffsetValuesIndex.ValueStartPosition + total;\n    }\n  }\n\n  const totalNewEntries = filteredClassBindingNames.length + filteredStyleBindingNames.length;\n\n  // in the event that there are new style values being inserted, all existing class and style\n  // bindings need to have their pointer values offsetted with the new amount of space that is\n  // used for the new style/class bindings.\n  for (let i = singleStylesStartIndex; i < context.length; i += StylingIndex.Size) {\n    const isMultiBased = i >= multiStylesStartIndex;\n    const isClassBased = i >= (isMultiBased ? multiClassesStartIndex : singleClassesStartIndex);\n    const flag = getPointers(context, i);\n    const staticIndex = getInitialIndex(flag);\n    let singleOrMultiIndex = getMultiOrSingleIndex(flag);\n    if (isMultiBased) {\n      singleOrMultiIndex +=\n          isClassBased ? (filteredStyleBindingNames.length * StylingIndex.Size) : 0;\n    } else {\n      singleOrMultiIndex += (totalNewEntries * StylingIndex.Size) +\n          ((isClassBased ? filteredStyleBindingNames.length : 0) * StylingIndex.Size);\n    }\n    setFlag(context, i, pointers(flag, staticIndex, singleOrMultiIndex));\n  }\n\n  // this is where we make space in the context for the new style bindings\n  for (let i = 0; i < filteredStyleBindingNames.length * StylingIndex.Size; i++) {\n    context.splice(multiClassesStartIndex, 0, null);\n    context.splice(singleClassesStartIndex, 0, null);\n    singleClassesStartIndex++;\n    multiStylesStartIndex++;\n    multiClassesStartIndex += 2;  // both single + multi slots were inserted\n  }\n\n  // this is where we make space in the context for the new class bindings\n  for (let i = 0; i < filteredClassBindingNames.length * StylingIndex.Size; i++) {\n    context.splice(multiStylesStartIndex, 0, null);\n    context.push(null);\n    multiStylesStartIndex++;\n    multiClassesStartIndex++;\n  }\n\n  const initialClasses = context[StylingIndex.InitialClassValuesPosition];\n  const initialStyles = context[StylingIndex.InitialStyleValuesPosition];\n\n  // the code below will insert each new entry into the context and assign the appropriate\n  // flags and index values to them. It's important this runs at the end of this function\n  // because the context, property offset and index values have all been computed just before.\n  for (let i = 0; i < totalNewEntries; i++) {\n    const entryIsClassBased = i >= filteredStyleBindingNames.length;\n    const adjustedIndex = entryIsClassBased ? (i - filteredStyleBindingNames.length) : i;\n    const propName = entryIsClassBased ? filteredClassBindingNames[adjustedIndex] :\n                                         filteredStyleBindingNames[adjustedIndex];\n\n    let multiIndex, singleIndex;\n    if (entryIsClassBased) {\n      multiIndex = multiClassesStartIndex +\n          ((totalCurrentClassBindings + adjustedIndex) * StylingIndex.Size);\n      singleIndex = singleClassesStartIndex +\n          ((totalCurrentClassBindings + adjustedIndex) * StylingIndex.Size);\n    } else {\n      multiIndex =\n          multiStylesStartIndex + ((totalCurrentStyleBindings + adjustedIndex) * StylingIndex.Size);\n      singleIndex = singleStylesStartIndex +\n          ((totalCurrentStyleBindings + adjustedIndex) * StylingIndex.Size);\n    }\n\n    // if a property is not found in the initial style values list then it\n    // is ALWAYS added in case a follow-up directive introduces the same initial\n    // style/class value later on.\n    let initialValuesToLookup = entryIsClassBased ? initialClasses : initialStyles;\n    let indexForInitial = getInitialStylingValuesIndexOf(initialValuesToLookup, propName);\n    if (indexForInitial === -1) {\n      indexForInitial = addOrUpdateStaticStyle(\n                            null, initialValuesToLookup, propName, entryIsClassBased ? false : null,\n                            directiveIndex) +\n          InitialStylingValuesIndex.ValueOffset;\n    } else {\n      indexForInitial += InitialStylingValuesIndex.ValueOffset;\n    }\n\n    const initialFlag =\n        prepareInitialFlag(context, propName, entryIsClassBased, styleSanitizer || null);\n\n    setFlag(context, singleIndex, pointers(initialFlag, indexForInitial, multiIndex));\n    setProp(context, singleIndex, propName);\n    setValue(context, singleIndex, null);\n    setPlayerBuilderIndex(context, singleIndex, 0, directiveIndex);\n\n    setFlag(context, multiIndex, pointers(initialFlag, indexForInitial, singleIndex));\n    setProp(context, multiIndex, propName);\n    setValue(context, multiIndex, null);\n    setPlayerBuilderIndex(context, multiIndex, 0, directiveIndex);\n  }\n\n  // the total classes/style values are updated so the next time the context is patched\n  // additional style/class bindings from another directive then it knows exactly where\n  // to insert them in the context\n  singlePropOffsetValues[SinglePropOffsetValuesIndex.ClassesCountPosition] =\n      totalCurrentClassBindings + filteredClassBindingNames.length;\n  singlePropOffsetValues[SinglePropOffsetValuesIndex.StylesCountPosition] =\n      totalCurrentStyleBindings + filteredStyleBindingNames.length;\n\n  // the map-based values also need to know how many entries got inserted\n  cachedClassMapValues[MapBasedOffsetValuesIndex.EntriesCountPosition] +=\n      filteredClassBindingNames.length;\n  cachedStyleMapValues[MapBasedOffsetValuesIndex.EntriesCountPosition] +=\n      filteredStyleBindingNames.length;\n  const newStylesSpaceAllocationSize = filteredStyleBindingNames.length * StylingIndex.Size;\n  const newClassesSpaceAllocationSize = filteredClassBindingNames.length * StylingIndex.Size;\n\n  // update the multi styles cache with a reference for the directive that was just inserted\n  const directiveMultiStylesStartIndex =\n      multiStylesStartIndex + totalCurrentStyleBindings * StylingIndex.Size;\n  const cachedStyleMapIndex = cachedStyleMapValues.length;\n  registerMultiMapEntry(\n      context, directiveIndex, false, directiveMultiStylesStartIndex,\n      filteredStyleBindingNames.length);\n\n  for (let i = MapBasedOffsetValuesIndex.ValuesStartPosition; i < cachedStyleMapIndex;\n       i += MapBasedOffsetValuesIndex.Size) {\n    // multi values start after all the single values (which is also where classes are) in the\n    // context therefore the new class allocation size should be taken into account\n    cachedStyleMapValues[i + MapBasedOffsetValuesIndex.PositionStartOffset] +=\n        newClassesSpaceAllocationSize + newStylesSpaceAllocationSize;\n  }\n\n  // update the multi classes cache with a reference for the directive that was just inserted\n  const directiveMultiClassesStartIndex =\n      multiClassesStartIndex + totalCurrentClassBindings * StylingIndex.Size;\n  const cachedClassMapIndex = cachedClassMapValues.length;\n  registerMultiMapEntry(\n      context, directiveIndex, true, directiveMultiClassesStartIndex,\n      filteredClassBindingNames.length);\n\n  for (let i = MapBasedOffsetValuesIndex.ValuesStartPosition; i < cachedClassMapIndex;\n       i += MapBasedOffsetValuesIndex.Size) {\n    // the reason why both the styles + classes space is allocated to the existing offsets is\n    // because the styles show up before the classes in the context and any new inserted\n    // styles will offset any existing class entries in the context (even if there are no\n    // new class entries added) also the reason why it's *2 is because both single + multi\n    // entries for each new style have been added in the context before the multi class values\n    // actually start\n    cachedClassMapValues[i + MapBasedOffsetValuesIndex.PositionStartOffset] +=\n        (newStylesSpaceAllocationSize * 2) + newClassesSpaceAllocationSize;\n  }\n\n  // there is no initial value flag for the master index since it doesn't\n  // reference an initial style value\n  const masterFlag = pointers(0, 0, multiStylesStartIndex);\n  setFlag(context, StylingIndex.MasterFlagPosition, masterFlag);\n}\n\n/**\n * Searches through the existing registry of directives\n */\nexport function findOrPatchDirectiveIntoRegistry(\n    context: StylingContext, directiveIndex: number, staticModeOnly: boolean,\n    styleSanitizer?: StyleSanitizeFn | null): boolean {\n  const directiveRegistry = context[StylingIndex.DirectiveRegistryPosition];\n  const index = directiveIndex * DirectiveRegistryValuesIndex.Size;\n  const singlePropStartPosition = index + DirectiveRegistryValuesIndex.SinglePropValuesIndexOffset;\n\n  // this means that the directive has already been registered into the registry\n  if (index < directiveRegistry.length &&\n      (directiveRegistry[singlePropStartPosition] as number) >= 0)\n    return false;\n\n  const singlePropsStartIndex =\n      staticModeOnly ? -1 : context[StylingIndex.SinglePropOffsetPositions].length;\n  allocateOrUpdateDirectiveIntoContext(\n      context, directiveIndex, singlePropsStartIndex, styleSanitizer);\n  return true;\n}\n\nfunction getMatchingBindingIndex(\n    context: StylingContext, bindingName: string, start: number, end: number) {\n  for (let j = start; j < end; j += StylingIndex.Size) {\n    if (getProp(context, j) === bindingName) return j;\n  }\n  return -1;\n}\n\n/**\n * Registers the provided multi class values to the context.\n *\n * This function will iterate over the provided `classesInput` values and\n * insert/update or remove them from the context at exactly the right spot.\n *\n * This function also takes in a directive which implies that the styling values will\n * be evaluated for that directive with respect to any other styling that already exists\n * on the context. When there are styles that conflict (e.g. say `ngClass` and `[class]`\n * both update the `foo` className value at the same time) then the styling algorithm code below\n * will decide which one wins based on the directive styling prioritization mechanism. (This\n * mechanism is better explained in render3/interfaces/styling.ts#directives).\n *\n * This function will not render any styling values on screen, but is rather designed to\n * prepare the context for that. `renderStyling` must be called afterwards to render any\n * styling data that was set in this function (note that `updateClassProp` and\n * `updateStyleProp` are designed to be run after this function is run).\n *\n * @param context The styling context that will be updated with the\n *    newly provided style values.\n * @param classesInput The key/value map of CSS class names that will be used for the update.\n * @param stylesInput The key/value map of CSS styles that will be used for the update.\n */\nexport function updateClassMap(\n    context: StylingContext, classesInput: {[key: string]: any} | string |\n        BoundPlayerFactory<null|string|{[key: string]: any}>| null,\n    directiveIndex: number = 0): void {\n  updateStylingMap(context, classesInput, true, directiveIndex);\n}\n\n/**\n * Registers the provided multi style values to the context.\n *\n * This function will iterate over the provided `stylesInput` values and\n * insert/update or remove them from the context at exactly the right spot.\n *\n * This function also takes in a directive which implies that the styling values will\n * be evaluated for that directive with respect to any other styling that already exists\n * on the context. When there are styles that conflict (e.g. say `ngStyle` and `[style]`\n * both update the `width` property at the same time) then the styling algorithm code below\n * will decide which one wins based on the directive styling prioritization mechanism. (This\n * mechanism is better explained in render3/interfaces/styling.ts#directives).\n *\n * This function will not render any styling values on screen, but is rather designed to\n * prepare the context for that. `renderStyling` must be called afterwards to render any\n * styling data that was set in this function (note that `updateClassProp` and\n * `updateStyleProp` are designed to be run after this function is run).\n *\n * @param context The styling context that will be updated with the\n *    newly provided style values.\n * @param stylesInput The key/value map of CSS styles that will be used for the update.\n */\nexport function updateStyleMap(\n    context: StylingContext, stylesInput: {[key: string]: any} | string |\n        BoundPlayerFactory<null|string|{[key: string]: any}>| null,\n    directiveIndex: number = 0): void {\n  updateStylingMap(context, stylesInput, false, directiveIndex);\n}\n\nfunction updateStylingMap(\n    context: StylingContext, input: {[key: string]: any} | string |\n        BoundPlayerFactory<null|string|{[key: string]: any}>| null,\n    entryIsClassBased: boolean, directiveIndex: number = 0): void {\n  ngDevMode && (entryIsClassBased ? ngDevMode.classMap++ : ngDevMode.styleMap++);\n  ngDevMode && assertValidDirectiveIndex(context, directiveIndex);\n\n  // early exit (this is what's done to avoid using ctx.bind() to cache the value)\n  if (isMultiValueCacheHit(context, entryIsClassBased, directiveIndex, input)) return;\n\n  input =\n      input === NO_CHANGE ? readCachedMapValue(context, entryIsClassBased, directiveIndex) : input;\n\n  const element = context[StylingIndex.ElementPosition] !as HTMLElement;\n  const playerBuilder = input instanceof BoundPlayerFactory ?\n      new ClassAndStylePlayerBuilder(\n          input as any, element, entryIsClassBased ? BindingType.Class : BindingType.Style) :\n      null;\n\n  const rawValue =\n      playerBuilder ? (input as BoundPlayerFactory<{[key: string]: any}|string>) !.value : input;\n\n  // the position is always the same, but whether the player builder gets set\n  // at all (depending if its set) will be reflected in the index value below...\n  const playerBuilderPosition = entryIsClassBased ? PlayerIndex.ClassMapPlayerBuilderPosition :\n                                                    PlayerIndex.StyleMapPlayerBuilderPosition;\n  let playerBuilderIndex = playerBuilder ? playerBuilderPosition : 0;\n  let playerBuildersAreDirty = false;\n  if (hasPlayerBuilderChanged(context, playerBuilder, playerBuilderPosition)) {\n    setPlayerBuilder(context, playerBuilder, playerBuilderPosition);\n    playerBuildersAreDirty = true;\n  }\n\n  // each time a string-based value pops up then it shouldn't require a deep\n  // check of what's changed.\n  let startIndex: number;\n  let endIndex: number;\n  let propNames: string[];\n  let applyAll = false;\n  if (entryIsClassBased) {\n    if (typeof rawValue == 'string') {\n      propNames = rawValue.split(/\\s+/);\n      // this boolean is used to avoid having to create a key/value map of `true` values\n      // since a className string implies that all those classes are added\n      applyAll = true;\n    } else {\n      propNames = rawValue ? Object.keys(rawValue) : EMPTY_ARRAY;\n    }\n    startIndex = getMultiClassesStartIndex(context);\n    endIndex = context.length;\n  } else {\n    startIndex = getMultiStylesStartIndex(context);\n    endIndex = getMultiClassesStartIndex(context);\n    propNames = rawValue ? Object.keys(rawValue) : EMPTY_ARRAY;\n  }\n\n  const values = (rawValue || EMPTY_OBJ) as{[key: string]: any};\n  patchStylingMapIntoContext(\n      context, directiveIndex, playerBuilderIndex, startIndex, endIndex, propNames,\n      applyAll || values, input, entryIsClassBased);\n\n  if (playerBuildersAreDirty) {\n    setContextPlayersDirty(context, true);\n  }\n\n  ngDevMode && (entryIsClassBased ? ngDevMode.classMapCacheMiss++ : ngDevMode.styleMapCacheMiss++);\n}\n\n/**\n * Applies the given multi styling (styles or classes) values to the context.\n *\n * The styling algorithm code that applies multi-level styling (things like `[style]` and `[class]`\n * values) resides here.\n *\n * Because this function understands that multiple directives may all write to the `[style]` and\n * `[class]` bindings (through host bindings), it relies of each directive applying its binding\n * value in order. This means that a directive like `classADirective` will always fire before\n * `classBDirective` and therefore its styling values (classes and styles) will always be evaluated\n * in the same order. Because of this consistent ordering, the first directive has a higher priority\n * than the second one. It is with this prioritzation mechanism that the styling algorithm knows how\n * to merge and apply redudant styling properties.\n *\n * The function itself applies the key/value entries (or an array of keys) to\n * the context in the following steps.\n *\n * STEP 1:\n *    First check to see what properties are already set and in use by another directive in the\n *    context (e.g. `ngClass` set the `width` value and `[style.width]=\"w\"` in a directive is\n *    attempting to set it as well).\n *\n * STEP 2:\n *    All remaining properties (that were not set prior to this directive) are now updated in\n *    the context. Any new properties are inserted exactly at their spot in the context and any\n *    previously set properties are shifted to exactly where the cursor sits while iterating over\n *    the context. The end result is a balanced context that includes the exact ordering of the\n *    styling properties/values for the provided input from the directive.\n *\n * STEP 3:\n *    Any unmatched properties in the context that belong to the directive are set to null\n *\n * Once the updating phase is done, then the algorithm will decide whether or not to flag the\n * follow-up directives (the directives that will pass in their styling values) depending on if\n * the \"shape\" of the multi-value map has changed (either if any keys are removed or added or\n * if there are any new `null` values). If any follow-up directives are flagged as dirty then the\n * algorithm will run again for them. Otherwise if the shape did not change then any follow-up\n * directives will not run (so long as their binding values stay the same).\n *\n * @returns the total amount of new slots that were allocated into the context due to new styling\n *          properties that were detected.\n */\nfunction patchStylingMapIntoContext(\n    context: StylingContext, directiveIndex: number, playerBuilderIndex: number, ctxStart: number,\n    ctxEnd: number, props: (string | null)[], values: {[key: string]: any} | true, cacheValue: any,\n    entryIsClassBased: boolean): number {\n  let dirty = false;\n\n  const cacheIndex = MapBasedOffsetValuesIndex.ValuesStartPosition +\n      directiveIndex * MapBasedOffsetValuesIndex.Size;\n\n  // the cachedValues array is the registry of all multi style values (map values). Each\n  // value is stored (cached) each time is updated.\n  const cachedValues =\n      context[entryIsClassBased ? StylingIndex.CachedMultiClasses : StylingIndex.CachedMultiStyles];\n\n  // this is the index in which this directive has ownership access to write to this\n  // value (anything before is owned by a previous directive that is more important)\n  const ownershipValuesStartIndex =\n      cachedValues[cacheIndex + MapBasedOffsetValuesIndex.PositionStartOffset];\n\n  const existingCachedValue = cachedValues[cacheIndex + MapBasedOffsetValuesIndex.ValueOffset];\n  const existingCachedValueCount =\n      cachedValues[cacheIndex + MapBasedOffsetValuesIndex.ValueCountOffset];\n  const existingCachedValueIsDirty =\n      cachedValues[cacheIndex + MapBasedOffsetValuesIndex.DirtyFlagOffset] === 1;\n\n  // A shape change means the provided map value has either removed or added new properties\n  // compared to what were in the last time. If a shape change occurs then it means that all\n  // follow-up multi-styling entries are obsolete and will be examined again when CD runs\n  // them. If a shape change has not occurred then there is no reason to check any other\n  // directive values if their identity has not changed. If a previous directive set this\n  // value as dirty (because its own shape changed) then this means that the object has been\n  // offset to a different area in the context. Because its value has been offset then it\n  // can't write to a region that it wrote to before (which may have been apart of another\n  // directive) and therefore its shape changes too.\n  let valuesEntryShapeChange =\n      existingCachedValueIsDirty || ((!existingCachedValue && cacheValue) ? true : false);\n\n  let totalUniqueValues = 0;\n  let totalNewAllocatedSlots = 0;\n\n  // this is a trick to avoid building {key:value} map where all the values\n  // are `true` (this happens when a className string is provided instead of a\n  // map as an input value to this styling algorithm)\n  const applyAllProps = values === true;\n\n  // STEP 1:\n  // loop through the earlier directives and figure out if any properties here will be placed\n  // in their area (this happens when the value is null because the earlier directive erased it).\n  let ctxIndex = ctxStart;\n  let totalRemainingProperties = props.length;\n  while (ctxIndex < ownershipValuesStartIndex) {\n    const currentProp = getProp(context, ctxIndex);\n    if (totalRemainingProperties) {\n      for (let i = 0; i < props.length; i++) {\n        const mapProp = props[i];\n        const normalizedProp = mapProp ? (entryIsClassBased ? mapProp : hyphenate(mapProp)) : null;\n        if (normalizedProp && currentProp === normalizedProp) {\n          const currentValue = getValue(context, ctxIndex);\n          const currentDirectiveIndex = getDirectiveIndexFromEntry(context, ctxIndex);\n          const value = applyAllProps ? true : (values as{[key: string]: any})[normalizedProp];\n          const currentFlag = getPointers(context, ctxIndex);\n          if (hasValueChanged(currentFlag, currentValue, value) &&\n              allowValueChange(currentValue, value, currentDirectiveIndex, directiveIndex)) {\n            setValue(context, ctxIndex, value);\n            setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);\n            if (hasInitialValueChanged(context, currentFlag, value)) {\n              setDirty(context, ctxIndex, true);\n              dirty = true;\n            }\n          }\n          props[i] = null;\n          totalRemainingProperties--;\n          break;\n        }\n      }\n    }\n    ctxIndex += StylingIndex.Size;\n  }\n\n  // STEP 2:\n  // apply the left over properties to the context in the correct order.\n  if (totalRemainingProperties) {\n    const sanitizer = entryIsClassBased ? null : getStyleSanitizer(context, directiveIndex);\n    propertiesLoop: for (let i = 0; i < props.length; i++) {\n      const mapProp = props[i];\n\n      if (!mapProp) {\n        // this is an early exit in case a value was already encountered above in the\n        // previous loop (which means that the property was applied or rejected)\n        continue;\n      }\n\n      const value = applyAllProps ? true : (values as{[key: string]: any})[mapProp];\n      const normalizedProp = entryIsClassBased ? mapProp : hyphenate(mapProp);\n      const isInsideOwnershipArea = ctxIndex >= ownershipValuesStartIndex;\n\n      for (let j = ctxIndex; j < ctxEnd; j += StylingIndex.Size) {\n        const distantCtxProp = getProp(context, j);\n        if (distantCtxProp === normalizedProp) {\n          const distantCtxDirectiveIndex = getDirectiveIndexFromEntry(context, j);\n          const distantCtxPlayerBuilderIndex = getPlayerBuilderIndex(context, j);\n          const distantCtxValue = getValue(context, j);\n          const distantCtxFlag = getPointers(context, j);\n\n          if (allowValueChange(distantCtxValue, value, distantCtxDirectiveIndex, directiveIndex)) {\n            // even if the entry isn't updated (by value or directiveIndex) then\n            // it should still be moved over to the correct spot in the array so\n            // the iteration loop is tighter.\n            if (isInsideOwnershipArea) {\n              swapMultiContextEntries(context, ctxIndex, j);\n              totalUniqueValues++;\n            }\n\n            if (hasValueChanged(distantCtxFlag, distantCtxValue, value)) {\n              if (value === null || value === undefined && value !== distantCtxValue) {\n                valuesEntryShapeChange = true;\n              }\n\n              setValue(context, ctxIndex, value);\n\n              // SKIP IF INITIAL CHECK\n              // If the former `value` is `null` then it means that an initial value\n              // could be being rendered on screen. If that is the case then there is\n              // no point in updating the value in case it matches. In other words if the\n              // new value is the exact same as the previously rendered value (which\n              // happens to be the initial value) then do nothing.\n              if (distantCtxValue !== null ||\n                  hasInitialValueChanged(context, distantCtxFlag, value)) {\n                setDirty(context, ctxIndex, true);\n                dirty = true;\n              }\n            }\n\n            if (distantCtxDirectiveIndex !== directiveIndex ||\n                playerBuilderIndex !== distantCtxPlayerBuilderIndex) {\n              setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);\n            }\n          }\n\n          ctxIndex += StylingIndex.Size;\n          continue propertiesLoop;\n        }\n      }\n\n      // fallback case ... value not found at all in the context\n      if (value != null) {\n        valuesEntryShapeChange = true;\n        totalUniqueValues++;\n        const flag = prepareInitialFlag(context, normalizedProp, entryIsClassBased, sanitizer) |\n            StylingFlags.Dirty;\n\n        const insertionIndex = isInsideOwnershipArea ?\n            ctxIndex :\n            (ownershipValuesStartIndex + totalNewAllocatedSlots * StylingIndex.Size);\n        insertNewMultiProperty(\n            context, insertionIndex, entryIsClassBased, normalizedProp, flag, value, directiveIndex,\n            playerBuilderIndex);\n\n        totalNewAllocatedSlots++;\n        ctxEnd += StylingIndex.Size;\n        ctxIndex += StylingIndex.Size;\n\n        dirty = true;\n      }\n    }\n  }\n\n  // STEP 3:\n  // Remove (nullify) any existing entries in the context that were not apart of the\n  // map input value that was passed into this algorithm for this directive.\n  while (ctxIndex < ctxEnd) {\n    valuesEntryShapeChange = true;  // some values are missing\n    const ctxValue = getValue(context, ctxIndex);\n    const ctxFlag = getPointers(context, ctxIndex);\n    const ctxDirective = getDirectiveIndexFromEntry(context, ctxIndex);\n    if (ctxValue != null) {\n      valuesEntryShapeChange = true;\n    }\n    if (hasValueChanged(ctxFlag, ctxValue, null)) {\n      setValue(context, ctxIndex, null);\n      // only if the initial value is falsy then\n      if (hasInitialValueChanged(context, ctxFlag, ctxValue)) {\n        setDirty(context, ctxIndex, true);\n        dirty = true;\n      }\n      setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);\n    }\n    ctxIndex += StylingIndex.Size;\n  }\n\n  // Because the object shape has changed, this means that all follow-up directives will need to\n  // reapply their values into the object. For this to happen, the cached array needs to be updated\n  // with dirty flags so that follow-up calls to `updateStylingMap` will reapply their styling code.\n  // the reapplication of styling code within the context will reshape it and update the offset\n  // values (also follow-up directives can write new values in case earlier directives set anything\n  // to null due to removals or falsy values).\n  valuesEntryShapeChange = valuesEntryShapeChange || existingCachedValueCount !== totalUniqueValues;\n  updateCachedMapValue(\n      context, directiveIndex, entryIsClassBased, cacheValue, ownershipValuesStartIndex, ctxEnd,\n      totalUniqueValues, valuesEntryShapeChange);\n\n  if (dirty) {\n    setContextDirty(context, true);\n  }\n\n  return totalNewAllocatedSlots;\n}\n\n/**\n * Sets and resolves a single class value on the provided `StylingContext` so\n * that they can be applied to the element once `renderStyling` is called.\n *\n * @param context The styling context that will be updated with the\n *    newly provided class value.\n * @param offset The index of the CSS class which is being updated.\n * @param addOrRemove Whether or not to add or remove the CSS class\n * @param forceOverride whether or not to skip all directive prioritization\n *    and just apply the value regardless.\n */\nexport function updateClassProp(\n    context: StylingContext, offset: number,\n    input: boolean | BoundPlayerFactory<boolean|null>| null, directiveIndex: number = 0,\n    forceOverride?: boolean): void {\n  updateSingleStylingValue(context, offset, input, true, directiveIndex, forceOverride);\n}\n\n/**\n * Sets and resolves a single style value on the provided `StylingContext` so\n * that they can be applied to the element once `renderStyling` is called.\n *\n * Note that prop-level styling values are considered higher priority than any styling that\n * has been applied using `updateStylingMap`, therefore, when styling values are rendered\n * then any styles/classes that have been applied using this function will be considered first\n * (then multi values second and then initial values as a backup).\n *\n * @param context The styling context that will be updated with the\n *    newly provided style value.\n * @param offset The index of the property which is being updated.\n * @param value The CSS style value that will be assigned\n * @param forceOverride whether or not to skip all directive prioritization\n *    and just apply the value regardless.\n */\nexport function updateStyleProp(\n    context: StylingContext, offset: number,\n    input: string | boolean | null | BoundPlayerFactory<string|boolean|null>,\n    directiveIndex: number = 0, forceOverride?: boolean): void {\n  updateSingleStylingValue(context, offset, input, false, directiveIndex, forceOverride);\n}\n\nfunction updateSingleStylingValue(\n    context: StylingContext, offset: number,\n    input: string | boolean | null | BoundPlayerFactory<string|boolean|null>, isClassBased: boolean,\n    directiveIndex: number, forceOverride?: boolean): void {\n  ngDevMode && assertValidDirectiveIndex(context, directiveIndex);\n  const singleIndex = getSinglePropIndexValue(context, directiveIndex, offset, isClassBased);\n  const currValue = getValue(context, singleIndex);\n  const currFlag = getPointers(context, singleIndex);\n  const currDirective = getDirectiveIndexFromEntry(context, singleIndex);\n  const value: string|boolean|null = (input instanceof BoundPlayerFactory) ? input.value : input;\n\n  ngDevMode && ngDevMode.stylingProp++;\n\n  if (hasValueChanged(currFlag, currValue, value) &&\n      (forceOverride || allowValueChange(currValue, value, currDirective, directiveIndex))) {\n    const isClassBased = (currFlag & StylingFlags.Class) === StylingFlags.Class;\n    const element = context[StylingIndex.ElementPosition] !as HTMLElement;\n    const playerBuilder = input instanceof BoundPlayerFactory ?\n        new ClassAndStylePlayerBuilder(\n            input as any, element, isClassBased ? BindingType.Class : BindingType.Style) :\n        null;\n    const value = (playerBuilder ? (input as BoundPlayerFactory<any>).value : input) as string |\n        boolean | null;\n    const currPlayerIndex = getPlayerBuilderIndex(context, singleIndex);\n\n    let playerBuildersAreDirty = false;\n    let playerBuilderIndex = playerBuilder ? currPlayerIndex : 0;\n    if (hasPlayerBuilderChanged(context, playerBuilder, currPlayerIndex)) {\n      const newIndex = setPlayerBuilder(context, playerBuilder, currPlayerIndex);\n      playerBuilderIndex = playerBuilder ? newIndex : 0;\n      playerBuildersAreDirty = true;\n    }\n\n    if (playerBuildersAreDirty || currDirective !== directiveIndex) {\n      setPlayerBuilderIndex(context, singleIndex, playerBuilderIndex, directiveIndex);\n    }\n\n    if (currDirective !== directiveIndex) {\n      const prop = getProp(context, singleIndex);\n      const sanitizer = getStyleSanitizer(context, directiveIndex);\n      setSanitizeFlag(\n          context, singleIndex,\n          (sanitizer && sanitizer(prop, null, StyleSanitizeMode.ValidateProperty)) ? true : false);\n    }\n\n    // the value will always get updated (even if the dirty flag is skipped)\n    setValue(context, singleIndex, value);\n    const indexForMulti = getMultiOrSingleIndex(currFlag);\n\n    // if the value is the same in the multi-area then there's no point in re-assembling\n    const valueForMulti = getValue(context, indexForMulti);\n    if (!valueForMulti || hasValueChanged(currFlag, valueForMulti, value)) {\n      let multiDirty = false;\n      let singleDirty = true;\n\n      // only when the value is set to `null` should the multi-value get flagged\n      if (!valueExists(value, isClassBased) && valueExists(valueForMulti, isClassBased)) {\n        multiDirty = true;\n        singleDirty = false;\n      }\n\n      setDirty(context, indexForMulti, multiDirty);\n      setDirty(context, singleIndex, singleDirty);\n      setContextDirty(context, true);\n    }\n\n    if (playerBuildersAreDirty) {\n      setContextPlayersDirty(context, true);\n    }\n\n    ngDevMode && ngDevMode.stylingPropCacheMiss++;\n  }\n}\n\n\n/**\n * Renders all queued styling using a renderer onto the given element.\n *\n * This function works by rendering any styles (that have been applied\n * using `updateStylingMap`) and any classes (that have been applied using\n * `updateStyleProp`) onto the provided element using the provided renderer.\n * Just before the styles/classes are rendered a final key/value style map\n * will be assembled (if `styleStore` or `classStore` are provided).\n *\n * @param lElement the element that the styles will be rendered on\n * @param context The styling context that will be used to determine\n *      what styles will be rendered\n * @param renderer the renderer that will be used to apply the styling\n * @param classesStore if provided, the updated class values will be applied\n *    to this key/value map instead of being renderered via the renderer.\n * @param stylesStore if provided, the updated style values will be applied\n *    to this key/value map instead of being renderered via the renderer.\n * @returns number the total amount of players that got queued for animation (if any)\n */\nexport function renderStyling(\n    context: StylingContext, renderer: Renderer3 | null, rootOrView: RootContext | LView,\n    isFirstRender: boolean, classesStore?: BindingStore | null, stylesStore?: BindingStore | null,\n    directiveIndex: number = 0): number {\n  let totalPlayersQueued = 0;\n  ngDevMode && ngDevMode.stylingApply++;\n\n  // this prevents multiple attempts to render style/class values on\n  // the same element...\n  if (allowHostInstructionsQueueFlush(context, directiveIndex)) {\n    // all styling instructions present within any hostBindings functions\n    // do not update the context immediately when called. They are instead\n    // queued up and applied to the context right at this point. Why? This\n    // is because Angular evaluates component/directive and directive\n    // sub-class code at different points and it's important that the\n    // styling values are applied to the context in the right order\n    // (see `interfaces/styling.ts` for more information).\n    flushHostInstructionsQueue(context);\n\n    if (isContextDirty(context)) {\n      ngDevMode && ngDevMode.stylingApplyCacheMiss++;\n\n      // this is here to prevent things like <ng-container [style] [class]>...</ng-container>\n      // or if there are any host style or class bindings present in a directive set on\n      // a container node\n      const native = context[StylingIndex.ElementPosition] !as HTMLElement;\n\n      const flushPlayerBuilders: any =\n          context[StylingIndex.MasterFlagPosition] & StylingFlags.PlayerBuildersDirty;\n      const multiStartIndex = getMultiStylesStartIndex(context);\n\n      for (let i = StylingIndex.SingleStylesStartPosition; i < context.length;\n           i += StylingIndex.Size) {\n        // there is no point in rendering styles that have not changed on screen\n        if (isDirty(context, i)) {\n          const flag = getPointers(context, i);\n          const directiveIndex = getDirectiveIndexFromEntry(context, i);\n          const prop = getProp(context, i);\n          const value = getValue(context, i);\n          const styleSanitizer =\n              (flag & StylingFlags.Sanitize) ? getStyleSanitizer(context, directiveIndex) : null;\n          const playerBuilder = getPlayerBuilder(context, i);\n          const isClassBased = flag & StylingFlags.Class ? true : false;\n          const isInSingleRegion = i < multiStartIndex;\n\n          let valueToApply: string|boolean|null = value;\n\n          // VALUE DEFER CASE 1: Use a multi value instead of a null single value\n          // this check implies that a single value was removed and we\n          // should now defer to a multi value and use that (if set).\n          if (isInSingleRegion && !valueExists(valueToApply, isClassBased)) {\n            // single values ALWAYS have a reference to a multi index\n            const multiIndex = getMultiOrSingleIndex(flag);\n            valueToApply = getValue(context, multiIndex);\n          }\n\n          // VALUE DEFER CASE 2: Use the initial value if all else fails (is falsy)\n          // the initial value will always be a string or null,\n          // therefore we can safely adopt it in case there's nothing else\n          // note that this should always be a falsy check since `false` is used\n          // for both class and style comparisons (styles can't be false and false\n          // classes are turned off and should therefore defer to their initial values)\n          // Note that we ignore class-based deferals because otherwise a class can never\n          // be removed in the case that it exists as true in the initial classes list...\n          if (!valueExists(valueToApply, isClassBased)) {\n            valueToApply = getInitialValue(context, flag);\n          }\n\n          // if the first render is true then we do not want to start applying falsy\n          // values to the DOM element's styling. Otherwise then we know there has\n          // been a change and even if it's falsy then it's removing something that\n          // was truthy before.\n          const doApplyValue = renderer && (isFirstRender ? valueToApply : true);\n          if (doApplyValue) {\n            if (isClassBased) {\n              setClass(\n                  native, prop, valueToApply ? true : false, renderer !, classesStore,\n                  playerBuilder);\n            } else {\n              setStyle(\n                  native, prop, valueToApply as string | null, renderer !, styleSanitizer,\n                  stylesStore, playerBuilder);\n            }\n          }\n\n          setDirty(context, i, false);\n        }\n      }\n\n      if (flushPlayerBuilders) {\n        const rootContext =\n            Array.isArray(rootOrView) ? getRootContext(rootOrView) : rootOrView as RootContext;\n        const playerContext = getPlayerContext(context) !;\n        const playersStartIndex = playerContext[PlayerIndex.NonBuilderPlayersStart];\n        for (let i = PlayerIndex.PlayerBuildersStartPosition; i < playersStartIndex;\n             i += PlayerIndex.PlayerAndPlayerBuildersTupleSize) {\n          const builder = playerContext[i] as ClassAndStylePlayerBuilder<any>| null;\n          const playerInsertionIndex = i + PlayerIndex.PlayerOffsetPosition;\n          const oldPlayer = playerContext[playerInsertionIndex] as Player | null;\n          if (builder) {\n            const player = builder.buildPlayer(oldPlayer, isFirstRender);\n            if (player !== undefined) {\n              if (player != null) {\n                const wasQueued = addPlayerInternal(\n                    playerContext, rootContext, native as HTMLElement, player,\n                    playerInsertionIndex);\n                wasQueued && totalPlayersQueued++;\n              }\n              if (oldPlayer) {\n                oldPlayer.destroy();\n              }\n            }\n          } else if (oldPlayer) {\n            // the player builder has been removed ... therefore we should delete the associated\n            // player\n            oldPlayer.destroy();\n          }\n        }\n        setContextPlayersDirty(context, false);\n      }\n\n      setContextDirty(context, false);\n    }\n  }\n\n  return totalPlayersQueued;\n}\n\n/**\n * Assigns a style value to a style property for the given element.\n *\n * This function renders a given CSS prop/value entry using the\n * provided renderer. If a `store` value is provided then\n * that will be used a render context instead of the provided\n * renderer.\n *\n * @param native the DOM Element\n * @param prop the CSS style property that will be rendered\n * @param value the CSS style value that will be rendered\n * @param renderer\n * @param store an optional key/value map that will be used as a context to render styles on\n */\nexport function setStyle(\n    native: any, prop: string, value: string | null, renderer: Renderer3,\n    sanitizer: StyleSanitizeFn | null, store?: BindingStore | null,\n    playerBuilder?: ClassAndStylePlayerBuilder<any>| null) {\n  value =\n      sanitizer && value ? sanitizer(prop, value, StyleSanitizeMode.ValidateAndSanitize) : value;\n  if (store || playerBuilder) {\n    if (store) {\n      store.setValue(prop, value);\n    }\n    if (playerBuilder) {\n      playerBuilder.setValue(prop, value);\n    }\n  } else if (value) {\n    value = value.toString();  // opacity, z-index and flexbox all have number values which may not\n    // assign as numbers\n    ngDevMode && ngDevMode.rendererSetStyle++;\n    isProceduralRenderer(renderer) ?\n        renderer.setStyle(native, prop, value, RendererStyleFlags3.DashCase) :\n        native.style.setProperty(prop, value);\n  } else {\n    ngDevMode && ngDevMode.rendererRemoveStyle++;\n    isProceduralRenderer(renderer) ?\n        renderer.removeStyle(native, prop, RendererStyleFlags3.DashCase) :\n        native.style.removeProperty(prop);\n  }\n}\n\n/**\n * Adds/removes the provided className value to the provided element.\n *\n * This function renders a given CSS class value using the provided\n * renderer (by adding or removing it from the provided element).\n * If a `store` value is provided then that will be used a render\n * context instead of the provided renderer.\n *\n * @param native the DOM Element\n * @param prop the CSS style property that will be rendered\n * @param value the CSS style value that will be rendered\n * @param renderer\n * @param store an optional key/value map that will be used as a context to render styles on\n */\nfunction setClass(\n    native: any, className: string, add: boolean, renderer: Renderer3, store?: BindingStore | null,\n    playerBuilder?: ClassAndStylePlayerBuilder<any>| null) {\n  if (store || playerBuilder) {\n    if (store) {\n      store.setValue(className, add);\n    }\n    if (playerBuilder) {\n      playerBuilder.setValue(className, add);\n    }\n    // DOMTokenList will throw if we try to add or remove an empty string.\n  } else if (className !== '') {\n    if (add) {\n      ngDevMode && ngDevMode.rendererAddClass++;\n      isProceduralRenderer(renderer) ? renderer.addClass(native, className) :\n                                       native['classList'].add(className);\n    } else {\n      ngDevMode && ngDevMode.rendererRemoveClass++;\n      isProceduralRenderer(renderer) ? renderer.removeClass(native, className) :\n                                       native['classList'].remove(className);\n    }\n  }\n}\n\nfunction setSanitizeFlag(context: StylingContext, index: number, sanitizeYes: boolean) {\n  if (sanitizeYes) {\n    (context[index] as number) |= StylingFlags.Sanitize;\n  } else {\n    (context[index] as number) &= ~StylingFlags.Sanitize;\n  }\n}\n\nfunction setDirty(context: StylingContext, index: number, isDirtyYes: boolean) {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  if (isDirtyYes) {\n    (context[adjustedIndex] as number) |= StylingFlags.Dirty;\n  } else {\n    (context[adjustedIndex] as number) &= ~StylingFlags.Dirty;\n  }\n}\n\nfunction isDirty(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Dirty) == StylingFlags.Dirty;\n}\n\nexport function isClassBasedValue(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Class) == StylingFlags.Class;\n}\n\nfunction isSanitizable(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Sanitize) == StylingFlags.Sanitize;\n}\n\nfunction pointers(configFlag: number, staticIndex: number, dynamicIndex: number) {\n  return (configFlag & StylingFlags.BitMask) | (staticIndex << StylingFlags.BitCountSize) |\n      (dynamicIndex << (StylingIndex.BitCountSize + StylingFlags.BitCountSize));\n}\n\nfunction getInitialValue(context: StylingContext, flag: number): string|boolean|null {\n  const index = getInitialIndex(flag);\n  const entryIsClassBased = flag & StylingFlags.Class;\n  const initialValues = entryIsClassBased ? context[StylingIndex.InitialClassValuesPosition] :\n                                            context[StylingIndex.InitialStyleValuesPosition];\n  return initialValues[index] as string | boolean | null;\n}\n\nfunction getInitialIndex(flag: number): number {\n  return (flag >> StylingFlags.BitCountSize) & StylingIndex.BitMask;\n}\n\nfunction getMultiOrSingleIndex(flag: number): number {\n  const index =\n      (flag >> (StylingIndex.BitCountSize + StylingFlags.BitCountSize)) & StylingIndex.BitMask;\n  return index >= StylingIndex.SingleStylesStartPosition ? index : -1;\n}\n\nfunction getMultiStartIndex(context: StylingContext): number {\n  return getMultiOrSingleIndex(context[StylingIndex.MasterFlagPosition]) as number;\n}\n\nfunction getMultiClassesStartIndex(context: StylingContext): number {\n  const classCache = context[StylingIndex.CachedMultiClasses];\n  return classCache\n      [MapBasedOffsetValuesIndex.ValuesStartPosition +\n       MapBasedOffsetValuesIndex.PositionStartOffset];\n}\n\nfunction getMultiStylesStartIndex(context: StylingContext): number {\n  const stylesCache = context[StylingIndex.CachedMultiStyles];\n  return stylesCache\n      [MapBasedOffsetValuesIndex.ValuesStartPosition +\n       MapBasedOffsetValuesIndex.PositionStartOffset];\n}\n\nfunction setProp(context: StylingContext, index: number, prop: string) {\n  context[index + StylingIndex.PropertyOffset] = prop;\n}\n\nfunction setValue(context: StylingContext, index: number, value: string | null | boolean) {\n  context[index + StylingIndex.ValueOffset] = value;\n}\n\nfunction hasPlayerBuilderChanged(\n    context: StylingContext, builder: ClassAndStylePlayerBuilder<any>| null, index: number) {\n  const playerContext = context[StylingIndex.PlayerContext] !;\n  if (builder) {\n    if (!playerContext || index === 0) {\n      return true;\n    }\n  } else if (!playerContext) {\n    return false;\n  }\n  return playerContext[index] !== builder;\n}\n\nfunction setPlayerBuilder(\n    context: StylingContext, builder: ClassAndStylePlayerBuilder<any>| null,\n    insertionIndex: number): number {\n  let playerContext = context[StylingIndex.PlayerContext] || allocPlayerContext(context);\n  if (insertionIndex > 0) {\n    playerContext[insertionIndex] = builder;\n  } else {\n    insertionIndex = playerContext[PlayerIndex.NonBuilderPlayersStart];\n    playerContext.splice(insertionIndex, 0, builder, null);\n    playerContext[PlayerIndex.NonBuilderPlayersStart] +=\n        PlayerIndex.PlayerAndPlayerBuildersTupleSize;\n  }\n  return insertionIndex;\n}\n\nexport function directiveOwnerPointers(directiveIndex: number, playerIndex: number) {\n  return (playerIndex << DirectiveOwnerAndPlayerBuilderIndex.BitCountSize) | directiveIndex;\n}\n\nfunction setPlayerBuilderIndex(\n    context: StylingContext, index: number, playerBuilderIndex: number, directiveIndex: number) {\n  const value = directiveOwnerPointers(directiveIndex, playerBuilderIndex);\n  context[index + StylingIndex.PlayerBuilderIndexOffset] = value;\n}\n\nfunction getPlayerBuilderIndex(context: StylingContext, index: number): number {\n  const flag = context[index + StylingIndex.PlayerBuilderIndexOffset] as number;\n  const playerBuilderIndex = (flag >> DirectiveOwnerAndPlayerBuilderIndex.BitCountSize) &\n      DirectiveOwnerAndPlayerBuilderIndex.BitMask;\n  return playerBuilderIndex;\n}\n\nfunction getPlayerBuilder(context: StylingContext, index: number): ClassAndStylePlayerBuilder<any>|\n    null {\n  const playerBuilderIndex = getPlayerBuilderIndex(context, index);\n  if (playerBuilderIndex) {\n    const playerContext = context[StylingIndex.PlayerContext];\n    if (playerContext) {\n      return playerContext[playerBuilderIndex] as ClassAndStylePlayerBuilder<any>| null;\n    }\n  }\n  return null;\n}\n\nfunction setFlag(context: StylingContext, index: number, flag: number) {\n  const adjustedIndex =\n      index === StylingIndex.MasterFlagPosition ? index : (index + StylingIndex.FlagsOffset);\n  context[adjustedIndex] = flag;\n}\n\nfunction getPointers(context: StylingContext, index: number): number {\n  const adjustedIndex =\n      index === StylingIndex.MasterFlagPosition ? index : (index + StylingIndex.FlagsOffset);\n  return context[adjustedIndex] as number;\n}\n\nexport function getValue(context: StylingContext, index: number): string|boolean|null {\n  return context[index + StylingIndex.ValueOffset] as string | boolean | null;\n}\n\nexport function getProp(context: StylingContext, index: number): string {\n  return context[index + StylingIndex.PropertyOffset] as string;\n}\n\nexport function isContextDirty(context: StylingContext): boolean {\n  return isDirty(context, StylingIndex.MasterFlagPosition);\n}\n\nexport function setContextDirty(context: StylingContext, isDirtyYes: boolean): void {\n  setDirty(context, StylingIndex.MasterFlagPosition, isDirtyYes);\n}\n\nexport function setContextPlayersDirty(context: StylingContext, isDirtyYes: boolean): void {\n  if (isDirtyYes) {\n    (context[StylingIndex.MasterFlagPosition] as number) |= StylingFlags.PlayerBuildersDirty;\n  } else {\n    (context[StylingIndex.MasterFlagPosition] as number) &= ~StylingFlags.PlayerBuildersDirty;\n  }\n}\n\nfunction swapMultiContextEntries(context: StylingContext, indexA: number, indexB: number) {\n  if (indexA === indexB) return;\n\n  const tmpValue = getValue(context, indexA);\n  const tmpProp = getProp(context, indexA);\n  const tmpFlag = getPointers(context, indexA);\n  const tmpPlayerBuilderIndex = getPlayerBuilderIndex(context, indexA);\n  const tmpDirectiveIndex = getDirectiveIndexFromEntry(context, indexA);\n\n  let flagA = tmpFlag;\n  let flagB = getPointers(context, indexB);\n\n  const singleIndexA = getMultiOrSingleIndex(flagA);\n  if (singleIndexA >= 0) {\n    const _flag = getPointers(context, singleIndexA);\n    const _initial = getInitialIndex(_flag);\n    setFlag(context, singleIndexA, pointers(_flag, _initial, indexB));\n  }\n\n  const singleIndexB = getMultiOrSingleIndex(flagB);\n  if (singleIndexB >= 0) {\n    const _flag = getPointers(context, singleIndexB);\n    const _initial = getInitialIndex(_flag);\n    setFlag(context, singleIndexB, pointers(_flag, _initial, indexA));\n  }\n\n  setValue(context, indexA, getValue(context, indexB));\n  setProp(context, indexA, getProp(context, indexB));\n  setFlag(context, indexA, getPointers(context, indexB));\n  const playerIndexA = getPlayerBuilderIndex(context, indexB);\n  const directiveIndexA = getDirectiveIndexFromEntry(context, indexB);\n  setPlayerBuilderIndex(context, indexA, playerIndexA, directiveIndexA);\n\n  setValue(context, indexB, tmpValue);\n  setProp(context, indexB, tmpProp);\n  setFlag(context, indexB, tmpFlag);\n  setPlayerBuilderIndex(context, indexB, tmpPlayerBuilderIndex, tmpDirectiveIndex);\n}\n\nfunction updateSinglePointerValues(context: StylingContext, indexStartPosition: number) {\n  for (let i = indexStartPosition; i < context.length; i += StylingIndex.Size) {\n    const multiFlag = getPointers(context, i);\n    const singleIndex = getMultiOrSingleIndex(multiFlag);\n    if (singleIndex > 0) {\n      const singleFlag = getPointers(context, singleIndex);\n      const initialIndexForSingle = getInitialIndex(singleFlag);\n      const flagValue = (isDirty(context, singleIndex) ? StylingFlags.Dirty : StylingFlags.None) |\n          (isClassBasedValue(context, singleIndex) ? StylingFlags.Class : StylingFlags.None) |\n          (isSanitizable(context, singleIndex) ? StylingFlags.Sanitize : StylingFlags.None);\n      const updatedFlag = pointers(flagValue, initialIndexForSingle, i);\n      setFlag(context, singleIndex, updatedFlag);\n    }\n  }\n}\n\nfunction insertNewMultiProperty(\n    context: StylingContext, index: number, classBased: boolean, name: string, flag: number,\n    value: string | boolean, directiveIndex: number, playerIndex: number): void {\n  const doShift = index < context.length;\n\n  // prop does not exist in the list, add it in\n  context.splice(\n      index, 0, flag | StylingFlags.Dirty | (classBased ? StylingFlags.Class : StylingFlags.None),\n      name, value, 0);\n  setPlayerBuilderIndex(context, index, playerIndex, directiveIndex);\n\n  if (doShift) {\n    // because the value was inserted midway into the array then we\n    // need to update all the shifted multi values' single value\n    // pointers to point to the newly shifted location\n    updateSinglePointerValues(context, index + StylingIndex.Size);\n  }\n}\n\nfunction valueExists(value: string | null | boolean, isClassBased?: boolean) {\n  return value !== null;\n}\n\nfunction prepareInitialFlag(\n    context: StylingContext, prop: string, entryIsClassBased: boolean,\n    sanitizer?: StyleSanitizeFn | null) {\n  let flag = (sanitizer && sanitizer(prop, null, StyleSanitizeMode.ValidateProperty)) ?\n      StylingFlags.Sanitize :\n      StylingFlags.None;\n\n  let initialIndex: number;\n  if (entryIsClassBased) {\n    flag |= StylingFlags.Class;\n    initialIndex =\n        getInitialStylingValuesIndexOf(context[StylingIndex.InitialClassValuesPosition], prop);\n  } else {\n    initialIndex =\n        getInitialStylingValuesIndexOf(context[StylingIndex.InitialStyleValuesPosition], prop);\n  }\n\n  initialIndex = initialIndex > 0 ? (initialIndex + InitialStylingValuesIndex.ValueOffset) : 0;\n  return pointers(flag, initialIndex, 0);\n}\n\nfunction hasInitialValueChanged(context: StylingContext, flag: number, newValue: any) {\n  const initialValue = getInitialValue(context, flag);\n  return !initialValue || hasValueChanged(flag, initialValue, newValue);\n}\n\nfunction hasValueChanged(\n    flag: number, a: string | boolean | null, b: string | boolean | null): boolean {\n  const isClassBased = flag & StylingFlags.Class;\n  const hasValues = a && b;\n  const usesSanitizer = flag & StylingFlags.Sanitize;\n  // the toString() comparison ensures that a value is checked\n  // ... otherwise (during sanitization bypassing) the === comparsion\n  // would fail since a new String() instance is created\n  if (!isClassBased && hasValues && usesSanitizer) {\n    // we know for sure we're dealing with strings at this point\n    return (a as string).toString() !== (b as string).toString();\n  }\n\n  // everything else is safe to check with a normal equality check\n  return a !== b;\n}\n\nexport class ClassAndStylePlayerBuilder<T> implements PlayerBuilder {\n  private _values: {[key: string]: string | null} = {};\n  private _dirty = false;\n  private _factory: BoundPlayerFactory<T>;\n\n  constructor(factory: PlayerFactory, private _element: HTMLElement, private _type: BindingType) {\n    this._factory = factory as any;\n  }\n\n  setValue(prop: string, value: any) {\n    if (this._values[prop] !== value) {\n      this._values[prop] = value;\n      this._dirty = true;\n    }\n  }\n\n  buildPlayer(currentPlayer: Player|null, isFirstRender: boolean): Player|undefined|null {\n    // if no values have been set here then this means the binding didn't\n    // change and therefore the binding values were not updated through\n    // `setValue` which means no new player will be provided.\n    if (this._dirty) {\n      const player = this._factory.fn(\n          this._element, this._type, this._values !, isFirstRender, currentPlayer || null);\n      this._values = {};\n      this._dirty = false;\n      return player;\n    }\n\n    return undefined;\n  }\n}\n\n/**\n * Used to provide a summary of the state of the styling context.\n *\n * This is an internal interface that is only used inside of test tooling to\n * help summarize what's going on within the styling context. None of this code\n * is designed to be exported publicly and will, therefore, be tree-shaken away\n * during runtime.\n */\nexport interface LogSummary {\n  name: string;          //\n  staticIndex: number;   //\n  dynamicIndex: number;  //\n  value: number;         //\n  flags: {\n    dirty: boolean;                    //\n    class: boolean;                    //\n    sanitize: boolean;                 //\n    playerBuildersDirty: boolean;      //\n    bindingAllocationLocked: boolean;  //\n  };\n}\n\n/**\n * This function is not designed to be used in production.\n * It is a utility tool for debugging and testing and it\n * will automatically be tree-shaken away during production.\n */\nexport function generateConfigSummary(source: number): LogSummary;\nexport function generateConfigSummary(source: StylingContext): LogSummary;\nexport function generateConfigSummary(source: StylingContext, index: number): LogSummary;\nexport function generateConfigSummary(source: number | StylingContext, index?: number): LogSummary {\n  let flag, name = 'config value for ';\n  if (Array.isArray(source)) {\n    if (index) {\n      name += 'index: ' + index;\n    } else {\n      name += 'master config';\n    }\n    index = index || StylingIndex.MasterFlagPosition;\n    flag = source[index] as number;\n  } else {\n    flag = source;\n    name += 'index: ' + flag;\n  }\n  const dynamicIndex = getMultiOrSingleIndex(flag);\n  const staticIndex = getInitialIndex(flag);\n  return {\n    name,\n    staticIndex,\n    dynamicIndex,\n    value: flag,\n    flags: {\n      dirty: flag & StylingFlags.Dirty ? true : false,\n      class: flag & StylingFlags.Class ? true : false,\n      sanitize: flag & StylingFlags.Sanitize ? true : false,\n      playerBuildersDirty: flag & StylingFlags.PlayerBuildersDirty ? true : false,\n      bindingAllocationLocked: flag & StylingFlags.BindingAllocationLocked ? true : false,\n    }\n  };\n}\n\nexport function getDirectiveIndexFromEntry(context: StylingContext, index: number) {\n  const value = context[index + StylingIndex.PlayerBuilderIndexOffset] as number;\n  return value & DirectiveOwnerAndPlayerBuilderIndex.BitMask;\n}\n\nfunction getInitialStylingValuesIndexOf(keyValues: InitialStylingValues, key: string): number {\n  for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < keyValues.length;\n       i += InitialStylingValuesIndex.Size) {\n    if (keyValues[i] === key) return i;\n  }\n  return -1;\n}\n\nexport function compareLogSummaries(a: LogSummary, b: LogSummary) {\n  const log: string[] = [];\n  const diffs: [string, any, any][] = [];\n  diffSummaryValues(diffs, 'staticIndex', 'staticIndex', a, b);\n  diffSummaryValues(diffs, 'dynamicIndex', 'dynamicIndex', a, b);\n  Object.keys(a.flags).forEach(\n      name => { diffSummaryValues(diffs, 'flags.' + name, name, a.flags, b.flags); });\n\n  if (diffs.length) {\n    log.push('Log Summaries for:');\n    log.push('  A: ' + a.name);\n    log.push('  B: ' + b.name);\n    log.push('\\n  Differ in the following way (A !== B):');\n    diffs.forEach(result => {\n      const [name, aVal, bVal] = result;\n      log.push('    => ' + name);\n      log.push('    => ' + aVal + ' !== ' + bVal + '\\n');\n    });\n  }\n\n  return log;\n}\n\nfunction diffSummaryValues(result: any[], name: string, prop: string, a: any, b: any) {\n  const aVal = a[prop];\n  const bVal = b[prop];\n  if (aVal !== bVal) {\n    result.push([name, aVal, bVal]);\n  }\n}\n\nexport function getSinglePropIndexValue(\n    context: StylingContext, directiveIndex: number, offset: number, isClassBased: boolean) {\n  const singlePropOffsetRegistryIndex =\n      context[StylingIndex.DirectiveRegistryPosition]\n             [(directiveIndex * DirectiveRegistryValuesIndex.Size) +\n              DirectiveRegistryValuesIndex.SinglePropValuesIndexOffset] as number;\n  const offsets = context[StylingIndex.SinglePropOffsetPositions];\n  const indexForOffset = singlePropOffsetRegistryIndex +\n      SinglePropOffsetValuesIndex.ValueStartPosition +\n      (isClassBased ?\n           offsets\n               [singlePropOffsetRegistryIndex + SinglePropOffsetValuesIndex.StylesCountPosition] :\n           0) +\n      offset;\n  return offsets[indexForOffset];\n}\n\nfunction getStyleSanitizer(context: StylingContext, directiveIndex: number): StyleSanitizeFn|null {\n  const dirs = context[StylingIndex.DirectiveRegistryPosition];\n  const value = dirs\n                    [directiveIndex * DirectiveRegistryValuesIndex.Size +\n                     DirectiveRegistryValuesIndex.StyleSanitizerOffset] ||\n      dirs[DirectiveRegistryValuesIndex.StyleSanitizerOffset] || null;\n  return value as StyleSanitizeFn | null;\n}\n\nfunction allowValueChange(\n    currentValue: string | boolean | null, newValue: string | boolean | null,\n    currentDirectiveOwner: number, newDirectiveOwner: number) {\n  // the code below relies the importance of directive's being tied to their\n  // index value. The index values for each directive are derived from being\n  // registered into the styling context directive registry. The most important\n  // directive is the parent component directive (the template) and each directive\n  // that is added after is considered less important than the previous entry. This\n  // prioritization of directives enables the styling algorithm to decide if a style\n  // or class should be allowed to be updated/replaced in case an earlier directive\n  // already wrote to the exact same style-property or className value. In other words\n  // this decides what to do if and when there is a collision.\n  if (currentValue != null) {\n    if (newValue != null) {\n      // if a directive index is lower than it always has priority over the\n      // previous directive's value...\n      return newDirectiveOwner <= currentDirectiveOwner;\n    } else {\n      // only write a null value in case it's the same owner writing it.\n      // this avoids having a higher-priority directive write to null\n      // only to have a lesser-priority directive change right to a\n      // non-null value immediately afterwards.\n      return currentDirectiveOwner === newDirectiveOwner;\n    }\n  }\n  return true;\n}\n\n/**\n * Returns the className string of all the initial classes for the element.\n *\n * This function is designed to populate and cache all the static class\n * values into a className string. The caching mechanism works by placing\n * the completed className string into the initial values array into a\n * dedicated slot. This will prevent the function from having to populate\n * the string each time an element is created or matched.\n *\n * @returns the className string (e.g. `on active red`)\n */\nexport function getInitialClassNameValue(context: StylingContext): string {\n  const initialClassValues = context[StylingIndex.InitialClassValuesPosition];\n  let className = initialClassValues[InitialStylingValuesIndex.CachedStringValuePosition];\n  if (className === null) {\n    className = '';\n    for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < initialClassValues.length;\n         i += InitialStylingValuesIndex.Size) {\n      const isPresent = initialClassValues[i + 1];\n      if (isPresent) {\n        className += (className.length ? ' ' : '') + initialClassValues[i];\n      }\n    }\n    initialClassValues[InitialStylingValuesIndex.CachedStringValuePosition] = className;\n  }\n  return className;\n}\n\n/**\n * Returns the style string of all the initial styles for the element.\n *\n * This function is designed to populate and cache all the static style\n * values into a style string. The caching mechanism works by placing\n * the completed style string into the initial values array into a\n * dedicated slot. This will prevent the function from having to populate\n * the string each time an element is created or matched.\n *\n * @returns the style string (e.g. `width:100px;height:200px`)\n */\nexport function getInitialStyleStringValue(context: StylingContext): string {\n  const initialStyleValues = context[StylingIndex.InitialStyleValuesPosition];\n  let styleString = initialStyleValues[InitialStylingValuesIndex.CachedStringValuePosition];\n  if (styleString === null) {\n    styleString = '';\n    for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < initialStyleValues.length;\n         i += InitialStylingValuesIndex.Size) {\n      const value = initialStyleValues[i + 1];\n      if (value !== null) {\n        styleString += (styleString.length ? ';' : '') + `${initialStyleValues[i]}:${value}`;\n      }\n    }\n    initialStyleValues[InitialStylingValuesIndex.CachedStringValuePosition] = styleString;\n  }\n  return styleString;\n}\n\n/**\n * Returns the current cached mutli-value for a given directiveIndex within the provided context.\n */\nfunction readCachedMapValue(\n    context: StylingContext, entryIsClassBased: boolean, directiveIndex: number) {\n  const values: MapBasedOffsetValues =\n      context[entryIsClassBased ? StylingIndex.CachedMultiClasses : StylingIndex.CachedMultiStyles];\n  const index = MapBasedOffsetValuesIndex.ValuesStartPosition +\n      directiveIndex * MapBasedOffsetValuesIndex.Size;\n  return values[index + MapBasedOffsetValuesIndex.ValueOffset] || null;\n}\n\n/**\n * Determines whether the provided multi styling value should be updated or not.\n *\n * Because `[style]` and `[class]` bindings rely on an identity change to occur before\n * applying new values, the styling algorithm may not update an existing entry into\n * the context if a previous directive's entry changed shape.\n *\n * This function will decide whether or not a value should be applied (if there is a\n * cache miss) to the context based on the following rules:\n *\n * - If there is an identity change between the existing value and new value\n * - If there is no existing value cached (first write)\n * - If a previous directive flagged the existing cached value as dirty\n */\nfunction isMultiValueCacheHit(\n    context: StylingContext, entryIsClassBased: boolean, directiveIndex: number,\n    newValue: any): boolean {\n  const indexOfCachedValues =\n      entryIsClassBased ? StylingIndex.CachedMultiClasses : StylingIndex.CachedMultiStyles;\n  const cachedValues = context[indexOfCachedValues] as MapBasedOffsetValues;\n  const index = MapBasedOffsetValuesIndex.ValuesStartPosition +\n      directiveIndex * MapBasedOffsetValuesIndex.Size;\n  if (cachedValues[index + MapBasedOffsetValuesIndex.DirtyFlagOffset]) return false;\n  return newValue === NO_CHANGE ||\n      readCachedMapValue(context, entryIsClassBased, directiveIndex) === newValue;\n}\n\n/**\n * Updates the cached status of a multi-styling value in the context.\n *\n * The cached map array (which exists in the context) contains a manifest of\n * each multi-styling entry (`[style]` and `[class]` entries) for the template\n * as well as all directives.\n *\n * This function will update the cached status of the provided multi-style\n * entry within the cache.\n *\n * When called, this function will update the following information:\n * - The actual cached value (the raw value that was passed into `[style]` or `[class]`)\n * - The total amount of unique styling entries that this value has written into the context\n * - The exact position of where the multi styling entries start in the context for this binding\n * - The dirty flag will be set to true\n *\n * If the `dirtyFutureValues` param is provided then it will update all future entries (binding\n * entries that exist as apart of other directives) to be dirty as well. This will force the\n * styling algorithm to reapply those values once change detection checks them (which will in\n * turn cause the styling context to update itself and the correct styling values will be\n * rendered on screen).\n */\nfunction updateCachedMapValue(\n    context: StylingContext, directiveIndex: number, entryIsClassBased: boolean, cacheValue: any,\n    startPosition: number, endPosition: number, totalValues: number, dirtyFutureValues: boolean) {\n  const values =\n      context[entryIsClassBased ? StylingIndex.CachedMultiClasses : StylingIndex.CachedMultiStyles];\n\n  const index = MapBasedOffsetValuesIndex.ValuesStartPosition +\n      directiveIndex * MapBasedOffsetValuesIndex.Size;\n\n  // in the event that this is true we assume that future values are dirty and therefore\n  // will be checked again in the next CD cycle\n  if (dirtyFutureValues) {\n    const nextStartPosition = startPosition + totalValues * MapBasedOffsetValuesIndex.Size;\n    for (let i = index + MapBasedOffsetValuesIndex.Size; i < values.length;\n         i += MapBasedOffsetValuesIndex.Size) {\n      values[i + MapBasedOffsetValuesIndex.PositionStartOffset] = nextStartPosition;\n      values[i + MapBasedOffsetValuesIndex.DirtyFlagOffset] = 1;\n    }\n  }\n\n  values[index + MapBasedOffsetValuesIndex.DirtyFlagOffset] = 0;\n  values[index + MapBasedOffsetValuesIndex.PositionStartOffset] = startPosition;\n  values[index + MapBasedOffsetValuesIndex.ValueOffset] = cacheValue;\n  values[index + MapBasedOffsetValuesIndex.ValueCountOffset] = totalValues;\n\n  // the code below counts the total amount of styling values that exist in\n  // the context up until this directive. This value will be later used to\n  // update the cached value map's total counter value.\n  let totalStylingEntries = totalValues;\n  for (let i = MapBasedOffsetValuesIndex.ValuesStartPosition; i < index;\n       i += MapBasedOffsetValuesIndex.Size) {\n    totalStylingEntries += values[i + MapBasedOffsetValuesIndex.ValueCountOffset];\n  }\n\n  // because style values come before class values in the context this means\n  // that if any new values were inserted then the cache values array for\n  // classes is out of sync. The code below will update the offsets to point\n  // to their new values.\n  if (!entryIsClassBased) {\n    const classCache = context[StylingIndex.CachedMultiClasses];\n    const classesStartPosition = classCache\n        [MapBasedOffsetValuesIndex.ValuesStartPosition +\n         MapBasedOffsetValuesIndex.PositionStartOffset];\n    const diffInStartPosition = endPosition - classesStartPosition;\n    for (let i = MapBasedOffsetValuesIndex.ValuesStartPosition; i < classCache.length;\n         i += MapBasedOffsetValuesIndex.Size) {\n      classCache[i + MapBasedOffsetValuesIndex.PositionStartOffset] += diffInStartPosition;\n    }\n  }\n\n  values[MapBasedOffsetValuesIndex.EntriesCountPosition] = totalStylingEntries;\n}\n\nfunction hyphenateEntries(entries: string[]): string[] {\n  const newEntries: string[] = [];\n  for (let i = 0; i < entries.length; i++) {\n    newEntries.push(hyphenate(entries[i]));\n  }\n  return newEntries;\n}\n\nfunction hyphenate(value: string): string {\n  return value.replace(\n      /[a-z][A-Z]/g, match => `${match.charAt(0)}-${match.charAt(1).toLowerCase()}`);\n}\n\nfunction registerMultiMapEntry(\n    context: StylingContext, directiveIndex: number, entryIsClassBased: boolean,\n    startPosition: number, count = 0) {\n  const cachedValues =\n      context[entryIsClassBased ? StylingIndex.CachedMultiClasses : StylingIndex.CachedMultiStyles];\n  if (directiveIndex > 0) {\n    const limit = MapBasedOffsetValuesIndex.ValuesStartPosition +\n        (directiveIndex * MapBasedOffsetValuesIndex.Size);\n    while (cachedValues.length < limit) {\n      // this means that ONLY directive class styling (like ngClass) was used\n      // therefore the root directive will still need to be filled in as well\n      // as any other directive spaces in case they only used static values\n      cachedValues.push(0, startPosition, null, 0);\n    }\n  }\n  cachedValues.push(0, startPosition, null, count);\n}\n\n/**\n * Inserts or updates an existing entry in the provided `staticStyles` collection.\n *\n * @param index the index representing an existing styling entry in the collection:\n *  if provided (numeric): then it will update the existing entry at the given position\n *  if null: then it will insert a new entry within the collection\n * @param staticStyles a collection of style or class entries where the value will\n *  be inserted or patched\n * @param prop the property value of the entry (e.g. `width` (styles) or `foo` (classes))\n * @param value the styling value of the entry (e.g. `absolute` (styles) or `true` (classes))\n * @param directiveOwnerIndex the directive owner index value of the styling source responsible\n *        for these styles (see `interfaces/styling.ts#directives` for more info)\n * @returns the index of the updated or new entry within the collection\n */\nfunction addOrUpdateStaticStyle(\n    index: number | null, staticStyles: InitialStylingValues, prop: string,\n    value: string | boolean | null, directiveOwnerIndex: number) {\n  if (index === null) {\n    index = staticStyles.length;\n    staticStyles.push(null, null, null);\n    staticStyles[index + InitialStylingValuesIndex.PropOffset] = prop;\n  }\n  staticStyles[index + InitialStylingValuesIndex.ValueOffset] = value;\n  staticStyles[index + InitialStylingValuesIndex.DirectiveOwnerOffset] = directiveOwnerIndex;\n  return index;\n}\n\nfunction assertValidDirectiveIndex(context: StylingContext, directiveIndex: number) {\n  const dirs = context[StylingIndex.DirectiveRegistryPosition];\n  const index = directiveIndex * DirectiveRegistryValuesIndex.Size;\n  if (index >= dirs.length ||\n      dirs[index + DirectiveRegistryValuesIndex.SinglePropValuesIndexOffset] === -1) {\n    throw new Error('The provided directive is not registered with the styling context');\n  }\n}\n"]}