@angular/core 9.0.0-rc.7 → 9.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (222) hide show
  1. package/bundles/core-testing.umd.js +18 -16
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +7 -7
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +6386 -6384
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +182 -175
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +726 -734
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.externs.js +5 -5
  12. package/esm2015/core.js +17 -15
  13. package/esm2015/index.js +2 -2
  14. package/esm2015/public_api.js +2 -2
  15. package/esm2015/src/application_init.js +10 -2
  16. package/esm2015/src/application_module.js +6 -3
  17. package/esm2015/src/application_ref.js +7 -7
  18. package/esm2015/src/core.js +4 -4
  19. package/esm2015/src/core_private_export.js +7 -7
  20. package/esm2015/src/core_render3_private_export.js +2 -2
  21. package/esm2015/src/debug/debug_node.js +55 -16
  22. package/esm2015/src/di/injectable.js +1 -13
  23. package/esm2015/src/di/injector.js +12 -10
  24. package/esm2015/src/di/interface/provider.js +1 -1
  25. package/esm2015/src/di/r3_injector.js +5 -4
  26. package/esm2015/src/i18n/locale_data_api.js +22 -6
  27. package/esm2015/src/i18n/locale_en.js +16 -5
  28. package/esm2015/src/i18n/localization.js +7 -1
  29. package/esm2015/src/i18n/tokens.js +41 -1
  30. package/esm2015/src/interface/type.js +1 -1
  31. package/esm2015/src/metadata/ng_module.js +1 -1
  32. package/esm2015/src/render/api.js +4 -1
  33. package/esm2015/src/render3/assert.js +9 -1
  34. package/esm2015/src/render3/bindings.js +16 -5
  35. package/esm2015/src/render3/component.js +54 -25
  36. package/esm2015/src/render3/component_ref.js +28 -18
  37. package/esm2015/src/render3/definition.js +3 -1
  38. package/esm2015/src/render3/di.js +3 -4
  39. package/esm2015/src/render3/di_setup.js +5 -7
  40. package/esm2015/src/render3/errors.js +3 -1
  41. package/esm2015/src/render3/features/inherit_definition_feature.js +89 -52
  42. package/esm2015/src/render3/features/ng_onchanges_feature.js +2 -2
  43. package/esm2015/src/render3/global_utils_api.js +3 -3
  44. package/esm2015/src/render3/i18n.js +60 -56
  45. package/esm2015/src/render3/index.js +2 -2
  46. package/esm2015/src/render3/instructions/advance.js +10 -11
  47. package/esm2015/src/render3/instructions/all.js +4 -5
  48. package/esm2015/src/render3/instructions/attribute.js +12 -5
  49. package/esm2015/src/render3/instructions/attribute_interpolation.js +66 -14
  50. package/esm2015/src/render3/instructions/change_detection.js +8 -23
  51. package/esm2015/src/render3/instructions/class_map_interpolation.js +13 -12
  52. package/esm2015/src/render3/instructions/container.js +15 -12
  53. package/esm2015/src/render3/instructions/element.js +45 -132
  54. package/esm2015/src/render3/instructions/element_container.js +8 -10
  55. package/esm2015/src/render3/instructions/embedded_view.js +7 -7
  56. package/esm2015/src/render3/instructions/host_property.js +10 -7
  57. package/esm2015/src/render3/instructions/listener.js +18 -16
  58. package/esm2015/src/render3/instructions/lview_debug.js +160 -23
  59. package/esm2015/src/render3/instructions/projection.js +7 -5
  60. package/esm2015/src/render3/instructions/property.js +27 -6
  61. package/esm2015/src/render3/instructions/property_interpolation.js +42 -23
  62. package/esm2015/src/render3/instructions/shared.js +279 -244
  63. package/esm2015/src/render3/instructions/storage.js +6 -8
  64. package/esm2015/src/render3/instructions/style_prop_interpolation.js +12 -12
  65. package/esm2015/src/render3/instructions/styling.js +731 -475
  66. package/esm2015/src/render3/instructions/text.js +5 -5
  67. package/esm2015/src/render3/interfaces/definition.js +41 -1
  68. package/esm2015/src/render3/interfaces/node.js +160 -115
  69. package/esm2015/src/render3/interfaces/styling.js +183 -375
  70. package/esm2015/src/render3/interfaces/view.js +10 -2
  71. package/esm2015/src/render3/jit/environment.js +1 -3
  72. package/esm2015/src/render3/namespaces.js +17 -0
  73. package/esm2015/src/render3/node_manipulation.js +177 -57
  74. package/esm2015/src/render3/node_selector_matcher.js +128 -24
  75. package/esm2015/src/render3/node_util.js +12 -7
  76. package/esm2015/src/render3/pipe.js +10 -14
  77. package/esm2015/src/render3/pure_function.js +107 -42
  78. package/esm2015/src/render3/query.js +32 -26
  79. package/esm2015/src/render3/state.js +57 -185
  80. package/esm2015/src/render3/styling/class_differ.js +47 -0
  81. package/esm2015/src/render3/styling/static_styling.js +54 -0
  82. package/esm2015/src/render3/styling/style_binding_list.js +437 -0
  83. package/esm2015/src/render3/styling/styling_parser.js +336 -0
  84. package/esm2015/src/render3/tokens.js +2 -2
  85. package/esm2015/src/render3/util/attrs_utils.js +125 -2
  86. package/esm2015/src/render3/util/change_detection_utils.js +33 -0
  87. package/esm2015/src/render3/util/discovery_utils.js +146 -119
  88. package/esm2015/src/render3/util/global_utils.js +5 -5
  89. package/esm2015/src/render3/util/view_utils.js +6 -6
  90. package/esm2015/src/render3/view_engine_compatibility.js +16 -17
  91. package/esm2015/src/render3/view_ref.js +16 -13
  92. package/esm2015/src/sanitization/bypass.js +1 -1
  93. package/esm2015/src/sanitization/sanitization.js +20 -5
  94. package/esm2015/src/util/array_utils.js +240 -1
  95. package/esm2015/src/util/assert.js +37 -21
  96. package/esm2015/src/util/char_code.js +8 -0
  97. package/esm2015/src/util/iterable.js +4 -1
  98. package/esm2015/src/util/ng_dev_mode.js +1 -12
  99. package/esm2015/src/util/stringify.js +14 -1
  100. package/esm2015/src/version.js +1 -1
  101. package/esm2015/src/view/services.js +1 -1
  102. package/esm2015/testing/src/r3_test_bed.js +5 -1
  103. package/esm2015/testing/src/r3_test_bed_compiler.js +5 -13
  104. package/esm2015/testing/src/styling.js +103 -0
  105. package/esm5/core.js +17 -15
  106. package/esm5/src/application_init.js +10 -2
  107. package/esm5/src/application_module.js +6 -3
  108. package/esm5/src/application_ref.js +6 -6
  109. package/esm5/src/core.js +2 -2
  110. package/esm5/src/core_private_export.js +7 -7
  111. package/esm5/src/core_render3_private_export.js +2 -2
  112. package/esm5/src/debug/debug_node.js +39 -14
  113. package/esm5/src/di/injectable.js +1 -1
  114. package/esm5/src/di/injector.js +12 -12
  115. package/esm5/src/di/interface/provider.js +1 -1
  116. package/esm5/src/di/r3_injector.js +5 -4
  117. package/esm5/src/i18n/locale_data_api.js +20 -6
  118. package/esm5/src/i18n/locale_en.js +16 -5
  119. package/esm5/src/i18n/localization.js +6 -1
  120. package/esm5/src/i18n/tokens.js +40 -1
  121. package/esm5/src/interface/type.js +1 -1
  122. package/esm5/src/metadata/ng_module.js +1 -1
  123. package/esm5/src/render/api.js +4 -1
  124. package/esm5/src/render3/assert.js +4 -1
  125. package/esm5/src/render3/bindings.js +19 -2
  126. package/esm5/src/render3/component.js +47 -22
  127. package/esm5/src/render3/component_ref.js +20 -17
  128. package/esm5/src/render3/definition.js +3 -1
  129. package/esm5/src/render3/di.js +3 -4
  130. package/esm5/src/render3/di_setup.js +4 -5
  131. package/esm5/src/render3/errors.js +3 -1
  132. package/esm5/src/render3/features/inherit_definition_feature.js +74 -42
  133. package/esm5/src/render3/features/ng_onchanges_feature.js +1 -1
  134. package/esm5/src/render3/global_utils_api.js +3 -3
  135. package/esm5/src/render3/i18n.js +51 -51
  136. package/esm5/src/render3/index.js +2 -2
  137. package/esm5/src/render3/instructions/advance.js +9 -11
  138. package/esm5/src/render3/instructions/all.js +1 -2
  139. package/esm5/src/render3/instructions/attribute.js +9 -5
  140. package/esm5/src/render3/instructions/attribute_interpolation.js +49 -13
  141. package/esm5/src/render3/instructions/change_detection.js +8 -21
  142. package/esm5/src/render3/instructions/class_map_interpolation.js +13 -12
  143. package/esm5/src/render3/instructions/container.js +13 -12
  144. package/esm5/src/render3/instructions/element.js +41 -113
  145. package/esm5/src/render3/instructions/element_container.js +8 -9
  146. package/esm5/src/render3/instructions/embedded_view.js +7 -7
  147. package/esm5/src/render3/instructions/host_property.js +8 -7
  148. package/esm5/src/render3/instructions/listener.js +13 -13
  149. package/esm5/src/render3/instructions/lview_debug.js +56 -15
  150. package/esm5/src/render3/instructions/projection.js +6 -5
  151. package/esm5/src/render3/instructions/property.js +17 -6
  152. package/esm5/src/render3/instructions/property_interpolation.js +32 -24
  153. package/esm5/src/render3/instructions/shared.js +258 -210
  154. package/esm5/src/render3/instructions/storage.js +4 -6
  155. package/esm5/src/render3/instructions/style_prop_interpolation.js +12 -12
  156. package/esm5/src/render3/instructions/styling.js +685 -367
  157. package/esm5/src/render3/instructions/text.js +5 -5
  158. package/esm5/src/render3/interfaces/definition.js +1 -1
  159. package/esm5/src/render3/interfaces/node.js +49 -1
  160. package/esm5/src/render3/interfaces/styling.js +57 -1
  161. package/esm5/src/render3/interfaces/view.js +1 -1
  162. package/esm5/src/render3/jit/environment.js +1 -3
  163. package/esm5/src/render3/namespaces.js +10 -0
  164. package/esm5/src/render3/node_manipulation.js +167 -54
  165. package/esm5/src/render3/node_selector_matcher.js +113 -20
  166. package/esm5/src/render3/node_util.js +12 -7
  167. package/esm5/src/render3/pipe.js +10 -14
  168. package/esm5/src/render3/pure_function.js +103 -33
  169. package/esm5/src/render3/query.js +25 -24
  170. package/esm5/src/render3/state.js +37 -133
  171. package/esm5/src/render3/styling/class_differ.js +39 -0
  172. package/esm5/src/render3/styling/static_styling.js +42 -0
  173. package/esm5/src/render3/styling/style_binding_list.js +411 -0
  174. package/esm5/src/render3/styling/styling_parser.js +265 -0
  175. package/esm5/src/render3/tokens.js +2 -2
  176. package/esm5/src/render3/util/attrs_utils.js +117 -2
  177. package/esm5/src/render3/util/change_detection_utils.js +23 -0
  178. package/esm5/src/render3/util/discovery_utils.js +115 -99
  179. package/esm5/src/render3/util/global_utils.js +5 -5
  180. package/esm5/src/render3/util/view_utils.js +5 -5
  181. package/esm5/src/render3/view_engine_compatibility.js +37 -39
  182. package/esm5/src/render3/view_ref.js +14 -13
  183. package/esm5/src/sanitization/bypass.js +1 -1
  184. package/esm5/src/sanitization/sanitization.js +16 -5
  185. package/esm5/src/util/array_utils.js +240 -1
  186. package/esm5/src/util/assert.js +37 -21
  187. package/esm5/src/util/char_code.js +8 -0
  188. package/esm5/src/util/iterable.js +4 -1
  189. package/esm5/src/util/ng_dev_mode.js +1 -12
  190. package/esm5/src/util/stringify.js +14 -1
  191. package/esm5/src/version.js +1 -1
  192. package/esm5/src/view/services.js +1 -1
  193. package/esm5/testing/src/r3_test_bed.js +9 -1
  194. package/esm5/testing/src/r3_test_bed_compiler.js +9 -15
  195. package/esm5/testing/src/styling.js +82 -0
  196. package/fesm2015/core.js +6431 -7075
  197. package/fesm2015/core.js.map +1 -1
  198. package/fesm2015/testing.js +10 -14
  199. package/fesm2015/testing.js.map +1 -1
  200. package/fesm5/core.js +6354 -6361
  201. package/fesm5/core.js.map +1 -1
  202. package/fesm5/testing.js +18 -16
  203. package/fesm5/testing.js.map +1 -1
  204. package/package.json +1 -1
  205. package/src/r3_symbols.d.ts +46 -23
  206. package/testing/testing.d.ts +3 -5
  207. package/testing/testing.metadata.json +1 -1
  208. package/testing.d.ts +2 -2
  209. package/esm2015/global.js +0 -7
  210. package/esm2015/src/render3/instructions/alloc_host_vars.js +0 -80
  211. package/esm2015/src/render3/styling/bindings.js +0 -1248
  212. package/esm2015/src/render3/styling/map_based_bindings.js +0 -384
  213. package/esm2015/src/render3/styling/state.js +0 -135
  214. package/esm2015/src/render3/styling/styling_debug.js +0 -655
  215. package/esm2015/src/render3/util/styling_utils.js +0 -625
  216. package/esm5/global.js +0 -9
  217. package/esm5/src/render3/instructions/alloc_host_vars.js +0 -62
  218. package/esm5/src/render3/styling/bindings.js +0 -949
  219. package/esm5/src/render3/styling/map_based_bindings.js +0 -310
  220. package/esm5/src/render3/styling/state.js +0 -56
  221. package/esm5/src/render3/styling/styling_debug.js +0 -315
  222. package/esm5/src/render3/util/styling_utils.js +0 -378
@@ -0,0 +1,336 @@
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * Generated from: packages/core/src/render3/styling/styling_parser.ts
4
+ * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
+ */
6
+ /**
7
+ * @license
8
+ * Copyright Google Inc. All Rights Reserved.
9
+ *
10
+ * Use of this source code is governed by an MIT-style license that can be
11
+ * found in the LICENSE file at https://angular.io/license
12
+ */
13
+ import { assertEqual, throwError } from '../../util/assert';
14
+ /**
15
+ * Stores the locations of key/value indexes while parsing styling.
16
+ *
17
+ * In case of `cssText` parsing the indexes are like so:
18
+ * ```
19
+ * "key1: value1; key2: value2; key3: value3"
20
+ * ^ ^ ^ ^ ^
21
+ * | | | | +-- textEnd
22
+ * | | | +---------------- valueEnd
23
+ * | | +---------------------- value
24
+ * | +------------------------ keyEnd
25
+ * +---------------------------- key
26
+ * ```
27
+ *
28
+ * In case of `className` parsing the indexes are like so:
29
+ * ```
30
+ * "key1 key2 key3"
31
+ * ^ ^ ^
32
+ * | | +-- textEnd
33
+ * | +------------------------ keyEnd
34
+ * +---------------------------- key
35
+ * ```
36
+ * NOTE: `value` and `valueEnd` are used only for styles, not classes.
37
+ * @record
38
+ */
39
+ function ParserState() { }
40
+ if (false) {
41
+ /** @type {?} */
42
+ ParserState.prototype.textEnd;
43
+ /** @type {?} */
44
+ ParserState.prototype.key;
45
+ /** @type {?} */
46
+ ParserState.prototype.keyEnd;
47
+ /** @type {?} */
48
+ ParserState.prototype.value;
49
+ /** @type {?} */
50
+ ParserState.prototype.valueEnd;
51
+ }
52
+ // Global state of the parser. (This makes parser non-reentrant, but that is not an issue)
53
+ /** @type {?} */
54
+ const parserState = {
55
+ textEnd: 0,
56
+ key: 0,
57
+ keyEnd: 0,
58
+ value: 0,
59
+ valueEnd: 0,
60
+ };
61
+ /**
62
+ * Retrieves the last parsed `key` of style.
63
+ * @param {?} text the text to substring the key from.
64
+ * @return {?}
65
+ */
66
+ export function getLastParsedKey(text) {
67
+ return text.substring(parserState.key, parserState.keyEnd);
68
+ }
69
+ /**
70
+ * Retrieves the last parsed `value` of style.
71
+ * @param {?} text the text to substring the key from.
72
+ * @return {?}
73
+ */
74
+ export function getLastParsedValue(text) {
75
+ return text.substring(parserState.value, parserState.valueEnd);
76
+ }
77
+ /**
78
+ * Initializes `className` string for parsing and parses the first token.
79
+ *
80
+ * This function is intended to be used in this format:
81
+ * ```
82
+ * for (let i = parseClassName(text); i >= 0; i = parseClassNameNext(text, i)) {
83
+ * const key = getLastParsedKey();
84
+ * ...
85
+ * }
86
+ * ```
87
+ * @param {?} text `className` to parse
88
+ * @return {?} index where the next invocation of `parseClassNameNext` should resume.
89
+ */
90
+ export function parseClassName(text) {
91
+ resetParserState(text);
92
+ return parseClassNameNext(text, consumeWhitespace(text, 0, parserState.textEnd));
93
+ }
94
+ /**
95
+ * Parses next `className` token.
96
+ *
97
+ * This function is intended to be used in this format:
98
+ * ```
99
+ * for (let i = parseClassName(text); i >= 0; i = parseClassNameNext(text, i)) {
100
+ * const key = getLastParsedKey();
101
+ * ...
102
+ * }
103
+ * ```
104
+ *
105
+ * @param {?} text `className` to parse
106
+ * @param {?} index where the parsing should resume.
107
+ * @return {?} index where the next invocation of `parseClassNameNext` should resume.
108
+ */
109
+ export function parseClassNameNext(text, index) {
110
+ /** @type {?} */
111
+ const end = parserState.textEnd;
112
+ if (end === index) {
113
+ return -1;
114
+ }
115
+ index = parserState.keyEnd = consumeClassToken(text, parserState.key = index, end);
116
+ return consumeWhitespace(text, index, end);
117
+ }
118
+ /**
119
+ * Initializes `cssText` string for parsing and parses the first key/values.
120
+ *
121
+ * This function is intended to be used in this format:
122
+ * ```
123
+ * for (let i = parseStyle(text); i >= 0; i = parseStyleNext(text, i))) {
124
+ * const key = getLastParsedKey();
125
+ * const value = getLastParsedValue();
126
+ * ...
127
+ * }
128
+ * ```
129
+ * @param {?} text `cssText` to parse
130
+ * @return {?} index where the next invocation of `parseStyleNext` should resume.
131
+ */
132
+ export function parseStyle(text) {
133
+ resetParserState(text);
134
+ return parseStyleNext(text, consumeWhitespace(text, 0, parserState.textEnd));
135
+ }
136
+ /**
137
+ * Parses the next `cssText` key/values.
138
+ *
139
+ * This function is intended to be used in this format:
140
+ * ```
141
+ * for (let i = parseStyle(text); i >= 0; i = parseStyleNext(text, i))) {
142
+ * const key = getLastParsedKey();
143
+ * const value = getLastParsedValue();
144
+ * ...
145
+ * }
146
+ *
147
+ * @param {?} text `cssText` to parse
148
+ * @param {?} startIndex
149
+ * @return {?} index where the next invocation of `parseStyleNext` should resume.
150
+ */
151
+ export function parseStyleNext(text, startIndex) {
152
+ /** @type {?} */
153
+ const end = parserState.textEnd;
154
+ /** @type {?} */
155
+ let index = parserState.key = consumeWhitespace(text, startIndex, end);
156
+ if (end === index) {
157
+ // we reached an end so just quit
158
+ return -1;
159
+ }
160
+ index = parserState.keyEnd = consumeStyleKey(text, index, end);
161
+ index = consumeSeparator(text, index, end, 58 /* COLON */);
162
+ index = parserState.value = consumeWhitespace(text, index, end);
163
+ index = parserState.valueEnd = consumeStyleValue(text, index, end);
164
+ return consumeSeparator(text, index, end, 59 /* SEMI_COLON */);
165
+ }
166
+ /**
167
+ * Reset the global state of the styling parser.
168
+ * @param {?} text The styling text to parse.
169
+ * @return {?}
170
+ */
171
+ export function resetParserState(text) {
172
+ parserState.key = 0;
173
+ parserState.keyEnd = 0;
174
+ parserState.value = 0;
175
+ parserState.valueEnd = 0;
176
+ parserState.textEnd = text.length;
177
+ }
178
+ /**
179
+ * Returns index of next non-whitespace character.
180
+ *
181
+ * @param {?} text Text to scan
182
+ * @param {?} startIndex Starting index of character where the scan should start.
183
+ * @param {?} endIndex Ending index of character where the scan should end.
184
+ * @return {?} Index of next non-whitespace character (May be the same as `start` if no whitespace at
185
+ * that location.)
186
+ */
187
+ export function consumeWhitespace(text, startIndex, endIndex) {
188
+ while (startIndex < endIndex && text.charCodeAt(startIndex) <= 32 /* SPACE */) {
189
+ startIndex++;
190
+ }
191
+ return startIndex;
192
+ }
193
+ /**
194
+ * Returns index of last char in class token.
195
+ *
196
+ * @param {?} text Text to scan
197
+ * @param {?} startIndex Starting index of character where the scan should start.
198
+ * @param {?} endIndex Ending index of character where the scan should end.
199
+ * @return {?} Index after last char in class token.
200
+ */
201
+ export function consumeClassToken(text, startIndex, endIndex) {
202
+ while (startIndex < endIndex && text.charCodeAt(startIndex) > 32 /* SPACE */) {
203
+ startIndex++;
204
+ }
205
+ return startIndex;
206
+ }
207
+ /**
208
+ * Consumes all of the characters belonging to style key and token.
209
+ *
210
+ * @param {?} text Text to scan
211
+ * @param {?} startIndex Starting index of character where the scan should start.
212
+ * @param {?} endIndex Ending index of character where the scan should end.
213
+ * @return {?} Index after last style key character.
214
+ */
215
+ export function consumeStyleKey(text, startIndex, endIndex) {
216
+ /** @type {?} */
217
+ let ch;
218
+ while (startIndex < endIndex &&
219
+ ((ch = text.charCodeAt(startIndex)) === 45 /* DASH */ || ch === 95 /* UNDERSCORE */ ||
220
+ ((ch & -33 /* UPPER_CASE */) >= 65 /* A */ && (ch & -33 /* UPPER_CASE */) <= 90 /* Z */))) {
221
+ startIndex++;
222
+ }
223
+ return startIndex;
224
+ }
225
+ /**
226
+ * Consumes all whitespace and the separator `:` after the style key.
227
+ *
228
+ * @param {?} text Text to scan
229
+ * @param {?} startIndex Starting index of character where the scan should start.
230
+ * @param {?} endIndex Ending index of character where the scan should end.
231
+ * @param {?} separator
232
+ * @return {?} Index after separator and surrounding whitespace.
233
+ */
234
+ export function consumeSeparator(text, startIndex, endIndex, separator) {
235
+ startIndex = consumeWhitespace(text, startIndex, endIndex);
236
+ if (startIndex < endIndex) {
237
+ if (ngDevMode && text.charCodeAt(startIndex) !== separator) {
238
+ malformedStyleError(text, String.fromCharCode(separator), startIndex);
239
+ }
240
+ startIndex++;
241
+ }
242
+ return startIndex;
243
+ }
244
+ /**
245
+ * Consumes style value honoring `url()` and `""` text.
246
+ *
247
+ * @param {?} text Text to scan
248
+ * @param {?} startIndex Starting index of character where the scan should start.
249
+ * @param {?} endIndex Ending index of character where the scan should end.
250
+ * @return {?} Index after last style value character.
251
+ */
252
+ export function consumeStyleValue(text, startIndex, endIndex) {
253
+ /** @type {?} */
254
+ let ch1 = -1;
255
+ // 1st previous character
256
+ /** @type {?} */
257
+ let ch2 = -1;
258
+ // 2nd previous character
259
+ /** @type {?} */
260
+ let ch3 = -1;
261
+ // 3rd previous character
262
+ /** @type {?} */
263
+ let i = startIndex;
264
+ /** @type {?} */
265
+ let lastChIndex = i;
266
+ while (i < endIndex) {
267
+ /** @type {?} */
268
+ const ch = text.charCodeAt(i++);
269
+ if (ch === 59 /* SEMI_COLON */) {
270
+ return lastChIndex;
271
+ }
272
+ else if (ch === 34 /* DOUBLE_QUOTE */ || ch === 39 /* SINGLE_QUOTE */) {
273
+ lastChIndex = i = consumeQuotedText(text, ch, i, endIndex);
274
+ }
275
+ else if (startIndex ===
276
+ i - 4 && // We have seen only 4 characters so far "URL(" (Ignore "foo_URL()")
277
+ ch3 === 85 /* U */ &&
278
+ ch2 === 82 /* R */ && ch1 === 76 /* L */ && ch === 40 /* OPEN_PAREN */) {
279
+ lastChIndex = i = consumeQuotedText(text, 41 /* CLOSE_PAREN */, i, endIndex);
280
+ }
281
+ else if (ch > 32 /* SPACE */) {
282
+ // if we have a non-whitespace character then capture its location
283
+ lastChIndex = i;
284
+ }
285
+ ch3 = ch2;
286
+ ch2 = ch1;
287
+ ch1 = ch & -33 /* UPPER_CASE */;
288
+ }
289
+ return lastChIndex;
290
+ }
291
+ /**
292
+ * Consumes all of the quoted characters.
293
+ *
294
+ * @param {?} text Text to scan
295
+ * @param {?} quoteCharCode CharCode of either `"` or `'` quote or `)` for `url(...)`.
296
+ * @param {?} startIndex Starting index of character where the scan should start.
297
+ * @param {?} endIndex Ending index of character where the scan should end.
298
+ * @return {?} Index after quoted characters.
299
+ */
300
+ export function consumeQuotedText(text, quoteCharCode, startIndex, endIndex) {
301
+ /** @type {?} */
302
+ let ch1 = -1;
303
+ // 1st previous character
304
+ /** @type {?} */
305
+ let index = startIndex;
306
+ while (index < endIndex) {
307
+ /** @type {?} */
308
+ const ch = text.charCodeAt(index++);
309
+ if (ch == quoteCharCode && ch1 !== 92 /* BACK_SLASH */) {
310
+ return index;
311
+ }
312
+ if (ch == 92 /* BACK_SLASH */ && ch1 === 92 /* BACK_SLASH */) {
313
+ // two back slashes cancel each other out. For example `"\\"` should properly end the
314
+ // quotation. (It should not assume that the last `"` is escaped.)
315
+ ch1 = 0;
316
+ }
317
+ else {
318
+ ch1 = ch;
319
+ }
320
+ }
321
+ throw ngDevMode ? malformedStyleError(text, String.fromCharCode(quoteCharCode), endIndex) :
322
+ new Error();
323
+ }
324
+ /**
325
+ * @param {?} text
326
+ * @param {?} expecting
327
+ * @param {?} index
328
+ * @return {?}
329
+ */
330
+ function malformedStyleError(text, expecting, index) {
331
+ ngDevMode && assertEqual(typeof text === 'string', true, 'String expected here');
332
+ throw throwError(`Malformed style at location ${index} in string '` + text.substring(0, index) + '[>>' +
333
+ text.substring(index, index + 1) + '<<]' + text.substr(index + 1) +
334
+ `'. Expecting '${expecting}'.`);
335
+ }
336
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling_parser.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/styling/styling_parser.ts"],"names":[],"mappings":";;;;;;;;;;;;AAQA,OAAO,EAAC,WAAW,EAAE,UAAU,EAAC,MAAM,mBAAmB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;AA2B1D,0BAMC;;;IALC,8BAAgB;;IAChB,0BAAY;;IACZ,6BAAe;;IACf,4BAAc;;IACd,+BAAiB;;;;MAGb,WAAW,GAAgB;IAC/B,OAAO,EAAE,CAAC;IACV,GAAG,EAAE,CAAC;IACN,MAAM,EAAE,CAAC;IACT,KAAK,EAAE,CAAC;IACR,QAAQ,EAAE,CAAC;CACZ;;;;;;AAMD,MAAM,UAAU,gBAAgB,CAAC,IAAY;IAC3C,OAAO,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,GAAG,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;AAC7D,CAAC;;;;;;AAMD,MAAM,UAAU,kBAAkB,CAAC,IAAY;IAC7C,OAAO,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,KAAK,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;AACjE,CAAC;;;;;;;;;;;;;;AAeD,MAAM,UAAU,cAAc,CAAC,IAAY;IACzC,gBAAgB,CAAC,IAAI,CAAC,CAAC;IACvB,OAAO,kBAAkB,CAAC,IAAI,EAAE,iBAAiB,CAAC,IAAI,EAAE,CAAC,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;AACnF,CAAC;;;;;;;;;;;;;;;;AAiBD,MAAM,UAAU,kBAAkB,CAAC,IAAY,EAAE,KAAa;;UACtD,GAAG,GAAG,WAAW,CAAC,OAAO;IAC/B,IAAI,GAAG,KAAK,KAAK,EAAE;QACjB,OAAO,CAAC,CAAC,CAAC;KACX;IACD,KAAK,GAAG,WAAW,CAAC,MAAM,GAAG,iBAAiB,CAAC,IAAI,EAAE,WAAW,CAAC,GAAG,GAAG,KAAK,EAAE,GAAG,CAAC,CAAC;IACnF,OAAO,iBAAiB,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;AAC7C,CAAC;;;;;;;;;;;;;;;AAgBD,MAAM,UAAU,UAAU,CAAC,IAAY;IACrC,gBAAgB,CAAC,IAAI,CAAC,CAAC;IACvB,OAAO,cAAc,CAAC,IAAI,EAAE,iBAAiB,CAAC,IAAI,EAAE,CAAC,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC;AAC/E,CAAC;;;;;;;;;;;;;;;;AAiBD,MAAM,UAAU,cAAc,CAAC,IAAY,EAAE,UAAkB;;UACvD,GAAG,GAAG,WAAW,CAAC,OAAO;;QAC3B,KAAK,GAAG,WAAW,CAAC,GAAG,GAAG,iBAAiB,CAAC,IAAI,EAAE,UAAU,EAAE,GAAG,CAAC;IACtE,IAAI,GAAG,KAAK,KAAK,EAAE;QACjB,iCAAiC;QACjC,OAAO,CAAC,CAAC,CAAC;KACX;IACD,KAAK,GAAG,WAAW,CAAC,MAAM,GAAG,eAAe,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;IAC/D,KAAK,GAAG,gBAAgB,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,iBAAiB,CAAC;IAC3D,KAAK,GAAG,WAAW,CAAC,KAAK,GAAG,iBAAiB,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;IAChE,KAAK,GAAG,WAAW,CAAC,QAAQ,GAAG,iBAAiB,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;IACnE,OAAO,gBAAgB,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,sBAAsB,CAAC;AACjE,CAAC;;;;;;AAMD,MAAM,UAAU,gBAAgB,CAAC,IAAY;IAC3C,WAAW,CAAC,GAAG,GAAG,CAAC,CAAC;IACpB,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;IACvB,WAAW,CAAC,KAAK,GAAG,CAAC,CAAC;IACtB,WAAW,CAAC,QAAQ,GAAG,CAAC,CAAC;IACzB,WAAW,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC;AACpC,CAAC;;;;;;;;;;AAWD,MAAM,UAAU,iBAAiB,CAAC,IAAY,EAAE,UAAkB,EAAE,QAAgB;IAClF,OAAO,UAAU,GAAG,QAAQ,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,kBAAkB,EAAE;QAC7E,UAAU,EAAE,CAAC;KACd;IACD,OAAO,UAAU,CAAC;AACpB,CAAC;;;;;;;;;AAUD,MAAM,UAAU,iBAAiB,CAAC,IAAY,EAAE,UAAkB,EAAE,QAAgB;IAClF,OAAO,UAAU,GAAG,QAAQ,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,iBAAiB,EAAE;QAC5E,UAAU,EAAE,CAAC;KACd;IACD,OAAO,UAAU,CAAC;AACpB,CAAC;;;;;;;;;AAUD,MAAM,UAAU,eAAe,CAAC,IAAY,EAAE,UAAkB,EAAE,QAAgB;;QAC5E,EAAU;IACd,OAAO,UAAU,GAAG,QAAQ;QACrB,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,kBAAkB,IAAI,EAAE,wBAAwB;YAClF,CAAC,CAAC,EAAE,uBAAsB,CAAC,cAAc,IAAI,CAAC,EAAE,uBAAsB,CAAC,cAAc,CAAC,CAAC,EAAE;QAC/F,UAAU,EAAE,CAAC;KACd;IACD,OAAO,UAAU,CAAC;AACpB,CAAC;;;;;;;;;;AAUD,MAAM,UAAU,gBAAgB,CAC5B,IAAY,EAAE,UAAkB,EAAE,QAAgB,EAAE,SAAiB;IACvE,UAAU,GAAG,iBAAiB,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;IAC3D,IAAI,UAAU,GAAG,QAAQ,EAAE;QACzB,IAAI,SAAS,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,SAAS,EAAE;YAC1D,mBAAmB,CAAC,IAAI,EAAE,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,UAAU,CAAC,CAAC;SACvE;QACD,UAAU,EAAE,CAAC;KACd;IACD,OAAO,UAAU,CAAC;AACpB,CAAC;;;;;;;;;AAWD,MAAM,UAAU,iBAAiB,CAAC,IAAY,EAAE,UAAkB,EAAE,QAAgB;;QAC9E,GAAG,GAAG,CAAC,CAAC;;;QACR,GAAG,GAAG,CAAC,CAAC;;;QACR,GAAG,GAAG,CAAC,CAAC;;;QACR,CAAC,GAAG,UAAU;;QACd,WAAW,GAAG,CAAC;IACnB,OAAO,CAAC,GAAG,QAAQ,EAAE;;cACb,EAAE,GAAW,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC;QACvC,IAAI,EAAE,wBAAwB,EAAE;YAC9B,OAAO,WAAW,CAAC;SACpB;aAAM,IAAI,EAAE,0BAA0B,IAAI,EAAE,0BAA0B,EAAE;YACvE,WAAW,GAAG,CAAC,GAAG,iBAAiB,CAAC,IAAI,EAAE,EAAE,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;SAC5D;aAAM,IACH,UAAU;YACN,CAAC,GAAG,CAAC,IAAK,oEAAoE;YAClF,GAAG,eAAe;YAClB,GAAG,eAAe,IAAI,GAAG,eAAe,IAAI,EAAE,wBAAwB,EAAE;YAC1E,WAAW,GAAG,CAAC,GAAG,iBAAiB,CAAC,IAAI,wBAAwB,CAAC,EAAE,QAAQ,CAAC,CAAC;SAC9E;aAAM,IAAI,EAAE,iBAAiB,EAAE;YAC9B,kEAAkE;YAClE,WAAW,GAAG,CAAC,CAAC;SACjB;QACD,GAAG,GAAG,GAAG,CAAC;QACV,GAAG,GAAG,GAAG,CAAC;QACV,GAAG,GAAG,EAAE,uBAAsB,CAAC;KAChC;IACD,OAAO,WAAW,CAAC;AACrB,CAAC;;;;;;;;;;AAWD,MAAM,UAAU,iBAAiB,CAC7B,IAAY,EAAE,aAAqB,EAAE,UAAkB,EAAE,QAAgB;;QACvE,GAAG,GAAG,CAAC,CAAC;;;QACR,KAAK,GAAG,UAAU;IACtB,OAAO,KAAK,GAAG,QAAQ,EAAE;;cACjB,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;QACnC,IAAI,EAAE,IAAI,aAAa,IAAI,GAAG,wBAAwB,EAAE;YACtD,OAAO,KAAK,CAAC;SACd;QACD,IAAI,EAAE,uBAAuB,IAAI,GAAG,wBAAwB,EAAE;YAC5D,qFAAqF;YACrF,kEAAkE;YAClE,GAAG,GAAG,CAAC,CAAC;SACT;aAAM;YACL,GAAG,GAAG,EAAE,CAAC;SACV;KACF;IACD,MAAM,SAAS,CAAC,CAAC,CAAC,mBAAmB,CAAC,IAAI,EAAE,MAAM,CAAC,YAAY,CAAC,aAAa,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC;QACzE,IAAI,KAAK,EAAE,CAAC;AAChC,CAAC;;;;;;;AAED,SAAS,mBAAmB,CAAC,IAAY,EAAE,SAAiB,EAAE,KAAa;IACzE,SAAS,IAAI,WAAW,CAAC,OAAO,IAAI,KAAK,QAAQ,EAAE,IAAI,EAAE,sBAAsB,CAAC,CAAC;IACjF,MAAM,UAAU,CACZ,+BAA+B,KAAK,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,KAAK;QACrF,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,GAAG,CAAC,CAAC,GAAG,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC;QACjE,iBAAiB,SAAS,IAAI,CAAC,CAAC;AACtC,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {assertEqual, throwError} from '../../util/assert';\nimport {CharCode} from '../../util/char_code';\n\n/**\n * Stores the locations of key/value indexes while parsing styling.\n *\n * In case of `cssText` parsing the indexes are like so:\n * ```\n *   \"key1: value1; key2: value2; key3: value3\"\n *                  ^   ^ ^     ^             ^\n *                  |   | |     |             +-- textEnd\n *                  |   | |     +---------------- valueEnd\n *                  |   | +---------------------- value\n *                  |   +------------------------ keyEnd\n *                  +---------------------------- key\n * ```\n *\n * In case of `className` parsing the indexes are like so:\n * ```\n *   \"key1 key2 key3\"\n *         ^   ^    ^\n *         |   |    +-- textEnd\n *         |   +------------------------ keyEnd\n *         +---------------------------- key\n * ```\n * NOTE: `value` and `valueEnd` are used only for styles, not classes.\n */\ninterface ParserState {\n  textEnd: number;\n  key: number;\n  keyEnd: number;\n  value: number;\n  valueEnd: number;\n}\n// Global state of the parser. (This makes parser non-reentrant, but that is not an issue)\nconst parserState: ParserState = {\n  textEnd: 0,\n  key: 0,\n  keyEnd: 0,\n  value: 0,\n  valueEnd: 0,\n};\n\n/**\n * Retrieves the last parsed `key` of style.\n * @param text the text to substring the key from.\n */\nexport function getLastParsedKey(text: string): string {\n  return text.substring(parserState.key, parserState.keyEnd);\n}\n\n/**\n * Retrieves the last parsed `value` of style.\n * @param text the text to substring the key from.\n */\nexport function getLastParsedValue(text: string): string {\n  return text.substring(parserState.value, parserState.valueEnd);\n}\n\n/**\n * Initializes `className` string for parsing and parses the first token.\n *\n * This function is intended to be used in this format:\n * ```\n * for (let i = parseClassName(text); i >= 0; i = parseClassNameNext(text, i)) {\n *   const key = getLastParsedKey();\n *   ...\n * }\n * ```\n * @param text `className` to parse\n * @returns index where the next invocation of `parseClassNameNext` should resume.\n */\nexport function parseClassName(text: string): number {\n  resetParserState(text);\n  return parseClassNameNext(text, consumeWhitespace(text, 0, parserState.textEnd));\n}\n\n/**\n * Parses next `className` token.\n *\n * This function is intended to be used in this format:\n * ```\n * for (let i = parseClassName(text); i >= 0; i = parseClassNameNext(text, i)) {\n *   const key = getLastParsedKey();\n *   ...\n * }\n * ```\n *\n * @param text `className` to parse\n * @param index where the parsing should resume.\n * @returns index where the next invocation of `parseClassNameNext` should resume.\n */\nexport function parseClassNameNext(text: string, index: number): number {\n  const end = parserState.textEnd;\n  if (end === index) {\n    return -1;\n  }\n  index = parserState.keyEnd = consumeClassToken(text, parserState.key = index, end);\n  return consumeWhitespace(text, index, end);\n}\n\n/**\n * Initializes `cssText` string for parsing and parses the first key/values.\n *\n * This function is intended to be used in this format:\n * ```\n * for (let i = parseStyle(text); i >= 0; i = parseStyleNext(text, i))) {\n *   const key = getLastParsedKey();\n *   const value = getLastParsedValue();\n *   ...\n * }\n * ```\n * @param text `cssText` to parse\n * @returns index where the next invocation of `parseStyleNext` should resume.\n */\nexport function parseStyle(text: string): number {\n  resetParserState(text);\n  return parseStyleNext(text, consumeWhitespace(text, 0, parserState.textEnd));\n}\n\n/**\n * Parses the next `cssText` key/values.\n *\n * This function is intended to be used in this format:\n * ```\n * for (let i = parseStyle(text); i >= 0; i = parseStyleNext(text, i))) {\n *   const key = getLastParsedKey();\n *   const value = getLastParsedValue();\n *   ...\n * }\n *\n * @param text `cssText` to parse\n * @param index where the parsing should resume.\n * @returns index where the next invocation of `parseStyleNext` should resume.\n */\nexport function parseStyleNext(text: string, startIndex: number): number {\n  const end = parserState.textEnd;\n  let index = parserState.key = consumeWhitespace(text, startIndex, end);\n  if (end === index) {\n    // we reached an end so just quit\n    return -1;\n  }\n  index = parserState.keyEnd = consumeStyleKey(text, index, end);\n  index = consumeSeparator(text, index, end, CharCode.COLON);\n  index = parserState.value = consumeWhitespace(text, index, end);\n  index = parserState.valueEnd = consumeStyleValue(text, index, end);\n  return consumeSeparator(text, index, end, CharCode.SEMI_COLON);\n}\n\n/**\n * Reset the global state of the styling parser.\n * @param text The styling text to parse.\n */\nexport function resetParserState(text: string): void {\n  parserState.key = 0;\n  parserState.keyEnd = 0;\n  parserState.value = 0;\n  parserState.valueEnd = 0;\n  parserState.textEnd = text.length;\n}\n\n/**\n * Returns index of next non-whitespace character.\n *\n * @param text Text to scan\n * @param startIndex Starting index of character where the scan should start.\n * @param endIndex Ending index of character where the scan should end.\n * @returns Index of next non-whitespace character (May be the same as `start` if no whitespace at\n *          that location.)\n */\nexport function consumeWhitespace(text: string, startIndex: number, endIndex: number): number {\n  while (startIndex < endIndex && text.charCodeAt(startIndex) <= CharCode.SPACE) {\n    startIndex++;\n  }\n  return startIndex;\n}\n\n/**\n * Returns index of last char in class token.\n *\n * @param text Text to scan\n * @param startIndex Starting index of character where the scan should start.\n * @param endIndex Ending index of character where the scan should end.\n * @returns Index after last char in class token.\n */\nexport function consumeClassToken(text: string, startIndex: number, endIndex: number): number {\n  while (startIndex < endIndex && text.charCodeAt(startIndex) > CharCode.SPACE) {\n    startIndex++;\n  }\n  return startIndex;\n}\n\n/**\n * Consumes all of the characters belonging to style key and token.\n *\n * @param text Text to scan\n * @param startIndex Starting index of character where the scan should start.\n * @param endIndex Ending index of character where the scan should end.\n * @returns Index after last style key character.\n */\nexport function consumeStyleKey(text: string, startIndex: number, endIndex: number): number {\n  let ch: number;\n  while (startIndex < endIndex &&\n         ((ch = text.charCodeAt(startIndex)) === CharCode.DASH || ch === CharCode.UNDERSCORE ||\n          ((ch & CharCode.UPPER_CASE) >= CharCode.A && (ch & CharCode.UPPER_CASE) <= CharCode.Z))) {\n    startIndex++;\n  }\n  return startIndex;\n}\n\n/**\n * Consumes all whitespace and the separator `:` after the style key.\n *\n * @param text Text to scan\n * @param startIndex Starting index of character where the scan should start.\n * @param endIndex Ending index of character where the scan should end.\n * @returns Index after separator and surrounding whitespace.\n */\nexport function consumeSeparator(\n    text: string, startIndex: number, endIndex: number, separator: number): number {\n  startIndex = consumeWhitespace(text, startIndex, endIndex);\n  if (startIndex < endIndex) {\n    if (ngDevMode && text.charCodeAt(startIndex) !== separator) {\n      malformedStyleError(text, String.fromCharCode(separator), startIndex);\n    }\n    startIndex++;\n  }\n  return startIndex;\n}\n\n\n/**\n * Consumes style value honoring `url()` and `\"\"` text.\n *\n * @param text Text to scan\n * @param startIndex Starting index of character where the scan should start.\n * @param endIndex Ending index of character where the scan should end.\n * @returns Index after last style value character.\n*/\nexport function consumeStyleValue(text: string, startIndex: number, endIndex: number): number {\n  let ch1 = -1;  // 1st previous character\n  let ch2 = -1;  // 2nd previous character\n  let ch3 = -1;  // 3rd previous character\n  let i = startIndex;\n  let lastChIndex = i;\n  while (i < endIndex) {\n    const ch: number = text.charCodeAt(i++);\n    if (ch === CharCode.SEMI_COLON) {\n      return lastChIndex;\n    } else if (ch === CharCode.DOUBLE_QUOTE || ch === CharCode.SINGLE_QUOTE) {\n      lastChIndex = i = consumeQuotedText(text, ch, i, endIndex);\n    } else if (\n        startIndex ===\n            i - 4 &&  // We have seen only 4 characters so far \"URL(\" (Ignore \"foo_URL()\")\n        ch3 === CharCode.U &&\n        ch2 === CharCode.R && ch1 === CharCode.L && ch === CharCode.OPEN_PAREN) {\n      lastChIndex = i = consumeQuotedText(text, CharCode.CLOSE_PAREN, i, endIndex);\n    } else if (ch > CharCode.SPACE) {\n      // if we have a non-whitespace character then capture its location\n      lastChIndex = i;\n    }\n    ch3 = ch2;\n    ch2 = ch1;\n    ch1 = ch & CharCode.UPPER_CASE;\n  }\n  return lastChIndex;\n}\n\n/**\n * Consumes all of the quoted characters.\n *\n * @param text Text to scan\n * @param quoteCharCode CharCode of either `\"` or `'` quote or `)` for `url(...)`.\n * @param startIndex Starting index of character where the scan should start.\n * @param endIndex Ending index of character where the scan should end.\n * @returns Index after quoted characters.\n */\nexport function consumeQuotedText(\n    text: string, quoteCharCode: number, startIndex: number, endIndex: number): number {\n  let ch1 = -1;  // 1st previous character\n  let index = startIndex;\n  while (index < endIndex) {\n    const ch = text.charCodeAt(index++);\n    if (ch == quoteCharCode && ch1 !== CharCode.BACK_SLASH) {\n      return index;\n    }\n    if (ch == CharCode.BACK_SLASH && ch1 === CharCode.BACK_SLASH) {\n      // two back slashes cancel each other out. For example `\"\\\\\"` should properly end the\n      // quotation. (It should not assume that the last `\"` is escaped.)\n      ch1 = 0;\n    } else {\n      ch1 = ch;\n    }\n  }\n  throw ngDevMode ? malformedStyleError(text, String.fromCharCode(quoteCharCode), endIndex) :\n                    new Error();\n}\n\nfunction malformedStyleError(text: string, expecting: string, index: number): never {\n  ngDevMode && assertEqual(typeof text === 'string', true, 'String expected here');\n  throw throwError(\n      `Malformed style at location ${index} in string '` + text.substring(0, index) + '[>>' +\n      text.substring(index, index + 1) + '<<]' + text.substr(index + 1) +\n      `'. Expecting '${expecting}'.`);\n}\n"]}
@@ -15,5 +15,5 @@
15
15
  * A special value which designates that a value has not changed.
16
16
  * @type {?}
17
17
  */
18
- export const NO_CHANGE = (/** @type {?} */ ({}));
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvcmVuZGVyMy90b2tlbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFjQSxNQUFNLE9BQU8sU0FBUyxHQUFHLG1CQUFBLEVBQUUsRUFBYSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuZXhwb3J0IGludGVyZmFjZSBOT19DSEFOR0Uge1xuICAvLyBUaGlzIGlzIGEgYnJhbmQgdGhhdCBlbnN1cmVzIHRoYXQgdGhpcyB0eXBlIGNhbiBuZXZlciBtYXRjaCBhbnl0aGluZyBlbHNlXG4gIGJyYW5kOiAnTk9fQ0hBTkdFJztcbn1cblxuLyoqIEEgc3BlY2lhbCB2YWx1ZSB3aGljaCBkZXNpZ25hdGVzIHRoYXQgYSB2YWx1ZSBoYXMgbm90IGNoYW5nZWQuICovXG5leHBvcnQgY29uc3QgTk9fQ0hBTkdFID0ge30gYXMgTk9fQ0hBTkdFO1xuIl19
18
+ export const NO_CHANGE = (typeof ngDevMode === 'undefined' || ngDevMode) ? { __brand__: 'NO_CHANGE' } : ((/** @type {?} */ ({})));
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvcmVuZGVyMy90b2tlbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFjQSxNQUFNLE9BQU8sU0FBUyxHQUNsQixDQUFDLE9BQU8sU0FBUyxLQUFLLFdBQVcsSUFBSSxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBQyxTQUFTLEVBQUUsV0FBVyxFQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsbUJBQUEsRUFBRSxFQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmV4cG9ydCBpbnRlcmZhY2UgTk9fQ0hBTkdFIHtcbiAgLy8gVGhpcyBpcyBhIGJyYW5kIHRoYXQgZW5zdXJlcyB0aGF0IHRoaXMgdHlwZSBjYW4gbmV2ZXIgbWF0Y2ggYW55dGhpbmcgZWxzZVxuICBfX2JyYW5kX186ICdOT19DSEFOR0UnO1xufVxuXG4vKiogQSBzcGVjaWFsIHZhbHVlIHdoaWNoIGRlc2lnbmF0ZXMgdGhhdCBhIHZhbHVlIGhhcyBub3QgY2hhbmdlZC4gKi9cbmV4cG9ydCBjb25zdCBOT19DSEFOR0U6IE5PX0NIQU5HRSA9XG4gICAgKHR5cGVvZiBuZ0Rldk1vZGUgPT09ICd1bmRlZmluZWQnIHx8IG5nRGV2TW9kZSkgPyB7X19icmFuZF9fOiAnTk9fQ0hBTkdFJ30gOiAoe30gYXMgTk9fQ0hBTkdFKTtcbiJdfQ==
@@ -105,6 +105,129 @@ export function isAnimationProp(name) {
105
105
  // Perf note: accessing charCodeAt to check for the first character of a string is faster as
106
106
  // compared to accessing a character at index 0 (ex. name[0]). The main reason for this is that
107
107
  // charCodeAt doesn't allocate memory to return a substring.
108
- return name.charCodeAt(0) === 64; // @
108
+ return name.charCodeAt(0) === 64 /* AT_SIGN */;
109
109
  }
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attrs_utils.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/util/attrs_utils.ts"],"names":[],"mappings":";;;;;AASA,OAAO,EAA2C,oBAAoB,EAAC,MAAM,wBAAwB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8BtG,MAAM,UAAU,eAAe,CAAC,QAAmB,EAAE,MAAgB,EAAE,KAAkB;;UACjF,MAAM,GAAG,oBAAoB,CAAC,QAAQ,CAAC;;QAEzC,CAAC,GAAG,CAAC;IACT,OAAO,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE;;cACjB,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC;QACtB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,wEAAwE;YACxE,+CAA+C;YAC/C,IAAI,KAAK,yBAAiC,EAAE;gBAC1C,MAAM;aACP;YAED,mDAAmD;YACnD,mCAAmC;YACnC,CAAC,EAAE,CAAC;;kBAEE,YAAY,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;;kBACnC,QAAQ,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;;kBAC/B,OAAO,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;YACpC,SAAS,IAAI,SAAS,CAAC,oBAAoB,EAAE,CAAC;YAC9C,MAAM,CAAC,CAAC;gBACJ,CAAC,mBAAA,QAAQ,EAAuB,CAAC,CAAC,YAAY,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;gBACzF,MAAM,CAAC,cAAc,CAAC,YAAY,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;SAC5D;aAAM;;;kBAEC,QAAQ,GAAG,mBAAA,KAAK,EAAU;;kBAC1B,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;YAC1B,sBAAsB;YACtB,SAAS,IAAI,SAAS,CAAC,oBAAoB,EAAE,CAAC;YAC9C,IAAI,eAAe,CAAC,QAAQ,CAAC,EAAE;gBAC7B,IAAI,MAAM,EAAE;oBACV,CAAC,mBAAA,QAAQ,EAAuB,CAAC,CAAC,WAAW,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;iBAC1E;aACF;iBAAM;gBACL,MAAM,CAAC,CAAC;oBACJ,CAAC,mBAAA,QAAQ,EAAuB,CAAC,CAAC,YAAY,CAAC,MAAM,EAAE,QAAQ,EAAE,mBAAA,OAAO,EAAU,CAAC,CAAC,CAAC;oBACrF,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE,mBAAA,OAAO,EAAU,CAAC,CAAC;aACtD;YACD,CAAC,EAAE,CAAC;SACL;KACF;IAED,8EAA8E;IAC9E,+EAA+E;IAC/E,iFAAiF;IACjF,iBAAiB;IACjB,OAAO,CAAC,CAAC;AACX,CAAC;;;;;;;;AASD,MAAM,UAAU,yBAAyB,CAAC,MAA8C;IACtF,OAAO,MAAM,qBAA6B,IAAI,MAAM,qBAA6B;QAC7E,MAAM,iBAAyB,CAAC;AACtC,CAAC;;;;;AAED,MAAM,UAAU,eAAe,CAAC,IAAY;IAC1C,4FAA4F;IAC5F,+FAA+F;IAC/F,4DAA4D;IAC5D,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAE,IAAI;AACzC,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {AttributeMarker, TAttributes} from '../interfaces/node';\nimport {CssSelector} from '../interfaces/projection';\nimport {ProceduralRenderer3, RElement, Renderer3, isProceduralRenderer} from '../interfaces/renderer';\n\n\n/**\n * Assigns all attribute values to the provided element via the inferred renderer.\n *\n * This function accepts two forms of attribute entries:\n *\n * default: (key, value):\n *  attrs = [key1, value1, key2, value2]\n *\n * namespaced: (NAMESPACE_MARKER, uri, name, value)\n *  attrs = [NAMESPACE_MARKER, uri, name, value, NAMESPACE_MARKER, uri, name, value]\n *\n * The `attrs` array can contain a mix of both the default and namespaced entries.\n * The \"default\" values are set without a marker, but if the function comes across\n * a marker value then it will attempt to set a namespaced value. If the marker is\n * not of a namespaced value then the function will quit and return the index value\n * where it stopped during the iteration of the attrs array.\n *\n * See [AttributeMarker] to understand what the namespace marker value is.\n *\n * Note that this instruction does not support assigning style and class values to\n * an element. See `elementStart` and `elementHostAttrs` to learn how styling values\n * are applied to an element.\n * @param renderer The renderer to be used\n * @param native The element that the attributes will be assigned to\n * @param attrs The attribute array of values that will be assigned to the element\n * @returns the index value that was last accessed in the attributes array\n */\nexport function setUpAttributes(renderer: Renderer3, native: RElement, attrs: TAttributes): number {\n  const isProc = isProceduralRenderer(renderer);\n\n  let i = 0;\n  while (i < attrs.length) {\n    const value = attrs[i];\n    if (typeof value === 'number') {\n      // only namespaces are supported. Other value types (such as style/class\n      // entries) are not supported in this function.\n      if (value !== AttributeMarker.NamespaceURI) {\n        break;\n      }\n\n      // we just landed on the marker value ... therefore\n      // we should skip to the next entry\n      i++;\n\n      const namespaceURI = attrs[i++] as string;\n      const attrName = attrs[i++] as string;\n      const attrVal = attrs[i++] as string;\n      ngDevMode && ngDevMode.rendererSetAttribute++;\n      isProc ?\n          (renderer as ProceduralRenderer3).setAttribute(native, attrName, attrVal, namespaceURI) :\n          native.setAttributeNS(namespaceURI, attrName, attrVal);\n    } else {\n      // attrName is string;\n      const attrName = value as string;\n      const attrVal = attrs[++i];\n      // Standard attributes\n      ngDevMode && ngDevMode.rendererSetAttribute++;\n      if (isAnimationProp(attrName)) {\n        if (isProc) {\n          (renderer as ProceduralRenderer3).setProperty(native, attrName, attrVal);\n        }\n      } else {\n        isProc ?\n            (renderer as ProceduralRenderer3).setAttribute(native, attrName, attrVal as string) :\n            native.setAttribute(attrName, attrVal as string);\n      }\n      i++;\n    }\n  }\n\n  // another piece of code may iterate over the same attributes array. Therefore\n  // it may be helpful to return the exact spot where the attributes array exited\n  // whether by running into an unsupported marker or if all the static values were\n  // iterated over.\n  return i;\n}\n\n/**\n * Test whether the given value is a marker that indicates that the following\n * attribute values in a `TAttributes` array are only the names of attributes,\n * and not name-value pairs.\n * @param marker The attribute marker to test.\n * @returns true if the marker is a \"name-only\" marker (e.g. `Bindings`, `Template` or `I18n`).\n */\nexport function isNameOnlyAttributeMarker(marker: string | AttributeMarker | CssSelector) {\n  return marker === AttributeMarker.Bindings || marker === AttributeMarker.Template ||\n      marker === AttributeMarker.I18n;\n}\n\nexport function isAnimationProp(name: string): boolean {\n  // Perf note: accessing charCodeAt to check for the first character of a string is faster as\n  // compared to accessing a character at index 0 (ex. name[0]). The main reason for this is that\n  // charCodeAt doesn't allocate memory to return a substring.\n  return name.charCodeAt(0) === 64;  // @\n}\n"]}
110
+ /**
111
+ * Merges `src` `TAttributes` into `dst` `TAttributes` removing any duplicates in the process.
112
+ *
113
+ * This merge function keeps the order of attrs same.
114
+ *
115
+ * @param {?} dst Location of where the merged `TAttributes` should end up.
116
+ * @param {?} src `TAttributes` which should be appended to `dst`
117
+ * @return {?}
118
+ */
119
+ export function mergeHostAttrs(dst, src) {
120
+ if (src === null || src.length === 0) {
121
+ // do nothing
122
+ }
123
+ else if (dst === null || dst.length === 0) {
124
+ // We have source, but dst is empty, just make a copy.
125
+ dst = src.slice();
126
+ }
127
+ else {
128
+ /** @type {?} */
129
+ let srcMarker = -1 /* ImplicitAttributes */;
130
+ for (let i = 0; i < src.length; i++) {
131
+ /** @type {?} */
132
+ const item = src[i];
133
+ if (typeof item === 'number') {
134
+ srcMarker = item;
135
+ }
136
+ else {
137
+ if (srcMarker === 0 /* NamespaceURI */) {
138
+ // Case where we need to consume `key1`, `key2`, `value` items.
139
+ }
140
+ else if (srcMarker === -1 /* ImplicitAttributes */ ||
141
+ srcMarker === 2 /* Styles */) {
142
+ // Case where we have to consume `key1` and `value` only.
143
+ mergeHostAttribute(dst, srcMarker, (/** @type {?} */ (item)), null, (/** @type {?} */ (src[++i])));
144
+ }
145
+ else {
146
+ // Case where we have to consume `key1` only.
147
+ mergeHostAttribute(dst, srcMarker, (/** @type {?} */ (item)), null, null);
148
+ }
149
+ }
150
+ }
151
+ }
152
+ return dst;
153
+ }
154
+ /**
155
+ * Append `key`/`value` to existing `TAttributes` taking region marker and duplicates into account.
156
+ *
157
+ * @param {?} dst `TAttributes` to append to.
158
+ * @param {?} marker Region where the `key`/`value` should be added.
159
+ * @param {?} key1 Key to add to `TAttributes`
160
+ * @param {?} key2 Key to add to `TAttributes` (in case of `AttributeMarker.NamespaceURI`)
161
+ * @param {?} value Value to add or to overwrite to `TAttributes` Only used if `marker` is not Class.
162
+ * @return {?}
163
+ */
164
+ export function mergeHostAttribute(dst, marker, key1, key2, value) {
165
+ /** @type {?} */
166
+ let i = 0;
167
+ // Assume that new markers will be inserted at the end.
168
+ /** @type {?} */
169
+ let markerInsertPosition = dst.length;
170
+ // scan until correct type.
171
+ if (marker === -1 /* ImplicitAttributes */) {
172
+ markerInsertPosition = -1;
173
+ }
174
+ else {
175
+ while (i < dst.length) {
176
+ /** @type {?} */
177
+ const dstValue = dst[i++];
178
+ if (typeof dstValue === 'number') {
179
+ if (dstValue === marker) {
180
+ markerInsertPosition = -1;
181
+ break;
182
+ }
183
+ else if (dstValue > marker) {
184
+ // We need to save this as we want the markers to be inserted in specific order.
185
+ markerInsertPosition = i - 1;
186
+ break;
187
+ }
188
+ }
189
+ }
190
+ }
191
+ // search until you find place of insertion
192
+ while (i < dst.length) {
193
+ /** @type {?} */
194
+ const item = dst[i];
195
+ if (typeof item === 'number') {
196
+ // since `i` started as the index after the marker, we did not find it if we are at the next
197
+ // marker
198
+ break;
199
+ }
200
+ else if (item === key1) {
201
+ // We already have same token
202
+ if (key2 === null) {
203
+ if (value !== null) {
204
+ dst[i + 1] = value;
205
+ }
206
+ return;
207
+ }
208
+ else if (key2 === dst[i + 1]) {
209
+ dst[i + 2] = (/** @type {?} */ (value));
210
+ return;
211
+ }
212
+ }
213
+ // Increment counter.
214
+ i++;
215
+ if (key2 !== null)
216
+ i++;
217
+ if (value !== null)
218
+ i++;
219
+ }
220
+ // insert at location.
221
+ if (markerInsertPosition !== -1) {
222
+ dst.splice(markerInsertPosition, 0, marker);
223
+ i = markerInsertPosition + 1;
224
+ }
225
+ dst.splice(i++, 0, key1);
226
+ if (key2 !== null) {
227
+ dst.splice(i++, 0, key2);
228
+ }
229
+ if (value !== null) {
230
+ dst.splice(i++, 0, value);
231
+ }
232
+ }
233
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attrs_utils.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/util/attrs_utils.ts"],"names":[],"mappings":";;;;;AAUA,OAAO,EAA2C,oBAAoB,EAAC,MAAM,wBAAwB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+BtG,MAAM,UAAU,eAAe,CAAC,QAAmB,EAAE,MAAgB,EAAE,KAAkB;;UACjF,MAAM,GAAG,oBAAoB,CAAC,QAAQ,CAAC;;QAEzC,CAAC,GAAG,CAAC;IACT,OAAO,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE;;cACjB,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC;QACtB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,wEAAwE;YACxE,+CAA+C;YAC/C,IAAI,KAAK,yBAAiC,EAAE;gBAC1C,MAAM;aACP;YAED,mDAAmD;YACnD,mCAAmC;YACnC,CAAC,EAAE,CAAC;;kBAEE,YAAY,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;;kBACnC,QAAQ,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;;kBAC/B,OAAO,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;YACpC,SAAS,IAAI,SAAS,CAAC,oBAAoB,EAAE,CAAC;YAC9C,MAAM,CAAC,CAAC;gBACJ,CAAC,mBAAA,QAAQ,EAAuB,CAAC,CAAC,YAAY,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;gBACzF,MAAM,CAAC,cAAc,CAAC,YAAY,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;SAC5D;aAAM;;;kBAEC,QAAQ,GAAG,mBAAA,KAAK,EAAU;;kBAC1B,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;YAC1B,sBAAsB;YACtB,SAAS,IAAI,SAAS,CAAC,oBAAoB,EAAE,CAAC;YAC9C,IAAI,eAAe,CAAC,QAAQ,CAAC,EAAE;gBAC7B,IAAI,MAAM,EAAE;oBACV,CAAC,mBAAA,QAAQ,EAAuB,CAAC,CAAC,WAAW,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;iBAC1E;aACF;iBAAM;gBACL,MAAM,CAAC,CAAC;oBACJ,CAAC,mBAAA,QAAQ,EAAuB,CAAC,CAAC,YAAY,CAAC,MAAM,EAAE,QAAQ,EAAE,mBAAA,OAAO,EAAU,CAAC,CAAC,CAAC;oBACrF,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE,mBAAA,OAAO,EAAU,CAAC,CAAC;aACtD;YACD,CAAC,EAAE,CAAC;SACL;KACF;IAED,8EAA8E;IAC9E,+EAA+E;IAC/E,iFAAiF;IACjF,iBAAiB;IACjB,OAAO,CAAC,CAAC;AACX,CAAC;;;;;;;;AASD,MAAM,UAAU,yBAAyB,CAAC,MAA8C;IACtF,OAAO,MAAM,qBAA6B,IAAI,MAAM,qBAA6B;QAC7E,MAAM,iBAAyB,CAAC;AACtC,CAAC;;;;;AAED,MAAM,UAAU,eAAe,CAAC,IAAY;IAC1C,4FAA4F;IAC5F,+FAA+F;IAC/F,4DAA4D;IAC5D,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,qBAAqB,CAAC;AACjD,CAAC;;;;;;;;;;AAUD,MAAM,UAAU,cAAc,CAAC,GAAuB,EAAE,GAAuB;IAC7E,IAAI,GAAG,KAAK,IAAI,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE;QACpC,aAAa;KACd;SAAM,IAAI,GAAG,KAAK,IAAI,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE;QAC3C,sDAAsD;QACtD,GAAG,GAAG,GAAG,CAAC,KAAK,EAAE,CAAC;KACnB;SAAM;;YACD,SAAS,8BAAsD;QACnE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;;kBAC7B,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC;YACnB,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;gBAC5B,SAAS,GAAG,IAAI,CAAC;aAClB;iBAAM;gBACL,IAAI,SAAS,yBAAiC,EAAE;oBAC9C,+DAA+D;iBAChE;qBAAM,IACH,SAAS,gCAAuC;oBAChD,SAAS,mBAA2B,EAAE;oBACxC,yDAAyD;oBACzD,kBAAkB,CAAC,GAAG,EAAE,SAAS,EAAE,mBAAA,IAAI,EAAU,EAAE,IAAI,EAAE,mBAAA,GAAG,CAAC,EAAE,CAAC,CAAC,EAAU,CAAC,CAAC;iBAC9E;qBAAM;oBACL,6CAA6C;oBAC7C,kBAAkB,CAAC,GAAG,EAAE,SAAS,EAAE,mBAAA,IAAI,EAAU,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;iBAChE;aACF;SACF;KACF;IACD,OAAO,GAAG,CAAC;AACb,CAAC;;;;;;;;;;;AAWD,MAAM,UAAU,kBAAkB,CAC9B,GAAgB,EAAE,MAAuB,EAAE,IAAY,EAAE,IAAmB,EAC5E,KAAoB;;QAClB,CAAC,GAAG,CAAC;;;QAEL,oBAAoB,GAAG,GAAG,CAAC,MAAM;IACrC,2BAA2B;IAC3B,IAAI,MAAM,gCAAuC,EAAE;QACjD,oBAAoB,GAAG,CAAC,CAAC,CAAC;KAC3B;SAAM;QACL,OAAO,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE;;kBACf,QAAQ,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC;YACzB,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE;gBAChC,IAAI,QAAQ,KAAK,MAAM,EAAE;oBACvB,oBAAoB,GAAG,CAAC,CAAC,CAAC;oBAC1B,MAAM;iBACP;qBAAM,IAAI,QAAQ,GAAG,MAAM,EAAE;oBAC5B,gFAAgF;oBAChF,oBAAoB,GAAG,CAAC,GAAG,CAAC,CAAC;oBAC7B,MAAM;iBACP;aACF;SACF;KACF;IAED,2CAA2C;IAC3C,OAAO,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE;;cACf,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC;QACnB,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;YAC5B,4FAA4F;YAC5F,SAAS;YACT,MAAM;SACP;aAAM,IAAI,IAAI,KAAK,IAAI,EAAE;YACxB,6BAA6B;YAC7B,IAAI,IAAI,KAAK,IAAI,EAAE;gBACjB,IAAI,KAAK,KAAK,IAAI,EAAE;oBAClB,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC;iBACpB;gBACD,OAAO;aACR;iBAAM,IAAI,IAAI,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE;gBAC9B,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,mBAAA,KAAK,EAAE,CAAC;gBACrB,OAAO;aACR;SACF;QACD,qBAAqB;QACrB,CAAC,EAAE,CAAC;QACJ,IAAI,IAAI,KAAK,IAAI;YAAE,CAAC,EAAE,CAAC;QACvB,IAAI,KAAK,KAAK,IAAI;YAAE,CAAC,EAAE,CAAC;KACzB;IAED,sBAAsB;IACtB,IAAI,oBAAoB,KAAK,CAAC,CAAC,EAAE;QAC/B,GAAG,CAAC,MAAM,CAAC,oBAAoB,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC;QAC5C,CAAC,GAAG,oBAAoB,GAAG,CAAC,CAAC;KAC9B;IACD,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;IACzB,IAAI,IAAI,KAAK,IAAI,EAAE;QACjB,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;KAC1B;IACD,IAAI,KAAK,KAAK,IAAI,EAAE;QAClB,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;KAC3B;AACH,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {CharCode} from '../../util/char_code';\nimport {AttributeMarker, TAttributes} from '../interfaces/node';\nimport {CssSelector} from '../interfaces/projection';\nimport {ProceduralRenderer3, RElement, Renderer3, isProceduralRenderer} from '../interfaces/renderer';\n\n\n\n/**\n * Assigns all attribute values to the provided element via the inferred renderer.\n *\n * This function accepts two forms of attribute entries:\n *\n * default: (key, value):\n *  attrs = [key1, value1, key2, value2]\n *\n * namespaced: (NAMESPACE_MARKER, uri, name, value)\n *  attrs = [NAMESPACE_MARKER, uri, name, value, NAMESPACE_MARKER, uri, name, value]\n *\n * The `attrs` array can contain a mix of both the default and namespaced entries.\n * The \"default\" values are set without a marker, but if the function comes across\n * a marker value then it will attempt to set a namespaced value. If the marker is\n * not of a namespaced value then the function will quit and return the index value\n * where it stopped during the iteration of the attrs array.\n *\n * See [AttributeMarker] to understand what the namespace marker value is.\n *\n * Note that this instruction does not support assigning style and class values to\n * an element. See `elementStart` and `elementHostAttrs` to learn how styling values\n * are applied to an element.\n * @param renderer The renderer to be used\n * @param native The element that the attributes will be assigned to\n * @param attrs The attribute array of values that will be assigned to the element\n * @returns the index value that was last accessed in the attributes array\n */\nexport function setUpAttributes(renderer: Renderer3, native: RElement, attrs: TAttributes): number {\n  const isProc = isProceduralRenderer(renderer);\n\n  let i = 0;\n  while (i < attrs.length) {\n    const value = attrs[i];\n    if (typeof value === 'number') {\n      // only namespaces are supported. Other value types (such as style/class\n      // entries) are not supported in this function.\n      if (value !== AttributeMarker.NamespaceURI) {\n        break;\n      }\n\n      // we just landed on the marker value ... therefore\n      // we should skip to the next entry\n      i++;\n\n      const namespaceURI = attrs[i++] as string;\n      const attrName = attrs[i++] as string;\n      const attrVal = attrs[i++] as string;\n      ngDevMode && ngDevMode.rendererSetAttribute++;\n      isProc ?\n          (renderer as ProceduralRenderer3).setAttribute(native, attrName, attrVal, namespaceURI) :\n          native.setAttributeNS(namespaceURI, attrName, attrVal);\n    } else {\n      // attrName is string;\n      const attrName = value as string;\n      const attrVal = attrs[++i];\n      // Standard attributes\n      ngDevMode && ngDevMode.rendererSetAttribute++;\n      if (isAnimationProp(attrName)) {\n        if (isProc) {\n          (renderer as ProceduralRenderer3).setProperty(native, attrName, attrVal);\n        }\n      } else {\n        isProc ?\n            (renderer as ProceduralRenderer3).setAttribute(native, attrName, attrVal as string) :\n            native.setAttribute(attrName, attrVal as string);\n      }\n      i++;\n    }\n  }\n\n  // another piece of code may iterate over the same attributes array. Therefore\n  // it may be helpful to return the exact spot where the attributes array exited\n  // whether by running into an unsupported marker or if all the static values were\n  // iterated over.\n  return i;\n}\n\n/**\n * Test whether the given value is a marker that indicates that the following\n * attribute values in a `TAttributes` array are only the names of attributes,\n * and not name-value pairs.\n * @param marker The attribute marker to test.\n * @returns true if the marker is a \"name-only\" marker (e.g. `Bindings`, `Template` or `I18n`).\n */\nexport function isNameOnlyAttributeMarker(marker: string | AttributeMarker | CssSelector) {\n  return marker === AttributeMarker.Bindings || marker === AttributeMarker.Template ||\n      marker === AttributeMarker.I18n;\n}\n\nexport function isAnimationProp(name: string): boolean {\n  // Perf note: accessing charCodeAt to check for the first character of a string is faster as\n  // compared to accessing a character at index 0 (ex. name[0]). The main reason for this is that\n  // charCodeAt doesn't allocate memory to return a substring.\n  return name.charCodeAt(0) === CharCode.AT_SIGN;\n}\n\n/**\n * Merges `src` `TAttributes` into `dst` `TAttributes` removing any duplicates in the process.\n *\n * This merge function keeps the order of attrs same.\n *\n * @param dst Location of where the merged `TAttributes` should end up.\n * @param src `TAttributes` which should be appended to `dst`\n */\nexport function mergeHostAttrs(dst: TAttributes | null, src: TAttributes | null): TAttributes|null {\n  if (src === null || src.length === 0) {\n    // do nothing\n  } else if (dst === null || dst.length === 0) {\n    // We have source, but dst is empty, just make a copy.\n    dst = src.slice();\n  } else {\n    let srcMarker: AttributeMarker = AttributeMarker.ImplicitAttributes;\n    for (let i = 0; i < src.length; i++) {\n      const item = src[i];\n      if (typeof item === 'number') {\n        srcMarker = item;\n      } else {\n        if (srcMarker === AttributeMarker.NamespaceURI) {\n          // Case where we need to consume `key1`, `key2`, `value` items.\n        } else if (\n            srcMarker === AttributeMarker.ImplicitAttributes ||\n            srcMarker === AttributeMarker.Styles) {\n          // Case where we have to consume `key1` and `value` only.\n          mergeHostAttribute(dst, srcMarker, item as string, null, src[++i] as string);\n        } else {\n          // Case where we have to consume `key1` only.\n          mergeHostAttribute(dst, srcMarker, item as string, null, null);\n        }\n      }\n    }\n  }\n  return dst;\n}\n\n/**\n * Append `key`/`value` to existing `TAttributes` taking region marker and duplicates into account.\n *\n * @param dst `TAttributes` to append to.\n * @param marker Region where the `key`/`value` should be added.\n * @param key1 Key to add to `TAttributes`\n * @param key2 Key to add to `TAttributes` (in case of `AttributeMarker.NamespaceURI`)\n * @param value Value to add or to overwrite to `TAttributes` Only used if `marker` is not Class.\n */\nexport function mergeHostAttribute(\n    dst: TAttributes, marker: AttributeMarker, key1: string, key2: string | null,\n    value: string | null): void {\n  let i = 0;\n  // Assume that new markers will be inserted at the end.\n  let markerInsertPosition = dst.length;\n  // scan until correct type.\n  if (marker === AttributeMarker.ImplicitAttributes) {\n    markerInsertPosition = -1;\n  } else {\n    while (i < dst.length) {\n      const dstValue = dst[i++];\n      if (typeof dstValue === 'number') {\n        if (dstValue === marker) {\n          markerInsertPosition = -1;\n          break;\n        } else if (dstValue > marker) {\n          // We need to save this as we want the markers to be inserted in specific order.\n          markerInsertPosition = i - 1;\n          break;\n        }\n      }\n    }\n  }\n\n  // search until you find place of insertion\n  while (i < dst.length) {\n    const item = dst[i];\n    if (typeof item === 'number') {\n      // since `i` started as the index after the marker, we did not find it if we are at the next\n      // marker\n      break;\n    } else if (item === key1) {\n      // We already have same token\n      if (key2 === null) {\n        if (value !== null) {\n          dst[i + 1] = value;\n        }\n        return;\n      } else if (key2 === dst[i + 1]) {\n        dst[i + 2] = value !;\n        return;\n      }\n    }\n    // Increment counter.\n    i++;\n    if (key2 !== null) i++;\n    if (value !== null) i++;\n  }\n\n  // insert at location.\n  if (markerInsertPosition !== -1) {\n    dst.splice(markerInsertPosition, 0, marker);\n    i = markerInsertPosition + 1;\n  }\n  dst.splice(i++, 0, key1);\n  if (key2 !== null) {\n    dst.splice(i++, 0, key2);\n  }\n  if (value !== null) {\n    dst.splice(i++, 0, value);\n  }\n}"]}
@@ -0,0 +1,33 @@
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * Generated from: packages/core/src/render3/util/change_detection_utils.ts
4
+ * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
+ */
6
+ /**
7
+ * @license
8
+ * Copyright Google Inc. All Rights Reserved.
9
+ *
10
+ * Use of this source code is governed by an MIT-style license that can be
11
+ * found in the LICENSE file at https://angular.io/license
12
+ */
13
+ import { detectChanges, markDirty } from '../instructions/all';
14
+ import { getRootComponents } from './discovery_utils';
15
+ /**
16
+ * Marks a component for check (in case of OnPush components) and synchronously
17
+ * performs change detection on the application this component belongs to.
18
+ *
19
+ * \@publicApi
20
+ * \@globalApi ng
21
+ * @param {?} component Component to {\@link ChangeDetectorRef#markForCheck mark for check}.
22
+ *
23
+ * @return {?}
24
+ */
25
+ export function applyChanges(component) {
26
+ markDirty(component);
27
+ getRootComponents(component).forEach((/**
28
+ * @param {?} rootComponent
29
+ * @return {?}
30
+ */
31
+ rootComponent => detectChanges(rootComponent)));
32
+ }
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhbmdlX2RldGVjdGlvbl91dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL3JlbmRlcjMvdXRpbC9jaGFuZ2VfZGV0ZWN0aW9uX3V0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQVFBLE9BQU8sRUFBQyxhQUFhLEVBQUUsU0FBUyxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDN0QsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sbUJBQW1CLENBQUM7Ozs7Ozs7Ozs7O0FBV3BELE1BQU0sVUFBVSxZQUFZLENBQUMsU0FBYTtJQUN4QyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDckIsaUJBQWlCLENBQUMsU0FBUyxDQUFDLENBQUMsT0FBTzs7OztJQUFDLGFBQWEsQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLGFBQWEsQ0FBQyxFQUFDLENBQUM7QUFDdEYsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtkZXRlY3RDaGFuZ2VzLCBtYXJrRGlydHl9IGZyb20gJy4uL2luc3RydWN0aW9ucy9hbGwnO1xuaW1wb3J0IHtnZXRSb290Q29tcG9uZW50c30gZnJvbSAnLi9kaXNjb3ZlcnlfdXRpbHMnO1xuXG4vKipcbiAqIE1hcmtzIGEgY29tcG9uZW50IGZvciBjaGVjayAoaW4gY2FzZSBvZiBPblB1c2ggY29tcG9uZW50cykgYW5kIHN5bmNocm9ub3VzbHlcbiAqIHBlcmZvcm1zIGNoYW5nZSBkZXRlY3Rpb24gb24gdGhlIGFwcGxpY2F0aW9uIHRoaXMgY29tcG9uZW50IGJlbG9uZ3MgdG8uXG4gKlxuICogQHBhcmFtIGNvbXBvbmVudCBDb21wb25lbnQgdG8ge0BsaW5rIENoYW5nZURldGVjdG9yUmVmI21hcmtGb3JDaGVjayBtYXJrIGZvciBjaGVja30uXG4gKlxuICogQHB1YmxpY0FwaVxuICogQGdsb2JhbEFwaSBuZ1xuICovXG5leHBvcnQgZnVuY3Rpb24gYXBwbHlDaGFuZ2VzKGNvbXBvbmVudDoge30pOiB2b2lkIHtcbiAgbWFya0RpcnR5KGNvbXBvbmVudCk7XG4gIGdldFJvb3RDb21wb25lbnRzKGNvbXBvbmVudCkuZm9yRWFjaChyb290Q29tcG9uZW50ID0+IGRldGVjdENoYW5nZXMocm9vdENvbXBvbmVudCkpO1xufVxuIl19